@veltdev/sdk-staging 5.0.2-beta.80 → 5.0.2-beta.81

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.
@@ -24,6 +24,7 @@ import { TagElement } from "../models/element/tag-element.model";
24
24
  import { FeatureType } from "../utils/enums";
25
25
  import { UserContact } from "../models/data/user-contact.data.model";
26
26
  import { DocumentMetadata } from "../models/data/document-metadata.model";
27
+ import { PageInfo } from "../models/data/page-info.model";
27
28
  import { ReactionElement } from "../models/element/reaction-element.model";
28
29
  import { CrdtElement } from "../models/element/crdt-element.model";
29
30
  import { VeltEventMetadata, VeltDebugInfo } from "../models/data/event-metadata.data.model";
@@ -55,6 +56,23 @@ export declare class Snippyly {
55
56
  * @param documentMetadata Document Metadata
56
57
  */
57
58
  setDocument: (id: string, documentMetadata?: DocumentMetadata) => Promise<void>;
59
+ /**
60
+ * Provide custom page info that the SDK should use instead of generating it from the browser
61
+ * (`window.location` / `document.title`). Newly created data (comments, reactions, recordings,
62
+ * presence, cursors, etc.) will use the provided page info. Already saved/existing data is not
63
+ * affected.
64
+ * @param pageInfo client-provided page info
65
+ * @param options optional; pass a `documentId` to scope the page info to a specific document
66
+ * (per-document page info takes precedence over the global page info)
67
+ */
68
+ setPageInfo: (pageInfo: PageInfo, options?: { documentId?: string; }) => void;
69
+ /**
70
+ * Clear custom page info previously set via `setPageInfo`. The SDK will resume generating
71
+ * page info from the browser.
72
+ * @param options optional; pass a `documentId` to clear only that document's page info,
73
+ * otherwise the global page info is cleared
74
+ */
75
+ clearPageInfo: (options?: { documentId?: string; }) => void;
58
76
  /**
59
77
  * Tell us the unique ID of the current document/resource on which you want to enable collaboration.
60
78
  * @param id unique document ID
@@ -47,4 +47,13 @@ export declare class PageInfo {
47
47
  */
48
48
  screenWidth?: number;
49
49
  deviceInfo?: IDeviceInfo;
50
+ /**
51
+ * @param applyClientOverride when true (default), merges the CURRENT document's client page
52
+ * info override at construction time — covers the bare `new PageInfo()` sites
53
+ * (cursor / presence / selection). No-op when the client hasn't provided any, so the
54
+ * default empty-page-info behavior is unchanged. `getPageInfo(documentId)` passes
55
+ * `false` so it can apply a specific document's override itself, without the current
56
+ * document's fields leaking onto a different document's page info.
57
+ */
58
+ constructor(applyClientOverride?: boolean);
50
59
  }
@@ -0,0 +1,25 @@
1
+ export declare class Console {
2
+ static log: {
3
+ (...data: any[]): void;
4
+ (message?: any, ...optionalParams: any[]): void;
5
+ };
6
+ static warn: {
7
+ (...data: any[]): void;
8
+ (message?: any, ...optionalParams: any[]): void;
9
+ };
10
+ static error: {
11
+ (...data: any[]): void;
12
+ (message?: any, ...optionalParams: any[]): void;
13
+ };
14
+ static debug: {
15
+ (...data: any[]): void;
16
+ (message?: any, ...optionalParams: any[]): void;
17
+ };
18
+ static info: {
19
+ (...data: any[]): void;
20
+ (message?: any, ...optionalParams: any[]): void;
21
+ };
22
+ static logsEnabled: boolean;
23
+ static catch: (message: string, error?: any) => void;
24
+ static showLogs(): boolean;
25
+ }
@@ -0,0 +1,29 @@
1
+ import type { PageInfo } from "../models/data/page-info.model";
2
+ /**
3
+ * Register a resolver that returns the current client document id.
4
+ * Used to pick the right per-document override when no explicit document id is passed.
5
+ */
6
+ export declare const registerCurrentClientDocumentIdGetter: (getter: () => string | number | undefined | null) => void;
7
+ /**
8
+ * Set client-provided page info.
9
+ * @param pageInfo page info provided by the client
10
+ * @param documentId optional client document id; when omitted, sets the global override
11
+ */
12
+ export declare const setClientPageInfo: (pageInfo: Partial<PageInfo> | undefined | null, documentId?: string | number) => void;
13
+ /**
14
+ * Clear client-provided page info.
15
+ * @param documentId optional client document id; when omitted, clears the global override
16
+ */
17
+ export declare const clearClientPageInfo: (documentId?: string | number) => void;
18
+ /**
19
+ * Get the client-provided page info that applies for the given (or current) document.
20
+ * Per-document override wins; otherwise falls back to the global override.
21
+ * @param documentId optional client document id; when omitted, resolves the current document
22
+ * @returns client page info, or undefined when the client has not provided any
23
+ */
24
+ export declare const getClientPageInfo: (documentId?: string | number) => Partial<PageInfo> | undefined;
25
+ /**
26
+ * Reset all client page info and the registered document-id resolver.
27
+ * Intended for tests.
28
+ */
29
+ export declare const resetClientPageInfo: () => void;
@@ -0,0 +1,45 @@
1
+ export declare const environment: {
2
+ production: boolean;
3
+ staging: boolean;
4
+ firebaseLogLevel: string;
5
+ firebaseConfig: {
6
+ apiKey: string;
7
+ authDomain: string;
8
+ projectId: string;
9
+ storageBucket: string;
10
+ messagingSenderId: string;
11
+ appId: string;
12
+ };
13
+ firebaseNotificationsDatabaseURL: string;
14
+ segmentAnalyticsWriteKey: string;
15
+ useEmulators: boolean;
16
+ debugMode: boolean;
17
+ cloudFunction: {
18
+ sa: string;
19
+ getIceServers: string;
20
+ validateClient: string;
21
+ convertRecording: string;
22
+ chatgptCompletion: string;
23
+ rewriterAskAi: string;
24
+ whisperTranscription: string;
25
+ getPlanDetails: string;
26
+ getAllowedDocuments: string;
27
+ getNotificationsForDocuments: string;
28
+ videoBackend: string;
29
+ processRecording: string;
30
+ sdkProxy: string;
31
+ screenshot: string;
32
+ usCentral1: {
33
+ setEncryptedData: string;
34
+ };
35
+ asiaSouthEast1: {
36
+ setEncryptedData: string;
37
+ };
38
+ europeWest1: {
39
+ setEncryptedData: string;
40
+ };
41
+ asiaNorthEast1: {
42
+ setEncryptedData: string;
43
+ };
44
+ };
45
+ };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@veltdev/sdk-staging",
3
- "version": "5.0.2-beta.80",
3
+ "version": "5.0.2-beta.81",
4
4
  "description": "Velt is an SDK to add collaborative features to your product within minutes. Example: Comments like Figma, Frame.io, Google docs or sheets, Recording like Loom, Huddles like Slack and much more.",
5
5
  "homepage": "https://velt.dev",
6
6
  "keywords": [