|  |  | 
 |  |  |               <el-form-item label="拉流地址" prop="src_url" v-if="proxyParam.type=='ffmpeg'"> | 
 |  |  |                 <el-input v-model="proxyParam.src_url" clearable></el-input> | 
 |  |  |               </el-form-item> | 
 |  |  |               <el-form-item label="超时时间" prop="timeout_ms" v-if="proxyParam.type=='ffmpeg'"> | 
 |  |  |               <el-form-item label="超时时间:毫秒" prop="timeout_ms" v-if="proxyParam.type=='ffmpeg'"> | 
 |  |  |                 <el-input v-model="proxyParam.timeout_ms" clearable></el-input> | 
 |  |  |               </el-form-item> | 
 |  |  |               <el-form-item label="节点选择" prop="rtp_type"> | 
 |  |  |                 <el-select | 
 |  |  |                   v-model="proxyParam.mediaServerId" | 
 |  |  |                   @change="mediaServerIdChange" | 
 |  |  |                   style="width: 100%" | 
 |  |  |                   placeholder="请选择拉流节点" | 
 |  |  |                 > | 
 |  |  |                   <el-option label="自动选择" value="auto"></el-option> | 
 |  |  |                   <el-option | 
 |  |  |                     v-for="item in mediaServerList" | 
 |  |  |                     :key="item.id" | 
 |  |  |                     :label="item.id" | 
 |  |  |                     :value="item.id"> | 
 |  |  |                   </el-option> | 
 |  |  |                 </el-select> | 
 |  |  |               </el-form-item> | 
 |  |  |               <el-form-item label="FFmpeg命令模板" prop="ffmpeg_cmd_key" v-if="proxyParam.type=='ffmpeg'"> | 
 |  |  |                 <el-input v-model="proxyParam.ffmpeg_cmd_key" clearable></el-input> | 
 |  |  | <!--                <el-input v-model="proxyParam.ffmpeg_cmd_key" clearable></el-input>--> | 
 |  |  |                 <el-select | 
 |  |  |                   v-model="proxyParam.ffmpeg_cmd_key" | 
 |  |  |                   style="width: 100%" | 
 |  |  |                   placeholder="请选择FFmpeg命令模板" | 
 |  |  |                 > | 
 |  |  |                   <el-option | 
 |  |  |                     v-for="item in Object.keys(ffmpegCmdList)" | 
 |  |  |                     :key="item" | 
 |  |  |                     :label="ffmpegCmdList[item]" | 
 |  |  |                     :value="item"> | 
 |  |  |                   </el-option> | 
 |  |  |                 </el-select> | 
 |  |  |               </el-form-item> | 
 |  |  |               <el-form-item label="国标编码" prop="gbId"> | 
 |  |  |                 <el-input v-model="proxyParam.gbId" placeholder="设置国标编码可推送到国标" clearable></el-input> | 
 |  |  | 
 |  |  |                   <el-option label="组播" value="2"></el-option> | 
 |  |  |                 </el-select> | 
 |  |  |               </el-form-item> | 
 |  |  |  | 
 |  |  |               <el-form-item label="国标平台"> | 
 |  |  |                 <el-select | 
 |  |  |                   v-model="proxyParam.platformGbId" | 
 |  |  |                   style="width: 100%" | 
 |  |  |                   placeholder="请选择国标平台" | 
 |  |  |                 > | 
 |  |  |                   <el-option | 
 |  |  |                     v-for="item in platformList" | 
 |  |  |                     :key="item.name" | 
 |  |  |                     :label="item.name" | 
 |  |  |                     :value="item.serverGBId"> | 
 |  |  |                     <span style="float: left">{{ item.name }}</span> | 
 |  |  |                     <span style="float: right; color: #8492a6; font-size: 13px">{{ item.serverGBId }}</span> | 
 |  |  |                   </el-option> | 
 |  |  |                 </el-select> | 
 |  |  |               </el-form-item> | 
 |  |  |               <el-form-item label="其他选项"> | 
 |  |  |                 <div style="float: left;"> | 
 |  |  |                   <el-checkbox label="启用" v-model="proxyParam.enable" ></el-checkbox> | 
 |  |  |                   <el-checkbox label="转HLS" v-model="proxyParam.enable_hls" ></el-checkbox> | 
 |  |  |                   <el-checkbox label="MP4录制" v-model="proxyParam.enable_mp4" ></el-checkbox> | 
 |  |  |                   <el-checkbox label="无人观看自动删除" v-model="proxyParam.enable_remove_none_reader" ></el-checkbox> | 
 |  |  |                 </div> | 
 |  |  |  | 
 |  |  |               </el-form-item> | 
 |  |  | 
 |  |  | </template> | 
 |  |  |  | 
 |  |  | <script> | 
 |  |  | import MediaServer from './../service/MediaServer' | 
 |  |  |  | 
 |  |  | export default { | 
 |  |  |   name: "streamProxyEdit", | 
 |  |  |   props: {}, | 
 |  |  | 
 |  |  |       isLoging: false, | 
 |  |  |       dialogLoading: false, | 
 |  |  |       onSubmit_text: "立即创建", | 
 |  |  |       platformList: [], | 
 |  |  |       mediaServer: new MediaServer(), | 
 |  |  |       proxyParam: { | 
 |  |  |           name: null, | 
 |  |  |           type: "default", | 
 |  |  |           app: null, | 
 |  |  |           stream: null, | 
 |  |  |           url: "rtmp://58.200.131.2/livetv/cctv5hd", | 
 |  |  |           url: "", | 
 |  |  |           src_url: null, | 
 |  |  |           timeout_ms: null, | 
 |  |  |           ffmpeg_cmd_key: null, | 
 |  |  | 
 |  |  |           enable: true, | 
 |  |  |           enable_hls: true, | 
 |  |  |           enable_mp4: false, | 
 |  |  |           enable_remove_none_reader: false, | 
 |  |  |           platformGbId: null, | 
 |  |  |           mediaServerId: "auto", | 
 |  |  |       }, | 
 |  |  |       mediaServerList:{}, | 
 |  |  |       ffmpegCmdList:{}, | 
 |  |  |  | 
 |  |  |       rules: { | 
 |  |  |         name: [{ required: true, message: "请输入名称", trigger: "blur" }], | 
 |  |  | 
 |  |  |       if (proxyParam != null) { | 
 |  |  |         this.proxyParam = proxyParam; | 
 |  |  |       } | 
 |  |  |  | 
 |  |  |       let that = this; | 
 |  |  |       this.$axios({ | 
 |  |  |         method: 'get', | 
 |  |  |         url:`/api/platform/query/10000/0` | 
 |  |  |       }).then(function (res) { | 
 |  |  |         that.platformList = res.data.list; | 
 |  |  |       }).catch(function (error) { | 
 |  |  |         console.log(error); | 
 |  |  |       }); | 
 |  |  |       this.mediaServer.getOnlineMediaServerList((data)=>{ | 
 |  |  |         this.mediaServerList = data; | 
 |  |  |       }) | 
 |  |  |     }, | 
 |  |  |     mediaServerIdChange:function (){ | 
 |  |  |       let that = this; | 
 |  |  |       if (that.proxyParam.mediaServerId !== "auto"){ | 
 |  |  |         that.$axios({ | 
 |  |  |           method: 'get', | 
 |  |  |           url:`/api/proxy/ffmpeg_cmd/list`, | 
 |  |  |           params: { | 
 |  |  |             mediaServerId: that.proxyParam.mediaServerId | 
 |  |  |           } | 
 |  |  |         }).then(function (res) { | 
 |  |  |           that.ffmpegCmdList = res.data.data; | 
 |  |  |         }).catch(function (error) { | 
 |  |  |           console.log(error); | 
 |  |  |         }); | 
 |  |  |       } | 
 |  |  |  | 
 |  |  |     }, | 
 |  |  |     onSubmit: function () { | 
 |  |  |       console.log("onSubmit"); | 
 |  |  |       this.dialogLoading = true; | 
 |  |  |       var that = this; | 
 |  |  |       that.$axios({ | 
 |  |  | 
 |  |  |       }); | 
 |  |  |     }, | 
 |  |  |     close: function () { | 
 |  |  |       console.log("关闭添加视频平台"); | 
 |  |  |       this.showDialog = false; | 
 |  |  |       this.dialogLoading = false; | 
 |  |  |       this.$refs.streamProxy.resetFields(); |