ultrawidify/src/csui/PlayerUiComponent.vue

369 lines
9.3 KiB
Vue
Raw Normal View History

2020-12-15 00:26:19 +01:00
<template>
<div class="uw-hover uv-hover-trigger-region">
TEST CONTENT
</div>
2021-10-22 00:30:56 +02:00
<div class="popup-panel flex flex-column">
<div>
<div class="popup-title">Ultrawidify <small>{{settings?.active?.version}} - {{BrowserDetect.processEnvChannel}}</small></div>
<div class="site-support-info">
<div class="site-support-site">{{site}}</div>
<div v-if="siteSupportLevel === 'official'" class="site-support official">
2021-10-22 00:30:56 +02:00
<mdicon name="check-decagram" />
<div>Official</div>
<div class="tooltip">The extension is being tested and should work on this site.</div>
2021-10-22 00:30:56 +02:00
</div>
<div v-if="siteSupportLevel === 'community'" class="site-support community">
<mdicon name="handshake" />
<div>Community</div>
<div class="tooltip">
People say extension works on this site (or have provided help getting the extension to work if it didn't).<br/><br/>
Tamius (the dev) does not test the extension on this site, probably because it requires a subscription or
is geoblocked.
</div>
2021-10-22 00:30:56 +02:00
</div>
<div v-if="siteSupportLevel === 'no-support'" class="site-support no-support">
2021-10-22 00:30:56 +02:00
<mdicon name="help-circle-outline" />
<div>Unknown</div>
<div class="tooltip">
Not officially supported. Extension will try to fix things, but no promises.<br/><br/>
Tamius (the dev) does not test the extension on this site for various reasons
(unaware, not using the site, language barrier, geoblocking, requires paid subscription).
</div>
2021-10-22 00:30:56 +02:00
</div>
<div v-if="siteSupportLevel === 'user-added'" class="site-support user-added">
<mdicon name="account" />
<div>Custom</div>
<div class="tooltip">
You have manually changed settings for this site. The extension is doing what you told it to do.
</div>
2021-10-22 00:30:56 +02:00
</div>
<mdicon v-if="siteSupportLevel === 'community'" class="site-support supported" name="checkbox-marked-circle" />
</div>
2021-10-22 00:30:56 +02:00
</div>
<div class="flex flex-row">
<div class="tab-row flex flex-column">
<div
class="tab"
@click="selectTab('videoSettings')"
>
2021-10-22 00:30:56 +02:00
<mdicon name="crop" />
Video options
</div>
<div
class="tab"
@click="selectTab('playerDetection')"
>
Player detection
</div>
<div
class="tab"
@click="selectTab('autodetectionSettings')"
>
2021-10-22 00:30:56 +02:00
Autodetection options
</div>
<div
class="tab"
@click="selectTab('advancedOptions')"
>
2021-10-22 00:30:56 +02:00
<mdicon name="cogs" />
Advanced options
</div>
<div class="tab">
<mdicon name="bug-outline" />
Debugging
</div>
</div>
2021-10-22 00:30:56 +02:00
<div class="content flex flex-column">
<!-- autodetection warning -->
2021-11-13 00:51:59 +01:00
<div v-if="ultrawidify?.videoData?.hasDrm" class="warning-area">
2021-10-22 00:30:56 +02:00
<div class="warning-box">
<div>
<mdicon name="alert" :size="42" />
</div>
<div>
This site uses <a href="https://en.wikipedia.org/wiki/Digital_rights_management" target="_blank">digital rights management</a> solutions that prevent this
extension from automatically detecting aspect ratio. You will have to adjust aspect ratio manually.
</div>
</div>
</div>
<div class="flex flex-row">
<!-- Panel section -->
<template v-if="settingsInitialized">
<VideoSettings
:settings="settings"
2021-11-13 00:51:59 +01:00
:eventBus="ultrawidify.eventBus"
2021-10-22 00:30:56 +02:00
></VideoSettings>
<!-- <ResizerDebugPanel :debugData="debugData">
</ResizerDebugPanel> -->
</template>
</div>
</div>
</div>
2020-12-15 00:26:19 +01:00
</div>
</template>
<script>
import VideoSettings from './PlayerUiPanels/VideoSettings.vue'
2020-12-15 00:26:19 +01:00
import { mapState } from 'vuex';
2021-10-22 00:30:36 +02:00
// import Icon from '../common/components/Icon';
import ResizerDebugPanel from './PlayerUiPanels/ResizerDebugPanelComponent';
import BrowserDetect from '../ext/conf/BrowserDetect';
import ExecAction from './ui-libs/ExecAction';
import Logger from '../ext/lib/Logger';
import Settings from '../ext/lib/Settings';
2020-12-15 00:26:19 +01:00
export default {
components: {
2021-10-22 00:30:36 +02:00
// Icon,
ResizerDebugPanel, VideoSettings
2020-12-15 00:26:19 +01:00
},
data() {
return {
// component properties
settings: {},
2021-10-22 00:30:56 +02:00
BrowserDetect: BrowserDetect,
settingsInitialized: false,
execAction: new ExecAction(),
logger: null,
site: window.location.hostname,
uiVisible: true,
debugData: {
resizer: {},
player: {},
2020-12-16 01:40:09 +01:00
},
debugDataPrettified: ''
2020-12-15 00:26:19 +01:00
};
},
computed: {
...mapState([
'showUi',
'resizerDebugData',
'playerDebugData'
2020-12-15 00:26:19 +01:00
]),
// LPT: NO ARROW FUNCTIONS IN COMPUTED,
// IS SUPER HARAM
// THINGS WILL NOT WORK IF YOU USE ARROWS
windowWidth() {
2020-12-16 01:40:09 +01:00
return window.innerWidth;
},
windowHeight() {
2020-12-16 01:40:09 +01:00
return window.innerHeight;
},
siteSupportLevel() {
console.warn('\n\n\n\n\n\n\n\n\n\n\nsite support level. site:', this, this?.site, this?.settings, this?.settings?.active?.sites[this.site]);
return (this.site && this.settings?.active) ? this.settings.active.sites[this.site]?.type || 'no-support' : 'waiting';
}
2020-12-15 00:26:19 +01:00
},
watch: {
showUi(visible) {
if (visible !== undefined) {
this.uiVisible = visible;
}
},
resizerDebugData(newData) {
this.debugData.resizer = newData;
2020-12-16 01:40:09 +01:00
this.debugDataPrettified = JSON.stringify(this.debugData, null, 2);
},
playerDebugData(newData) {
this.debugData.player = newData;
2020-12-16 01:40:09 +01:00
this.debugDataPrettified = JSON.stringify(this.debugData, null, 2);
2020-12-15 00:26:19 +01:00
}
},
async created() {
try {
this.logger = new Logger();
await this.logger.init({
allowLogging: true,
});
this.settings = new Settings({afterSettingsSaved: this.updateConfig, logger: this.logger});
await this.settings.init();
this.settingsInitialized = true;
console.log("settings inited")
this.execAction.setSettings(this.settings);
console.log("created!");
console.log("store:", this.$store, this);
console.log("settings:", this.settings)
console.log("windowPD", window.ultrawidify);
console.log("this:", this);
} catch (e) {
console.error('Failed to initiate ultrawidify player ui.', e);
}
2020-12-15 00:26:19 +01:00
},
methods: {
2020-12-22 03:14:03 +01:00
getUrl(url) {
2020-12-30 15:35:54 +01:00
return BrowserDetect.getURL(url);
},
2020-12-15 00:26:19 +01:00
}
}
</script>
<style lang="scss" src="../res/css/uwui-base.scss" scoped module></style>
<style lang="scss" src="../res/css/flex.scss" scoped module></style>
<style lang="scss" src="./res-common/common.scss" scoped module></style>
<style lang="scss" scoped module>
2020-12-15 00:26:19 +01:00
@import '../res/css/uwui-base.scss';
@import '../res/css/colors.scss';
@import '../res/css/font/overpass.css';
@import '../res/css/font/overpass-mono.css';
@import '../res/css/common.scss';
.uw-ultrawidify-container-root {
// .relative-wrapper {
// position: relative;
// width: 100%;
// height: 100%;
// }
.site-support-info {
display: flex;
flex-direction: row;
// padding-left: 2rem;
.site-support-site {
font-size: 1.2em;
}
.site-support {
display: inline-flex;
flex-direction: row;
align-items: center;
margin-left: 2rem;
border-radius: 8px;
padding: 0rem 1.5rem 0rem 1rem;
position: relative;
.tooltip {
padding: 1rem;
display: none;
position: absolute;
bottom: 0;
transform: translateY(110%);
width: 42em;
background-color: rgba(0,0,0,0.90);
color: #ccc;
}
&:hover {
.tooltip {
display: block;
}
}
.mdi {
margin-right: 1rem;
}
&.official {
background-color: #fa6;
color: #000;
.mdi {
fill: #000 !important;
}
}
&.community {
background-color: rgb(47, 47, 97);
color: #fff;
.mdi {
fill: #fff !important;
}
}
&.no-support {
background-color: rgb(138, 65, 126);
color: #eee;
.mdi {
fill: #eee !important;
}
}
&.user-added {
border: 1px solid #ff0;
color: #ff0;
.mdi {
fill: #ff0 !important;
}
}
}
}
2020-12-15 00:26:19 +01:00
.uw-hover {
position: absolute;
top: 10%;
left: 10%;
2020-12-15 00:26:19 +01:00
width: 100px;
height: 100px;
color: #fff;
background-color: #000;
2020-12-16 01:40:09 +01:00
z-index: 999999999999999999;
2020-12-15 00:26:19 +01:00
}
.uw-hover:hover {
background-color: #f00;
}
2020-12-16 01:40:09 +01:00
.popup-panel {
position: absolute;
top: 10%;
left: 10%;
z-index: 999999999999999999;
width: 2500px;
height: 1200px;
max-width: 80%;
max-height: 80%;
2020-12-16 01:40:09 +01:00
pointer-events: all !important;
2021-10-22 00:30:56 +02:00
background-color: rgba(0,0,0,0.50);
2020-12-16 01:40:09 +01:00
color: #fff;
overflow-y: auto;
2021-10-22 00:30:56 +02:00
backdrop-filter: blur(16px) saturate(120%);
.popup-title, .popup-title h1 {
font-size: 48px !important;
}
.tab {
display: block;
height: 42px;
font-size: 2.5rem;
background: rgb(87, 54, 26);
}
.tab:hover {
background-color: #f00;
}
2020-12-16 01:40:09 +01:00
}
pre {
white-space: pre-wrap;
}
2020-12-15 00:26:19 +01:00
}
</style>