@liveblocks/emails
Advanced tools
Comparing version 2.13.0 to 2.13.1-emails1
@@ -1,6 +0,6 @@ | ||
import { CommentBodyText, CommentBodyLink, BaseUserMeta, DU, CommentBodyMention, ResolveUsersArgs, OptionalPromise, CommentBody, DRI } from '@liveblocks/core'; | ||
import { CommentBodyText, CommentBodyLink, BaseUserMeta, DU, CommentBodyMention, ResolveUsersArgs, OptionalPromise, DRI, CommentBody } from '@liveblocks/core'; | ||
export { ResolveUsersArgs } from '@liveblocks/core'; | ||
import React from 'react'; | ||
import { Properties } from 'csstype'; | ||
import { Liveblocks, ThreadNotificationEvent } from '@liveblocks/node'; | ||
import { Liveblocks, TextMentionNotificationEvent, ThreadNotificationEvent } from '@liveblocks/node'; | ||
@@ -98,2 +98,200 @@ /** | ||
declare type ResolveRoomInfoArgs = { | ||
/** | ||
* The ID of the room to resolve | ||
*/ | ||
roomId: string; | ||
}; | ||
/** | ||
* Liveblocks Text Editor | ||
* | ||
* Expose common types to transform nodes from different editors like `Lexical` or `TipTap` | ||
* and then convert them more easily as React or as html. | ||
*/ | ||
declare type LiveblocksTextEditorTextFormat = { | ||
bold: boolean; | ||
italic: boolean; | ||
strikethrough: boolean; | ||
code: boolean; | ||
}; | ||
declare type LiveblocksTextEditorTextNode = { | ||
type: "text"; | ||
text: string; | ||
} & LiveblocksTextEditorTextFormat; | ||
declare type LiveblocksTextEditorMentionNode = { | ||
type: "mention"; | ||
userId: string; | ||
}; | ||
/** | ||
* ------------------------------------------------------------------------------------------------- | ||
* `LiveblocksTextEditorNode` is common structure to represents text editor nodes coming from | ||
* like `Lexical`, `TipTap` or so. | ||
* | ||
* This (simple) structure is made to be scalable and to accommodate with other text editors we could potentially | ||
* want to support in the future. | ||
* | ||
* It allows to manipulate nodes more easily and converts them with ease either as React nodes or as an html safe string. | ||
* From a DX standpoint it provides to developers the same structure to use when using custom React components or inline css | ||
* to represents a text mention with its surrounding text. | ||
* ------------------------------------------------------------------------------------------------- | ||
*/ | ||
declare type LiveblocksTextEditorNode = LiveblocksTextEditorTextNode | LiveblocksTextEditorMentionNode; | ||
declare type TextEditorContainerComponentProps = { | ||
/** | ||
* The nodes of the text editor | ||
*/ | ||
children: React.ReactNode; | ||
}; | ||
declare type TextEditorMentionComponentProps<U extends BaseUserMeta = DU> = { | ||
/** | ||
* The mention element. | ||
*/ | ||
element: LiveblocksTextEditorMentionNode; | ||
/** | ||
* The mention's user info, if the `resolvedUsers` option was provided. | ||
*/ | ||
user?: U["info"]; | ||
}; | ||
declare type TextEditorTextComponentProps = { | ||
/** | ||
* The text element. | ||
*/ | ||
element: LiveblocksTextEditorTextNode; | ||
}; | ||
declare type ConvertTextEditorNodesAsReactComponents<U extends BaseUserMeta = DU> = { | ||
/** | ||
* | ||
* The component used to act as a container to wrap text editor nodes, | ||
*/ | ||
Container: React.ComponentType<TextEditorContainerComponentProps>; | ||
/** | ||
* The component used to display mentions. | ||
*/ | ||
Mention: React.ComponentType<TextEditorMentionComponentProps<U>>; | ||
/** | ||
* The component used to display text nodes. | ||
*/ | ||
Text: React.ComponentType<TextEditorTextComponentProps>; | ||
}; | ||
declare type ConvertTextEditorNodesAsHtmlStyles = { | ||
/** | ||
* The default inline CSS styles used to display container element. | ||
*/ | ||
container: CSSProperties; | ||
/** | ||
* The default inline CSS styles used to display text `<strong />` elements. | ||
*/ | ||
strong: CSSProperties; | ||
/** | ||
* The default inline CSS styles used to display text `<code />` elements. | ||
*/ | ||
code: CSSProperties; | ||
/** | ||
* The default inline CSS styles used to display mentions. | ||
*/ | ||
mention: CSSProperties; | ||
}; | ||
declare type MentionEmailBaseData = { | ||
id: string; | ||
roomId: string; | ||
userId: string; | ||
textEditorNodes: LiveblocksTextEditorNode[]; | ||
createdAt: Date; | ||
}; | ||
declare type PrepareTextMentionNotificationEmailBaseDataOptions = { | ||
/** | ||
* A function that returns room info from room IDs. | ||
*/ | ||
resolveRoomInfo?: (args: ResolveRoomInfoArgs) => OptionalPromise<DRI | undefined>; | ||
}; | ||
declare type MentionEmailAsReactData<U extends BaseUserMeta = DU> = Omit<MentionEmailBaseData, "userId" | "textEditorNodes"> & { | ||
author: U; | ||
reactContent: React.ReactNode; | ||
}; | ||
declare type MentionEmailAsHtmlData<U extends BaseUserMeta = DU> = Omit<MentionEmailBaseData, "userId" | "textEditorNodes"> & { | ||
author: U; | ||
htmlContent: string; | ||
}; | ||
declare type PrepareTextMentionNotificationEmailAsReactOptions<U extends BaseUserMeta = DU> = PrepareTextMentionNotificationEmailBaseDataOptions & { | ||
/** | ||
* A function that returns info from user IDs. | ||
*/ | ||
resolveUsers?: (args: ResolveUsersArgs) => OptionalPromise<(U["info"] | undefined)[] | undefined>; | ||
/** | ||
* The components used to customize the resulting React nodes. Each components has | ||
* priority over the base components inherited. | ||
*/ | ||
components?: Partial<ConvertTextEditorNodesAsReactComponents<U>>; | ||
}; | ||
declare type TextMentionNotificationEmailData<U extends BaseUserMeta, M extends MentionEmailAsReactData<U> | MentionEmailAsHtmlData<U>> = { | ||
mention: M; | ||
roomInfo: DRI; | ||
}; | ||
declare type TextMentionNotificationEmailDataAsReact = TextMentionNotificationEmailData<BaseUserMeta, MentionEmailAsReactData>; | ||
/** | ||
* Prepares data from a `TextMentionNotificationEvent` and convert content as React nodes. | ||
* | ||
* @param client The `Liveblocks` node client | ||
* @param event The `TextMentionNotificationEvent` received in the webhook handler | ||
* @param options The optional options to provide to resolve users, resolve room info and customize comment bodies React components. | ||
* | ||
* It returns a `TextMentionNotificationEmailDataAsReact` or `null` if there are no existing text mention. | ||
* | ||
* @example | ||
* import { Liveblocks} from "@liveblocks/node" | ||
* import { prepareTextMentionNotificationEmailAsReact } from "@liveblocks/emails" | ||
* | ||
* const liveblocks = new Liveblocks({ secret: "sk_..." }) | ||
* const emailData = prepareTextMentionNotificationEmailAsReact( | ||
* liveblocks, | ||
* event, | ||
* { | ||
* resolveUsers, | ||
* resolveRoomInfo, | ||
* components, | ||
* } | ||
* ) | ||
*/ | ||
declare function prepareTextMentionNotificationEmailAsReact(client: Liveblocks, event: TextMentionNotificationEvent, options?: PrepareTextMentionNotificationEmailAsReactOptions<BaseUserMeta>): Promise<TextMentionNotificationEmailDataAsReact | null>; | ||
declare type PrepareTextMentionNotificationEmailAsHtmlOptions<U extends BaseUserMeta = DU> = PrepareTextMentionNotificationEmailBaseDataOptions & { | ||
/** | ||
* A function that returns info from user IDs. | ||
*/ | ||
resolveUsers?: (args: ResolveUsersArgs) => OptionalPromise<(U["info"] | undefined)[] | undefined>; | ||
/** | ||
* The styles used to customize the html elements in the resulting html safe string. | ||
* Each styles has priority over the base styles inherited. | ||
*/ | ||
styles?: Partial<ConvertTextEditorNodesAsHtmlStyles>; | ||
}; | ||
declare type TextMentionNotificationEmailDataAsHtml = TextMentionNotificationEmailData<BaseUserMeta, MentionEmailAsHtmlData>; | ||
/** | ||
* Prepares data from a `TextMentionNotificationEvent` and convert content as an html safe string. | ||
* | ||
* @param client The `Liveblocks` node client | ||
* @param event The `TextMentionNotificationEvent` received in the webhook handler | ||
* @param options The optional options to provide to resolve users, resolve room info and customize comment bodies React components. | ||
* | ||
* It returns a `TextMentionNotificationEmailDataAsReact` or `null` if there are no existing text mention. | ||
* | ||
* @example | ||
* import { Liveblocks} from "@liveblocks/node" | ||
* import { prepareTextMentionNotificationEmailAsHtml } from "@liveblocks/emails" | ||
* | ||
* const liveblocks = new Liveblocks({ secret: "sk_..." }) | ||
* const emailData = prepareTextMentionNotificationEmailAsHtml( | ||
* liveblocks, | ||
* event, | ||
* { | ||
* resolveUsers, | ||
* resolveRoomInfo, | ||
* styles, | ||
* } | ||
* ) | ||
*/ | ||
declare function prepareTextMentionNotificationEmailAsHtml(client: Liveblocks, event: TextMentionNotificationEvent, options?: PrepareTextMentionNotificationEmailAsHtmlOptions<BaseUserMeta>): Promise<TextMentionNotificationEmailDataAsHtml | null>; | ||
declare type CommentEmailBaseData = { | ||
@@ -108,8 +306,2 @@ id: string; | ||
}; | ||
declare type ResolveRoomInfoArgs = { | ||
/** | ||
* The ID of the room to resolve | ||
*/ | ||
roomId: string; | ||
}; | ||
declare type PrepareThreadNotificationEmailBaseDataOptions = { | ||
@@ -218,2 +410,2 @@ /** | ||
export { type CommentBodyContainerComponentProps, type CommentBodyLinkComponentProps, type CommentBodyMentionComponentProps, type CommentBodyParagraphComponentProps, type CommentBodyTextComponentProps, type CommentEmailAsHtmlData, type CommentEmailAsReactData, type ConvertCommentBodyAsHtmlStyles, type ConvertCommentBodyAsReactComponents, type PrepareThreadNotificationEmailAsHtmlOptions, type PrepareThreadNotificationEmailAsReactOptions, type ResolveRoomInfoArgs, type ThreadNotificationEmailDataAsHtml, type ThreadNotificationEmailDataAsReact, prepareThreadNotificationEmailAsHtml, prepareThreadNotificationEmailAsReact }; | ||
export { type CommentBodyContainerComponentProps, type CommentBodyLinkComponentProps, type CommentBodyMentionComponentProps, type CommentBodyParagraphComponentProps, type CommentBodyTextComponentProps, type CommentEmailAsHtmlData, type CommentEmailAsReactData, type ConvertCommentBodyAsHtmlStyles, type ConvertCommentBodyAsReactComponents, type ConvertTextEditorNodesAsHtmlStyles, type ConvertTextEditorNodesAsReactComponents, type MentionEmailAsHtmlData, type MentionEmailAsReactData, type PrepareTextMentionNotificationEmailAsHtmlOptions, type PrepareTextMentionNotificationEmailAsReactOptions, type PrepareThreadNotificationEmailAsHtmlOptions, type PrepareThreadNotificationEmailAsReactOptions, type ResolveRoomInfoArgs, type TextEditorContainerComponentProps, type TextEditorMentionComponentProps, type TextEditorTextComponentProps, type TextMentionNotificationEmailDataAsHtml, type TextMentionNotificationEmailDataAsReact, type ThreadNotificationEmailDataAsHtml, type ThreadNotificationEmailDataAsReact, prepareTextMentionNotificationEmailAsHtml, prepareTextMentionNotificationEmailAsReact, prepareThreadNotificationEmailAsHtml, prepareThreadNotificationEmailAsReact }; |
{ | ||
"name": "@liveblocks/emails", | ||
"version": "2.13.0", | ||
"version": "2.13.1-emails1", | ||
"description": "A set of functions and utilities to make sending emails based on Liveblocks notification events easy. Liveblocks is the all-in-one toolkit to build collaborative products like Figma, Notion, and more.", | ||
@@ -38,4 +38,4 @@ "license": "Apache-2.0", | ||
"dependencies": { | ||
"@liveblocks/core": "2.13.0", | ||
"@liveblocks/node": "2.13.0" | ||
"@liveblocks/core": "2.13.1-emails1", | ||
"@liveblocks/node": "2.13.1-emails1" | ||
}, | ||
@@ -42,0 +42,0 @@ "peerDependencies": { |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
Environment variable access
Supply chain riskPackage accesses environment variables, which may be a sign of credential stuffing or data theft.
Found 2 instances in 1 package
No v1
QualityPackage is not semver >=1. This means it is not stable and does not support ^ ranges.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
1830142
17866
1
6
+ Added@liveblocks/core@2.13.1-emails1(transitive)
+ Added@liveblocks/node@2.13.1-emails1(transitive)
- Removed@liveblocks/core@2.13.0(transitive)
- Removed@liveblocks/node@2.13.0(transitive)