The smartclientcore is provided as a JavaScript file smartclientcore.min.js that can be used in two ways:
The file must be copied to the video player project.
We recommend using a place that already hosts third-party JS modules for your project.
But please do not use the folder node_modules because it is managed by Node package manager (npm).
If not yet established, let's create a folder named vendor_modules.
import smartclientcore from './vendor_modules/smartclip/smartclientcore.min';The file must be included once by putting the following HTML one-liner next to the Video Player source files.
     <script src="js/videoplayer.js"></script>
+    <script src="js/smartclientcore.min.js"></script>Sample code - step 1 :: Adding the smartclientcore to the page
Certainly your HTML page already includes a HTML5 Audio or Video Player. Otherwise you should take this step first. Next steps assume that your content runs smoothly and the player fulfills the following preconditions:
     advertising: {
-        schedule: {
-            'pre-roll-ad': {
-                offset: 'pre',
-                tag: 'https://adserver.com/tag?type=vast3xml'
-            }
-        }
     }Sample code - step 2 :: Clean-up configuration Object
In order to avoid unexpected calls to the player API, it is not only recommended but mandatory to safeguard the player API with your own facade (proxy). The facade interface has to match with the Facade and Video Player Interface.
Using the facade has two main reasons:
For your reference the smartclientcore package contains a file FacadeBase.js that can be extended by your custom player facade.
import { FacadeBase } from './FacadeBase';
const FACADE_VERSION = '3.2';
export class MyPlayerFacade extends FacadeBase {
    constructor(playerReference = {}) {
        super(playerReference);
    }
}Sample code - step 3 ::  Set up MyPlayerFacade.js
import smartclientcore from './vendor_modules/smartclip/smartclientcore.min';
import { MyPlayerFacade } from './MyPlayerFacade';
// Let's assume the page uses a HTML5 VideoElement, though `myPlayer` can be any other Video Player
const myPlayer = document.querySelector('video#myplayer');
const myPlayerFacade = new MyPlayerFacade(myPlayer);
let globalAdConfig = smartclientcore.SCHEMA.create(smartclientcore.SCHEMA.GLOBAL_CONFIG);
globalAdConfig.debug = true;
let adSlotAPI = null;
let adCoreInstance = smartclientcore.connect(myPlayerFacade);
if (adCoreInstance) {
    adCoreInstance.setup(globalAdConfig).then(api => {
        adSlotAPI = api;
        smartclientcore.debug.info('Ready to request and play out video ads.');
        /**
         * You are ready to request your first ads
         * this is also a good point to subscribe to ad events
         */
        smartclientcore.EVENTS.forEach(eventType => {
            adSlotAPI.addEventListener(eventType, (event) => { /* do something */ });
        });
    }, (failure) => {
        smartclientcore.debug.critical(failure);
    });
}
else {
    // manually turn on the debug logger in the browser console by calling
    // 'localStorage.setItem('debug', true)'
    smartclientcore.debug.critical('Connecting facade and smartclientcore failed. See console output for details.');
}Sample code - step 4 :: Creation and setup of the smartclientcore