lbry-desktop/ui/effects/use-get-ads.js

56 lines
2 KiB
JavaScript
Raw Normal View History

2021-04-12 12:43:47 -04:00
// @flow
import React from 'react';
import { VASTClient } from 'vast-client';
import analytics from 'analytics';
2021-04-12 13:14:20 -04:00
const PRE_ROLL_ADS_PROVIDER = 'https://tag.targeting.unrulymedia.com/rmp/216276/0/vast2?vastfw=vpaid&w=300&h=500&url=';
2021-04-12 12:43:47 -04:00
// Ignores any call made 1 minutes or less after the last successful ad
const ADS_CAP_LEVEL = 1 * 60 * 1000;
const vastClient = new VASTClient(0, ADS_CAP_LEVEL);
export function useGetAds(approvedVideo: boolean, adsEnabled: boolean): [?string, (?string) => void, boolean] {
2021-04-12 12:43:47 -04:00
const [isFetching, setIsFetching] = React.useState(true);
const [adUrl, setAdUrl] = React.useState();
// Fetch ads for all approved videos, even if we won't show ads to the user
// Unruly needs more fetches before they will start returning ads ¯\_(ツ)_/¯
2021-04-12 12:43:47 -04:00
React.useEffect(() => {
if (!approvedVideo) {
2021-04-12 12:43:47 -04:00
setIsFetching(false);
return;
}
analytics.adsFetchedEvent();
const encodedHref = encodeURI(window.location.href);
const url = `${PRE_ROLL_ADS_PROVIDER}${encodedHref}`;
// Used for testing on local dev
// const url = 'https://raw.githubusercontent.com/dailymotion/vast-client-js/master/test/vastfiles/sample.xml';
vastClient
.get(url)
.then((res) => {
if (res.ads.length > 0) {
// Let this line error if res.ads is empty
// I took this from an example response from Dailymotion
// It will be caught below and sent to matomo to figure out if there if this needs to be something changed to deal with unrulys data
const adUrl = res.ads[0].creatives[0].mediaFiles[0].fileURL;
// Dummy video file
// const adUrl = 'https://interactive-examples.mdn.mozilla.net/media/cc0-videos/flower.mp4';
if (adsEnabled && adUrl) {
2021-04-12 12:43:47 -04:00
setAdUrl(adUrl);
}
}
setIsFetching(false);
})
.catch(() => {
setIsFetching(false);
});
}, [approvedVideo, adsEnabled]);
2021-04-12 12:43:47 -04:00
return [adUrl, setAdUrl, isFetching];
}