Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@smg-automotive/advertisement-pkg

Package Overview
Dependencies
Maintainers
0
Versions
21
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@smg-automotive/advertisement-pkg

Contains Relevant Digital Header Bidding Wrapper for advertisements

  • 1.0.8
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
69
decreased by-20.69%
Maintainers
0
Weekly downloads
 
Created
Source

advertisement-pkg

Contains Relevant Digital Header Bidding Wrapper for advertisements.

CircleCI semantic-release

About

This library is created in an effort to integrate Relevant Digital HB Wrapper. It wraps Relevant HB JavaScript API that includes:

Usage

npm install @smg-automotive/advertisement-pkg

AdProvider

The library needs a few configuration variables to work. For that reason, you should wrap your page/top level app component with the <AdProvider/> context.

import { AdProvider } from "@smg-automotive/advertisement-pkg";

const App = () => {
    return (
        <AdProvider
            relevantDigitalConfigId="123abc"
            astCdnUrl="https://acdn.adnxs.com/ast/ast.js"
            relevantDigitalCdnUrl="https://relevant-cdn/123abc.js"
        >
            <AdSlot />
        </AdProvider>
    )
}
export default App

AdSlot component

The AdSlot component can be used to set two types of placements:

  • Inactive placement(default): set on the page and invoked only when useRelevantDigital hook is called. When this happens if you have mixed lazy and non-lazy loaded ads on page it will first initiate all non-lazy ones and in following request it will initiate the remaining lazy ones. On leaving the page hook will call destroySlots
  • Standalone placement: invoked on component render, does not require useRelevantDigital to get invoked, but requires keywords to be set. Can still be used on same page with inactive ads, in that case there is no need to call destroySlots() as hook will clean them all. If is not used on page with the hook, then it should be set to call destroySlots() on its own by setting the param destroyOnUnmount to true.
Inactive AdSlot example
import { AdSlot, useRelevantDigital } from "@smg-automotive/advertisement-pkg";

const keywords = { page: ['home'], site: ['yoursite.ch'], foo: "bar" };

const BrandPage = () => {
    return (
        <div>
            <AdSlot
                adUnitId={1234567}
                id="brand-outside-right"
                standalone
                keywords={keywords}
                destroyOnUnmount
            />
        </div>
    );
}

export default BrandPage;
Inactive AdSlot example
import { AdSlot, useRelevantDigital } from "@smg-automotive/advertisement-pkg";

const keywords = { page: ['home'], site: ['yoursite.ch'], foo: "bar" };

const HomePage = () => {
	useRelevantDigital({ keywords });
	
	return (
		<div>
			<AdSlot adUnitId={1234567} id="home-top-banner" />
		</div>
	);
}

export default HomePage;

Lazy loading

Is set per placement slot in Relevant Yield dashboard for detailed instructions check here Reloads and Lazy loads in HB Manager

Placement size depending on viewport size

Also covered in Relevant Yield dashboard.

Debugging

Set URL param:

  • ?debugAdScripts=true - activate debugging for react-relevant library together with prebid (pbjs) and xanrd (apntag)
  • ?ast_test=true - we need to add when testing mobile web through simulation on a desktop device (else test with actual mobile device)
  • ?pbjs_debug=true - debug only prebid
  • ?ast_test=true - if we suddenly start getting AdBadRequest on testing environment, we probably got blocked by Xandr, in that case we should add this to URL

Analytics

Is injected automatically with relevant ad-stack. Chances are that is already set, but if not check Overview of setting up HB Analytics Can be customized per-site in Relevant Yield dashboard like: "Publisher accounts" > "SMG" (Edit button) > Tutti (or other site) "Programmatic tag" > expand "Custom Global JavaScript code". More in Adding Custom Dimensions

Development

npm run build

You can link your local npm package to integrate it with any local project:

cd advertisement-pkg
npm run build

cd <project directory>
npm link ../smg-automotive-example-pkg

Release a new version

New versions are released on the ci using semantic-release as soon as you merge into master. Please make sure your merge commit message adheres to the corresponding conventions and your branch name does not contain forward slashes /.

FAQs

Package last updated on 26 Nov 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc