Security News
Node.js EOL Versions CVE Dubbed the Worst CVE of the Year by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
@piwikpro/next-piwik-pro
Advanced tools
Dedicated Piwik PRO library that helps with implementing Piwik PRO Tag Manager and the Piwik PRO tracking client in Next.js applications.
To use this package in your project, run the following command.
npm install @piwikpro/next-piwik-pro
yarn add @piwikpro/next-piwik-pro
In your Next.js Project, include the default PiwikProProvider
in the layout.tsx
file. To set up the Piwik PRO Tag
Manager container in the app.
In the arguments, pass your container id and your container url as parameters (marked container-id
and container-url
in the example below).
import PiwikProProvider from '@piwikpro/next-piwik-pro'
export default function RootLayout({
children
}: {
children: React.ReactNode
}) {
return (
<html lang='en'>
<body>
<PiwikProProvider
containerId='container-id'
containerUrl='container-url'
>
{children}
</PiwikProProvider>
</body>
</html>
)
}
In the next.config.js
use transpilePackages
option.
/** @type {import('next').NextConfig} */
const nextConfig = {
transpilePackages: ['@piwikpro/next-piwik-pro']
}
module.exports = nextConfig
If you plan to use environmental variables to config your Piwik account you can do it with adding them to your .env
file. Remember that variables to be visible in component need to be named with NEXT_PUBLIC_
prefix, in other cases
they will be visible only in Node context but not in Next.
NEXT_PUBLIC_CONTAINER_ID=0a0b8661-8c10-4d59-e8fg-1h926ijkl184
NEXT_PUBLIC_CONTAINER_URL=https://example.piwik.pro
import PiwikProProvider from '@piwikpro/next-piwik-pro'
export default function RootLayout({
children
}: {
children: React.ReactNode
}) {
return (
<html lang='en'>
<body>
<PiwikProProvider
containerUrl={process.env.NEXT_PUBLIC_CONTAINER_URL}
containerId={process.env.NEXT_PUBLIC_CONTAINER_ID}
>
{children}
</PiwikProProvider>
</body>
</html>
)
}
The nonce attribute is useful to allow-list specific elements, such as a particular inline script or style elements. It can help you to avoid using the CSP unsafe-inline directive, which would allow-list all inline scripts or styles.
If you want your nonce to be passed to the script, pass it as the third argument when calling the script initialization method.
import PiwikProProvider from '@piwikpro/next-piwik-pro'
export default function RootLayout({
children
}: {
children: React.ReactNode
}) {
return (
<html lang='en'>
<body>
<PiwikProProvider
containerId='container-id'
containerUrl='container-url'
nonce='nonce-string'
>
{children}
</PiwikProProvider>
</body>
</html>
)
}
To use methods in your page you need to include usePiwikPro
from the library.
Make sure to use usePiwikPro
in client components only, otherwise you will get an error.
To make it work You need to use it in separated client component (use component
)
import { usePiwikPro } from '@piwikpro/next-piwik-pro'
Then you need to define modules you want to use and initialize it from previously included usePiwikPro
context. In
example below you can see the initialization of the PageViews
module.
const { PageViews } = usePiwikPro()
You can use those methods in all hooks and props for ex. useEffect
or onClick
.
useEffect(() => {
PageViews.trackPageView('optional title')
}, [])
<button
onClick={() => {
CustomEvent.trackEvent('Post', pageData.title)
}}
>
CustomEvent.trackEvent button
</button>
Ƭ Dimensions: Record
<`dimension${number}`, string
>
Ƭ InitOptions: Object
Name | Type | Description |
---|---|---|
dataLayerName? | string | Defaults to 'dataLayer' |
nonce? | string | - |
Ƭ PaymentInformation: Object
Name | Type |
---|---|
discount? | number | string |
grandTotal | number | string |
orderId | string |
shipping? | number | string |
subTotal? | number | string |
tax? | number | string |
Ƭ Product: Object
Name | Type |
---|---|
brand? | string |
category? | LimitedArrayFiveStrings |
customDimensions? | Record <number , string > |
name? | string |
price? | number |
quantity? | number |
sku | string |
variant? | string |
Ƭ VisitorInfo: [isNew: "0" | "1", visitorId: string, firstVisitTS: number, previousVisitCount: string | number, currentVisitTS: number, lastVisitTS: number | "", lastEcommerceOrderTS: number | ""]
• Const
default: Object
Name | Type |
---|---|
getInitScript | typeof PiwikPro.getInitScript |
initialize | typeof PiwikPro.init |
▸ getDomains(): Promise
<string
[]>
Returns list of internal domains (set with "setDomains" function and used in outlink tracking).
Promise
<string
[]>
▸ setDomains(domains
): void
Allows to define a list of internal domains or mobile app URIs. Used in outlink tracking for determining whether a link is an outlink and in cross domain linking for determining which links should have visitor ID parameter injected.
Name | Type |
---|---|
domains | string [] |
void
▸ logAllContentBlocksOnPage(): void
Print all content blocks to the console for debugging purposes
void
▸ trackAllContentImpressions(): void
Scans the entire DOM for content blocks and tracks impressions after all page elements load. It does not send duplicates on repeated calls unless trackPageView was called in between trackAllContentImpressions invocations
void
▸ trackContentImpression(contentName
, contentPiece
, contentTarget
): void
Name | Type |
---|---|
contentName | string |
contentPiece | string |
contentTarget | string |
void
▸ trackContentImpressionsWithinNode(domNode
): void
Name | Type |
---|---|
domNode | Node |
void
▸ trackContentInteraction(contentInteraction
, contentName
, contentPiece
, contentTarget
): void
Tracks manual content interaction event
Name | Type | Description |
---|---|---|
contentInteraction | string | Type of interaction (e.g. "click") |
contentName | string | Name of a content block |
contentPiece | string | Name of the content that was displayed (e.g. link to an image) |
contentTarget | string | Where the content leads to (e.g. URL of some external website) |
void
▸ trackContentInteractionNode(domNode
, contentInteraction?
): void
Tracks interaction with a block in domNode. Can be called from code placed in onclick attribute
Name | Type | Description |
---|---|---|
domNode | Node | Node marked as content block or containing content blocks. If content block can’t be found, nothing will tracked. |
contentInteraction? | string | Name of interaction (e.g. "click") |
void
▸ trackVisibleContentImpressions(checkOnScroll?
, watchInterval?
): void
Scans DOM for all visible content blocks and tracks impressions
Name | Type | Description |
---|---|---|
checkOnScroll? | boolean | Whether to scan for visible content on scroll event |
watchInterval? | number | Delay, in milliseconds, between scans for new visible content. Periodic checks can be disabled by passing 0 |
void
▸ deleteCookies(): void
Deletes existing tracking cookies on the next page view
void
▸ disableCookies(): void
Disables all first party cookies. Existing cookies will be deleted in the next page view
void
▸ enableCookies(): void
Enables all first party cookies. Cookies will be created on the next tracking request
void
▸ getConfigVisitorCookieTimeout(): Promise
<number
>
Returns expiration time of visitor cookies (in milliseconds)
Promise
<number
>
▸ getCookieDomain(): Promise
<string
>
Returns domain of the analytics tracking cookies (set with setCookieDomain()).
Promise
<string
>
▸ getCookiePath(): Promise
<string
>
Returns the analytics tracking cookies path
Promise
<string
>
▸ getSessionCookieTimeout(): Promise
<number
>
Returns expiration time of session cookies
Promise
<number
>
▸ hasCookies(): Promise
<boolean
>
Returns true if cookies are enabled in this browser
Promise
<boolean
>
▸ setCookieDomain(domain
): void
Sets the domain for the analytics tracking cookies
Name | Type |
---|---|
domain | string |
void
▸ setCookieNamePrefix(prefix
): void
Sets the prefix for analytics tracking cookies. Default is "pk".
Name | Type |
---|---|
prefix | string |
void
▸ setCookiePath(path
): void
Sets the analytics tracking cookies path
Name | Type |
---|---|
path | string |
void
▸ setReferralCookieTimeout(seconds
): void
Sets the expiration time of referral cookies
Name | Type |
---|---|
seconds | number |
void
▸ setSecureCookie(secure
): void
Toggles the secure cookie flag on all first party cookies (if you are using HTTPS)
Name | Type |
---|---|
secure | boolean |
void
▸ setSessionCookieTimeout(seconds
): void
Sets the expiration time of session cookies
Name | Type |
---|---|
seconds | number |
void
▸ setVisitorCookieTimeout(seconds
): void
Sets the expiration time of visitor cookies
Name | Type |
---|---|
seconds | number |
void
▸ setVisitorIdCookie(): void
Sets cookie containing analytics ID in browser
void
Ƭ LinkDecorator: (url
: string
, value
: string
, name
: string
) => string
| null
▸ (url
, value
, name
): string
| null
Name | Type |
---|---|
url | string |
value | string |
name | string |
string
| null
Ƭ VisitorIdGetter: (url
: string
, name
: string
) => string
▸ (url
, name
): string
Name | Type |
---|---|
url | string |
name | string |
string
▸ customCrossDomainLinkDecorator(decorator
): void
Sets custom cross domains URL decorator for injecting visitor ID into URLs. Used when cross domain linking is enabled.
Name | Type |
---|---|
decorator | LinkDecorator |
void
▸ customCrossDomainLinkVisitorIdGetter(getter
): void
Sets custom cross domain URL parser for extracting visitor ID from URLs. Should extract data injected by URL decorator. The getter should return visitor ID extracted from page URL.
Name | Type |
---|---|
getter | VisitorIdGetter |
void
▸ disableCrossDomainLinking(): void
Disables cross domain linking.
void
▸ enableCrossDomainLinking(): void
Enables cross domain linking. Visitors across domains configured with "setDomains" function will be linked by passing visitor ID parameter in links.
void
▸ getCrossDomainLinkingUrlParameter(): Promise
<string
>
Returns the name of a cross domain URL parameter (query parameter by default) holding visitor ID. This is "pk_vid" by default.
Promise
<string
>
▸ isCrossDomainLinkingEnabled(): Promise
<boolean
>
Returns boolean telling whether cross domain linking is enabled.
Promise
<boolean
>
▸ setCrossDomainLinkingTimeout(timeout
): void
Changes the time in which two visits across domains will be linked. The default timeout is 180 seconds (3 minutes).
Name | Type |
---|---|
timeout | number |
void
▸ deleteCustomDimension(customDimensionId
): void
Removes a custom dimension with the specified ID.
Name | Type |
---|---|
customDimensionId | string | number |
void
▸ getCustomDimensionValue(customDimensionId
): Promise
<string
| undefined
>
Returns the value of a custom dimension with the specified ID.
Name | Type |
---|---|
customDimensionId | string | number |
Promise
<string
| undefined
>
▸ setCustomDimensionValue(customDimensionId
, customDimensionValue
): void
Sets a custom dimension value to be used later.
Name | Type |
---|---|
customDimensionId | string | number |
customDimensionValue | string |
void
▸ trackEvent(category
, action
, name?
, value?
, dimensions?
): void
Tracks a custom event, e.g. when a visitor interacts with the page
Name | Type |
---|---|
category | string |
action | string |
name? | string |
value? | number |
dimensions? | Dimensions |
void
Ƭ DataLayerEntry: Record
<string
, AnyData
>
▸ push(data
): number
Adds entry to a data layer
Name | Type |
---|---|
data | DataLayerEntry |
number
▸ setDataLayerName(name
): void
Name | Type |
---|---|
name | string |
void
▸ addDownloadExtensions(extensions
): void
Adds new extensions to the download extensions list
Name | Type |
---|---|
extensions | string [] |
void
▸ enableLinkTracking(trackAlsoMiddleAndRightClicks?
): void
Enables automatic link tracking. If called with true
, left, right and
middle clicks on links will be treated as opening a link. Opening a links to
an external site (different domain) creates an outlink event. Opening a link
to a downloadable file creates a download event
Name | Type |
---|---|
trackAlsoMiddleAndRightClicks? | boolean |
void
▸ getLinkTrackingTimer(): Promise
<number
>
Returns lock/wait time after a request set by setLinkTrackingTimer
Promise
<number
>
▸ removeDownloadExtensions(extensions
): void
Removes extensions from the download extensions list
Name | Type |
---|---|
extensions | string [] |
void
▸ setDownloadClasses(classes
): void
Sets a list of class names that indicate whether a list is a download and not an outlink
Name | Type |
---|---|
classes | string [] |
void
▸ setDownloadExtensions(extensions
): void
Overwrites the list of file extensions indicating that a link is a download
Name | Type |
---|---|
extensions | string [] |
void
▸ setIgnoreClasses(classes
): void
Set a list of class names that indicate a link should not be tracked
Name | Type |
---|---|
classes | string [] |
void
▸ setLinkClasses(classes
): void
Sets a list of class names that indicate whether a link is an outlink and not download
Name | Type |
---|---|
classes | string [] |
void
▸ setLinkTrackingTimer(time
): void
When a visitor produces an events and closes the page immediately afterwards, e.g. when opening a link, the request might get cancelled. To avoid loosing the last event this way, JavaScript Tracking Client will lock the page for a fraction of a second (if wait time hasn’t passed), giving the request time to reach the Collecting & Processing Pipeline
Name | Type |
---|---|
time | number |
void
▸ trackLink(url
, linkType
, dimensions?
, callback?
): void
Manually tracks outlink or download event with provided values
Name | Type |
---|---|
url | string |
linkType | string |
dimensions? | Dimensions |
callback? | () => void |
void
▸ enableJSErrorTracking(unique?
): void
Enables tracking of unhandled JavaScript errors.
Name | Type | Description |
---|---|---|
unique? | boolean | track only unique errors |
void
▸ trackError(error
): void
Attempts to send error tracking request using same format as native errors caught by enableJSErrorTracking(). Such error request will still follow rules set for tracker, so it will be sent only when JS error tracking is enabled (enableJSErrorTracking function was called before this attempt). It will also respect rules for tracking only unique errors.
Name | Type |
---|---|
error | Error |
void
▸ trackGoal(goalId
, conversionValue
, dimensions?
): void
Tracks manual goal conversion
Name | Type |
---|---|
goalId | string | number |
conversionValue | number |
dimensions? | Dimensions |
void
▸ disableHeartBeatTimer(): void
Disables sending heartbeats if they were previously enabled by "enableHeartBeatTimer" function.
void
▸ enableHeartBeatTimer(delays?
): void
When a visitor is not producing any events (e.g. because they are reading an article or watching a video), we don’t know if they are still on the page. This might skew page statistics, e.g. time on page value. Heartbeat timer allows us to determine how much time visitors spend on a page by sending heartbeats to the Tracker as long as the page is in focus.
Name | Type |
---|---|
delays? | number [] |
void
▸ trackPageView(customPageTitle?
): void
Tracks a visit on the page that the function was run on
Name | Type |
---|---|
customPageTitle? | string |
void
▸ trackSiteSearch(keyword
, category?
, searchCount?
, dimensions?
): void
Tracks search requests on a website
Name | Type |
---|---|
keyword | string |
category? | string |
searchCount? | number |
dimensions? | Dimensions |
void
▸ deanonymizeUser(): void
Disables anonymous tracking and sends deanonymization event to the Tracker. Recommended method for disabling anonymous tracking.
void
▸ getUserId(): Promise
<string
>
The function that will return user ID
Promise
<string
>
▸ getVisitorId(): Promise
<string
>
Returns 16-character hex ID of the visitor
Promise
<string
>
▸ getVisitorInfo(): Promise
<VisitorInfo
>
Returns visitor information in an array
Promise
<VisitorInfo
>
▸ resetUserId(): void
Clears previously set userID, e.g. when visitor logs out
void
▸ setUserId(userId
): void
User ID is an additional parameter that allows you to aggregate data. When set up, you will be able to search through sessions by this parameter, filter reports through it or create Multi attribution reports using User ID
Name | Type |
---|---|
userId | string |
void
▸ setUserIsAnonymous(isAnonymous
): void
Enables or disables anonymous tracking (anonymous = without consent). The next emitted event will have anonymous mode set accordingly.
Name | Type |
---|---|
isAnonymous | boolean |
void
▸ addEcommerceItem(productSKU
, productName
, productCategory
, productPrice
, productQuantity
): void
Name | Type |
---|---|
productSKU | string |
productName | string |
productCategory | string | string [] |
productPrice | number |
productQuantity | number |
void
Deprecated
Please use the ecommerceAddToCart instead.
▸ clearEcommerceCart(): void
void
Deprecated
▸ ecommerceAddToCart(products
): void
Tracks action of adding products to a cart
Name | Type |
---|---|
products | Product [] |
void
▸ ecommerceCartUpdate(products
, grandTotal
): void
Tracks current state of a cart
Name | Type |
---|---|
products | Product [] |
grandTotal | string | number |
void
▸ ecommerceOrder(products
, paymentInformation
): void
Tracks conversion, including products and payment details
Name | Type |
---|---|
products | Product [] |
paymentInformation | PaymentInformation |
void
▸ ecommerceProductDetailView(products
): void
Tracks action of viewing product page
Name | Type |
---|---|
products | Product [] |
void
▸ ecommerceRemoveFromCart(products
): void
Tracks action of removing a products from a cart
Name | Type |
---|---|
products | Product [] |
void
▸ getEcommerceItems(): Promise
<object
>
Promise
<object
>
Deprecated
▸ removeEcommerceItem(productSKU
): void
Name | Type |
---|---|
productSKU | string |
void
Deprecated
Please use the ecommerceRemoveFromCart instead.
▸ setEcommerceView(productSKU
, productName?
, productCategory?
, productPrice?
): void
Name | Type |
---|---|
productSKU | string |
productName? | string |
productCategory? | string [] |
productPrice? | string |
void
Deprecated
▸ trackEcommerceCartUpdate(cartAmount
): void
Name | Type |
---|---|
cartAmount | number |
void
Deprecated
Please use the ecommerceCartUpdate instead.
▸ trackEcommerceOrder(orderId
, orderGrandTotal
, orderSubTotal?
, orderTax?
, orderShipping?
, orderDiscount?
): void
Name | Type |
---|---|
orderId | string |
orderGrandTotal | number |
orderSubTotal? | number |
orderTax? | number |
orderShipping? | number |
orderDiscount? | number |
void
Deprecated
Please use the ecommerceOrder instead.
Ƭ PiwikProProviderProps: { children
: ReactNode
; containerId
: string
; containerUrl
: string
} & InitOptions
▸ default(props
, context?
): ReactNode
Name | Type |
---|---|
props | PiwikProProviderProps |
context? | any |
ReactNode
▸ usePiwikPro(): __module
__module
FAQs
Piwik PRO tracking library for Next.js
The npm package @piwikpro/next-piwik-pro receives a total of 2,133 weekly downloads. As such, @piwikpro/next-piwik-pro popularity was classified as popular.
We found that @piwikpro/next-piwik-pro demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
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.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.