@se-studio/core-ui 1.0.13 → 1.0.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +45 -0
- package/dist/analytics/AnalyticsProvider.d.ts +9 -0
- package/dist/analytics/AnalyticsProvider.d.ts.map +1 -0
- package/dist/analytics/AnalyticsProvider.js +15 -0
- package/dist/analytics/AnalyticsProvider.js.map +1 -0
- package/dist/analytics/adapters/ConsoleAnalyticsAdapter.d.ts +8 -0
- package/dist/analytics/adapters/ConsoleAnalyticsAdapter.d.ts.map +1 -0
- package/dist/analytics/adapters/ConsoleAnalyticsAdapter.js +16 -0
- package/dist/analytics/adapters/ConsoleAnalyticsAdapter.js.map +1 -0
- package/dist/analytics/adapters/index.d.ts +2 -0
- package/dist/analytics/adapters/index.d.ts.map +1 -0
- package/dist/analytics/adapters/index.js +2 -0
- package/dist/analytics/adapters/index.js.map +1 -0
- package/dist/analytics/types.d.ts +18 -0
- package/dist/analytics/types.d.ts.map +1 -0
- package/dist/analytics/types.js +2 -0
- package/dist/analytics/types.js.map +1 -0
- package/dist/analytics/useAnalytics.d.ts +10 -0
- package/dist/analytics/useAnalytics.d.ts.map +1 -0
- package/dist/analytics/useAnalytics.js +35 -0
- package/dist/analytics/useAnalytics.js.map +1 -0
- package/dist/components/ClientMonitor.d.ts +1 -0
- package/dist/components/ClientMonitor.d.ts.map +1 -1
- package/dist/components/ClientMonitor.js +187 -18
- package/dist/components/ClientMonitor.js.map +1 -1
- package/dist/elements/TrackedLink.d.ts +16 -0
- package/dist/elements/TrackedLink.d.ts.map +1 -0
- package/dist/elements/TrackedLink.js +63 -0
- package/dist/elements/TrackedLink.js.map +1 -0
- package/dist/index.d.ts +6 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +4 -1
- package/dist/index.js.map +1 -1
- package/package.json +8 -7
- package/dist/elements/UtmLinkOrDiv.d.ts +0 -5
- package/dist/elements/UtmLinkOrDiv.d.ts.map +0 -1
- package/dist/elements/UtmLinkOrDiv.js +0 -9
- package/dist/elements/UtmLinkOrDiv.js.map +0 -1
package/README.md
CHANGED
|
@@ -87,6 +87,51 @@ In your Next.js app layout or root component:
|
|
|
87
87
|
import '@se-studio/core-ui/styles';
|
|
88
88
|
```
|
|
89
89
|
|
|
90
|
+
### Analytics Integration
|
|
91
|
+
|
|
92
|
+
Core UI ships analytics primitives but intentionally does not select a vendor.
|
|
93
|
+
Wrap your app with `AnalyticsProvider` and pass an adapter that implements the
|
|
94
|
+
`AnalyticsAdapter` interface.
|
|
95
|
+
|
|
96
|
+
```tsx
|
|
97
|
+
import { AnalyticsProvider, ConsoleAnalyticsAdapter } from '@se-studio/core-ui';
|
|
98
|
+
|
|
99
|
+
const analyticsAdapter = new ConsoleAnalyticsAdapter(); // example adapter
|
|
100
|
+
|
|
101
|
+
export function AppProviders({ children }: { children: React.ReactNode }) {
|
|
102
|
+
return <AnalyticsProvider adapter={analyticsAdapter}>{children}</AnalyticsProvider>;
|
|
103
|
+
}
|
|
104
|
+
```
|
|
105
|
+
|
|
106
|
+
Use the `useAnalytics` hook anywhere within the provider to trigger events:
|
|
107
|
+
|
|
108
|
+
```tsx
|
|
109
|
+
import { useAnalytics } from '@se-studio/core-ui';
|
|
110
|
+
|
|
111
|
+
export function NewsletterCta() {
|
|
112
|
+
const { trackClick } = useAnalytics();
|
|
113
|
+
|
|
114
|
+
return (
|
|
115
|
+
<button
|
|
116
|
+
type="button"
|
|
117
|
+
onClick={() =>
|
|
118
|
+
trackClick('Button', 'Sign up', {
|
|
119
|
+
page_title: 'Home',
|
|
120
|
+
page_type: 'landing',
|
|
121
|
+
slug: 'home',
|
|
122
|
+
})
|
|
123
|
+
}
|
|
124
|
+
>
|
|
125
|
+
Sign up
|
|
126
|
+
</button>
|
|
127
|
+
);
|
|
128
|
+
}
|
|
129
|
+
```
|
|
130
|
+
|
|
131
|
+
The provided `ConsoleAnalyticsAdapter` simply logs events for development and
|
|
132
|
+
documentation purposes. Each project should supply an adapter that forwards
|
|
133
|
+
events to its analytics platform of choice.
|
|
134
|
+
|
|
90
135
|
## Components
|
|
91
136
|
|
|
92
137
|
### CMS Infrastructure Components
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type React from 'react';
|
|
2
|
+
import type { AnalyticsAdapter } from './types';
|
|
3
|
+
export interface AnalyticsProviderProps {
|
|
4
|
+
adapter: AnalyticsAdapter;
|
|
5
|
+
children: React.ReactNode;
|
|
6
|
+
}
|
|
7
|
+
export declare function AnalyticsProvider({ adapter, children }: AnalyticsProviderProps): import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
export declare function useAnalyticsContext(): AnalyticsAdapter;
|
|
9
|
+
//# sourceMappingURL=AnalyticsProvider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AnalyticsProvider.d.ts","sourceRoot":"","sources":["../../src/analytics/AnalyticsProvider.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAIhD,MAAM,WAAW,sBAAsB;IACrC,OAAO,EAAE,gBAAgB,CAAC;IAC1B,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B;AAKD,wBAAgB,iBAAiB,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,sBAAsB,2CAE9E;AAMD,wBAAgB,mBAAmB,IAAI,gBAAgB,CAMtD"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { createContext, useContext } from 'react';
|
|
4
|
+
const AnalyticsContext = createContext(null);
|
|
5
|
+
export function AnalyticsProvider({ adapter, children }) {
|
|
6
|
+
return _jsx(AnalyticsContext.Provider, { value: adapter, children: children });
|
|
7
|
+
}
|
|
8
|
+
export function useAnalyticsContext() {
|
|
9
|
+
const adapter = useContext(AnalyticsContext);
|
|
10
|
+
if (!adapter) {
|
|
11
|
+
throw new Error('useAnalyticsContext must be used within an AnalyticsProvider');
|
|
12
|
+
}
|
|
13
|
+
return adapter;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=AnalyticsProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AnalyticsProvider.js","sourceRoot":"","sources":["../../src/analytics/AnalyticsProvider.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAGb,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAGlD,MAAM,gBAAgB,GAAG,aAAa,CAA0B,IAAI,CAAC,CAAC;AAUtE,MAAM,UAAU,iBAAiB,CAAC,EAAE,OAAO,EAAE,QAAQ,EAA0B;IAC7E,OAAO,KAAC,gBAAgB,CAAC,QAAQ,IAAC,KAAK,EAAE,OAAO,YAAG,QAAQ,GAA6B,CAAC;AAC3F,CAAC;AAMD,MAAM,UAAU,mBAAmB;IACjC,MAAM,OAAO,GAAG,UAAU,CAAC,gBAAgB,CAAC,CAAC;IAC7C,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,8DAA8D,CAAC,CAAC;IAClF,CAAC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { AnalyticsAdapter, ClickTrackingProperties, PageTrackingProperties } from '../types';
|
|
2
|
+
export declare class ConsoleAnalyticsAdapter implements AnalyticsAdapter {
|
|
3
|
+
private log;
|
|
4
|
+
trackEvent(event: string, properties: Record<string, unknown>): void;
|
|
5
|
+
trackPage(url: string, properties: PageTrackingProperties): void;
|
|
6
|
+
trackClick(properties: ClickTrackingProperties): void;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=ConsoleAnalyticsAdapter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConsoleAnalyticsAdapter.d.ts","sourceRoot":"","sources":["../../../src/analytics/adapters/ConsoleAnalyticsAdapter.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,gBAAgB,EAAE,uBAAuB,EAAE,sBAAsB,EAAE,MAAM,UAAU,CAAC;AAMlG,qBAAa,uBAAwB,YAAW,gBAAgB;IAC9D,OAAO,CAAC,GAAG;IAKX,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAIpE,SAAS,CAAC,GAAG,EAAE,MAAM,EAAE,UAAU,EAAE,sBAAsB,GAAG,IAAI;IAIhE,UAAU,CAAC,UAAU,EAAE,uBAAuB,GAAG,IAAI;CAGtD"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
export class ConsoleAnalyticsAdapter {
|
|
3
|
+
log(...args) {
|
|
4
|
+
console.log('[Analytics]', ...args);
|
|
5
|
+
}
|
|
6
|
+
trackEvent(event, properties) {
|
|
7
|
+
this.log('event', event, properties);
|
|
8
|
+
}
|
|
9
|
+
trackPage(url, properties) {
|
|
10
|
+
this.log('page', { ...properties, url });
|
|
11
|
+
}
|
|
12
|
+
trackClick(properties) {
|
|
13
|
+
this.log('click', properties);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=ConsoleAnalyticsAdapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConsoleAnalyticsAdapter.js","sourceRoot":"","sources":["../../../src/analytics/adapters/ConsoleAnalyticsAdapter.ts"],"names":[],"mappings":"AAAA,YAAY,CAAC;AAQb,MAAM,OAAO,uBAAuB;IAC1B,GAAG,CAAC,GAAG,IAAe;QAE5B,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,GAAG,IAAI,CAAC,CAAC;IACtC,CAAC;IAED,UAAU,CAAC,KAAa,EAAE,UAAmC;QAC3D,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;IACvC,CAAC;IAED,SAAS,CAAC,GAAW,EAAE,UAAkC;QACvD,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,EAAE,GAAG,UAAU,EAAE,GAAG,EAAE,CAAC,CAAC;IAC3C,CAAC;IAED,UAAU,CAAC,UAAmC;QAC5C,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;IAChC,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/analytics/adapters/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,2BAA2B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/analytics/adapters/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,2BAA2B,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { IAnalyticsContext } from '@se-studio/core-data-types';
|
|
2
|
+
export interface ClickTrackingProperties extends IAnalyticsContext {
|
|
3
|
+
componentType: string;
|
|
4
|
+
url: string;
|
|
5
|
+
targetUrl?: string;
|
|
6
|
+
linkText: string;
|
|
7
|
+
location?: string;
|
|
8
|
+
}
|
|
9
|
+
export interface PageTrackingProperties extends IAnalyticsContext {
|
|
10
|
+
url: string;
|
|
11
|
+
pathname: string;
|
|
12
|
+
}
|
|
13
|
+
export interface AnalyticsAdapter {
|
|
14
|
+
trackEvent(event: string, properties: Record<string, unknown>): void;
|
|
15
|
+
trackPage(url: string, properties: PageTrackingProperties): void;
|
|
16
|
+
trackClick(properties: ClickTrackingProperties): void;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/analytics/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAKpE,MAAM,WAAW,uBAAwB,SAAQ,iBAAiB;IAChE,aAAa,EAAE,MAAM,CAAC;IACtB,GAAG,EAAE,MAAM,CAAC;IACZ,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAKD,MAAM,WAAW,sBAAuB,SAAQ,iBAAiB;IAC/D,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,EAAE,MAAM,CAAC;CAClB;AAKD,MAAM,WAAW,gBAAgB;IAM/B,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAOrE,SAAS,CAAC,GAAG,EAAE,MAAM,EAAE,UAAU,EAAE,sBAAsB,GAAG,IAAI,CAAC;IAMjE,UAAU,CAAC,UAAU,EAAE,uBAAuB,GAAG,IAAI,CAAC;CACvD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/analytics/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { IAnalyticsContext } from '@se-studio/core-data-types';
|
|
2
|
+
export declare function useAnalytics(): {
|
|
3
|
+
trackEvent: (event: string, properties: Record<string, unknown>) => void;
|
|
4
|
+
trackPage: (url: string, pathname: string, analyticsContext: IAnalyticsContext) => void;
|
|
5
|
+
trackClick: (componentType: string, linkText: string, analyticsContext: IAnalyticsContext, options?: {
|
|
6
|
+
targetUrl?: string;
|
|
7
|
+
location?: string;
|
|
8
|
+
}) => void;
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=useAnalytics.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useAnalytics.d.ts","sourceRoot":"","sources":["../../src/analytics/useAnalytics.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AASpE,wBAAgB,YAAY;wBAIhB,MAAM,cAAc,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;qBAO7C,MAAM,YAAY,MAAM,oBAAoB,iBAAiB;gCAalD,MAAM,YACX,MAAM,oBACE,iBAAiB,YACzB;QACR,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;KACnB;EAqBN"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { useCallback } from 'react';
|
|
3
|
+
import { useAnalyticsContext } from './AnalyticsProvider';
|
|
4
|
+
export function useAnalytics() {
|
|
5
|
+
const adapter = useAnalyticsContext();
|
|
6
|
+
const trackEvent = useCallback((event, properties) => {
|
|
7
|
+
adapter.trackEvent(event, properties);
|
|
8
|
+
}, [adapter]);
|
|
9
|
+
const trackPage = useCallback((url, pathname, analyticsContext) => {
|
|
10
|
+
const properties = {
|
|
11
|
+
url,
|
|
12
|
+
pathname,
|
|
13
|
+
...analyticsContext,
|
|
14
|
+
};
|
|
15
|
+
adapter.trackPage(url, properties);
|
|
16
|
+
}, [adapter]);
|
|
17
|
+
const trackClick = useCallback((componentType, linkText, analyticsContext, options) => {
|
|
18
|
+
const url = typeof window !== 'undefined' ? window.location.href : '';
|
|
19
|
+
const properties = {
|
|
20
|
+
componentType,
|
|
21
|
+
url,
|
|
22
|
+
linkText,
|
|
23
|
+
location: options?.location,
|
|
24
|
+
targetUrl: options?.targetUrl,
|
|
25
|
+
...analyticsContext,
|
|
26
|
+
};
|
|
27
|
+
adapter.trackClick(properties);
|
|
28
|
+
}, [adapter]);
|
|
29
|
+
return {
|
|
30
|
+
trackEvent,
|
|
31
|
+
trackPage,
|
|
32
|
+
trackClick,
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=useAnalytics.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useAnalytics.js","sourceRoot":"","sources":["../../src/analytics/useAnalytics.ts"],"names":[],"mappings":"AAAA,YAAY,CAAC;AAGb,OAAO,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AACpC,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAO1D,MAAM,UAAU,YAAY;IAC1B,MAAM,OAAO,GAAG,mBAAmB,EAAE,CAAC;IAEtC,MAAM,UAAU,GAAG,WAAW,CAC5B,CAAC,KAAa,EAAE,UAAmC,EAAE,EAAE;QACrD,OAAO,CAAC,UAAU,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;IACxC,CAAC,EACD,CAAC,OAAO,CAAC,CACV,CAAC;IAEF,MAAM,SAAS,GAAG,WAAW,CAC3B,CAAC,GAAW,EAAE,QAAgB,EAAE,gBAAmC,EAAE,EAAE;QACrE,MAAM,UAAU,GAA2B;YACzC,GAAG;YACH,QAAQ;YACR,GAAG,gBAAgB;SACpB,CAAC;QACF,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC;IACrC,CAAC,EACD,CAAC,OAAO,CAAC,CACV,CAAC;IAEF,MAAM,UAAU,GAAG,WAAW,CAC5B,CACE,aAAqB,EACrB,QAAgB,EAChB,gBAAmC,EACnC,OAGC,EACD,EAAE;QACF,MAAM,GAAG,GAAG,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;QACtE,MAAM,UAAU,GAA4B;YAC1C,aAAa;YACb,GAAG;YACH,QAAQ;YACR,QAAQ,EAAE,OAAO,EAAE,QAAQ;YAC3B,SAAS,EAAE,OAAO,EAAE,SAAS;YAC7B,GAAG,gBAAgB;SACpB,CAAC;QACF,OAAO,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;IACjC,CAAC,EACD,CAAC,OAAO,CAAC,CACV,CAAC;IAEF,OAAO;QACL,UAAU;QACV,SAAS;QACT,UAAU;KACX,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ClientMonitor.d.ts","sourceRoot":"","sources":["../../src/components/ClientMonitor.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"ClientMonitor.d.ts","sourceRoot":"","sources":["../../src/components/ClientMonitor.tsx"],"names":[],"mappings":"AAkbA,UAAU,kBAAkB;IAC1B,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB;AAED,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC,kBAAkB,CAuBtD,CAAC"}
|
|
@@ -3,6 +3,77 @@ import { usePathname } from 'next/navigation';
|
|
|
3
3
|
import { useEffect } from 'react';
|
|
4
4
|
import { useDocumentVisible } from '../hooks/useDocumentVisible';
|
|
5
5
|
const _observers = new Map();
|
|
6
|
+
const _sectionHeights = new Map();
|
|
7
|
+
const _sectionThresholds = new Map();
|
|
8
|
+
const SECTION_THRESHOLDS = Array.from({ length: 21 }, (_, i) => i * 0.05);
|
|
9
|
+
const _intersectingTallElements = new Set();
|
|
10
|
+
let _scrollRAFId = null;
|
|
11
|
+
let _scrollListenerAttached = false;
|
|
12
|
+
const isDevelopment = process.env.NODE_ENV === 'development';
|
|
13
|
+
let _debugEnabled = false;
|
|
14
|
+
function shouldDebug(element) {
|
|
15
|
+
if (!isDevelopment)
|
|
16
|
+
return false;
|
|
17
|
+
if (_debugEnabled)
|
|
18
|
+
return true;
|
|
19
|
+
if (element?.hasAttribute('data-debug'))
|
|
20
|
+
return true;
|
|
21
|
+
return false;
|
|
22
|
+
}
|
|
23
|
+
function updateScrollProgress(element) {
|
|
24
|
+
const elementHeight = _sectionHeights.get(element);
|
|
25
|
+
const threshold = _sectionThresholds.get(element);
|
|
26
|
+
if (elementHeight === undefined || threshold === undefined)
|
|
27
|
+
return;
|
|
28
|
+
const rect = element.getBoundingClientRect();
|
|
29
|
+
const scrollProgress = (window.innerHeight - rect.top) / elementHeight;
|
|
30
|
+
const shouldTrigger = scrollProgress >= threshold;
|
|
31
|
+
element.dataset.visible = shouldTrigger ? 'true' : 'false';
|
|
32
|
+
if (shouldTrigger && !element.dataset.seen) {
|
|
33
|
+
element.dataset.seen = 'true';
|
|
34
|
+
}
|
|
35
|
+
if (shouldDebug(element)) {
|
|
36
|
+
element.dataset.debugScrollProgress = scrollProgress.toFixed(3);
|
|
37
|
+
element.dataset.debugElementHeight = elementHeight.toFixed(1);
|
|
38
|
+
element.dataset.debugThreshold = threshold.toFixed(3);
|
|
39
|
+
element.dataset.debugScrollY = window.scrollY.toFixed(1);
|
|
40
|
+
element.dataset.debugViewportHeight = window.innerHeight.toFixed(1);
|
|
41
|
+
element.dataset.debugShouldTrigger = shouldTrigger ? 'true' : 'false';
|
|
42
|
+
element.dataset.debugIsTallElement = 'true';
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
function handleScroll() {
|
|
46
|
+
if (_scrollRAFId !== null)
|
|
47
|
+
return;
|
|
48
|
+
_scrollRAFId = requestAnimationFrame(() => {
|
|
49
|
+
_scrollRAFId = null;
|
|
50
|
+
for (const element of _intersectingTallElements) {
|
|
51
|
+
updateScrollProgress(element);
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
function attachScrollListener() {
|
|
56
|
+
if (!_scrollListenerAttached) {
|
|
57
|
+
window.addEventListener('scroll', handleScroll, { passive: true });
|
|
58
|
+
_scrollListenerAttached = true;
|
|
59
|
+
if (shouldDebug()) {
|
|
60
|
+
console.log('[ClientMonitor] Scroll listener attached for tall elements');
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
function detachScrollListener() {
|
|
65
|
+
if (_scrollListenerAttached && _intersectingTallElements.size === 0) {
|
|
66
|
+
window.removeEventListener('scroll', handleScroll);
|
|
67
|
+
_scrollListenerAttached = false;
|
|
68
|
+
if (_scrollRAFId !== null) {
|
|
69
|
+
cancelAnimationFrame(_scrollRAFId);
|
|
70
|
+
_scrollRAFId = null;
|
|
71
|
+
}
|
|
72
|
+
if (shouldDebug()) {
|
|
73
|
+
console.log('[ClientMonitor] Scroll listener detached');
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|
|
6
77
|
function roundThreshold(threshold) {
|
|
7
78
|
return Math.round(threshold * 10) / 10;
|
|
8
79
|
}
|
|
@@ -51,12 +122,61 @@ function handleAnimation(animation, isIntersecting) {
|
|
|
51
122
|
}
|
|
52
123
|
}
|
|
53
124
|
}
|
|
54
|
-
function handleAnimatedSection(section, isIntersecting) {
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
125
|
+
function handleAnimatedSection(section, isIntersecting, entry) {
|
|
126
|
+
const elementHeight = _sectionHeights.get(section);
|
|
127
|
+
const threshold = _sectionThresholds.get(section);
|
|
128
|
+
if (elementHeight === undefined || threshold === undefined) {
|
|
129
|
+
section.dataset.visible = isIntersecting ? 'true' : 'false';
|
|
130
|
+
if (isIntersecting && !section.dataset.seen) {
|
|
58
131
|
section.dataset.seen = 'true';
|
|
59
132
|
}
|
|
133
|
+
if (shouldDebug(section)) {
|
|
134
|
+
section.dataset.debugIntersectionRatio = entry.intersectionRatio.toFixed(3);
|
|
135
|
+
section.dataset.debugBoundingTop = entry.boundingClientRect.top.toFixed(1);
|
|
136
|
+
section.dataset.debugScrollY = window.scrollY.toFixed(1);
|
|
137
|
+
section.dataset.debugViewportHeight = window.innerHeight.toFixed(1);
|
|
138
|
+
section.dataset.debugShouldTrigger = isIntersecting ? 'true' : 'false';
|
|
139
|
+
delete section.dataset.debugScrollProgress;
|
|
140
|
+
delete section.dataset.debugElementHeight;
|
|
141
|
+
delete section.dataset.debugThreshold;
|
|
142
|
+
}
|
|
143
|
+
return;
|
|
144
|
+
}
|
|
145
|
+
const isTallElement = elementHeight > window.innerHeight;
|
|
146
|
+
if (isTallElement) {
|
|
147
|
+
if (isIntersecting) {
|
|
148
|
+
_intersectingTallElements.add(section);
|
|
149
|
+
attachScrollListener();
|
|
150
|
+
updateScrollProgress(section);
|
|
151
|
+
}
|
|
152
|
+
else {
|
|
153
|
+
_intersectingTallElements.delete(section);
|
|
154
|
+
detachScrollListener();
|
|
155
|
+
section.dataset.visible = 'false';
|
|
156
|
+
}
|
|
157
|
+
if (shouldDebug(section)) {
|
|
158
|
+
section.dataset.debugIntersectionRatio = entry.intersectionRatio.toFixed(3);
|
|
159
|
+
section.dataset.debugBoundingTop = entry.boundingClientRect.top.toFixed(1);
|
|
160
|
+
section.dataset.debugIsTallElement = 'true';
|
|
161
|
+
}
|
|
162
|
+
return;
|
|
163
|
+
}
|
|
164
|
+
const scrollProgress = (window.innerHeight - entry.boundingClientRect.top) / elementHeight;
|
|
165
|
+
const shouldTrigger = scrollProgress >= threshold;
|
|
166
|
+
section.dataset.visible = shouldTrigger ? 'true' : 'false';
|
|
167
|
+
if (shouldTrigger && !section.dataset.seen) {
|
|
168
|
+
section.dataset.seen = 'true';
|
|
169
|
+
}
|
|
170
|
+
if (shouldDebug(section)) {
|
|
171
|
+
section.dataset.debugIntersectionRatio = entry.intersectionRatio.toFixed(3);
|
|
172
|
+
section.dataset.debugBoundingTop = entry.boundingClientRect.top.toFixed(1);
|
|
173
|
+
section.dataset.debugScrollProgress = scrollProgress.toFixed(3);
|
|
174
|
+
section.dataset.debugElementHeight = elementHeight.toFixed(1);
|
|
175
|
+
section.dataset.debugThreshold = threshold.toFixed(3);
|
|
176
|
+
section.dataset.debugScrollY = window.scrollY.toFixed(1);
|
|
177
|
+
section.dataset.debugViewportHeight = window.innerHeight.toFixed(1);
|
|
178
|
+
section.dataset.debugShouldTrigger = shouldTrigger ? 'true' : 'false';
|
|
179
|
+
section.dataset.debugIsTallElement = 'false';
|
|
60
180
|
}
|
|
61
181
|
}
|
|
62
182
|
function intersectionHandler(entries) {
|
|
@@ -72,7 +192,7 @@ function intersectionHandler(entries) {
|
|
|
72
192
|
default:
|
|
73
193
|
{
|
|
74
194
|
const element = target;
|
|
75
|
-
handleAnimatedSection(element, entry.isIntersecting);
|
|
195
|
+
handleAnimatedSection(element, entry.isIntersecting, entry);
|
|
76
196
|
}
|
|
77
197
|
break;
|
|
78
198
|
}
|
|
@@ -91,11 +211,18 @@ function getObserver(threshold) {
|
|
|
91
211
|
function findAllVideos(defaultThreshold) {
|
|
92
212
|
const videos = document.getElementsByTagName('video');
|
|
93
213
|
const videoObservers = new Map();
|
|
214
|
+
if (shouldDebug()) {
|
|
215
|
+
console.log(`[ClientMonitor] Found ${videos.length} video(s)`);
|
|
216
|
+
}
|
|
94
217
|
for (const video of videos) {
|
|
95
218
|
video.controls = false;
|
|
96
219
|
video.muted = true;
|
|
97
220
|
const threshold = getElementThreshold(video, defaultThreshold);
|
|
98
221
|
const observer = getObserver(threshold);
|
|
222
|
+
if (shouldDebug(video)) {
|
|
223
|
+
video.setAttribute('data-monitor-threshold', threshold.toString());
|
|
224
|
+
video.setAttribute('data-monitor-observed', 'true');
|
|
225
|
+
}
|
|
99
226
|
let videoList = videoObservers.get(observer);
|
|
100
227
|
if (!videoList) {
|
|
101
228
|
videoList = [];
|
|
@@ -115,9 +242,16 @@ function findAllVideos(defaultThreshold) {
|
|
|
115
242
|
function findAllAnimations(defaultThreshold) {
|
|
116
243
|
const animations = document.getElementsByTagName('lottie-player');
|
|
117
244
|
const animationObservers = new Map();
|
|
245
|
+
if (shouldDebug()) {
|
|
246
|
+
console.log(`[ClientMonitor] Found ${animations.length} animation(s)`);
|
|
247
|
+
}
|
|
118
248
|
for (const animation of animations) {
|
|
119
249
|
const threshold = getElementThreshold(animation, defaultThreshold);
|
|
120
250
|
const observer = getObserver(threshold);
|
|
251
|
+
if (shouldDebug(animation)) {
|
|
252
|
+
animation.setAttribute('data-monitor-threshold', threshold.toString());
|
|
253
|
+
animation.setAttribute('data-monitor-observed', 'true');
|
|
254
|
+
}
|
|
121
255
|
let animationList = animationObservers.get(observer);
|
|
122
256
|
if (!animationList) {
|
|
123
257
|
animationList = [];
|
|
@@ -136,24 +270,55 @@ function findAllAnimations(defaultThreshold) {
|
|
|
136
270
|
}
|
|
137
271
|
function findAllAnimatedSections(defaultThreshold) {
|
|
138
272
|
const sections = document.querySelectorAll('[data-component]');
|
|
139
|
-
const
|
|
273
|
+
const sectionElements = [];
|
|
274
|
+
if (shouldDebug()) {
|
|
275
|
+
console.log(`[ClientMonitor] Found ${sections.length} animated section(s)`);
|
|
276
|
+
}
|
|
277
|
+
const sectionObserver = new IntersectionObserver((entries) => {
|
|
278
|
+
for (const entry of entries) {
|
|
279
|
+
const element = entry.target;
|
|
280
|
+
handleAnimatedSection(element, entry.isIntersecting, entry);
|
|
281
|
+
}
|
|
282
|
+
}, { threshold: SECTION_THRESHOLDS });
|
|
283
|
+
const resizeObserver = new ResizeObserver((entries) => {
|
|
284
|
+
for (const entry of entries) {
|
|
285
|
+
const element = entry.target;
|
|
286
|
+
_sectionHeights.set(element, entry.contentRect.height);
|
|
287
|
+
}
|
|
288
|
+
});
|
|
140
289
|
for (const section of sections) {
|
|
141
|
-
const
|
|
142
|
-
const
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
290
|
+
const sectionElement = section;
|
|
291
|
+
const threshold = getElementThreshold(sectionElement, defaultThreshold);
|
|
292
|
+
_sectionThresholds.set(sectionElement, threshold);
|
|
293
|
+
const height = sectionElement.offsetHeight;
|
|
294
|
+
_sectionHeights.set(sectionElement, height);
|
|
295
|
+
resizeObserver.observe(sectionElement);
|
|
296
|
+
sectionElements.push(sectionElement);
|
|
297
|
+
if (shouldDebug(sectionElement)) {
|
|
298
|
+
sectionElement.setAttribute('data-monitor-threshold', threshold.toString());
|
|
299
|
+
sectionElement.setAttribute('data-monitor-observed', 'true');
|
|
147
300
|
}
|
|
148
|
-
|
|
149
|
-
observer.observe(section);
|
|
301
|
+
sectionObserver.observe(sectionElement);
|
|
150
302
|
}
|
|
151
303
|
return () => {
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
304
|
+
sectionObserver.disconnect();
|
|
305
|
+
for (const sectionElement of sectionElements) {
|
|
306
|
+
resizeObserver.unobserve(sectionElement);
|
|
307
|
+
_sectionHeights.delete(sectionElement);
|
|
308
|
+
_sectionThresholds.delete(sectionElement);
|
|
309
|
+
_intersectingTallElements.delete(sectionElement);
|
|
310
|
+
}
|
|
311
|
+
if (_scrollListenerAttached) {
|
|
312
|
+
window.removeEventListener('scroll', handleScroll);
|
|
313
|
+
_scrollListenerAttached = false;
|
|
314
|
+
if (_scrollRAFId !== null) {
|
|
315
|
+
cancelAnimationFrame(_scrollRAFId);
|
|
316
|
+
_scrollRAFId = null;
|
|
155
317
|
}
|
|
156
318
|
}
|
|
319
|
+
if (shouldDebug()) {
|
|
320
|
+
console.log('[ClientMonitor] Animated sections cleanup complete');
|
|
321
|
+
}
|
|
157
322
|
};
|
|
158
323
|
}
|
|
159
324
|
function findAll(defaultThreshold) {
|
|
@@ -166,13 +331,17 @@ function findAll(defaultThreshold) {
|
|
|
166
331
|
animatedSectionCleanup();
|
|
167
332
|
};
|
|
168
333
|
}
|
|
169
|
-
export const ClientMonitor = ({ defaultThreshold = 0.2 }) => {
|
|
334
|
+
export const ClientMonitor = ({ defaultThreshold = 0.2, enableDebug = false, }) => {
|
|
335
|
+
_debugEnabled = enableDebug;
|
|
170
336
|
const isDocumentVisible = useDocumentVisible();
|
|
171
337
|
const pathname = usePathname();
|
|
172
338
|
const roundedDefaultThreshold = roundThreshold(defaultThreshold);
|
|
173
339
|
useEffect(() => {
|
|
174
340
|
pathname;
|
|
175
341
|
if (isDocumentVisible) {
|
|
342
|
+
if (shouldDebug()) {
|
|
343
|
+
console.log(`[ClientMonitor] Initializing with defaultThreshold: ${roundedDefaultThreshold}`);
|
|
344
|
+
}
|
|
176
345
|
return findAll(roundedDefaultThreshold);
|
|
177
346
|
}
|
|
178
347
|
return undefined;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ClientMonitor.js","sourceRoot":"","sources":["../../src/components/ClientMonitor.tsx"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ClientMonitor.js","sourceRoot":"","sources":["../../src/components/ClientMonitor.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { IAnalyticsContext } from '@se-studio/core-data-types';
|
|
2
|
+
import { type LinkProps } from 'next/link';
|
|
3
|
+
import type React from 'react';
|
|
4
|
+
export interface TrackedLinkProps extends Omit<LinkProps<string>, 'href'>, Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, keyof LinkProps<string>> {
|
|
5
|
+
href?: string | null;
|
|
6
|
+
componentType?: string;
|
|
7
|
+
location?: string | null;
|
|
8
|
+
analyticsContext?: IAnalyticsContext;
|
|
9
|
+
linkText?: string;
|
|
10
|
+
appendUtmParams?: boolean;
|
|
11
|
+
asChild?: boolean;
|
|
12
|
+
component?: React.ElementType;
|
|
13
|
+
children: React.ReactNode;
|
|
14
|
+
}
|
|
15
|
+
export declare const TrackedLink: React.ForwardRefExoticComponent<TrackedLinkProps & React.RefAttributes<HTMLAnchorElement>>;
|
|
16
|
+
//# sourceMappingURL=TrackedLink.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TrackedLink.d.ts","sourceRoot":"","sources":["../../src/elements/TrackedLink.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAEpE,OAAa,EAAE,KAAK,SAAS,EAAE,MAAM,WAAW,CAAC;AACjD,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAI/B,MAAM,WAAW,gBACf,SAAQ,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC,EACrC,IAAI,CAAC,KAAK,CAAC,oBAAoB,CAAC,iBAAiB,CAAC,EAAE,MAAM,SAAS,CAAC,MAAM,CAAC,CAAC;IAC9E,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,gBAAgB,CAAC,EAAE,iBAAiB,CAAC;IACrC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,KAAK,CAAC,WAAW,CAAC;IAC9B,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B;AAUD,eAAO,MAAM,WAAW,4FA+GtB,CAAC"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { Slot } from '@radix-ui/react-slot';
|
|
4
|
+
import Link from 'next/link';
|
|
5
|
+
import { forwardRef, isValidElement, useCallback, useEffect, useState } from 'react';
|
|
6
|
+
import { useAnalytics } from '../analytics/useAnalytics';
|
|
7
|
+
export const TrackedLink = forwardRef(function TrackedLink({ href, componentType = 'Link', location, analyticsContext, linkText, appendUtmParams = true, children, onClick, asChild = false, component, prefetch, replace, scroll, shallow, passHref, locale, ...props }, ref) {
|
|
8
|
+
const { trackClick } = useAnalytics();
|
|
9
|
+
const [finalHref, setFinalHref] = useState(href || '#');
|
|
10
|
+
useEffect(() => {
|
|
11
|
+
if (!href || href === '#') {
|
|
12
|
+
setFinalHref('#');
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
if (!appendUtmParams) {
|
|
16
|
+
setFinalHref(href);
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
const search = typeof window !== 'undefined' ? window.location.search : '';
|
|
20
|
+
if (search && href.indexOf('?') < 0) {
|
|
21
|
+
setFinalHref((href + search));
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
setFinalHref(href);
|
|
25
|
+
}
|
|
26
|
+
}, [href, appendUtmParams]);
|
|
27
|
+
const getLinkText = useCallback(() => {
|
|
28
|
+
if (linkText)
|
|
29
|
+
return linkText;
|
|
30
|
+
if (typeof children === 'string')
|
|
31
|
+
return children;
|
|
32
|
+
if (isValidElement(children)) {
|
|
33
|
+
const childrenElement = children;
|
|
34
|
+
const props = childrenElement.props;
|
|
35
|
+
if (typeof props?.children === 'string' && props.children) {
|
|
36
|
+
return props.children;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
return '';
|
|
40
|
+
}, [linkText, children]);
|
|
41
|
+
const handleClick = useCallback((event) => {
|
|
42
|
+
if (analyticsContext) {
|
|
43
|
+
trackClick(componentType, getLinkText(), analyticsContext, {
|
|
44
|
+
targetUrl: href || undefined,
|
|
45
|
+
location: location || undefined,
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
onClick?.(event);
|
|
49
|
+
}, [analyticsContext, componentType, getLinkText, href, location, onClick, trackClick]);
|
|
50
|
+
const linkProps = {
|
|
51
|
+
prefetch,
|
|
52
|
+
replace,
|
|
53
|
+
scroll,
|
|
54
|
+
shallow,
|
|
55
|
+
locale,
|
|
56
|
+
};
|
|
57
|
+
if (asChild || component) {
|
|
58
|
+
const Component = (component || Slot);
|
|
59
|
+
return (_jsx(Link, { href: finalHref, onClick: handleClick, passHref: true, ...linkProps, children: _jsx(Component, { ref: ref, ...props, children: children }) }));
|
|
60
|
+
}
|
|
61
|
+
return (_jsx(Link, { href: finalHref, onClick: handleClick, prefetch: prefetch, replace: replace, scroll: scroll, shallow: shallow, passHref: passHref, locale: locale, ref: ref, ...props, children: children }));
|
|
62
|
+
});
|
|
63
|
+
//# sourceMappingURL=TrackedLink.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TrackedLink.js","sourceRoot":"","sources":["../../src/elements/TrackedLink.tsx"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,3 +1,7 @@
|
|
|
1
|
+
export { AnalyticsProvider, useAnalyticsContext } from './analytics/AnalyticsProvider';
|
|
2
|
+
export { ConsoleAnalyticsAdapter } from './analytics/adapters';
|
|
3
|
+
export type { AnalyticsAdapter, ClickTrackingProperties, PageTrackingProperties, } from './analytics/types';
|
|
4
|
+
export { useAnalytics } from './analytics/useAnalytics';
|
|
1
5
|
export type { CmsRendererConfig, CmsRendererTypes } from './CmsRendererConfig';
|
|
2
6
|
export { ClientMonitor } from './components/ClientMonitor.js';
|
|
3
7
|
export type { CollectionMap, CollectionRenderer, CollectionRendererProps, EmbeddedCollectionMap, EmbeddedCollectionRenderer, } from './components/CmsCollection';
|
|
@@ -14,8 +18,9 @@ export type { IVisualProps } from './components/Visual';
|
|
|
14
18
|
export { calculateCropDetails, calculateImagePriority, calculateImageWidthStyleVariable, } from './components/Visual';
|
|
15
19
|
export { Visual } from './components/VisualComponent';
|
|
16
20
|
export { RtfOrString } from './elements/RtfOrString';
|
|
21
|
+
export type { TrackedLinkProps } from './elements/TrackedLink';
|
|
22
|
+
export { TrackedLink } from './elements/TrackedLink';
|
|
17
23
|
export { UtmLink } from './elements/UtmLink';
|
|
18
|
-
export { UtmLinkOrDiv } from './elements/UtmLinkOrDiv';
|
|
19
24
|
export { BackgroundMedia } from './framework/BackgroundMedia';
|
|
20
25
|
export { ComponentErrorIndicator } from './framework/ComponentErrorIndicator';
|
|
21
26
|
export { showComponentError, showInlineError } from './framework/componentErrors';
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AAEvF,OAAO,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAC;AAC/D,YAAY,EACV,gBAAgB,EAChB,uBAAuB,EACvB,sBAAsB,GACvB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,YAAY,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAC/E,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAE9D,YAAY,EACV,aAAa,EACb,kBAAkB,EAClB,uBAAuB,EACvB,qBAAqB,EACrB,0BAA0B,GAC3B,MAAM,4BAA4B,CAAC;AACpC,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,YAAY,EACV,YAAY,EACZ,iBAAiB,EACjB,sBAAsB,EACtB,oBAAoB,EACpB,yBAAyB,GAC1B,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,YAAY,EACV,oBAAoB,EACpB,uBAAuB,GACxB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,kCAAkC,CAAC;AACvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,iCAAiC,CAAC;AACrE,YAAY,EACV,4BAA4B,EAC5B,iCAAiC,EACjC,oBAAoB,EACpB,yBAAyB,EACzB,8BAA8B,GAC/B,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAClD,YAAY,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAExD,OAAO,EACL,oBAAoB,EACpB,sBAAsB,EACtB,gCAAgC,GACjC,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,MAAM,EAAE,MAAM,8BAA8B,CAAC;AACtD,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AACrD,YAAY,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAE9D,OAAO,EAAE,uBAAuB,EAAE,MAAM,qCAAqC,CAAC;AAC9E,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAClF,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAE3E,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,GAAG,EAAE,MAAM,WAAW,CAAC;AAChC,YAAY,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AACnE,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAE9D,OAAO,EAAE,EAAE,EAAE,MAAM,YAAY,CAAC;AAEhC,YAAY,EACV,YAAY,EACZ,gBAAgB,EAChB,yBAAyB,EACzB,eAAe,EACf,wBAAwB,EACxB,sBAAsB,EACtB,iCAAiC,EACjC,gCAAgC,GACjC,MAAM,wBAAwB,CAAC;AAChC,OAAO,EACL,qBAAqB,EACrB,oBAAoB,EACpB,qBAAqB,EACrB,oBAAoB,EACpB,kBAAkB,GACnB,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,YAAY,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EACL,sBAAsB,EACtB,sBAAsB,EACtB,qBAAqB,EACrB,eAAe,GAChB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAEhE,OAAO,EAAE,sBAAsB,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAC9E,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,EAAE,oCAAoC,EAAE,MAAM,yBAAyB,CAAC;AAC/E,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
export { AnalyticsProvider, useAnalyticsContext } from './analytics/AnalyticsProvider';
|
|
2
|
+
export { ConsoleAnalyticsAdapter } from './analytics/adapters';
|
|
3
|
+
export { useAnalytics } from './analytics/useAnalytics';
|
|
1
4
|
export { ClientMonitor } from './components/ClientMonitor.js';
|
|
2
5
|
export { CmsCollection } from './components/CmsCollection';
|
|
3
6
|
export { CmsComponent } from './components/CmsComponent';
|
|
@@ -8,8 +11,8 @@ export { Preview } from './components/Preview.js';
|
|
|
8
11
|
export { calculateCropDetails, calculateImagePriority, calculateImageWidthStyleVariable, } from './components/Visual';
|
|
9
12
|
export { Visual } from './components/VisualComponent';
|
|
10
13
|
export { RtfOrString } from './elements/RtfOrString';
|
|
14
|
+
export { TrackedLink } from './elements/TrackedLink';
|
|
11
15
|
export { UtmLink } from './elements/UtmLink';
|
|
12
|
-
export { UtmLinkOrDiv } from './elements/UtmLinkOrDiv';
|
|
13
16
|
export { BackgroundMedia } from './framework/BackgroundMedia';
|
|
14
17
|
export { ComponentErrorIndicator } from './framework/ComponentErrorIndicator';
|
|
15
18
|
export { showComponentError, showInlineError } from './framework/componentErrors';
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAS9D,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAQ3D,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAKzD,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,kCAAkC,CAAC;AACvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,iCAAiC,CAAC;AAQrE,OAAO,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAGlD,OAAO,EACL,oBAAoB,EACpB,sBAAsB,EACtB,gCAAgC,GACjC,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,MAAM,EAAE,MAAM,8BAA8B,CAAC;AACtD,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AAEvF,OAAO,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAC;AAM/D,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAExD,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAS9D,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAQ3D,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAKzD,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,kCAAkC,CAAC;AACvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,iCAAiC,CAAC;AAQrE,OAAO,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAGlD,OAAO,EACL,oBAAoB,EACpB,sBAAsB,EACtB,gCAAgC,GACjC,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,MAAM,EAAE,MAAM,8BAA8B,CAAC;AACtD,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAE9D,OAAO,EAAE,uBAAuB,EAAE,MAAM,qCAAqC,CAAC;AAC9E,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAClF,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAE3E,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,GAAG,EAAE,MAAM,WAAW,CAAC;AAEhC,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAE9D,OAAO,EAAE,EAAE,EAAE,MAAM,YAAY,CAAC;AAYhC,OAAO,EACL,qBAAqB,EACrB,oBAAoB,EACpB,qBAAqB,EACrB,oBAAoB,EACpB,kBAAkB,GACnB,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAEvD,OAAO,EACL,sBAAsB,EACtB,sBAAsB,EACtB,qBAAqB,EACrB,eAAe,GAChB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAEhE,OAAO,EAAE,sBAAsB,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAC9E,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,EAAE,oCAAoC,EAAE,MAAM,yBAAyB,CAAC;AAC/E,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@se-studio/core-ui",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.14",
|
|
4
4
|
"description": "Shared React UI component library with Tailwind CSS v4 for SE Studio applications",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -34,29 +34,30 @@
|
|
|
34
34
|
"react-dom": "^19.0.0"
|
|
35
35
|
},
|
|
36
36
|
"dependencies": {
|
|
37
|
-
"@contentful/live-preview": "^4.
|
|
37
|
+
"@contentful/live-preview": "^4.7.0",
|
|
38
38
|
"@contentful/rich-text-react-renderer": "^16.1.6",
|
|
39
39
|
"@contentful/rich-text-types": "^17.2.5",
|
|
40
40
|
"@extractus/oembed-extractor": "^4.0.9",
|
|
41
|
+
"@radix-ui/react-slot": "^1.2.4",
|
|
41
42
|
"change-case": "^5.4.4",
|
|
42
43
|
"clsx": "^2.1.1",
|
|
43
44
|
"html-entities": "^2.6.0",
|
|
44
45
|
"tailwind-merge": "^3.4.0",
|
|
45
|
-
"@se-studio/contentful-rest-api": "1.0.
|
|
46
|
-
"@se-studio/core-data-types": "1.0.
|
|
46
|
+
"@se-studio/contentful-rest-api": "1.0.14",
|
|
47
|
+
"@se-studio/core-data-types": "1.0.14"
|
|
47
48
|
},
|
|
48
49
|
"devDependencies": {
|
|
49
|
-
"@biomejs/biome": "^2.3.
|
|
50
|
+
"@biomejs/biome": "^2.3.7",
|
|
50
51
|
"@testing-library/jest-dom": "^6.9.1",
|
|
51
52
|
"@testing-library/react": "^16.3.0",
|
|
52
53
|
"@types/node": "^24.10.1",
|
|
53
|
-
"@types/react": "^19.2.
|
|
54
|
+
"@types/react": "^19.2.7",
|
|
54
55
|
"@types/react-dom": "^19.2.3",
|
|
55
56
|
"@vitejs/plugin-react": "^5.1.1",
|
|
56
57
|
"jsdom": "^27.2.0",
|
|
57
58
|
"next": "^15.5.6",
|
|
58
59
|
"typescript": "^5.9.3",
|
|
59
|
-
"vitest": "^4.0.
|
|
60
|
+
"vitest": "^4.0.14"
|
|
60
61
|
},
|
|
61
62
|
"scripts": {
|
|
62
63
|
"build": "tsc --project tsconfig.build.json",
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
import type { LinkProps } from 'next/link';
|
|
2
|
-
import type React from 'react';
|
|
3
|
-
import type { PropsWithChildren } from 'react';
|
|
4
|
-
export declare const UtmLinkOrDiv: React.FC<PropsWithChildren<Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, keyof LinkProps<Record<string, unknown>>> & Omit<LinkProps<Record<string, unknown>>, 'href'> & Partial<Pick<LinkProps<Record<string, unknown>>, 'href'>> & React.RefAttributes<HTMLAnchorElement>>>;
|
|
5
|
-
//# sourceMappingURL=UtmLinkOrDiv.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"UtmLinkOrDiv.d.ts","sourceRoot":"","sources":["../../src/elements/UtmLinkOrDiv.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAC3C,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAC;AAG/C,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CACjC,iBAAiB,CACf,IAAI,CAAC,KAAK,CAAC,oBAAoB,CAAC,iBAAiB,CAAC,EAAE,MAAM,SAAS,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,GAC3F,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,EAAE,MAAM,CAAC,GAChD,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,GACzD,KAAK,CAAC,aAAa,CAAC,iBAAiB,CAAC,CACzC,CAcF,CAAC"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import { UtmLink } from './UtmLink';
|
|
3
|
-
export const UtmLinkOrDiv = ({ href, className, style, children, ...props }) => {
|
|
4
|
-
if (href) {
|
|
5
|
-
return (_jsx(UtmLink, { href: href, className: className, style: style, ...props, children: children }));
|
|
6
|
-
}
|
|
7
|
-
return (_jsx("div", { className: className, style: style, children: children }));
|
|
8
|
-
};
|
|
9
|
-
//# sourceMappingURL=UtmLinkOrDiv.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"UtmLinkOrDiv.js","sourceRoot":"","sources":["../../src/elements/UtmLinkOrDiv.tsx"],"names":[],"mappings":";AAGA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,MAAM,CAAC,MAAM,YAAY,GAOrB,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,KAAK,EAAE,EAAE,EAAE;IACrD,IAAI,IAAI,EAAE,CAAC;QACT,OAAO,CACL,KAAC,OAAO,IAAC,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,KAAM,KAAK,YAC/D,QAAQ,GACD,CACX,CAAC;IACJ,CAAC;IACD,OAAO,CACL,cAAK,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,YACpC,QAAQ,GACL,CACP,CAAC;AACJ,CAAC,CAAC"}
|