<template>
<el-row>
<el-form @submit.prevent :effect="themes" ref="form" size="mini" style="width: 100%">
<el-form-item :effect="themes" :label="t('visualization.video_type')">
<el-radio-group :effect="themes" v-model="state.streamMediaInfoTemp.videoType">
<el-radio :effect="themes" :label="'flv'">FLV</el-radio>
</el-radio-group>
</el-form-item>
<el-row v-if="state.streamMediaInfoTemp.videoType === 'flv'" style="display: block">
<el-form-item :effect="themes" :label="t('visualization.is_live')">
<el-radio-group
:effect="themes"
@change="onChange"
v-model="state.streamMediaInfoTemp[state.streamMediaInfoTemp.videoType].isLive"
>
<el-radio :effect="themes" :label="true">{{ t('visualization.yes') }}</el-radio>
<el-radio :effect="themes" :label="false">{{ t('visualization.no') }}</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item
:effect="themes"
v-if="!state.streamMediaInfoTemp[state.streamMediaInfoTemp.videoType].isLive"
:label="t('visualization.play_frequency')"
>
<el-radio-group
:effect="themes"
@change="onChange"
v-model="state.streamMediaInfoTemp[state.streamMediaInfoTemp.videoType].loop"
>
<el-radio :effect="themes" :label="false">{{ t('visualization.play_once') }}</el-radio>
<el-radio :effect="themes" :label="true">{{ t('visualization.play_circle') }}</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item :effect="themes" :label="t('visualization.video_links')">
<el-input
:effect="themes"
v-model="state.streamMediaInfoTemp[state.streamMediaInfoTemp.videoType].url"
@blur="onChange"
/>
<span class="tips-class"> Tips:{{ t('visualization.live_tips') }} </span>
</el-form-item>
</el-row>
</el-form>
</el-row>
</template>
<script setup lang="ts">
import { reactive, toRefs, watch } from 'vue'
import { dvMainStoreWithOut } from '../../store/modules/data-visualization/dvMain'
import { storeToRefs } from 'pinia/dist/pinia'
import { checkAddHttp, deepCopy } from '../../utils/utils'
import { snapshotStoreWithOut } from '../../store/modules/data-visualization/snapshot'
import { useI18n } from '../../hooks/web/useI18n'
import { useEmitt } from '@/hooks/web/useEmitt'
const dvMainStore = dvMainStoreWithOut()
const { curComponent, curActiveTabInner } = storeToRefs(dvMainStore)
const snapshotStore = snapshotStoreWithOut()
const { t } = useI18n()
const props = defineProps({
themes: {
type: String,
required: true,
default: 'dark'
},
linkInfo: {
type: Object,
required: true
},
// 属性所属组件位置
attrPosition: {
type: String,
required: false,
default: 'panel'
}
})
const { linkInfo, attrPosition } = toRefs(props)
const state = reactive({
streamMediaInfoTemp: {
videoType: 'flv',
flv: {
type: 'flv',
isLive: false,
cors: true, // 允许跨域
loop: true,
autoplay: false
// url: null // 网络动画视频
}
}
})
const init = () => {
state.streamMediaInfoTemp = deepCopy(linkInfo.value)
}
const onChange = () => {
state.streamMediaInfoTemp[state.streamMediaInfoTemp.videoType].url = checkAddHttp(
state.streamMediaInfoTemp[state.streamMediaInfoTemp.videoType].url
)
if (attrPosition.value === 'panel') {
curComponent.value.streamMediaLinks = state.streamMediaInfoTemp
} else {
curActiveTabInner.value.streamMediaLinks = state.streamMediaInfoTemp
}
snapshotStore.recordSnapshotCache('stream-onChange')
useEmitt().emitter.emit('streamMediaLinksChange-' + curComponent.value.id)
}
init()
watch(
() => linkInfo.value,
() => {
init()
},
{ deep: true }
)
</script>
<style lang="less" scoped>
.slot-class {
color: white;
}
.bottom {
margin-top: 20px;
text-align: center;
}
.ellipsis-area {
margin-left: 10px;
margin-right: 10px;
overflow: hidden; /*超出部分隐藏*/
white-space: nowrap; /*不换行*/
text-overflow: ellipsis; /*超出部分文字以...显示*/
background-color: #f7f8fa;
color: #3d4d66;
font-size: 12px;
line-height: 24px;
height: 24px;
border-radius: 3px;
}
.select-filed {
margin-left: 10px;
margin-right: 10px;
overflow: hidden; /*超出部分隐藏*/
white-space: nowrap; /*不换行*/
text-overflow: ellipsis; /*超出部分文字以...显示*/
color: #3d4d66;
font-size: 12px;
line-height: 35px;
height: 35px;
border-radius: 3px;
}
.tips-class {
color: #909399;
font-size: 8px;
margin-left: 3px;
}
.hint-icon {
cursor: pointer;
font-size: 14px;
color: #646a73;
&.hint-icon--dark {
color: #a6a6a6;
}
}
.data-area-label {
display: flex;
flex-direction: row;
align-items: center;
}
</style>