Skip auto ad
This commit is contained in:
parent
86aafec16d
commit
ce26885a90
|
@ -1,5 +1,9 @@
|
||||||
# Changelog
|
# Changelog
|
||||||
|
|
||||||
|
## Canary
|
||||||
|
* Skip button for auto-post ads
|
||||||
|
|
||||||
|
|
||||||
## 1.8.0
|
## 1.8.0
|
||||||
* Added colorblind mode (settings -> rising -> colorblind mode)
|
* Added colorblind mode (settings -> rising -> colorblind mode)
|
||||||
|
|
||||||
|
|
|
@ -108,8 +108,9 @@
|
||||||
<div class="update">{{adAutoPostUpdate}}</div>
|
<div class="update">{{adAutoPostUpdate}}</div>
|
||||||
|
|
||||||
<div v-show="adAutoPostNextAd" class="next">
|
<div v-show="adAutoPostNextAd" class="next">
|
||||||
<h5>{{l('admgr.comingNext')}}</h5>
|
<h5>{{l('admgr.comingNext')}} <a @click="skipAd()"><i class='adAction fas fa-arrow-right' /></a></h5>
|
||||||
<div>{{(adAutoPostNextAd ? adAutoPostNextAd.substr(0, 64) : '')}}...</div>
|
<div>{{(adAutoPostNextAd ? adAutoPostNextAd.substr(0, 100) : '')}}...</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<a class="btn btn-sm btn-outline-primary renew-autoposts" @click="renewAutoPosting()" v-if="!adsRequireSetup">{{l('admgr.renew')}}</a>
|
<a class="btn btn-sm btn-outline-primary renew-autoposts" @click="renewAutoPosting()" v-if="!adsRequireSetup">{{l('admgr.renew')}}</a>
|
||||||
|
@ -503,6 +504,12 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
skipAd(): void {
|
||||||
|
this.conversation.adManager.skipAd();
|
||||||
|
this.updateAutoPostingState();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
stopAutoPostAds(): void {
|
stopAutoPostAds(): void {
|
||||||
this.conversation.adManager.stop();
|
this.conversation.adManager.stop();
|
||||||
}
|
}
|
||||||
|
@ -525,6 +532,35 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
updateAutoPostingState() {
|
||||||
|
const adManager = this.conversation.adManager;
|
||||||
|
|
||||||
|
this.adAutoPostNextAd = adManager.getNextAd() || null;
|
||||||
|
|
||||||
|
if(this.adAutoPostNextAd) {
|
||||||
|
const diff = ((adManager.getNextPostDue() || new Date()).getTime() - Date.now()) / 1000;
|
||||||
|
const expDiff = ((adManager.getExpireDue() || new Date()).getTime() - Date.now()) / 1000;
|
||||||
|
|
||||||
|
const diffMins = Math.floor(diff / 60);
|
||||||
|
const diffSecs = Math.floor(diff % 60);
|
||||||
|
const expDiffMins = Math.floor(expDiff / 60);
|
||||||
|
const expDiffSecs = Math.floor(expDiff % 60);
|
||||||
|
|
||||||
|
this.adAutoPostUpdate = l(
|
||||||
|
((adManager.getNextPostDue()) && (!adManager.getFirstPost())) ? 'admgr.postingBegins' : 'admgr.nextPostDue',
|
||||||
|
diffMins,
|
||||||
|
diffSecs
|
||||||
|
) + l('admgr.expiresIn', expDiffMins, expDiffSecs);
|
||||||
|
|
||||||
|
this.adsRequireSetup = false;
|
||||||
|
} else {
|
||||||
|
this.adAutoPostNextAd = null;
|
||||||
|
|
||||||
|
this.adAutoPostUpdate = l('admgr.noAds');
|
||||||
|
this.adsRequireSetup = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
refreshAutoPostingTimer(): void {
|
refreshAutoPostingTimer(): void {
|
||||||
if (this.autoPostingUpdater)
|
if (this.autoPostingUpdater)
|
||||||
window.clearInterval(this.autoPostingUpdater);
|
window.clearInterval(this.autoPostingUpdater);
|
||||||
|
@ -535,38 +571,8 @@
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const updateAutoPostingState = () => {
|
this.autoPostingUpdater = window.setInterval(() => this.updateAutoPostingState(), 1000);
|
||||||
const adManager = this.conversation.adManager;
|
this.updateAutoPostingState();
|
||||||
|
|
||||||
this.adAutoPostNextAd = adManager.getNextAd() || null;
|
|
||||||
|
|
||||||
if(this.adAutoPostNextAd) {
|
|
||||||
const diff = ((adManager.getNextPostDue() || new Date()).getTime() - Date.now()) / 1000;
|
|
||||||
const expDiff = ((adManager.getExpireDue() || new Date()).getTime() - Date.now()) / 1000;
|
|
||||||
|
|
||||||
const diffMins = Math.floor(diff / 60);
|
|
||||||
const diffSecs = Math.floor(diff % 60);
|
|
||||||
const expDiffMins = Math.floor(expDiff / 60);
|
|
||||||
const expDiffSecs = Math.floor(expDiff % 60);
|
|
||||||
|
|
||||||
this.adAutoPostUpdate = l(
|
|
||||||
((adManager.getNextPostDue()) && (!adManager.getFirstPost())) ? 'admgr.postingBegins' : 'admgr.nextPostDue',
|
|
||||||
diffMins,
|
|
||||||
diffSecs
|
|
||||||
) + l('admgr.expiresIn', expDiffMins, expDiffSecs);
|
|
||||||
|
|
||||||
this.adsRequireSetup = false;
|
|
||||||
} else {
|
|
||||||
this.adAutoPostNextAd = null;
|
|
||||||
|
|
||||||
this.adAutoPostUpdate = l('admgr.noAds');
|
|
||||||
this.adsRequireSetup = true;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
this.autoPostingUpdater = window.setInterval(updateAutoPostingState, 1000);
|
|
||||||
|
|
||||||
updateAutoPostingState();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -673,6 +679,16 @@
|
||||||
position: relative;
|
position: relative;
|
||||||
margin-top: 5px;
|
margin-top: 5px;
|
||||||
|
|
||||||
|
.adAction {
|
||||||
|
&:hover {
|
||||||
|
color: rgba(255, 255, 255, 0.8);
|
||||||
|
}
|
||||||
|
|
||||||
|
&:active {
|
||||||
|
color: rgba(255, 255, 255, 0.6);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.renew-autoposts {
|
.renew-autoposts {
|
||||||
display: block;
|
display: block;
|
||||||
float: right;
|
float: right;
|
||||||
|
|
|
@ -47,6 +47,10 @@ export class AdManager {
|
||||||
return this.active;
|
return this.active;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
skipAd(): void {
|
||||||
|
this.adIndex += 1;
|
||||||
|
}
|
||||||
|
|
||||||
// tslint:disable-next-line
|
// tslint:disable-next-line
|
||||||
private async delay(ms: number): Promise<void> {
|
private async delay(ms: number): Promise<void> {
|
||||||
return new Promise((resolve) => setTimeout(resolve, ms));
|
return new Promise((resolve) => setTimeout(resolve, ms));
|
||||||
|
|
Loading…
Reference in New Issue