@payloadcms/plugin-form-builder 1.0.16-beta.0 → 1.1.1

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.
Files changed (45) hide show
  1. package/README.md +4 -323
  2. package/dist/collections/FormSubmissions/hooks/sendEmail.d.ts.map +1 -1
  3. package/dist/collections/FormSubmissions/hooks/sendEmail.js +9 -6
  4. package/dist/collections/Forms/DynamicPriceSelector.d.ts.map +1 -1
  5. package/dist/collections/Forms/DynamicPriceSelector.js +4 -3
  6. package/dist/utilities/lexical/converters/heading.d.ts +3 -0
  7. package/dist/utilities/lexical/converters/heading.d.ts.map +1 -0
  8. package/dist/utilities/lexical/converters/heading.js +29 -0
  9. package/dist/utilities/lexical/converters/linebreak.d.ts +3 -0
  10. package/dist/utilities/lexical/converters/linebreak.d.ts.map +1 -0
  11. package/dist/utilities/lexical/converters/linebreak.js +20 -0
  12. package/dist/utilities/lexical/converters/link.d.ts +3 -0
  13. package/dist/utilities/lexical/converters/link.d.ts.map +1 -0
  14. package/dist/utilities/lexical/converters/link.js +31 -0
  15. package/dist/utilities/lexical/converters/list.d.ts +4 -0
  16. package/dist/utilities/lexical/converters/list.d.ts.map +1 -0
  17. package/dist/utilities/lexical/converters/list.js +63 -0
  18. package/dist/utilities/lexical/converters/paragraph.d.ts +3 -0
  19. package/dist/utilities/lexical/converters/paragraph.d.ts.map +1 -0
  20. package/dist/utilities/lexical/converters/paragraph.js +29 -0
  21. package/dist/utilities/lexical/converters/quote.d.ts +3 -0
  22. package/dist/utilities/lexical/converters/quote.d.ts.map +1 -0
  23. package/dist/utilities/lexical/converters/quote.js +29 -0
  24. package/dist/utilities/lexical/converters/text.d.ts +3 -0
  25. package/dist/utilities/lexical/converters/text.d.ts.map +1 -0
  26. package/dist/utilities/lexical/converters/text.js +43 -0
  27. package/dist/utilities/lexical/defaultConverters.d.ts +3 -0
  28. package/dist/utilities/lexical/defaultConverters.d.ts.map +1 -0
  29. package/dist/utilities/lexical/defaultConverters.js +29 -0
  30. package/dist/utilities/lexical/nodeFormat.d.ts +39 -0
  31. package/dist/utilities/lexical/nodeFormat.d.ts.map +1 -0
  32. package/dist/utilities/lexical/nodeFormat.js +133 -0
  33. package/dist/utilities/lexical/serializeLexical.d.ts +8 -0
  34. package/dist/utilities/lexical/serializeLexical.d.ts.map +1 -0
  35. package/dist/utilities/lexical/serializeLexical.js +56 -0
  36. package/dist/utilities/lexical/types.d.ts +13 -0
  37. package/dist/utilities/lexical/types.d.ts.map +1 -0
  38. package/dist/utilities/lexical/types.js +6 -0
  39. package/dist/utilities/slate/serializeSlate.d.ts +12 -0
  40. package/dist/utilities/slate/serializeSlate.d.ts.map +1 -0
  41. package/dist/utilities/slate/serializeSlate.js +132 -0
  42. package/package.json +8 -8
  43. package/dist/utilities/serializeRichText.d.ts +0 -11
  44. package/dist/utilities/serializeRichText.d.ts.map +0 -1
  45. package/dist/utilities/serializeRichText.js +0 -106
package/README.md CHANGED
@@ -1,326 +1,7 @@
1
1
  # Payload Form Builder Plugin
2
2
 
