1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
| <template>
| <div
| class="bs-design-wrap"
| :class="{ 'no-pointer': isDesign }"
| >
| <div class="iframe-wrap">
| <iframe
| class="iframe"
| allowfullscreen="true"
| webkitallowfullscreen="true"
| mozallowfullscreen="true"
| oallowfullscreen="true"
| msallowfullscreen="true"
| :style="{
| width: '200%',
| height: '200%',
| transform: 'scale(.5, .5) translate(-50%, -50%)',
| border: 'none'
| }"
| :src="newUrl"
| />
| </div>
| </div>
| </template>
|
| <script>
| export default {
| name: 'IframeChart',
| props: {
| config: {
| type: Object,
| default: () => {}
| }
| },
| data () {
| return { newUrl: '' }
| },
| computed: {
| isDesign () {
| return (window?.BS_CONFIG?.routers?.designUrl || '/big-screen/design') === this.$route.path
| }
| },
| watch: {},
| mounted () {
| this.changeStyle()
| },
| methods: {
| changeStyle (config) {
| this.newUrl = this.replaceUrlVariables(this.config.url)
| },
| replaceUrlVariables (url) {
| const variableRegex = /\${([A-Za-z0-9_.]+)}/g
| const variables = {}
| let match
| while ((match = variableRegex.exec(url))) {
| const variable = match[1]
| try {
| const value = eval(variable)
| variables[variable] = value !== undefined ? value : ''
| } catch (e) {
| variables[variable] = ''
| }
| }
| const replacedUrl = url.replace(variableRegex, (match, variable) => {
| return variables[variable] || match
| })
| return replacedUrl
| }
| }
| }
| </script>
|
| <style lang="scss" scoped>
| .bs-design-wrap {
| position: relative;
| overflow: hidden;
| background: #fff;
| width: 100%;
| height: 100%;
| .iframe-wrap {
| height: 100%;
| }
| }
| .no-pointer {
| pointer-events: none;
| }
| </style>
|
|