3
- [![NPM](https://img.shields.io/npm/v/@payloadcms/plugin-form-builder)](https://www.npmjs.com/package/@payloadcms/plugin-form-builder)
3
+ A plugin for [Payload](https://github.com/payloadcms/payload) to easily allow admin editors to build and manage forms within the admin panel.
4
4
 
5
- A plugin for [Payload CMS](https://github.com/payloadcms/payload) to easily allow your admin editors to build and manage forms from the admin panel.
6
-
7
- Core features:
8
-
9
- - Creates a `forms` collection where you can:
10
- - Build dynamic forms with any number of fields
11
- - Add payment fields that can handle dynamic prices
12
- - Build completely custom and dynamic emails
13
- - Creates a `formSubmissions` collection that:
14
- - Validates and saves the form data submitted by your frontend
15
- - Sends emails (if applicable)
16
- - Handles payment processing (if applicable)
17
-
18
- ## Installation
19
-
20
- ```bash
21
- yarn add @payloadcms/plugin-form-builder
22
- # OR
23
- npm i @payloadcms/plugin-form-builder
24
- ```
25
-
26
- ## Basic Usage
27
-
28
- In the `plugins` array of your [Payload config](https://payloadcms.com/docs/configuration/overview), call the plugin with [options](#options):
29
-
30
- ```js
31
- import { buildConfig } from 'payload/config'
32
- import formBuilder from '@payloadcms/plugin-form-builder'
33
-
34
- const config = buildConfig({
35
- collections: [
36
- {
37
- slug: 'pages',
38
- fields: [],
39
- },
40
- ],
41
- plugins: [formBuilder()],
42
- })
43
-
44
- export default config
45
- ```
46
-
47
- ### Options
48
-
49
- - `fields`
50
-
51
- An object of field types to allow your admin editors to build forms with. To override default settings pass either a boolean value or a partial [Payload Block](https://payloadcms.com/docs/fields/blocks#block-configs) keyed to the block slug. See [Fields](#fields) for more details.
52
-
53
- ```js
54
- fields: {
55
- text: true,
56
- textarea: true,
57
- select: true,
58
- email: true,
59
- state: true,
60
- country: true,
61
- checkbox: true,
62
- number: true,
63
- message: true,
64
- payment: false
65
- }
66
- ```
67
-
68
- - `redirectRelationships`
69
-
70
- An array of collection slugs that, when enabled, are populated as options in form redirect fields.
71
-
72
- ```js
73
- redirectRelationships: ['pages']
74
- ```
75
-
76
- - `handlePayment`
77
-
78
- A [beforeChange](<[beforeChange](https://payloadcms.com/docs/hooks/globals#beforechange)>) hook that is called upon form submissions. You can integrate into any third-party payment processing API here. There is a `getPaymentTotal` function that will calculate the total cost after all conditions have been applied.
79
-
80
- ```js
81
- import { getPaymentTotal } from '@payloadcms/plugin-form-builder';
82
- ...
83
- handlePayment: async ({ form, submissionData }) => {
84
- // first calculate the price
85
- const paymentField = form.fields?.find((field) => field.blockType === 'payment');
86
- const price = getPaymentTotal({
87
- basePrice: paymentField.basePrice,
88
- priceConditions: paymentField.priceConditions,
89
- fieldValues: submissionData,
90
- });
91
- // then asynchronously process the payment here
92
- }
93
- ```
94
-
95
- - `beforeEmail`
96
-
97
- A [beforeChange](<[beforeChange](https://payloadcms.com/docs/hooks/globals#beforechange)>) hook that is called just after emails are prepared, but before they are sent. This is a great place to inject your own HTML template to add custom styles.
98
-
99
- ```js
100
- beforeEmail: (emailsToSend) => {
101
- // modify the emails in any way before they are sent
102
- return emails.map((email) => ({
103
- ...email,
104
- html: email.html, // transform the html in any way you'd like (maybe wrap it in an html template?)
105
- }))
106
- }
107
- ```
108
-
109
- - `formOverrides`
110
-
111
- Override anything on the form collection by sending a [Payload Collection Config](https://payloadcms.com/docs/configuration/collections). Your overrides will be merged into the default `forms` collection.
112
-
113
- ```ts
114
- formOverrides: {
115
- slug: "contact-forms",
116
- access: {
117
- read: () => true,
118
- update: () => false,
119
- },
120
- fields: [
121
- {
122
- name: "custom-field",
123
- type: "text"
124
- }
125
- ]
126
- }
127
- ```
128
-
129
- - `formSubmissionOverrides`
130
-
131
- By default, this plugin relies on [Payload access control](https://payloadcms.com/docs/access-control/collections) to restrict the `update` and `read` operations. This is because anyone should be able to create a form submission, even from a public-facing website - but no one should be able to update a submission one it has been created, or read a submission unless they have permission.
132
-
133
- You can override access control and anything else on the form submission collection by sending a [Payload Collection Config](https://payloadcms.com/docs/configuration/collections). Your overrides will be merged into the default `formSubmissions` collection.
134
-
135
- ```js
136
- formSubmissionOverrides: {
137
- slug: "leads",
138
- }
139
- ```
140
-
141
- ## Fields
142
-
143
- Each field represents a form input. To override default settings pass either a boolean value or a partial [Payload Block](https://payloadcms.com/docs/fields/blocks) _keyed to the block's slug_. See [Field Overrides](#field-overrides) for more details on how to do this.
144
-
145
- > NOTE: "fields" here are in reference to the _fields to build forms with_, not to be confused with the _fields of a collection_ which are set via `formOverrides.fields`.
146
-
147
- - `text`
148
- - `name`: string
149
- - `label`: string
150
- - `defaultValue`: string
151
- - `width`: string
152
- - `required`: checkbox
153
- - `textarea`
154
- - `name`: string
155
- - `label`: string
156
- - `defaultValue`: string
157
- - `width`: string
158
- - `required`: checkbox
159
- - `select`
160
- - `name`: string
161
- - `label`: string
162
- - `defaultValue`: string
163
- - `width`: string
164
- - `options`: array
165
- - `required`: checkbox
166
- - `email`
167
- - `name`: string
168
- - `label`: string
169
- - `defaultValue`: string
170
- - `width`: string
171
- - `required`: checkbox
172
- - `state`
173
- - `name`: string
174
- - `label`: string
175
- - `defaultValue`: string
176
- - `width`: string
177
- - `required`: checkbox
178
- - `country`
179
- - `name`: string
180
- - `label`: string
181
- - `defaultValue`: string
182
- - `width`: string
183
- - `required`: checkbox
184
- - `checkbox`
185
- - `name`: string
186
- - `label`: string
187
- - `defaultValue`: checkbox
188
- - `width`: string
189
- - `required`: checkbox
190
- - `number`
191
- - `name`: string
192
- - `label`: string
193
- - `defaultValue`: number
194
- - `width`: string
195
- - `required`: checkbox
196
- - `message`
197
- - `message`: richText
198
- - `payment`
199
-
200
- - `name`: string
201
- - `label`: string
202
- - `defaultValue`: number
203
- - `width`: string
204
- - `required`: checkbox
205
- - `priceConditions`: array
206
- - `fieldToUse`: relationship, dynamically populated based on the fields in your form
207
- - `condition`: string - `equals`, `notEquals` | `hasValue`
208
- - `valueForOperator`: string - only if `condition` is `equals` or `notEquals`
209
- - `operator`: string - `add`, `subtract`, `multiply`, `divide`
210
- - `valueType`: string - `static`, `valueOfField`
211
- - `value`: string - only if `valueType` is `static`
212
-
213
- ### Field Overrides
214
-
215
- You can also provide your own custom field definitions by passing a new [Payload Block](https://payloadcms.com/docs/fields/blocks#block-configs) object into `fields`. You can override or extend any existing fields by first importing the `fields` from the plugin:
216
-
217
- ```ts
218
- import { fields } from '@payloadcms/plugin-form-builder'
219
- ```
220
-
221
- Then merging it into your own custom field:
222
-
223
- ```ts
224
- fields: {
225
- text: {
226
- ...fields.text,
227
- labels: {
228
- singular: "Custom Text Field",
229
- plural: "Custom Text Fields",
230
- }
231
- }
232
- }
233
- ```
234
-
235
- ## Email
236
-
237
- This plugin relies on the [email configuration](https://payloadcms.com/docs/email/overview) defined in your `payload.init()`. It will read from your config and attempt to send your emails using the credentials provided.
238
-
239
- ## TypeScript
240
-
241
- All types can be directly imported:
242
-
243
- ```js
244
- import {
245
- PluginConfig,
246
- Form,
247
- FormSubmission,
248
- FieldsConfig,
249
- BeforePayment,
250
- BeforeEmail,
251
- HandlePayment,
252
- ...
253
- } from "@payloadcms/plugin-form-builder/types";
254
- ```
255
-
256
- ## Development
257
-
258
- To actively develop or debug this plugin you can either work directly within the demo directory of this repo, or link your own project.
259
-
260
- 1. #### Internal Demo
261
-
262
- This repo includes a fully working, self-seeding instance of Payload that installs the plugin directly from the source code. This is the easiest way to get started. To spin up this demo, follow these steps:
263
-
264
- 1. First clone the repo
265
- 1. Then, `cd YOUR_PLUGIN_REPO && yarn && cd demo && cp env.example .env && yarn && yarn dev`
266
- 1. Now open `http://localhost:3000/admin` in your browser
267
- 1. Enter username `dev@payloadcms.com` and password `test`
268
-
269
- That's it! Changes made in `./src` will be reflected in your demo. Keep in mind that the demo database is automatically seeded on every startup, any changes you make to the data get destroyed each time you reboot the app.
270
-
271
- 1. #### Linked Project
272
-
273
- You can alternatively link your own project to the source code:
274
-
275
- 1. First clone the repo
276
- 1. Then, `cd YOUR_PLUGIN_REPO && yarn && yarn build && yarn link`
277
- 1. Now `cd` back into your own project and run, `yarn link @payloadcms/plugin-form-builder`
278
- 1. If this plugin using React in any way, continue to the next step. Otherwise skip to step 7.
279
- 1. From your own project, `cd node_modules/react && yarn link && cd ../react-dom && yarn link && cd ../../`
280
- 1. Then, `cd YOUR_PLUGIN_REPO && yarn link react react-dom`
281
-
282
- All set! You can now boot up your own project as normal, and your local copy of the plugin source code will be used. Keep in mind that changes to the source code require a rebuild, `yarn build`.
283
-
284
- You might also need to alias these modules in your Webpack config. To do this, open your project's Payload config and add the following:
285
-
286
- ```ts
287
- import { buildConfig } from 'payload/config'
288
-
289
- export default buildConfig({
290
- admin: {
291
- webpack: (config) => ({
292
- ...config,
293
- resolve: {
294
- ...config.resolve,
295
- alias: {
296
- ...config.resolve.alias,
297
- react: path.join(__dirname, '../node_modules/react'),
298
- 'react-dom': path.join(__dirname, '../node_modules/react-dom'),
299
- payload: path.join(__dirname, '../node_modules/payload'),
300
- '@payloadcms/plugin-form-builder': path.join(
301
- __dirname,
302
- '../../payload/plugin-form-builder/src',
303
- ),
304
- },
305
- },
306
- }),
307
- },
308
- })
309
- ```
310
-
311
- ## Troubleshooting
312
-
313
- Below are some common troubleshooting tips. To help other developers, please contribute to this section as you troubleshoot your own application.
314
-
315
- ### SendGrid 403 Forbidden Error
316
-
317
- - If you are using [SendGrid Link Branding](https://docs.sendgrid.com/ui/account-and-settings/how-to-set-up-link-branding) to remove the "via sendgrid.net" part of your email, you must also setup [Domain Authentication](https://docs.sendgrid.com/ui/account-and-settings/how-to-set-up-domain-authentication). This means you can only send emails from an address on this domain — so the `from` addresses in your form submission emails **_cannot_** be anything other than `something@your_domain.com`. This means that from `{{email}}` will not work, but `website@your_domain.com` will. You can still send the form's email address in the body of the email.
318
-
319
- ## Screenshots
320
-
321
- ![screenshot 1](https://github.com/payloadcms/plugin-form-builder/blob/main/images/screenshot-1.jpg?raw=true)
322
- ![screenshot 2](https://github.com/payloadcms/plugin-form-builder/blob/main/images/screenshot-2.jpg?raw=true)
323
- ![screenshot 3](https://github.com/payloadcms/plugin-form-builder/blob/main/images/screenshot-3.jpg?raw=true)
324
- ![screenshot 4](https://github.com/payloadcms/plugin-form-builder/blob/main/images/screenshot-4.jpg?raw=true)
325
- ![screenshot 5](https://github.com/payloadcms/plugin-form-builder/blob/main/images/screenshot-5.jpg?raw=true)
326
- ![screenshot 6](https://github.com/payloadcms/plugin-form-builder/blob/main/images/screenshot-6.jpg?raw=true)
5
+ - [Source code](https://github.com/payloadcms/payload/tree/main/packages/plugin-form-builder)
6
+ - [Documentation](https://payloadcms.com/docs/plugins/form-builder)
7
+ - [Documentation source](https://github.com/payloadcms/payload/tree/main/docs/plugins/form-builder.mdx)
@@ -1 +1 @@
1
- {"version":3,"file":"sendEmail.d.ts","sourceRoot":"","sources":["../../../../src/collections/FormSubmissions/hooks/sendEmail.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAyB,YAAY,EAAE,MAAM,gBAAgB,CAAA;AAKzE,QAAA,MAAM,SAAS,qBAA4B,GAAG,cAAc,YAAY,KAAG,QAAQ,GAAG,CAoFrF,CAAA;AAED,eAAe,SAAS,CAAA"}
1
+ {"version":3,"file":"sendEmail.d.ts","sourceRoot":"","sources":["../../../../src/collections/FormSubmissions/hooks/sendEmail.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAyB,YAAY,EAAE,MAAM,gBAAgB,CAAA;AAMzE,QAAA,MAAM,SAAS,qBAA4B,GAAG,cAAc,YAAY,KAAG,QAAQ,GAAG,CA4FrF,CAAA;AAED,eAAe,SAAS,CAAA"}
@@ -8,8 +8,9 @@ Object.defineProperty(exports, "default", {
8
8
  return _default;
9
9
  }
10
10
  });
11
+ const _serializeLexical = require("../../../utilities/lexical/serializeLexical");
11
12
  const _replaceDoubleCurlys = require("../../../utilities/replaceDoubleCurlys");
12
- const _serializeRichText = require("../../../utilities/serializeRichText");
13
+ const _serializeSlate = require("../../../utilities/slate/serializeSlate");
13
14
  const sendEmail = async (beforeChangeData, formConfig)=>{
14
15
  const { data, operation } = beforeChangeData;
15
16
  if (operation === 'create') {
@@ -24,23 +25,25 @@ const sendEmail = async (beforeChangeData, formConfig)=>{
24
25
  });
25
26
  const { emails } = form;
26
27
  if (emails && emails.length) {
27
- const formattedEmails = emails.map((email)=>{
28
+ const formattedEmails = await Promise.all(emails.map(async (email)=>{
28
29
  const { bcc: emailBCC, cc: emailCC, emailFrom, emailTo, message, replyTo: emailReplyTo, subject } = email;
29
30
  const to = (0, _replaceDoubleCurlys.replaceDoubleCurlys)(emailTo, submissionData);
30
31
  const cc = emailCC ? (0, _replaceDoubleCurlys.replaceDoubleCurlys)(emailCC, submissionData) : '';
31
32
  const bcc = emailBCC ? (0, _replaceDoubleCurlys.replaceDoubleCurlys)(emailBCC, submissionData) : '';
32
33
  const from = (0, _replaceDoubleCurlys.replaceDoubleCurlys)(emailFrom, submissionData);
33
34
  const replyTo = (0, _replaceDoubleCurlys.replaceDoubleCurlys)(emailReplyTo || emailFrom, submissionData);
35
+ const isLexical = message && !Array.isArray(message) && 'root' in message;
36
+ const serializedMessage = isLexical ? await (0, _serializeLexical.serializeLexical)(message, submissionData) : (0, _serializeSlate.serializeSlate)(message, submissionData);
34
37
  return {
35
38
  bcc,
36
39
  cc,
37
40
  from,
38
- html: `<div>${(0, _serializeRichText.serialize)(message, submissionData)}</div>`,
41
+ html: `<div>${serializedMessage}</div>`,
39
42
  replyTo,
40
43
  subject: (0, _replaceDoubleCurlys.replaceDoubleCurlys)(subject, submissionData),
41
44
  to
42
45
  };
43
- });
46
+ }));
44
47
  let emailsToSend = formattedEmails;
45
48
  if (typeof beforeEmail === 'function') {
46
49
  emailsToSend = await beforeEmail(formattedEmails);
@@ -53,7 +56,7 @@ const sendEmail = async (beforeChangeData, formConfig)=>{
53
56
  return emailPromise;
54
57
  } catch (err) {
55
58
  payload.logger.error({
56
- err: `Error while sending email to address: ${to}. Email not sent: ${err}`
59
+ err: `Error while sending email to address: ${to}. Email not sent: ${JSON.stringify(err)}`
57
60
  });
58
61
  }
59
62
  }));
@@ -73,4 +76,4 @@ const sendEmail = async (beforeChangeData, formConfig)=>{
73
76
  };
74
77
  const _default = sendEmail;
75
78
 
76
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb2xsZWN0aW9ucy9Gb3JtU3VibWlzc2lvbnMvaG9va3Mvc2VuZEVtYWlsLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRW1haWwsIEZvcm1hdHRlZEVtYWlsLCBQbHVnaW5Db25maWcgfSBmcm9tICcuLi8uLi8uLi90eXBlcydcblxuaW1wb3J0IHsgcmVwbGFjZURvdWJsZUN1cmx5cyB9IGZyb20gJy4uLy4uLy4uL3V0aWxpdGllcy9yZXBsYWNlRG91YmxlQ3VybHlzJ1xuaW1wb3J0IHsgc2VyaWFsaXplIH0gZnJvbSAnLi4vLi4vLi4vdXRpbGl0aWVzL3NlcmlhbGl6ZVJpY2hUZXh0J1xuXG5jb25zdCBzZW5kRW1haWwgPSBhc3luYyAoYmVmb3JlQ2hhbmdlRGF0YTogYW55LCBmb3JtQ29uZmlnOiBQbHVnaW5Db25maWcpOiBQcm9taXNlPGFueT4gPT4ge1xuICBjb25zdCB7IGRhdGEsIG9wZXJhdGlvbiB9ID0gYmVmb3JlQ2hhbmdlRGF0YVxuXG4gIGlmIChvcGVyYXRpb24gPT09ICdjcmVhdGUnKSB7XG4gICAgY29uc3Qge1xuICAgICAgZGF0YTogeyBpZDogZm9ybVN1Ym1pc3Npb25JRCB9LFxuICAgICAgcmVxOiB7IGxvY2FsZSwgcGF5bG9hZCB9LFxuICAgIH0gPSBiZWZvcmVDaGFuZ2VEYXRhXG5cbiAgICBjb25zdCB7IGZvcm06IGZvcm1JRCwgc3VibWlzc2lvbkRhdGEgfSA9IGRhdGEgfHwge31cblxuICAgIGNvbnN0IHsgYmVmb3JlRW1haWwsIGZvcm1PdmVycmlkZXMgfSA9IGZvcm1Db25maWcgfHwge31cblxuICAgIHRyeSB7XG4gICAgICBjb25zdCBmb3JtID0gYXdhaXQgcGF5bG9hZC5maW5kQnlJRCh7XG4gICAgICAgIGlkOiBmb3JtSUQsXG4gICAgICAgIGNvbGxlY3Rpb246IGZvcm1PdmVycmlkZXM/LnNsdWcgfHwgJ2Zvcm1zJyxcbiAgICAgICAgbG9jYWxlLFxuICAgICAgfSlcblxuICAgICAgY29uc3QgeyBlbWFpbHMgfSA9IGZvcm1cblxuICAgICAgaWYgKGVtYWlscyAmJiBlbWFpbHMubGVuZ3RoKSB7XG4gICAgICAgIGNvbnN0IGZvcm1hdHRlZEVtYWlsczogRm9ybWF0dGVkRW1haWxbXSA9IGVtYWlscy5tYXAoXG4gICAgICAgICAgKGVtYWlsOiBFbWFpbCk6IEZvcm1hdHRlZEVtYWlsIHwgbnVsbCA9PiB7XG4gICAgICAgICAgICBjb25zdCB7XG4gICAgICAgICAgICAgIGJjYzogZW1haWxCQ0MsXG4gICAgICAgICAgICAgIGNjOiBlbWFpbENDLFxuICAgICAgICAgICAgICBlbWFpbEZyb20sXG4gICAgICAgICAgICAgIGVtYWlsVG8sXG4gICAgICAgICAgICAgIG1lc3NhZ2UsXG4gICAgICAgICAgICAgIHJlcGx5VG86IGVtYWlsUmVwbHlUbyxcbiAgICAgICAgICAgICAgc3ViamVjdCxcbiAgICAgICAgICAgIH0gPSBlbWFpbFxuXG4gICAgICAgICAgICBjb25zdCB0byA9IHJlcGxhY2VEb3VibGVDdXJseXMoZW1haWxUbywgc3VibWlzc2lvbkRhdGEpXG4gICAgICAgICAgICBjb25zdCBjYyA9IGVtYWlsQ0MgPyByZXBsYWNlRG91YmxlQ3VybHlzKGVtYWlsQ0MsIHN1Ym1pc3Npb25EYXRhKSA6ICcnXG4gICAgICAgICAgICBjb25zdCBiY2MgPSBlbWFpbEJDQyA/IHJlcGxhY2VEb3VibGVDdXJseXMoZW1haWxCQ0MsIHN1Ym1pc3Npb25EYXRhKSA6ICcnXG4gICAgICAgICAgICBjb25zdCBmcm9tID0gcmVwbGFjZURvdWJsZUN1cmx5cyhlbWFpbEZyb20sIHN1Ym1pc3Npb25EYXRhKVxuICAgICAgICAgICAgY29uc3QgcmVwbHlUbyA9IHJlcGxhY2VEb3VibGVDdXJseXMoZW1haWxSZXBseVRvIHx8IGVtYWlsRnJvbSwgc3VibWlzc2lvbkRhdGEpXG5cbiAgICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAgIGJjYyxcbiAgICAgICAgICAgICAgY2MsXG4gICAgICAgICAgICAgIGZyb20sXG4gICAgICAgICAgICAgIGh0bWw6IGA8ZGl2PiR7c2VyaWFsaXplKG1lc3NhZ2UsIHN1Ym1pc3Npb25EYXRhKX08L2Rpdj5gLFxuICAgICAgICAgICAgICByZXBseVRvLFxuICAgICAgICAgICAgICBzdWJqZWN0OiByZXBsYWNlRG91YmxlQ3VybHlzKHN1YmplY3QsIHN1Ym1pc3Npb25EYXRhKSxcbiAgICAgICAgICAgICAgdG8sXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfSxcbiAgICAgICAgKVxuXG4gICAgICAgIGxldCBlbWFpbHNUb1NlbmQgPSBmb3JtYXR0ZWRFbWFpbHNcblxuICAgICAgICBpZiAodHlwZW9mIGJlZm9yZUVtYWlsID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgICAgZW1haWxzVG9TZW5kID0gYXdhaXQgYmVmb3JlRW1haWwoZm9ybWF0dGVkRW1haWxzKVxuICAgICAgICB9XG5cbiAgICAgICAgLy8gY29uc3QgbG9nID0gZW1haWxzVG9TZW5kLm1hcCgoeyBodG1sLCAuLi5yZXN0IH0pID0+ICh7IC4uLnJlc3QgfSkpXG5cbiAgICAgICAgYXdhaXQgUHJvbWlzZS5hbGwoXG4gICAgICAgICAgZW1haWxzVG9TZW5kLm1hcChhc3luYyAoZW1haWwpID0+IHtcbiAgICAgICAgICAgIGNvbnN0IHsgdG8gfSA9IGVtYWlsXG4gICAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgICBjb25zdCBlbWFpbFByb21pc2UgPSBhd2FpdCBwYXlsb2FkLnNlbmRFbWFpbChlbWFpbClcbiAgICAgICAgICAgICAgcmV0dXJuIGVtYWlsUHJvbWlzZVxuICAgICAgICAgICAgfSBjYXRjaCAoZXJyOiB1bmtub3duKSB7XG4gICAgICAgICAgICAgIHBheWxvYWQubG9nZ2VyLmVycm9yKHtcbiAgICAgICAgICAgICAgICBlcnI6IGBFcnJvciB3aGlsZSBzZW5kaW5nIGVtYWlsIHRvIGFkZHJlc3M6ICR7dG99LiBFbWFpbCBub3Qgc2VudDogJHtlcnJ9YCxcbiAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9KSxcbiAgICAgICAgKVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcGF5bG9hZC5sb2dnZXIuaW5mbyh7IG1zZzogJ05vIGVtYWlscyB0byBzZW5kLicgfSlcbiAgICAgIH1cbiAgICB9IGNhdGNoIChlcnI6IHVua25vd24pIHtcbiAgICAgIGNvbnN0IG1zZyA9IGBFcnJvciB3aGlsZSBzZW5kaW5nIG9uZSBvciBtb3JlIGVtYWlscyBpbiBmb3JtIHN1Ym1pc3Npb24gaWQ6ICR7Zm9ybVN1Ym1pc3Npb25JRH0uYFxuICAgICAgcGF5bG9hZC5sb2dnZXIuZXJyb3IoeyBlcnI6IG1zZyB9KVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiBkYXRhXG59XG5cbmV4cG9ydCBkZWZhdWx0IHNlbmRFbWFpbFxuIl0sIm5hbWVzIjpbInNlbmRFbWFpbCIsImJlZm9yZUNoYW5nZURhdGEiLCJmb3JtQ29uZmlnIiwiZGF0YSIsIm9wZXJhdGlvbiIsImlkIiwiZm9ybVN1Ym1pc3Npb25JRCIsInJlcSIsImxvY2FsZSIsInBheWxvYWQiLCJmb3JtIiwiZm9ybUlEIiwic3VibWlzc2lvbkRhdGEiLCJiZWZvcmVFbWFpbCIsImZvcm1PdmVycmlkZXMiLCJmaW5kQnlJRCIsImNvbGxlY3Rpb24iLCJzbHVnIiwiZW1haWxzIiwibGVuZ3RoIiwiZm9ybWF0dGVkRW1haWxzIiwibWFwIiwiZW1haWwiLCJiY2MiLCJlbWFpbEJDQyIsImNjIiwiZW1haWxDQyIsImVtYWlsRnJvbSIsImVtYWlsVG8iLCJtZXNzYWdlIiwicmVwbHlUbyIsImVtYWlsUmVwbHlUbyIsInN1YmplY3QiLCJ0byIsInJlcGxhY2VEb3VibGVDdXJseXMiLCJmcm9tIiwiaHRtbCIsInNlcmlhbGl6ZSIsImVtYWlsc1RvU2VuZCIsIlByb21pc2UiLCJhbGwiLCJlbWFpbFByb21pc2UiLCJlcnIiLCJsb2dnZXIiLCJlcnJvciIsImluZm8iLCJtc2ciXSwibWFwcGluZ3MiOiI7Ozs7K0JB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
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../src/collections/FormSubmissions/hooks/sendEmail.ts"],"sourcesContent":["import type { Email, FormattedEmail, PluginConfig } from '../../../types'\n\nimport { serializeLexical } from '../../../utilities/lexical/serializeLexical'\nimport { replaceDoubleCurlys } from '../../../utilities/replaceDoubleCurlys'\nimport { serializeSlate } from '../../../utilities/slate/serializeSlate'\n\nconst sendEmail = async (beforeChangeData: any, formConfig: PluginConfig): Promise<any> => {\n  const { data, operation } = beforeChangeData\n\n  if (operation === 'create') {\n    const {\n      data: { id: formSubmissionID },\n      req: { locale, payload },\n    } = beforeChangeData\n\n    const { form: formID, submissionData } = data || {}\n\n    const { beforeEmail, formOverrides } = formConfig || {}\n\n    try {\n      const form = await payload.findByID({\n        id: formID,\n        collection: formOverrides?.slug || 'forms',\n        locale,\n      })\n\n      const { emails } = form\n\n      if (emails && emails.length) {\n        const formattedEmails: FormattedEmail[] = await Promise.all(\n          emails.map(async (email: Email): Promise<FormattedEmail | null> => {\n            const {\n              bcc: emailBCC,\n              cc: emailCC,\n              emailFrom,\n              emailTo,\n              message,\n              replyTo: emailReplyTo,\n              subject,\n            } = email\n\n            const to = replaceDoubleCurlys(emailTo, submissionData)\n            const cc = emailCC ? replaceDoubleCurlys(emailCC, submissionData) : ''\n            const bcc = emailBCC ? replaceDoubleCurlys(emailBCC, submissionData) : ''\n            const from = replaceDoubleCurlys(emailFrom, submissionData)\n            const replyTo = replaceDoubleCurlys(emailReplyTo || emailFrom, submissionData)\n\n            const isLexical = message && !Array.isArray(message) && 'root' in message\n\n            const serializedMessage = isLexical\n              ? await serializeLexical(message, submissionData)\n              : serializeSlate(message, submissionData)\n\n            return {\n              bcc,\n              cc,\n              from,\n              html: `<div>${serializedMessage}</div>`,\n              replyTo,\n              subject: replaceDoubleCurlys(subject, submissionData),\n              to,\n            }\n          }),\n        )\n\n        let emailsToSend = formattedEmails\n\n        if (typeof beforeEmail === 'function') {\n          emailsToSend = await beforeEmail(formattedEmails)\n        }\n\n        // const log = emailsToSend.map(({ html, ...rest }) => ({ ...rest }))\n\n        await Promise.all(\n          emailsToSend.map(async (email) => {\n            const { to } = email\n            try {\n              const emailPromise = await payload.sendEmail(email)\n              return emailPromise\n            } catch (err: unknown) {\n              payload.logger.error({\n                err: `Error while sending email to address: ${to}. Email not sent: ${JSON.stringify(\n                  err,\n                )}`,\n              })\n            }\n          }),\n        )\n      } else {\n        payload.logger.info({ msg: 'No emails to send.' })\n      }\n    } catch (err: unknown) {\n      const msg = `Error while sending one or more emails in form submission id: ${formSubmissionID}.`\n      payload.logger.error({ err: msg })\n    }\n  }\n\n  return data\n}\n\nexport default sendEmail\n"],"names":["sendEmail","beforeChangeData","formConfig","data","operation","id","formSubmissionID","req","locale","payload","form","formID","submissionData","beforeEmail","formOverrides","findByID","collection","slug","emails","length","formattedEmails","Promise","all","map","email","bcc","emailBCC","cc","emailCC","emailFrom","emailTo","message","replyTo","emailReplyTo","subject","to","replaceDoubleCurlys","from","isLexical","Array","isArray","serializedMessage","serializeLexical","serializeSlate","html","emailsToSend","emailPromise","err","logger","error","JSON","stringify","info","msg"],"mappings":";;;;+BAoGA;;;eAAA;;;kCAlGiC;qCACG;gCACL;AAE/B,MAAMA,YAAY,OAAOC,kBAAuBC;IAC9C,MAAM,EAAEC,IAAI,EAAEC,SAAS,EAAE,GAAGH;IAE5B,IAAIG,cAAc,UAAU;QAC1B,MAAM,EACJD,MAAM,EAAEE,IAAIC,gBAAgB,EAAE,EAC9BC,KAAK,EAAEC,MAAM,EAAEC,OAAO,EAAE,EACzB,GAAGR;QAEJ,MAAM,EAAES,MAAMC,MAAM,EAAEC,cAAc,EAAE,GAAGT,QAAQ,CAAC;QAElD,MAAM,EAAEU,WAAW,EAAEC,aAAa,EAAE,GAAGZ,cAAc,CAAC;QAEtD,IAAI;YACF,MAAMQ,OAAO,MAAMD,QAAQM,QAAQ,CAAC;gBAClCV,IAAIM;gBACJK,YAAYF,eAAeG,QAAQ;gBACnCT;YACF;YAEA,MAAM,EAAEU,MAAM,EAAE,GAAGR;YAEnB,IAAIQ,UAAUA,OAAOC,MAAM,EAAE;gBAC3B,MAAMC,kBAAoC,MAAMC,QAAQC,GAAG,CACzDJ,OAAOK,GAAG,CAAC,OAAOC;oBAChB,MAAM,EACJC,KAAKC,QAAQ,EACbC,IAAIC,OAAO,EACXC,SAAS,EACTC,OAAO,EACPC,OAAO,EACPC,SAASC,YAAY,EACrBC,OAAO,EACR,GAAGV;oBAEJ,MAAMW,KAAKC,IAAAA,wCAAmB,EAACN,SAASlB;oBACxC,MAAMe,KAAKC,UAAUQ,IAAAA,wCAAmB,EAACR,SAAShB,kBAAkB;oBACpE,MAAMa,MAAMC,WAAWU,IAAAA,wCAAmB,EAACV,UAAUd,kBAAkB;oBACvE,MAAMyB,OAAOD,IAAAA,wCAAmB,EAACP,WAAWjB;oBAC5C,MAAMoB,UAAUI,IAAAA,wCAAmB,EAACH,gBAAgBJ,WAAWjB;oBAE/D,MAAM0B,YAAYP,WAAW,CAACQ,MAAMC,OAAO,CAACT,YAAY,UAAUA;oBAElE,MAAMU,oBAAoBH,YACtB,MAAMI,IAAAA,kCAAgB,EAACX,SAASnB,kBAChC+B,IAAAA,8BAAc,EAACZ,SAASnB;oBAE5B,OAAO;wBACLa;wBACAE;wBACAU;wBACAO,MAAM,CAAC,KAAK,EAAEH,kBAAkB,MAAM,CAAC;wBACvCT;wBACAE,SAASE,IAAAA,wCAAmB,EAACF,SAAStB;wBACtCuB;oBACF;gBACF;gBAGF,IAAIU,eAAezB;gBAEnB,IAAI,OAAOP,gBAAgB,YAAY;oBACrCgC,eAAe,MAAMhC,YAAYO;gBACnC;gBAEA,qEAAqE;gBAErE,MAAMC,QAAQC,GAAG,CACfuB,aAAatB,GAAG,CAAC,OAAOC;oBACtB,MAAM,EAAEW,EAAE,EAAE,GAAGX;oBACf,IAAI;wBACF,MAAMsB,eAAe,MAAMrC,QAAQT,SAAS,CAACwB;wBAC7C,OAAOsB;oBACT,EAAE,OAAOC,KAAc;wBACrBtC,QAAQuC,MAAM,CAACC,KAAK,CAAC;4BACnBF,KAAK,CAAC,sCAAsC,EAAEZ,GAAG,kBAAkB,EAAEe,KAAKC,SAAS,CACjFJ,KACA,CAAC;wBACL;oBACF;gBACF;YAEJ,OAAO;gBACLtC,QAAQuC,MAAM,CAACI,IAAI,CAAC;oBAAEC,KAAK;gBAAqB;YAClD;QACF,EAAE,OAAON,KAAc;YACrB,MAAMM,MAAM,CAAC,8DAA8D,EAAE/C,iBAAiB,CAAC,CAAC;YAChGG,QAAQuC,MAAM,CAACC,KAAK,CAAC;gBAAEF,KAAKM;YAAI;QAClC;IACF;IAEA,OAAOlD;AACT;MAEA,WAAeH"}
@@ -1 +1 @@
1
- {"version":3,"file":"DynamicPriceSelector.d.ts","sourceRoot":"","sources":["../../../src/collections/Forms/DynamicPriceSelector.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,KAAK,IAAI,aAAa,EAAE,MAAM,4DAA4D,CAAA;AAIxG,OAAO,KAA8B,MAAM,OAAO,CAAA;AAOlD,eAAO,MAAM,oBAAoB,EAAE,KAAK,CAAC,EAAE,CAAC,aAAa,CAwDxD,CAAA"}
1
+ {"version":3,"file":"DynamicPriceSelector.d.ts","sourceRoot":"","sources":["../../../src/collections/Forms/DynamicPriceSelector.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,KAAK,IAAI,aAAa,EAAE,MAAM,4DAA4D,CAAA;AAIxG,OAAO,KAA8B,MAAM,OAAO,CAAA;AAOlD,eAAO,MAAM,oBAAoB,EAAE,KAAK,CAAC,EAAE,CAAC,aAAa,CA0DxD,CAAA"}
@@ -83,10 +83,11 @@ const DynamicPriceSelector = (props)=>{
83
83
  if (valueType === 'static') {
84
84
  return /*#__PURE__*/ _react.default.createElement(_forms.Text, props);
85
85
  }
86
+ const localeCode = typeof locale === 'object' && 'code' in locale ? locale.code : locale;
86
87
  const localLabels = typeof label === 'object' ? label : {
87
- [locale]: label
88
+ [localeCode]: label
88
89
  };
89
- const labelValue = localLabels[locale] || localLabels['en'] || '';
90
+ const labelValue = localLabels[localeCode] || localLabels['en'] || '';
90
91
  if (valueType === 'valueOfField' && !isNumberField) {
91
92
  return /*#__PURE__*/ _react.default.createElement("div", null, /*#__PURE__*/ _react.default.createElement("div", null, labelValue), /*#__PURE__*/ _react.default.createElement("div", {
92
93
  style: {
@@ -97,4 +98,4 @@ const DynamicPriceSelector = (props)=>{
97
98
  return null;
98
99
  };
99
100
 
100
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb2xsZWN0aW9ucy9Gb3Jtcy9EeW5hbWljUHJpY2VTZWxlY3Rvci50c3giXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCB0eXBlIHsgRGF0YSB9IGZyb20gJ3BheWxvYWQvZGlzdC9hZG1pbi9jb21wb25lbnRzL2Zvcm1zL0Zvcm0vdHlwZXMnXG5pbXBvcnQgdHlwZSB7IFByb3BzIGFzIFRleHRGaWVsZFR5cGUgfSBmcm9tICdwYXlsb2FkL2Rpc3QvYWRtaW4vY29tcG9uZW50cy9mb3Jtcy9maWVsZC10eXBlcy9UZXh0L3R5cGVzJ1xuXG5pbXBvcnQgeyBUZXh0LCB1c2VXYXRjaEZvcm0gfSBmcm9tICdwYXlsb2FkL2NvbXBvbmVudHMvZm9ybXMnXG5pbXBvcnQgeyB1c2VMb2NhbGUgfSBmcm9tICdwYXlsb2FkL2NvbXBvbmVudHMvdXRpbGl0aWVzJ1xuaW1wb3J0IFJlYWN0LCB7IHVzZUVmZmVjdCwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcblxudHlwZSBGaWVsZFdpdGhJRCA9IHtcbiAgaWQ6IHN0cmluZ1xuICBuYW1lOiBzdHJpbmdcbn1cblxuZXhwb3J0IGNvbnN0IER5bmFtaWNQcmljZVNlbGVjdG9yOiBSZWFjdC5GQzxUZXh0RmllbGRUeXBlPiA9IChwcm9wcykgPT4ge1xuICBjb25zdCB7IGxhYmVsLCBwYXRoIH0gPSBwcm9wc1xuXG4gIGNvbnN0IHsgZmllbGRzLCBnZXREYXRhLCBnZXREYXRhQnlQYXRoIH0gPSB1c2VXYXRjaEZvcm0oKVxuXG4gIGNvbnN0IGxvY2FsZSA9IHVzZUxvY2FsZSgpXG5cbiAgY29uc3QgW2lzTnVtYmVyRmllbGQsIHNldElzTnVtYmVyRmllbGRdID0gdXNlU3RhdGU8Ym9vbGVhbj4oKVxuICBjb25zdCBbdmFsdWVUeXBlLCBzZXRWYWx1ZVR5cGVdID0gdXNlU3RhdGU8J3N0YXRpYycgfCAndmFsdWVPZkZpZWxkJz4oKVxuXG4gIC8vIG9ubHkgbnVtYmVyIGZpZWxkcyBjYW4gdXNlICd2YWx1ZU9mRmllbGRgXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKHBhdGgpIHtcbiAgICAgIGNvbnN0IHBhcmVudFBhdGggPSBwYXRoLnNwbGl0KCcuJykuc2xpY2UoMCwgLTEpLmpvaW4oJy4nKVxuICAgICAgY29uc3QgcGF5bWVudEZpZWxkRGF0YTogYW55ID0gZ2V0RGF0YUJ5UGF0aChwYXJlbnRQYXRoKVxuXG4gICAgICBpZiAocGF5bWVudEZpZWxkRGF0YSkge1xuICAgICAgICBjb25zdCB7IGZpZWxkVG9Vc2UsIHZhbHVlVHlwZSB9ID0gcGF5bWVudEZpZWxkRGF0YVxuXG4gICAgICAgIHNldFZhbHVlVHlwZSh2YWx1ZVR5cGUpXG5cbiAgICAgICAgY29uc3QgeyBmaWVsZHM6IGFsbEZpZWxkcyB9OiBEYXRhID0gZ2V0RGF0YSgpXG4gICAgICAgIGNvbnN0IGZpZWxkID0gYWxsRmllbGRzLmZpbmQoKGZpZWxkOiBGaWVsZFdpdGhJRCkgPT4gZmllbGQubmFtZSA9PT0gZmllbGRUb1VzZSlcblxuICAgICAgICBpZiAoZmllbGQpIHtcbiAgICAgICAgICBjb25zdCB7IGJsb2NrVHlwZSB9ID0gZmllbGRcbiAgICAgICAgICBzZXRJc051bWJlckZpZWxkKGJsb2NrVHlwZSA9PT0gJ251bWJlcicpXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH0sIFtmaWVsZHMsIHBhdGgsIGdldERhdGFCeVBhdGgsIGdldERhdGFdKVxuXG4gIC8vIFRPRE86IG1ha2UgdGhpcyBhIG51bWJlciBmaWVsZCwgYmxvY2sgYnkgUGF5bG9hZFxuICBpZiAodmFsdWVUeXBlID09PSAnc3RhdGljJykge1xuICAgIHJldHVybiA8VGV4dCB7Li4ucHJvcHN9IC8+XG4gIH1cblxuICBjb25zdCBsb2NhbExhYmVscyA9IHR5cGVvZiBsYWJlbCA9PT0gJ29iamVjdCcgPyBsYWJlbCA6IHsgW2xvY2FsZV06IGxhYmVsIH1cbiAgY29uc3QgbGFiZWxWYWx1ZSA9IGxvY2FsTGFiZWxzW2xvY2FsZV0gfHwgbG9jYWxMYWJlbHNbJ2VuJ10gfHwgJydcblxuICBpZiAodmFsdWVUeXBlID09PSAndmFsdWVPZkZpZWxkJyAmJiAhaXNOdW1iZXJGaWVsZCkge1xuICAgIHJldHVybiAoXG4gICAgICA8ZGl2PlxuICAgICAgICA8ZGl2PntsYWJlbFZhbHVlfTwvZGl2PlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgIGNvbG9yOiAnIzlBOUE5QScsXG4gICAgICAgICAgfX1cbiAgICAgICAgPlxuICAgICAgICAgIFRoZSBzZWxlY3RlZCBmaWVsZCBtdXN0IGJlIGEgbnVtYmVyIGZpZWxkLlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuICAgIClcbiAgfVxuXG4gIHJldHVybiBudWxsXG59XG4iXSwibmFtZXMiOlsiRHluYW1pY1ByaWNlU2VsZWN0b3IiLCJwcm9wcyIsImxhYmVsIiwicGF0aCIsImZpZWxkcyIsImdldERhdGEiLCJnZXREYXRhQnlQYXRoIiwidXNlV2F0Y2hGb3JtIiwibG9jYWxlIiwidXNlTG9jYWxlIiwiaXNOdW1iZXJGaWVsZCIsInNldElzTnVtYmVyRmllbGQiLCJ1c2VTdGF0ZSIsInZhbHVlVHlwZSIsInNldFZhbHVlVHlwZSIsInVzZUVmZmVjdCIsInBhcmVudFBhdGgiLCJzcGxpdCIsInNsaWNlIiwiam9pbiIsInBheW1lbnRGaWVsZERhdGEiLCJmaWVsZFRvVXNlIiwiYWxsRmllbGRzIiwiZmllbGQiLCJmaW5kIiwibmFtZSIsImJsb2NrVHlwZSIsIlRleHQiLCJsb2NhbExhYmVscyIsImxhYmVsVmFsdWUiLCJkaXYiLCJzdHlsZSIsImNvbG9yIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7K0JBY2FBOzs7ZUFBQUE7Ozt1QkFUc0I7MkJBQ1Q7K0RBQ2lCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBT3BDLE1BQU1BLHVCQUFnRCxDQUFDQztJQUM1RCxNQUFNLEVBQUVDLEtBQUssRUFBRUMsSUFBSSxFQUFFLEdBQUdGO0lBRXhCLE1BQU0sRUFBRUcsTUFBTSxFQUFFQyxPQUFPLEVBQUVDLGFBQWEsRUFBRSxHQUFHQyxJQUFBQSxtQkFBWTtJQUV2RCxNQUFNQyxTQUFTQyxJQUFBQSxvQkFBUztJQUV4QixNQUFNLENBQUNDLGVBQWVDLGlCQUFpQixHQUFHQyxJQUFBQSxlQUFRO0lBQ2xELE1BQU0sQ0FBQ0MsV0FBV0MsYUFBYSxHQUFHRixJQUFBQSxlQUFRO0lBRTFDLDRDQUE0QztJQUM1Q0csSUFBQUEsZ0JBQVMsRUFBQztRQUNSLElBQUlaLE1BQU07WUFDUixNQUFNYSxhQUFhYixLQUFLYyxLQUFLLENBQUMsS0FBS0MsS0FBSyxDQUFDLEdBQUcsQ0FBQyxHQUFHQyxJQUFJLENBQUM7WUFDckQsTUFBTUMsbUJBQXdCZCxjQUFjVTtZQUU1QyxJQUFJSSxrQkFBa0I7Z0JBQ3BCLE1BQU0sRUFBRUMsVUFBVSxFQUFFUixTQUFTLEVBQUUsR0FBR087Z0JBRWxDTixhQUFhRDtnQkFFYixNQUFNLEVBQUVULFFBQVFrQixTQUFTLEVBQUUsR0FBU2pCO2dCQUNwQyxNQUFNa0IsUUFBUUQsVUFBVUUsSUFBSSxDQUFDLENBQUNELFFBQXVCQSxNQUFNRSxJQUFJLEtBQUtKO2dCQUVwRSxJQUFJRSxPQUFPO29CQUNULE1BQU0sRUFBRUcsU0FBUyxFQUFFLEdBQUdIO29CQUN0QlosaUJBQWlCZSxjQUFjO2dCQUNqQztZQUNGO1FBQ0Y7SUFDRixHQUFHO1FBQUN0QjtRQUFRRDtRQUFNRztRQUFlRDtLQUFRO0lBRXpDLG1EQUFtRDtJQUNuRCxJQUFJUSxjQUFjLFVBQVU7UUFDMUIscUJBQU8sNkJBQUNjLFdBQUksRUFBSzFCO0lBQ25CO0lBRUEsTUFBTTJCLGNBQWMsT0FBTzFCLFVBQVUsV0FBV0EsUUFBUTtRQUFFLENBQUNNLE9BQU8sRUFBRU47SUFBTTtJQUMxRSxNQUFNMkIsYUFBYUQsV0FBVyxDQUFDcEIsT0FBTyxJQUFJb0IsV0FBVyxDQUFDLEtBQUssSUFBSTtJQUUvRCxJQUFJZixjQUFjLGtCQUFrQixDQUFDSCxlQUFlO1FBQ2xELHFCQUNFLDZCQUFDb0IsMkJBQ0MsNkJBQUNBLGFBQUtELDJCQUNOLDZCQUFDQztZQUNDQyxPQUFPO2dCQUNMQyxPQUFPO1lBQ1Q7V0FDRDtJQUtQO0lBRUEsT0FBTztBQUNUIn0=
101
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb2xsZWN0aW9ucy9Gb3Jtcy9EeW5hbWljUHJpY2VTZWxlY3Rvci50c3giXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCB0eXBlIHsgRGF0YSB9IGZyb20gJ3BheWxvYWQvZGlzdC9hZG1pbi9jb21wb25lbnRzL2Zvcm1zL0Zvcm0vdHlwZXMnXG5pbXBvcnQgdHlwZSB7IFByb3BzIGFzIFRleHRGaWVsZFR5cGUgfSBmcm9tICdwYXlsb2FkL2Rpc3QvYWRtaW4vY29tcG9uZW50cy9mb3Jtcy9maWVsZC10eXBlcy9UZXh0L3R5cGVzJ1xuXG5pbXBvcnQgeyBUZXh0LCB1c2VXYXRjaEZvcm0gfSBmcm9tICdwYXlsb2FkL2NvbXBvbmVudHMvZm9ybXMnXG5pbXBvcnQgeyB1c2VMb2NhbGUgfSBmcm9tICdwYXlsb2FkL2NvbXBvbmVudHMvdXRpbGl0aWVzJ1xuaW1wb3J0IFJlYWN0LCB7IHVzZUVmZmVjdCwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcblxudHlwZSBGaWVsZFdpdGhJRCA9IHtcbiAgaWQ6IHN0cmluZ1xuICBuYW1lOiBzdHJpbmdcbn1cblxuZXhwb3J0IGNvbnN0IER5bmFtaWNQcmljZVNlbGVjdG9yOiBSZWFjdC5GQzxUZXh0RmllbGRUeXBlPiA9IChwcm9wcykgPT4ge1xuICBjb25zdCB7IGxhYmVsLCBwYXRoIH0gPSBwcm9wc1xuXG4gIGNvbnN0IHsgZmllbGRzLCBnZXREYXRhLCBnZXREYXRhQnlQYXRoIH0gPSB1c2VXYXRjaEZvcm0oKVxuXG4gIGNvbnN0IGxvY2FsZSA9IHVzZUxvY2FsZSgpXG5cbiAgY29uc3QgW2lzTnVtYmVyRmllbGQsIHNldElzTnVtYmVyRmllbGRdID0gdXNlU3RhdGU8Ym9vbGVhbj4oKVxuICBjb25zdCBbdmFsdWVUeXBlLCBzZXRWYWx1ZVR5cGVdID0gdXNlU3RhdGU8J3N0YXRpYycgfCAndmFsdWVPZkZpZWxkJz4oKVxuXG4gIC8vIG9ubHkgbnVtYmVyIGZpZWxkcyBjYW4gdXNlICd2YWx1ZU9mRmllbGRgXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKHBhdGgpIHtcbiAgICAgIGNvbnN0IHBhcmVudFBhdGggPSBwYXRoLnNwbGl0KCcuJykuc2xpY2UoMCwgLTEpLmpvaW4oJy4nKVxuICAgICAgY29uc3QgcGF5bWVudEZpZWxkRGF0YTogYW55ID0gZ2V0RGF0YUJ5UGF0aChwYXJlbnRQYXRoKVxuXG4gICAgICBpZiAocGF5bWVudEZpZWxkRGF0YSkge1xuICAgICAgICBjb25zdCB7IGZpZWxkVG9Vc2UsIHZhbHVlVHlwZSB9ID0gcGF5bWVudEZpZWxkRGF0YVxuXG4gICAgICAgIHNldFZhbHVlVHlwZSh2YWx1ZVR5cGUpXG5cbiAgICAgICAgY29uc3QgeyBmaWVsZHM6IGFsbEZpZWxkcyB9OiBEYXRhID0gZ2V0RGF0YSgpXG4gICAgICAgIGNvbnN0IGZpZWxkID0gYWxsRmllbGRzLmZpbmQoKGZpZWxkOiBGaWVsZFdpdGhJRCkgPT4gZmllbGQubmFtZSA9PT0gZmllbGRUb1VzZSlcblxuICAgICAgICBpZiAoZmllbGQpIHtcbiAgICAgICAgICBjb25zdCB7IGJsb2NrVHlwZSB9ID0gZmllbGRcbiAgICAgICAgICBzZXRJc051bWJlckZpZWxkKGJsb2NrVHlwZSA9PT0gJ251bWJlcicpXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH0sIFtmaWVsZHMsIHBhdGgsIGdldERhdGFCeVBhdGgsIGdldERhdGFdKVxuXG4gIC8vIFRPRE86IG1ha2UgdGhpcyBhIG51bWJlciBmaWVsZCwgYmxvY2sgYnkgUGF5bG9hZFxuICBpZiAodmFsdWVUeXBlID09PSAnc3RhdGljJykge1xuICAgIHJldHVybiA8VGV4dCB7Li4ucHJvcHN9IC8+XG4gIH1cblxuICBjb25zdCBsb2NhbGVDb2RlID0gdHlwZW9mIGxvY2FsZSA9PT0gJ29iamVjdCcgJiYgJ2NvZGUnIGluIGxvY2FsZSA/IGxvY2FsZS5jb2RlIDogbG9jYWxlXG5cbiAgY29uc3QgbG9jYWxMYWJlbHMgPSB0eXBlb2YgbGFiZWwgPT09ICdvYmplY3QnID8gbGFiZWwgOiB7IFtsb2NhbGVDb2RlXTogbGFiZWwgfVxuICBjb25zdCBsYWJlbFZhbHVlID0gbG9jYWxMYWJlbHNbbG9jYWxlQ29kZV0gfHwgbG9jYWxMYWJlbHNbJ2VuJ10gfHwgJydcblxuICBpZiAodmFsdWVUeXBlID09PSAndmFsdWVPZkZpZWxkJyAmJiAhaXNOdW1iZXJGaWVsZCkge1xuICAgIHJldHVybiAoXG4gICAgICA8ZGl2PlxuICAgICAgICA8ZGl2PntsYWJlbFZhbHVlfTwvZGl2PlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgIGNvbG9yOiAnIzlBOUE5QScsXG4gICAgICAgICAgfX1cbiAgICAgICAgPlxuICAgICAgICAgIFRoZSBzZWxlY3RlZCBmaWVsZCBtdXN0IGJlIGEgbnVtYmVyIGZpZWxkLlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuICAgIClcbiAgfVxuXG4gIHJldHVybiBudWxsXG59XG4iXSwibmFtZXMiOlsiRHluYW1pY1ByaWNlU2VsZWN0b3IiLCJwcm9wcyIsImxhYmVsIiwicGF0aCIsImZpZWxkcyIsImdldERhdGEiLCJnZXREYXRhQnlQYXRoIiwidXNlV2F0Y2hGb3JtIiwibG9jYWxlIiwidXNlTG9jYWxlIiwiaXNOdW1iZXJGaWVsZCIsInNldElzTnVtYmVyRmllbGQiLCJ1c2VTdGF0ZSIsInZhbHVlVHlwZSIsInNldFZhbHVlVHlwZSIsInVzZUVmZmVjdCIsInBhcmVudFBhdGgiLCJzcGxpdCIsInNsaWNlIiwiam9pbiIsInBheW1lbnRGaWVsZERhdGEiLCJmaWVsZFRvVXNlIiwiYWxsRmllbGRzIiwiZmllbGQiLCJmaW5kIiwibmFtZSIsImJsb2NrVHlwZSIsIlRleHQiLCJsb2NhbGVDb2RlIiwiY29kZSIsImxvY2FsTGFiZWxzIiwibGFiZWxWYWx1ZSIsImRpdiIsInN0eWxlIiwiY29sb3IiXSwibWFwcGluZ3MiOiJBQUFBOzs7OzsrQkFjYUE7OztlQUFBQTs7O3VCQVRzQjsyQkFDVDsrREFDaUI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFPcEMsTUFBTUEsdUJBQWdELENBQUNDO0lBQzVELE1BQU0sRUFBRUMsS0FBSyxFQUFFQyxJQUFJLEVBQUUsR0FBR0Y7SUFFeEIsTUFBTSxFQUFFRyxNQUFNLEVBQUVDLE9BQU8sRUFBRUMsYUFBYSxFQUFFLEdBQUdDLElBQUFBLG1CQUFZO0lBRXZELE1BQU1DLFNBQVNDLElBQUFBLG9CQUFTO0lBRXhCLE1BQU0sQ0FBQ0MsZUFBZUMsaUJBQWlCLEdBQUdDLElBQUFBLGVBQVE7SUFDbEQsTUFBTSxDQUFDQyxXQUFXQyxhQUFhLEdBQUdGLElBQUFBLGVBQVE7SUFFMUMsNENBQTRDO0lBQzVDRyxJQUFBQSxnQkFBUyxFQUFDO1FBQ1IsSUFBSVosTUFBTTtZQUNSLE1BQU1hLGFBQWFiLEtBQUtjLEtBQUssQ0FBQyxLQUFLQyxLQUFLLENBQUMsR0FBRyxDQUFDLEdBQUdDLElBQUksQ0FBQztZQUNyRCxNQUFNQyxtQkFBd0JkLGNBQWNVO1lBRTVDLElBQUlJLGtCQUFrQjtnQkFDcEIsTUFBTSxFQUFFQyxVQUFVLEVBQUVSLFNBQVMsRUFBRSxHQUFHTztnQkFFbENOLGFBQWFEO2dCQUViLE1BQU0sRUFBRVQsUUFBUWtCLFNBQVMsRUFBRSxHQUFTakI7Z0JBQ3BDLE1BQU1rQixRQUFRRCxVQUFVRSxJQUFJLENBQUMsQ0FBQ0QsUUFBdUJBLE1BQU1FLElBQUksS0FBS0o7Z0JBRXBFLElBQUlFLE9BQU87b0JBQ1QsTUFBTSxFQUFFRyxTQUFTLEVBQUUsR0FBR0g7b0JBQ3RCWixpQkFBaUJlLGNBQWM7Z0JBQ2pDO1lBQ0Y7UUFDRjtJQUNGLEdBQUc7UUFBQ3RCO1FBQVFEO1FBQU1HO1FBQWVEO0tBQVE7SUFFekMsbURBQW1EO0lBQ25ELElBQUlRLGNBQWMsVUFBVTtRQUMxQixxQkFBTyw2QkFBQ2MsV0FBSSxFQUFLMUI7SUFDbkI7SUFFQSxNQUFNMkIsYUFBYSxPQUFPcEIsV0FBVyxZQUFZLFVBQVVBLFNBQVNBLE9BQU9xQixJQUFJLEdBQUdyQjtJQUVsRixNQUFNc0IsY0FBYyxPQUFPNUIsVUFBVSxXQUFXQSxRQUFRO1FBQUUsQ0FBQzBCLFdBQVcsRUFBRTFCO0lBQU07SUFDOUUsTUFBTTZCLGFBQWFELFdBQVcsQ0FBQ0YsV0FBVyxJQUFJRSxXQUFXLENBQUMsS0FBSyxJQUFJO0lBRW5FLElBQUlqQixjQUFjLGtCQUFrQixDQUFDSCxlQUFlO1FBQ2xELHFCQUNFLDZCQUFDc0IsMkJBQ0MsNkJBQUNBLGFBQUtELDJCQUNOLDZCQUFDQztZQUNDQyxPQUFPO2dCQUNMQyxPQUFPO1lBQ1Q7V0FDRDtJQUtQO0lBRUEsT0FBTztBQUNUIn0=
@@ -0,0 +1,3 @@
1
+ import type { HTMLConverter } from '../types';
2
+ export declare const HeadingHTMLConverter: HTMLConverter<any>;
3
+ //# sourceMappingURL=heading.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"heading.d.ts","sourceRoot":"","sources":["../../../../src/utilities/lexical/converters/heading.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAI7C,eAAO,MAAM,oBAAoB,EAAE,aAAa,CAAC,GAAG,CAcnD,CAAA"}
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "HeadingHTMLConverter", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return HeadingHTMLConverter;
9
+ }
10
+ });
11
+ const _serializeLexical = require("../serializeLexical");
12
+ const HeadingHTMLConverter = {
13
+ async converter ({ converters, node, parent }) {
14
+ const childrenText = await (0, _serializeLexical.convertLexicalNodesToHTML)({
15
+ converters,
16
+ lexicalNodes: node.children,
17
+ parent: {
18
+ ...node,
19
+ parent
20
+ }
21
+ });
22
+ return '<' + node?.tag + '>' + childrenText + '</' + node?.tag + '>';
23
+ },
24
+ nodeTypes: [
25
+ 'heading'
26
+ ]
27
+ };
28
+
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy91dGlsaXRpZXMvbGV4aWNhbC9jb252ZXJ0ZXJzL2hlYWRpbmcudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBIVE1MQ29udmVydGVyIH0gZnJvbSAnLi4vdHlwZXMnXG5cbmltcG9ydCB7IGNvbnZlcnRMZXhpY2FsTm9kZXNUb0hUTUwgfSBmcm9tICcuLi9zZXJpYWxpemVMZXhpY2FsJ1xuXG5leHBvcnQgY29uc3QgSGVhZGluZ0hUTUxDb252ZXJ0ZXI6IEhUTUxDb252ZXJ0ZXI8YW55PiA9IHtcbiAgYXN5bmMgY29udmVydGVyKHsgY29udmVydGVycywgbm9kZSwgcGFyZW50IH0pIHtcbiAgICBjb25zdCBjaGlsZHJlblRleHQgPSBhd2FpdCBjb252ZXJ0TGV4aWNhbE5vZGVzVG9IVE1MKHtcbiAgICAgIGNvbnZlcnRlcnMsXG4gICAgICBsZXhpY2FsTm9kZXM6IG5vZGUuY2hpbGRyZW4sXG4gICAgICBwYXJlbnQ6IHtcbiAgICAgICAgLi4ubm9kZSxcbiAgICAgICAgcGFyZW50LFxuICAgICAgfSxcbiAgICB9KVxuXG4gICAgcmV0dXJuICc8JyArIG5vZGU/LnRhZyArICc+JyArIGNoaWxkcmVuVGV4dCArICc8LycgKyBub2RlPy50YWcgKyAnPidcbiAgfSxcbiAgbm9kZVR5cGVzOiBbJ2hlYWRpbmcnXSxcbn1cbiJdLCJuYW1lcyI6WyJIZWFkaW5nSFRNTENvbnZlcnRlciIsImNvbnZlcnRlciIsImNvbnZlcnRlcnMiLCJub2RlIiwicGFyZW50IiwiY2hpbGRyZW5UZXh0IiwiY29udmVydExleGljYWxOb2Rlc1RvSFRNTCIsImxleGljYWxOb2RlcyIsImNoaWxkcmVuIiwidGFnIiwibm9kZVR5cGVzIl0sIm1hcHBpbmdzIjoiOzs7OytCQUlhQTs7O2VBQUFBOzs7a0NBRjZCO0FBRW5DLE1BQU1BLHVCQUEyQztJQUN0RCxNQUFNQyxXQUFVLEVBQUVDLFVBQVUsRUFBRUMsSUFBSSxFQUFFQyxNQUFNLEVBQUU7UUFDMUMsTUFBTUMsZUFBZSxNQUFNQyxJQUFBQSwyQ0FBeUIsRUFBQztZQUNuREo7WUFDQUssY0FBY0osS0FBS0ssUUFBUTtZQUMzQkosUUFBUTtnQkFDTixHQUFHRCxJQUFJO2dCQUNQQztZQUNGO1FBQ0Y7UUFFQSxPQUFPLE1BQU1ELE1BQU1NLE1BQU0sTUFBTUosZUFBZSxPQUFPRixNQUFNTSxNQUFNO0lBQ25FO0lBQ0FDLFdBQVc7UUFBQztLQUFVO0FBQ3hCIn0=
@@ -0,0 +1,3 @@
1
+ import type { HTMLConverter } from '../types';
2
+ export declare const LinebreakHTMLConverter: HTMLConverter<any>;
3
+ //# sourceMappingURL=linebreak.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"linebreak.d.ts","sourceRoot":"","sources":["../../../../src/utilities/lexical/converters/linebreak.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAE7C,eAAO,MAAM,sBAAsB,EAAE,aAAa,CAAC,GAAG,CAKrD,CAAA"}
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "LinebreakHTMLConverter", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return LinebreakHTMLConverter;
9
+ }
10
+ });
11
+ const LinebreakHTMLConverter = {
12
+ converter () {
13
+ return `<br>`;
14
+ },
15
+ nodeTypes: [
16
+ 'linebreak'
17
+ ]
18
+ };
19
+
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy91dGlsaXRpZXMvbGV4aWNhbC9jb252ZXJ0ZXJzL2xpbmVicmVhay50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEhUTUxDb252ZXJ0ZXIgfSBmcm9tICcuLi90eXBlcydcblxuZXhwb3J0IGNvbnN0IExpbmVicmVha0hUTUxDb252ZXJ0ZXI6IEhUTUxDb252ZXJ0ZXI8YW55PiA9IHtcbiAgY29udmVydGVyKCkge1xuICAgIHJldHVybiBgPGJyPmBcbiAgfSxcbiAgbm9kZVR5cGVzOiBbJ2xpbmVicmVhayddLFxufVxuIl0sIm5hbWVzIjpbIkxpbmVicmVha0hUTUxDb252ZXJ0ZXIiLCJjb252ZXJ0ZXIiLCJub2RlVHlwZXMiXSwibWFwcGluZ3MiOiI7Ozs7K0JBRWFBOzs7ZUFBQUE7OztBQUFOLE1BQU1BLHlCQUE2QztJQUN4REM7UUFDRSxPQUFPLENBQUMsSUFBSSxDQUFDO0lBQ2Y7SUFDQUMsV0FBVztRQUFDO0tBQVk7QUFDMUIifQ==
@@ -0,0 +1,3 @@
1
+ import type { HTMLConverter } from '../types';
2
+ export declare const LinkHTMLConverter: HTMLConverter<any>;
3
+ //# sourceMappingURL=link.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"link.d.ts","sourceRoot":"","sources":["../../../../src/utilities/lexical/converters/link.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAI7C,eAAO,MAAM,iBAAiB,EAAE,aAAa,CAAC,GAAG,CAmBhD,CAAA"}
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "LinkHTMLConverter", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return LinkHTMLConverter;
9
+ }
10
+ });
11
+ const _serializeLexical = require("../serializeLexical");
12
+ const LinkHTMLConverter = {
13
+ async converter ({ converters, node, parent }) {
14
+ const childrenText = await (0, _serializeLexical.convertLexicalNodesToHTML)({
15
+ converters,
16
+ lexicalNodes: node.children,
17
+ parent: {
18
+ ...node,
19
+ parent
20
+ }
21
+ });
22
+ const rel = node.fields.newTab ? ' rel="noopener noreferrer"' : '';
23
+ const href = node.fields.linkType === 'custom' ? node.fields.url : node.fields.doc?.value?.id;
24
+ return `<a href="${href}"${rel}>${childrenText}</a>`;
25
+ },
26
+ nodeTypes: [
27
+ 'link'
28
+ ]
29
+ };
30
+
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy91dGlsaXRpZXMvbGV4aWNhbC9jb252ZXJ0ZXJzL2xpbmsudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBIVE1MQ29udmVydGVyIH0gZnJvbSAnLi4vdHlwZXMnXG5cbmltcG9ydCB7IGNvbnZlcnRMZXhpY2FsTm9kZXNUb0hUTUwgfSBmcm9tICcuLi9zZXJpYWxpemVMZXhpY2FsJ1xuXG5leHBvcnQgY29uc3QgTGlua0hUTUxDb252ZXJ0ZXI6IEhUTUxDb252ZXJ0ZXI8YW55PiA9IHtcbiAgYXN5bmMgY29udmVydGVyKHsgY29udmVydGVycywgbm9kZSwgcGFyZW50IH0pIHtcbiAgICBjb25zdCBjaGlsZHJlblRleHQgPSBhd2FpdCBjb252ZXJ0TGV4aWNhbE5vZGVzVG9IVE1MKHtcbiAgICAgIGNvbnZlcnRlcnMsXG4gICAgICBsZXhpY2FsTm9kZXM6IG5vZGUuY2hpbGRyZW4sXG4gICAgICBwYXJlbnQ6IHtcbiAgICAgICAgLi4ubm9kZSxcbiAgICAgICAgcGFyZW50LFxuICAgICAgfSxcbiAgICB9KVxuXG4gICAgY29uc3QgcmVsOiBzdHJpbmcgPSBub2RlLmZpZWxkcy5uZXdUYWIgPyAnIHJlbD1cIm5vb3BlbmVyIG5vcmVmZXJyZXJcIicgOiAnJ1xuXG4gICAgY29uc3QgaHJlZjogc3RyaW5nID1cbiAgICAgIG5vZGUuZmllbGRzLmxpbmtUeXBlID09PSAnY3VzdG9tJyA/IG5vZGUuZmllbGRzLnVybCA6IG5vZGUuZmllbGRzLmRvYz8udmFsdWU/LmlkXG5cbiAgICByZXR1cm4gYDxhIGhyZWY9XCIke2hyZWZ9XCIke3JlbH0+JHtjaGlsZHJlblRleHR9PC9hPmBcbiAgfSxcbiAgbm9kZVR5cGVzOiBbJ2xpbmsnXSxcbn1cbiJdLCJuYW1lcyI6WyJMaW5rSFRNTENvbnZlcnRlciIsImNvbnZlcnRlciIsImNvbnZlcnRlcnMiLCJub2RlIiwicGFyZW50IiwiY2hpbGRyZW5UZXh0IiwiY29udmVydExleGljYWxOb2Rlc1RvSFRNTCIsImxleGljYWxOb2RlcyIsImNoaWxkcmVuIiwicmVsIiwiZmllbGRzIiwibmV3VGFiIiwiaHJlZiIsImxpbmtUeXBlIiwidXJsIiwiZG9jIiwidmFsdWUiLCJpZCIsIm5vZGVUeXBlcyJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFJYUE7OztlQUFBQTs7O2tDQUY2QjtBQUVuQyxNQUFNQSxvQkFBd0M7SUFDbkQsTUFBTUMsV0FBVSxFQUFFQyxVQUFVLEVBQUVDLElBQUksRUFBRUMsTUFBTSxFQUFFO1FBQzFDLE1BQU1DLGVBQWUsTUFBTUMsSUFBQUEsMkNBQXlCLEVBQUM7WUFDbkRKO1lBQ0FLLGNBQWNKLEtBQUtLLFFBQVE7WUFDM0JKLFFBQVE7Z0JBQ04sR0FBR0QsSUFBSTtnQkFDUEM7WUFDRjtRQUNGO1FBRUEsTUFBTUssTUFBY04sS0FBS08sTUFBTSxDQUFDQyxNQUFNLEdBQUcsK0JBQStCO1FBRXhFLE1BQU1DLE9BQ0pULEtBQUtPLE1BQU0sQ0FBQ0csUUFBUSxLQUFLLFdBQVdWLEtBQUtPLE1BQU0sQ0FBQ0ksR0FBRyxHQUFHWCxLQUFLTyxNQUFNLENBQUNLLEdBQUcsRUFBRUMsT0FBT0M7UUFFaEYsT0FBTyxDQUFDLFNBQVMsRUFBRUwsS0FBSyxDQUFDLEVBQUVILElBQUksQ0FBQyxFQUFFSixhQUFhLElBQUksQ0FBQztJQUN0RDtJQUNBYSxXQUFXO1FBQUM7S0FBTztBQUNyQiJ9
@@ -0,0 +1,4 @@
1
+ import type { HTMLConverter } from '../types';
2
+ export declare const ListHTMLConverter: HTMLConverter<any>;
3
+ export declare const ListItemHTMLConverter: HTMLConverter<any>;
4
+ //# sourceMappingURL=list.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list.d.ts","sourceRoot":"","sources":["../../../../src/utilities/lexical/converters/list.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAI7C,eAAO,MAAM,iBAAiB,EAAE,aAAa,CAAC,GAAG,CAchD,CAAA;AAED,eAAO,MAAM,qBAAqB,EAAE,aAAa,CAAC,GAAG,CA4BpD,CAAA"}