@atlaskit/adf-schema 19.2.0
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/CHANGELOG.md +1524 -0
- package/LICENSE +13 -0
- package/build/tsconfig.json +17 -0
- package/dist/cjs/index.js +1089 -0
- package/dist/cjs/schema/bitbucket-schema.js +14 -0
- package/dist/cjs/schema/confluence-schema.js +21 -0
- package/dist/cjs/schema/create-schema.js +354 -0
- package/dist/cjs/schema/default-schema.js +52 -0
- package/dist/cjs/schema/groups.js +35 -0
- package/dist/cjs/schema/index.js +755 -0
- package/dist/cjs/schema/inline-nodes.js +20 -0
- package/dist/cjs/schema/jira-schema.js +118 -0
- package/dist/cjs/schema/marks/alignment.js +39 -0
- package/dist/cjs/schema/marks/annotation.js +96 -0
- package/dist/cjs/schema/marks/breakout.js +32 -0
- package/dist/cjs/schema/marks/code.js +46 -0
- package/dist/cjs/schema/marks/confluence-inline-comment.js +30 -0
- package/dist/cjs/schema/marks/data-consumer.js +71 -0
- package/dist/cjs/schema/marks/em.js +25 -0
- package/dist/cjs/schema/marks/indentation.js +32 -0
- package/dist/cjs/schema/marks/index.js +189 -0
- package/dist/cjs/schema/marks/link.js +128 -0
- package/dist/cjs/schema/marks/strike.js +29 -0
- package/dist/cjs/schema/marks/strong.js +37 -0
- package/dist/cjs/schema/marks/subsup.js +61 -0
- package/dist/cjs/schema/marks/text-color.js +93 -0
- package/dist/cjs/schema/marks/type-ahead-query.js +31 -0
- package/dist/cjs/schema/marks/underline.js +25 -0
- package/dist/cjs/schema/marks/unsupported-mark.js +15 -0
- package/dist/cjs/schema/marks/unsupported-node-attributes.js +16 -0
- package/dist/cjs/schema/nodes/block-card.js +56 -0
- package/dist/cjs/schema/nodes/blockquote.js +23 -0
- package/dist/cjs/schema/nodes/bodied-extension.js +66 -0
- package/dist/cjs/schema/nodes/bullet-list.js +29 -0
- package/dist/cjs/schema/nodes/caption.js +27 -0
- package/dist/cjs/schema/nodes/code-block.js +160 -0
- package/dist/cjs/schema/nodes/confluence-jira-issue.js +54 -0
- package/dist/cjs/schema/nodes/confluence-unsupported-block.js +33 -0
- package/dist/cjs/schema/nodes/confluence-unsupported-inline.js +34 -0
- package/dist/cjs/schema/nodes/date.js +36 -0
- package/dist/cjs/schema/nodes/decision-item.js +45 -0
- package/dist/cjs/schema/nodes/decision-list.js +45 -0
- package/dist/cjs/schema/nodes/doc.js +15 -0
- package/dist/cjs/schema/nodes/embed-card.js +62 -0
- package/dist/cjs/schema/nodes/emoji.js +73 -0
- package/dist/cjs/schema/nodes/expand.js +86 -0
- package/dist/cjs/schema/nodes/extension.js +59 -0
- package/dist/cjs/schema/nodes/hard-break.js +22 -0
- package/dist/cjs/schema/nodes/heading.js +69 -0
- package/dist/cjs/schema/nodes/image.js +40 -0
- package/dist/cjs/schema/nodes/index.js +539 -0
- package/dist/cjs/schema/nodes/inline-card.js +64 -0
- package/dist/cjs/schema/nodes/inline-extension.js +54 -0
- package/dist/cjs/schema/nodes/layout-column.js +53 -0
- package/dist/cjs/schema/nodes/layout-section.js +61 -0
- package/dist/cjs/schema/nodes/list-item.js +25 -0
- package/dist/cjs/schema/nodes/media-group.js +29 -0
- package/dist/cjs/schema/nodes/media-inline.js +11 -0
- package/dist/cjs/schema/nodes/media-single.js +101 -0
- package/dist/cjs/schema/nodes/media.js +196 -0
- package/dist/cjs/schema/nodes/mention.js +90 -0
- package/dist/cjs/schema/nodes/nested-expand.js +64 -0
- package/dist/cjs/schema/nodes/ordered-list.js +29 -0
- package/dist/cjs/schema/nodes/panel.js +85 -0
- package/dist/cjs/schema/nodes/paragraph.js +45 -0
- package/dist/cjs/schema/nodes/placeholder.js +39 -0
- package/dist/cjs/schema/nodes/rule.js +21 -0
- package/dist/cjs/schema/nodes/status.js +56 -0
- package/dist/cjs/schema/nodes/tableNodes.js +276 -0
- package/dist/cjs/schema/nodes/task-item.js +46 -0
- package/dist/cjs/schema/nodes/task-list.js +45 -0
- package/dist/cjs/schema/nodes/text.js +17 -0
- package/dist/cjs/schema/nodes/types/block-content.js +5 -0
- package/dist/cjs/schema/nodes/types/extensions.js +5 -0
- package/dist/cjs/schema/nodes/types/inline-content.js +5 -0
- package/dist/cjs/schema/nodes/types/mark.js +5 -0
- package/dist/cjs/schema/nodes/types/non-nestable-block-content.js +5 -0
- package/dist/cjs/schema/nodes/types/rich-media-common.js +5 -0
- package/dist/cjs/schema/nodes/unknown-block.js +21 -0
- package/dist/cjs/schema/nodes/unsupported-block.js +33 -0
- package/dist/cjs/schema/nodes/unsupported-inline.js +32 -0
- package/dist/cjs/schema/unsupported.js +8 -0
- package/dist/cjs/steps/analytics.js +183 -0
- package/dist/cjs/steps/set-attrs.js +106 -0
- package/dist/cjs/steps/table/add-column.js +453 -0
- package/dist/cjs/steps/table/constants.js +13 -0
- package/dist/cjs/steps/table/sort-column.js +87 -0
- package/dist/cjs/steps/table/types.js +5 -0
- package/dist/cjs/steps/table/utils/cell-step.js +233 -0
- package/dist/cjs/steps/table/utils/cells-at-column.js +94 -0
- package/dist/cjs/steps/table/utils/find-column.js +94 -0
- package/dist/cjs/steps/table/utils/get-table-rect-from-doc.js +38 -0
- package/dist/cjs/steps/table/utils/side-effects/rows.js +370 -0
- package/dist/cjs/steps/table/utils/side-effects/side-effects.js +106 -0
- package/dist/cjs/steps/table/utils/side-effects/table.js +126 -0
- package/dist/cjs/steps/table/utils/side-effects/types.js +5 -0
- package/dist/cjs/steps/table/utils/table-map.js +36 -0
- package/dist/cjs/steps/type-ahead.js +134 -0
- package/dist/cjs/steps.js +59 -0
- package/dist/cjs/utils/colors.js +234 -0
- package/dist/cjs/utils/confluence/emoji.js +97 -0
- package/dist/cjs/utils/extensions.js +39 -0
- package/dist/cjs/utils/index.js +373 -0
- package/dist/cjs/utils/parseDOM.js +12 -0
- package/dist/cjs/utils/url.js +38 -0
- package/dist/cjs/utils/uuid.js +28 -0
- package/dist/cjs/version.json +5 -0
- package/dist/es2019/index.js +2 -0
- package/dist/es2019/schema/bitbucket-schema.js +5 -0
- package/dist/es2019/schema/confluence-schema.js +11 -0
- package/dist/es2019/schema/create-schema.js +325 -0
- package/dist/es2019/schema/default-schema.js +35 -0
- package/dist/es2019/schema/groups.js +23 -0
- package/dist/es2019/schema/index.js +9 -0
- package/dist/es2019/schema/inline-nodes.js +3 -0
- package/dist/es2019/schema/jira-schema.js +88 -0
- package/dist/es2019/schema/marks/alignment.js +32 -0
- package/dist/es2019/schema/marks/annotation.js +80 -0
- package/dist/es2019/schema/marks/breakout.js +29 -0
- package/dist/es2019/schema/marks/code.js +43 -0
- package/dist/es2019/schema/marks/confluence-inline-comment.js +24 -0
- package/dist/es2019/schema/marks/data-consumer.js +61 -0
- package/dist/es2019/schema/marks/em.js +22 -0
- package/dist/es2019/schema/marks/indentation.js +27 -0
- package/dist/es2019/schema/marks/index.js +17 -0
- package/dist/es2019/schema/marks/link.js +105 -0
- package/dist/es2019/schema/marks/strike.js +24 -0
- package/dist/es2019/schema/marks/strong.js +40 -0
- package/dist/es2019/schema/marks/subsup.js +51 -0
- package/dist/es2019/schema/marks/text-color.js +67 -0
- package/dist/es2019/schema/marks/type-ahead-query.js +23 -0
- package/dist/es2019/schema/marks/underline.js +20 -0
- package/dist/es2019/schema/marks/unsupported-mark.js +9 -0
- package/dist/es2019/schema/marks/unsupported-node-attributes.js +10 -0
- package/dist/es2019/schema/nodes/block-card.js +50 -0
- package/dist/es2019/schema/nodes/blockquote.js +17 -0
- package/dist/es2019/schema/nodes/bodied-extension.js +58 -0
- package/dist/es2019/schema/nodes/bullet-list.js +23 -0
- package/dist/es2019/schema/nodes/caption.js +21 -0
- package/dist/es2019/schema/nodes/code-block.js +143 -0
- package/dist/es2019/schema/nodes/confluence-jira-issue.js +49 -0
- package/dist/es2019/schema/nodes/confluence-unsupported-block.js +30 -0
- package/dist/es2019/schema/nodes/confluence-unsupported-inline.js +31 -0
- package/dist/es2019/schema/nodes/date.js +28 -0
- package/dist/es2019/schema/nodes/decision-item.js +37 -0
- package/dist/es2019/schema/nodes/decision-list.js +41 -0
- package/dist/es2019/schema/nodes/doc.js +7 -0
- package/dist/es2019/schema/nodes/embed-card.js +55 -0
- package/dist/es2019/schema/nodes/emoji.js +67 -0
- package/dist/es2019/schema/nodes/expand.js +73 -0
- package/dist/es2019/schema/nodes/extension.js +51 -0
- package/dist/es2019/schema/nodes/hard-break.js +16 -0
- package/dist/es2019/schema/nodes/heading.js +63 -0
- package/dist/es2019/schema/nodes/image.js +37 -0
- package/dist/es2019/schema/nodes/index.js +44 -0
- package/dist/es2019/schema/nodes/inline-card.js +58 -0
- package/dist/es2019/schema/nodes/inline-extension.js +46 -0
- package/dist/es2019/schema/nodes/layout-column.js +49 -0
- package/dist/es2019/schema/nodes/layout-section.js +56 -0
- package/dist/es2019/schema/nodes/list-item.js +20 -0
- package/dist/es2019/schema/nodes/media-group.js +23 -0
- package/dist/es2019/schema/nodes/media-inline.js +2 -0
- package/dist/es2019/schema/nodes/media-single.js +77 -0
- package/dist/es2019/schema/nodes/media.js +165 -0
- package/dist/es2019/schema/nodes/mention.js +81 -0
- package/dist/es2019/schema/nodes/nested-expand.js +58 -0
- package/dist/es2019/schema/nodes/ordered-list.js +23 -0
- package/dist/es2019/schema/nodes/panel.js +79 -0
- package/dist/es2019/schema/nodes/paragraph.js +39 -0
- package/dist/es2019/schema/nodes/placeholder.js +33 -0
- package/dist/es2019/schema/nodes/rule.js +15 -0
- package/dist/es2019/schema/nodes/status.js +54 -0
- package/dist/es2019/schema/nodes/tableNodes.js +222 -0
- package/dist/es2019/schema/nodes/task-item.js +38 -0
- package/dist/es2019/schema/nodes/task-list.js +37 -0
- package/dist/es2019/schema/nodes/text.js +7 -0
- package/dist/es2019/schema/nodes/types/block-content.js +1 -0
- package/dist/es2019/schema/nodes/types/extensions.js +1 -0
- package/dist/es2019/schema/nodes/types/inline-content.js +1 -0
- package/dist/es2019/schema/nodes/types/mark.js +1 -0
- package/dist/es2019/schema/nodes/types/non-nestable-block-content.js +1 -0
- package/dist/es2019/schema/nodes/types/rich-media-common.js +1 -0
- package/dist/es2019/schema/nodes/unknown-block.js +16 -0
- package/dist/es2019/schema/nodes/unsupported-block.js +26 -0
- package/dist/es2019/schema/nodes/unsupported-inline.js +25 -0
- package/dist/es2019/schema/unsupported.js +1 -0
- package/dist/es2019/steps/analytics.js +122 -0
- package/dist/es2019/steps/set-attrs.js +57 -0
- package/dist/es2019/steps/table/add-column.js +349 -0
- package/dist/es2019/steps/table/constants.js +6 -0
- package/dist/es2019/steps/table/sort-column.js +41 -0
- package/dist/es2019/steps/table/types.js +1 -0
- package/dist/es2019/steps/table/utils/cell-step.js +204 -0
- package/dist/es2019/steps/table/utils/cells-at-column.js +57 -0
- package/dist/es2019/steps/table/utils/find-column.js +86 -0
- package/dist/es2019/steps/table/utils/get-table-rect-from-doc.js +30 -0
- package/dist/es2019/steps/table/utils/side-effects/rows.js +297 -0
- package/dist/es2019/steps/table/utils/side-effects/side-effects.js +81 -0
- package/dist/es2019/steps/table/utils/side-effects/table.js +99 -0
- package/dist/es2019/steps/table/utils/side-effects/types.js +1 -0
- package/dist/es2019/steps/table/utils/table-map.js +19 -0
- package/dist/es2019/steps/type-ahead.js +85 -0
- package/dist/es2019/steps.js +6 -0
- package/dist/es2019/utils/colors.js +148 -0
- package/dist/es2019/utils/confluence/emoji.js +83 -0
- package/dist/es2019/utils/extensions.js +26 -0
- package/dist/es2019/utils/index.js +4 -0
- package/dist/es2019/utils/parseDOM.js +1 -0
- package/dist/es2019/utils/url.js +19 -0
- package/dist/es2019/utils/uuid.js +18 -0
- package/dist/es2019/version.json +5 -0
- package/dist/esm/index.js +2 -0
- package/dist/esm/schema/bitbucket-schema.js +5 -0
- package/dist/esm/schema/confluence-schema.js +11 -0
- package/dist/esm/schema/create-schema.js +338 -0
- package/dist/esm/schema/default-schema.js +36 -0
- package/dist/esm/schema/groups.js +23 -0
- package/dist/esm/schema/index.js +9 -0
- package/dist/esm/schema/inline-nodes.js +5 -0
- package/dist/esm/schema/jira-schema.js +88 -0
- package/dist/esm/schema/marks/alignment.js +30 -0
- package/dist/esm/schema/marks/annotation.js +82 -0
- package/dist/esm/schema/marks/breakout.js +25 -0
- package/dist/esm/schema/marks/code.js +41 -0
- package/dist/esm/schema/marks/confluence-inline-comment.js +22 -0
- package/dist/esm/schema/marks/data-consumer.js +63 -0
- package/dist/esm/schema/marks/em.js +20 -0
- package/dist/esm/schema/marks/indentation.js +23 -0
- package/dist/esm/schema/marks/index.js +17 -0
- package/dist/esm/schema/marks/link.js +113 -0
- package/dist/esm/schema/marks/strike.js +24 -0
- package/dist/esm/schema/marks/strong.js +32 -0
- package/dist/esm/schema/marks/subsup.js +53 -0
- package/dist/esm/schema/marks/text-color.js +78 -0
- package/dist/esm/schema/marks/type-ahead-query.js +21 -0
- package/dist/esm/schema/marks/underline.js +20 -0
- package/dist/esm/schema/marks/unsupported-mark.js +8 -0
- package/dist/esm/schema/marks/unsupported-node-attributes.js +9 -0
- package/dist/esm/schema/nodes/block-card.js +48 -0
- package/dist/esm/schema/nodes/blockquote.js +15 -0
- package/dist/esm/schema/nodes/bodied-extension.js +58 -0
- package/dist/esm/schema/nodes/bullet-list.js +21 -0
- package/dist/esm/schema/nodes/caption.js +19 -0
- package/dist/esm/schema/nodes/code-block.js +149 -0
- package/dist/esm/schema/nodes/confluence-jira-issue.js +47 -0
- package/dist/esm/schema/nodes/confluence-unsupported-block.js +26 -0
- package/dist/esm/schema/nodes/confluence-unsupported-inline.js +27 -0
- package/dist/esm/schema/nodes/date.js +28 -0
- package/dist/esm/schema/nodes/decision-item.js +36 -0
- package/dist/esm/schema/nodes/decision-list.js +39 -0
- package/dist/esm/schema/nodes/doc.js +7 -0
- package/dist/esm/schema/nodes/embed-card.js +54 -0
- package/dist/esm/schema/nodes/emoji.js +68 -0
- package/dist/esm/schema/nodes/expand.js +75 -0
- package/dist/esm/schema/nodes/extension.js +51 -0
- package/dist/esm/schema/nodes/hard-break.js +14 -0
- package/dist/esm/schema/nodes/heading.js +61 -0
- package/dist/esm/schema/nodes/image.js +33 -0
- package/dist/esm/schema/nodes/index.js +44 -0
- package/dist/esm/schema/nodes/inline-card.js +56 -0
- package/dist/esm/schema/nodes/inline-extension.js +46 -0
- package/dist/esm/schema/nodes/layout-column.js +45 -0
- package/dist/esm/schema/nodes/layout-section.js +52 -0
- package/dist/esm/schema/nodes/list-item.js +18 -0
- package/dist/esm/schema/nodes/media-group.js +21 -0
- package/dist/esm/schema/nodes/media-inline.js +2 -0
- package/dist/esm/schema/nodes/media-single.js +84 -0
- package/dist/esm/schema/nodes/media.js +174 -0
- package/dist/esm/schema/nodes/mention.js +80 -0
- package/dist/esm/schema/nodes/nested-expand.js +56 -0
- package/dist/esm/schema/nodes/ordered-list.js +21 -0
- package/dist/esm/schema/nodes/panel.js +76 -0
- package/dist/esm/schema/nodes/paragraph.js +37 -0
- package/dist/esm/schema/nodes/placeholder.js +31 -0
- package/dist/esm/schema/nodes/rule.js +13 -0
- package/dist/esm/schema/nodes/status.js +51 -0
- package/dist/esm/schema/nodes/tableNodes.js +238 -0
- package/dist/esm/schema/nodes/task-item.js +37 -0
- package/dist/esm/schema/nodes/task-list.js +35 -0
- package/dist/esm/schema/nodes/text.js +9 -0
- package/dist/esm/schema/nodes/types/block-content.js +1 -0
- package/dist/esm/schema/nodes/types/extensions.js +1 -0
- package/dist/esm/schema/nodes/types/inline-content.js +1 -0
- package/dist/esm/schema/nodes/types/mark.js +1 -0
- package/dist/esm/schema/nodes/types/non-nestable-block-content.js +1 -0
- package/dist/esm/schema/nodes/types/rich-media-common.js +1 -0
- package/dist/esm/schema/nodes/unknown-block.js +14 -0
- package/dist/esm/schema/nodes/unsupported-block.js +26 -0
- package/dist/esm/schema/nodes/unsupported-inline.js +25 -0
- package/dist/esm/schema/unsupported.js +1 -0
- package/dist/esm/steps/analytics.js +166 -0
- package/dist/esm/steps/set-attrs.js +89 -0
- package/dist/esm/steps/table/add-column.js +431 -0
- package/dist/esm/steps/table/constants.js +6 -0
- package/dist/esm/steps/table/sort-column.js +69 -0
- package/dist/esm/steps/table/types.js +1 -0
- package/dist/esm/steps/table/utils/cell-step.js +216 -0
- package/dist/esm/steps/table/utils/cells-at-column.js +84 -0
- package/dist/esm/steps/table/utils/find-column.js +87 -0
- package/dist/esm/steps/table/utils/get-table-rect-from-doc.js +30 -0
- package/dist/esm/steps/table/utils/side-effects/rows.js +360 -0
- package/dist/esm/steps/table/utils/side-effects/side-effects.js +93 -0
- package/dist/esm/steps/table/utils/side-effects/table.js +113 -0
- package/dist/esm/steps/table/utils/side-effects/types.js +1 -0
- package/dist/esm/steps/table/utils/table-map.js +19 -0
- package/dist/esm/steps/type-ahead.js +117 -0
- package/dist/esm/steps.js +6 -0
- package/dist/esm/utils/colors.js +160 -0
- package/dist/esm/utils/confluence/emoji.js +85 -0
- package/dist/esm/utils/extensions.js +27 -0
- package/dist/esm/utils/index.js +4 -0
- package/dist/esm/utils/parseDOM.js +3 -0
- package/dist/esm/utils/url.js +21 -0
- package/dist/esm/utils/uuid.js +18 -0
- package/dist/esm/version.json +5 -0
- package/dist/json-schema/v1/full.json +2536 -0
- package/dist/json-schema/v1/stage-0.json +2737 -0
- package/dist/types/index.d.ts +4 -0
- package/dist/types/schema/bitbucket-schema.d.ts +2 -0
- package/dist/types/schema/confluence-schema.d.ts +3 -0
- package/dist/types/schema/create-schema.d.ts +31 -0
- package/dist/types/schema/default-schema.d.ts +7 -0
- package/dist/types/schema/groups.d.ts +6 -0
- package/dist/types/schema/index.d.ts +11 -0
- package/dist/types/schema/inline-nodes.d.ts +1 -0
- package/dist/types/schema/jira-schema.d.ts +26 -0
- package/dist/types/schema/marks/alignment.d.ts +16 -0
- package/dist/types/schema/marks/annotation.d.ts +32 -0
- package/dist/types/schema/marks/breakout.d.ts +12 -0
- package/dist/types/schema/marks/code.d.ts +8 -0
- package/dist/types/schema/marks/confluence-inline-comment.d.ts +12 -0
- package/dist/types/schema/marks/data-consumer.d.ts +41 -0
- package/dist/types/schema/marks/em.d.ts +8 -0
- package/dist/types/schema/marks/indentation.d.ts +16 -0
- package/dist/types/schema/marks/index.d.ts +30 -0
- package/dist/types/schema/marks/link.d.ts +32 -0
- package/dist/types/schema/marks/strike.d.ts +8 -0
- package/dist/types/schema/marks/strong.d.ts +8 -0
- package/dist/types/schema/marks/subsup.d.ts +15 -0
- package/dist/types/schema/marks/text-color.d.ts +21 -0
- package/dist/types/schema/marks/type-ahead-query.d.ts +2 -0
- package/dist/types/schema/marks/underline.d.ts +8 -0
- package/dist/types/schema/marks/unsupported-mark.d.ts +2 -0
- package/dist/types/schema/marks/unsupported-node-attributes.d.ts +2 -0
- package/dist/types/schema/nodes/block-card.d.ts +19 -0
- package/dist/types/schema/nodes/blockquote.d.ts +14 -0
- package/dist/types/schema/nodes/bodied-extension.d.ts +27 -0
- package/dist/types/schema/nodes/bullet-list.d.ts +14 -0
- package/dist/types/schema/nodes/caption.d.ts +21 -0
- package/dist/types/schema/nodes/code-block.d.ts +31 -0
- package/dist/types/schema/nodes/confluence-jira-issue.d.ts +2 -0
- package/dist/types/schema/nodes/confluence-unsupported-block.d.ts +2 -0
- package/dist/types/schema/nodes/confluence-unsupported-inline.d.ts +2 -0
- package/dist/types/schema/nodes/date.d.ts +14 -0
- package/dist/types/schema/nodes/decision-item.d.ts +17 -0
- package/dist/types/schema/nodes/decision-list.d.ts +18 -0
- package/dist/types/schema/nodes/doc.d.ts +18 -0
- package/dist/types/schema/nodes/embed-card.d.ts +15 -0
- package/dist/types/schema/nodes/emoji.d.ts +14 -0
- package/dist/types/schema/nodes/expand.d.ts +33 -0
- package/dist/types/schema/nodes/extension.d.ts +21 -0
- package/dist/types/schema/nodes/hard-break.d.ts +11 -0
- package/dist/types/schema/nodes/heading.d.ts +36 -0
- package/dist/types/schema/nodes/image.d.ts +2 -0
- package/dist/types/schema/nodes/index.d.ts +93 -0
- package/dist/types/schema/nodes/inline-card.d.ts +19 -0
- package/dist/types/schema/nodes/inline-extension.d.ts +21 -0
- package/dist/types/schema/nodes/layout-column.d.ts +21 -0
- package/dist/types/schema/nodes/layout-section.d.ts +44 -0
- package/dist/types/schema/nodes/list-item.d.ts +20 -0
- package/dist/types/schema/nodes/media-group.d.ts +14 -0
- package/dist/types/schema/nodes/media-inline.d.ts +16 -0
- package/dist/types/schema/nodes/media-single.d.ts +59 -0
- package/dist/types/schema/nodes/media.d.ts +60 -0
- package/dist/types/schema/nodes/mention.d.ts +26 -0
- package/dist/types/schema/nodes/nested-expand.d.ts +27 -0
- package/dist/types/schema/nodes/ordered-list.d.ts +20 -0
- package/dist/types/schema/nodes/panel.d.ts +46 -0
- package/dist/types/schema/nodes/paragraph.d.ts +37 -0
- package/dist/types/schema/nodes/placeholder.d.ts +11 -0
- package/dist/types/schema/nodes/rule.d.ts +8 -0
- package/dist/types/schema/nodes/status.d.ts +20 -0
- package/dist/types/schema/nodes/tableNodes.d.ts +111 -0
- package/dist/types/schema/nodes/task-item.d.ts +17 -0
- package/dist/types/schema/nodes/task-list.d.ts +21 -0
- package/dist/types/schema/nodes/text.d.ts +15 -0
- package/dist/types/schema/nodes/types/block-content.d.ts +22 -0
- package/dist/types/schema/nodes/types/extensions.d.ts +34 -0
- package/dist/types/schema/nodes/types/inline-content.d.ts +32 -0
- package/dist/types/schema/nodes/types/mark.d.ts +15 -0
- package/dist/types/schema/nodes/types/non-nestable-block-content.d.ts +20 -0
- package/dist/types/schema/nodes/types/rich-media-common.d.ts +9 -0
- package/dist/types/schema/nodes/unknown-block.d.ts +3 -0
- package/dist/types/schema/nodes/unsupported-block.d.ts +2 -0
- package/dist/types/schema/nodes/unsupported-inline.d.ts +2 -0
- package/dist/types/schema/unsupported.d.ts +1 -0
- package/dist/types/steps/analytics.d.ts +59 -0
- package/dist/types/steps/set-attrs.d.ts +23 -0
- package/dist/types/steps/table/add-column.d.ts +88 -0
- package/dist/types/steps/table/constants.d.ts +4 -0
- package/dist/types/steps/table/sort-column.d.ts +18 -0
- package/dist/types/steps/table/types.d.ts +39 -0
- package/dist/types/steps/table/utils/cell-step.d.ts +47 -0
- package/dist/types/steps/table/utils/cells-at-column.d.ts +20 -0
- package/dist/types/steps/table/utils/find-column.d.ts +8 -0
- package/dist/types/steps/table/utils/get-table-rect-from-doc.d.ts +8 -0
- package/dist/types/steps/table/utils/side-effects/rows.d.ts +25 -0
- package/dist/types/steps/table/utils/side-effects/side-effects.d.ts +15 -0
- package/dist/types/steps/table/utils/side-effects/table.d.ts +16 -0
- package/dist/types/steps/table/utils/side-effects/types.d.ts +33 -0
- package/dist/types/steps/table/utils/table-map.d.ts +6 -0
- package/dist/types/steps/type-ahead.d.ts +35 -0
- package/dist/types/steps.d.ts +8 -0
- package/dist/types/utils/colors.d.ts +71 -0
- package/dist/types/utils/confluence/emoji.d.ts +50 -0
- package/dist/types/utils/extensions.d.ts +3 -0
- package/dist/types/utils/index.d.ts +6 -0
- package/dist/types/utils/parseDOM.d.ts +1 -0
- package/dist/types/utils/url.d.ts +15 -0
- package/dist/types/utils/uuid.d.ts +5 -0
- package/document-fixtures/unsupported-content.json +526 -0
- package/json-schema/v1/full.json +2536 -0
- package/json-schema/v1/stage-0.json +2737 -0
- package/package.json +63 -0
- package/steps/package.json +7 -0
- package/test-helpers/html-helpers.ts +40 -0
- package/test-helpers/matches.ts +8 -0
- package/test-helpers/schema-builder.ts +329 -0
- package/test-helpers/schema.ts +79 -0
- package/tsconfig.json +18 -0
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { uuid } from '../../utils/uuid';
|
|
2
|
+
export const taskItem = {
|
|
3
|
+
content: 'inline*',
|
|
4
|
+
defining: true,
|
|
5
|
+
selectable: false,
|
|
6
|
+
marks: '_',
|
|
7
|
+
attrs: {
|
|
8
|
+
localId: {
|
|
9
|
+
default: ''
|
|
10
|
+
},
|
|
11
|
+
state: {
|
|
12
|
+
default: 'TODO'
|
|
13
|
+
}
|
|
14
|
+
},
|
|
15
|
+
parseDOM: [{
|
|
16
|
+
tag: 'div[data-task-local-id]',
|
|
17
|
+
// Default priority is 50. We normally don't change this but since this node type is
|
|
18
|
+
// also used by list-item we need to make sure that we run this parser first.
|
|
19
|
+
priority: 100,
|
|
20
|
+
getAttrs: dom => ({
|
|
21
|
+
localId: uuid.generate(),
|
|
22
|
+
state: dom.getAttribute('data-task-state') || 'TODO'
|
|
23
|
+
})
|
|
24
|
+
}],
|
|
25
|
+
|
|
26
|
+
toDOM(node) {
|
|
27
|
+
const {
|
|
28
|
+
localId,
|
|
29
|
+
state
|
|
30
|
+
} = node.attrs;
|
|
31
|
+
const attrs = {
|
|
32
|
+
'data-task-local-id': localId || 'local-task',
|
|
33
|
+
'data-task-state': state || 'TODO'
|
|
34
|
+
};
|
|
35
|
+
return ['div', attrs, 0];
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
};
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { uuid } from '../../utils/uuid';
|
|
2
|
+
const name = 'actionList';
|
|
3
|
+
export const taskListSelector = `[data-node-type="${name}"]`;
|
|
4
|
+
export const taskList = {
|
|
5
|
+
group: 'block',
|
|
6
|
+
defining: true,
|
|
7
|
+
selectable: false,
|
|
8
|
+
content: '(taskItem|unsupportedBlock)+ (taskItem|taskList|unsupportedBlock)*',
|
|
9
|
+
marks: 'unsupportedMark unsupportedNodeAttribute',
|
|
10
|
+
attrs: {
|
|
11
|
+
localId: {
|
|
12
|
+
default: ''
|
|
13
|
+
}
|
|
14
|
+
},
|
|
15
|
+
parseDOM: [{
|
|
16
|
+
tag: `div${taskListSelector}`,
|
|
17
|
+
// Default priority is 50. We normally don't change this but since this node type is
|
|
18
|
+
// also used by ordered-list we need to make sure that we run this parser first.
|
|
19
|
+
priority: 100,
|
|
20
|
+
getAttrs: () => ({
|
|
21
|
+
localId: uuid.generate()
|
|
22
|
+
})
|
|
23
|
+
}],
|
|
24
|
+
|
|
25
|
+
toDOM(node) {
|
|
26
|
+
const {
|
|
27
|
+
localId
|
|
28
|
+
} = node.attrs;
|
|
29
|
+
const attrs = {
|
|
30
|
+
'data-node-type': name,
|
|
31
|
+
'data-task-list-local-id': localId || 'local-task-list',
|
|
32
|
+
style: 'list-style: none; padding-left: 0'
|
|
33
|
+
};
|
|
34
|
+
return ['div', attrs, 0];
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export const unsupportedBlock = {
|
|
2
|
+
inline: false,
|
|
3
|
+
group: 'block',
|
|
4
|
+
atom: true,
|
|
5
|
+
selectable: true,
|
|
6
|
+
attrs: {
|
|
7
|
+
originalValue: {
|
|
8
|
+
default: {}
|
|
9
|
+
}
|
|
10
|
+
},
|
|
11
|
+
parseDOM: [{
|
|
12
|
+
tag: '[data-node-type="unsupportedBlock"]',
|
|
13
|
+
getAttrs: dom => ({
|
|
14
|
+
originalValue: JSON.parse(dom.getAttribute('data-original-value') || '{}')
|
|
15
|
+
})
|
|
16
|
+
}],
|
|
17
|
+
|
|
18
|
+
toDOM(node) {
|
|
19
|
+
const attrs = {
|
|
20
|
+
'data-node-type': 'unsupportedBlock',
|
|
21
|
+
'data-original-value': JSON.stringify(node.attrs.originalValue)
|
|
22
|
+
};
|
|
23
|
+
return ['div', attrs, 'Unsupported content'];
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export const unsupportedInline = {
|
|
2
|
+
inline: true,
|
|
3
|
+
group: 'inline',
|
|
4
|
+
selectable: true,
|
|
5
|
+
attrs: {
|
|
6
|
+
originalValue: {
|
|
7
|
+
default: {}
|
|
8
|
+
}
|
|
9
|
+
},
|
|
10
|
+
parseDOM: [{
|
|
11
|
+
tag: '[data-node-type="unsupportedInline"]',
|
|
12
|
+
getAttrs: dom => ({
|
|
13
|
+
originalValue: JSON.parse(dom.getAttribute('data-original-value') || '{}')
|
|
14
|
+
})
|
|
15
|
+
}],
|
|
16
|
+
|
|
17
|
+
toDOM(node) {
|
|
18
|
+
const attrs = {
|
|
19
|
+
'data-node-type': 'unsupportedInline',
|
|
20
|
+
'data-original-value': JSON.stringify(node.attrs.originalValue)
|
|
21
|
+
};
|
|
22
|
+
return ['span', attrs, 'Unsupported content'];
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const unsupportedNodeTypesForMediaCards = new Set(['decisionItem', 'taskItem']);
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
2
|
+
import { Step, StepResult, StepMap, ReplaceStep } from 'prosemirror-transform';
|
|
3
|
+
import { Slice } from 'prosemirror-model';
|
|
4
|
+
export const analyticsStepType = 'atlaskit-analytics';
|
|
5
|
+
export const analyticsInvertStepType = 'atlaskit-analytics-invert';
|
|
6
|
+
var HISTORY_ACTIONS;
|
|
7
|
+
|
|
8
|
+
(function (HISTORY_ACTIONS) {
|
|
9
|
+
HISTORY_ACTIONS["UNDID"] = "undid";
|
|
10
|
+
HISTORY_ACTIONS["REDID"] = "redid";
|
|
11
|
+
})(HISTORY_ACTIONS || (HISTORY_ACTIONS = {}));
|
|
12
|
+
|
|
13
|
+
/** Creates undo event from a normal analytics event */
|
|
14
|
+
function createUndoEvent(analyticsEvent) {
|
|
15
|
+
var _analyticsEvent$paylo;
|
|
16
|
+
|
|
17
|
+
return { ...analyticsEvent,
|
|
18
|
+
payload: {
|
|
19
|
+
action: HISTORY_ACTIONS.UNDID,
|
|
20
|
+
actionSubject: analyticsEvent.payload.actionSubject,
|
|
21
|
+
actionSubjectId: analyticsEvent.payload.action,
|
|
22
|
+
attributes: { ...analyticsEvent.payload.attributes,
|
|
23
|
+
actionSubjectId: analyticsEvent.payload.actionSubjectId,
|
|
24
|
+
inputMethod: ((_analyticsEvent$paylo = analyticsEvent.payload.attributes) === null || _analyticsEvent$paylo === void 0 ? void 0 : _analyticsEvent$paylo.inputMethod) || ''
|
|
25
|
+
},
|
|
26
|
+
eventType: 'track'
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
/** Toggles event action between undo & redo */
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
const toggleEventAction = analyticsEvent => ({ ...analyticsEvent,
|
|
34
|
+
payload: { ...analyticsEvent.payload,
|
|
35
|
+
action: analyticsEvent.payload.action === HISTORY_ACTIONS.UNDID ? HISTORY_ACTIONS.REDID : HISTORY_ACTIONS.UNDID
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
function isHistoryAnalyticsEvent(event) {
|
|
40
|
+
return event.payload.action === HISTORY_ACTIONS.UNDID || event.payload.action === HISTORY_ACTIONS.REDID;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Custom Prosemirror Step to fire our GAS V3 analytics events
|
|
45
|
+
* Using a Step means that it will work with prosemirror-history and we get
|
|
46
|
+
* undo/redo events for free
|
|
47
|
+
*/
|
|
48
|
+
export class AnalyticsStep extends Step {
|
|
49
|
+
constructor(analyticsEvents, actionsToIgnore = [], pos // Used to create the map, prevent splitting history.
|
|
50
|
+
) {
|
|
51
|
+
super();
|
|
52
|
+
|
|
53
|
+
_defineProperty(this, "analyticsEvents", []);
|
|
54
|
+
|
|
55
|
+
_defineProperty(this, "actionsToIgnore", []);
|
|
56
|
+
|
|
57
|
+
this.analyticsEvents = analyticsEvents;
|
|
58
|
+
this.actionsToIgnore = actionsToIgnore;
|
|
59
|
+
this.pos = pos;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Generate new undo/redo analytics event when step is inverted
|
|
63
|
+
*/
|
|
64
|
+
|
|
65
|
+
|
|
66
|
+
invert() {
|
|
67
|
+
const analyticsEvents = this.analyticsEvents.filter(analyticsEvent => this.actionsToIgnore.indexOf(analyticsEvent.payload.action) === -1).map(analyticsEvent => {
|
|
68
|
+
if (isHistoryAnalyticsEvent(analyticsEvent)) {
|
|
69
|
+
return toggleEventAction(analyticsEvent);
|
|
70
|
+
} else {
|
|
71
|
+
return createUndoEvent(analyticsEvent);
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
return new AnalyticsStep(analyticsEvents, []);
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
apply(doc) {
|
|
78
|
+
return StepResult.ok(doc);
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
map(mapping) {
|
|
82
|
+
let newPos = this.pos;
|
|
83
|
+
|
|
84
|
+
if (typeof newPos === 'number') {
|
|
85
|
+
newPos = mapping.map(newPos);
|
|
86
|
+
} // Return the same events, this step will never be removed
|
|
87
|
+
|
|
88
|
+
|
|
89
|
+
return new AnalyticsStep(this.analyticsEvents, this.actionsToIgnore, newPos);
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
getMap() {
|
|
93
|
+
if (typeof this.pos === 'number') {
|
|
94
|
+
return new StepMap([this.pos, 0, 0]);
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
return new StepMap([]);
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
merge(other) {
|
|
101
|
+
if (other instanceof AnalyticsStep) {
|
|
102
|
+
const otherAnalyticsEvents = other.analyticsEvents;
|
|
103
|
+
return new AnalyticsStep([...otherAnalyticsEvents, ...this.analyticsEvents]);
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
return null;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
toJSON() {
|
|
110
|
+
return {
|
|
111
|
+
stepType: analyticsStepType
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
static fromJSON() {
|
|
116
|
+
return new ReplaceStep(0, 0, Slice.empty);
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
}
|
|
120
|
+
/** Register this step with Prosemirror */
|
|
121
|
+
|
|
122
|
+
Step.jsonID(analyticsStepType, AnalyticsStep);
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { Step, StepResult } from 'prosemirror-transform';
|
|
2
|
+
import { Slice, Fragment } from 'prosemirror-model';
|
|
3
|
+
/**
|
|
4
|
+
* For more context on what this is about:
|
|
5
|
+
* @see https://discuss.prosemirror.net/t/preventing-image-placeholder-replacement-from-being-undone/1394
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
export class SetAttrsStep extends Step {
|
|
9
|
+
constructor(pos, attrs) {
|
|
10
|
+
super();
|
|
11
|
+
this.pos = pos;
|
|
12
|
+
this.attrs = attrs;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
apply(doc) {
|
|
16
|
+
let target = doc.nodeAt(this.pos);
|
|
17
|
+
|
|
18
|
+
if (!target) {
|
|
19
|
+
return StepResult.fail('No node at given position');
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
const attrs = { ...(target.attrs || {}),
|
|
23
|
+
...(this.attrs || {})
|
|
24
|
+
};
|
|
25
|
+
let newNode = target.type.create(attrs, Fragment.empty, target.marks);
|
|
26
|
+
let slice = new Slice(Fragment.from(newNode), 0, target.isLeaf ? 0 : 1);
|
|
27
|
+
return StepResult.fromReplace(doc, this.pos, this.pos + 1, slice);
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
invert(doc) {
|
|
31
|
+
let target = doc.nodeAt(this.pos);
|
|
32
|
+
return new SetAttrsStep(this.pos, target ? target.attrs : {});
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
map(mapping) {
|
|
36
|
+
let result = mapping.mapResult(this.pos, 1);
|
|
37
|
+
return result.deleted ? null : new SetAttrsStep(result.pos, this.attrs);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
toJSON() {
|
|
41
|
+
return {
|
|
42
|
+
stepType: 'setAttrs',
|
|
43
|
+
pos: this.pos,
|
|
44
|
+
attrs: this.attrs
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
static fromJSON(_schema, json) {
|
|
49
|
+
if (typeof json.pos !== 'number' || json.attrs !== null && typeof json.attrs !== 'object') {
|
|
50
|
+
throw new RangeError('Invalid input for SetAttrsStep.fromJSON');
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
return new SetAttrsStep(json.pos, json.attrs);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
}
|
|
57
|
+
Step.jsonID('setAttrs', SetAttrsStep);
|
|
@@ -0,0 +1,349 @@
|
|
|
1
|
+
import { Step, StepMap, StepResult, Transform } from 'prosemirror-transform';
|
|
2
|
+
import { cellsAtColumn } from './utils/cells-at-column';
|
|
3
|
+
import { findColumn } from './utils/find-column';
|
|
4
|
+
import { getTableRectFromDoc } from './utils/get-table-rect-from-doc';
|
|
5
|
+
import { applyCellStep, createCellStep, getMapFromCellStep, invertCellStep } from './utils/cell-step';
|
|
6
|
+
import { SideEffectsHandler } from './utils/side-effects/side-effects';
|
|
7
|
+
import memoizeOne from 'memoize-one';
|
|
8
|
+
const ADD_COLUMN_STEP = 'ak-add-column';
|
|
9
|
+
|
|
10
|
+
function printColumnInfo(columnInfo) {
|
|
11
|
+
let cellsFrom = [];
|
|
12
|
+
|
|
13
|
+
for (const cellInfo of columnInfo.values()) {
|
|
14
|
+
cellsFrom.push(cellInfo.from);
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
return `[${cellsFrom.join(',')}]`;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
function createColumnInfo(cellsInfo) {
|
|
21
|
+
return new Map(cellsInfo.map(cellInfo => [cellInfo.from, cellInfo]));
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
const getTableRectAndColumnFactory = (doc, pos, columnInfo) => {
|
|
25
|
+
return memoizeOne(() => {
|
|
26
|
+
const rect = getTableRectFromDoc(doc, pos);
|
|
27
|
+
const column = findColumn(columnInfo, rect);
|
|
28
|
+
|
|
29
|
+
if (column === null) {
|
|
30
|
+
throw new Error('no column');
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
return {
|
|
34
|
+
rect,
|
|
35
|
+
column
|
|
36
|
+
};
|
|
37
|
+
});
|
|
38
|
+
};
|
|
39
|
+
/**
|
|
40
|
+
* Index and positions looks like
|
|
41
|
+
* 0 1 2 3 -> Add Column Index
|
|
42
|
+
* | 5 | 10 | 15 | -> Table with Positions
|
|
43
|
+
* | 20 | 25 | 30 |
|
|
44
|
+
* 0 1 2 x -> Remove Column Index
|
|
45
|
+
*
|
|
46
|
+
*/
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
export class AddColumnStep extends Step {
|
|
50
|
+
constructor(tablePos, addColumnStepInfo, isDelete = false) {
|
|
51
|
+
super();
|
|
52
|
+
this.tablePos = tablePos;
|
|
53
|
+
this.isDelete = isDelete;
|
|
54
|
+
this.sideEffectsHandler = new SideEffectsHandler(addColumnStepInfo.sideEffects);
|
|
55
|
+
this.columnInfo = createColumnInfo(addColumnStepInfo.cells);
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Detect the column based on all the cells step in column info.
|
|
59
|
+
* Recreate columnInfo based on the current document. We might need to add new cells added by insert row or unmerge cells.
|
|
60
|
+
* If isDelete
|
|
61
|
+
* Decrease colspan if one row has merged cell
|
|
62
|
+
* Remove all the cells using columnInfo.cellStep[].from
|
|
63
|
+
* else
|
|
64
|
+
* Increase colspan if one row had merged cell
|
|
65
|
+
* Add all new cells at columnInfo.cellStep[].from,
|
|
66
|
+
* if there is columnInfo.cellStep[].newCell use it
|
|
67
|
+
* else create an empty cell
|
|
68
|
+
*
|
|
69
|
+
* @param doc Current document
|
|
70
|
+
*/
|
|
71
|
+
|
|
72
|
+
|
|
73
|
+
apply(doc) {
|
|
74
|
+
const {
|
|
75
|
+
tablePos
|
|
76
|
+
} = this; // Create transform base on the doc
|
|
77
|
+
|
|
78
|
+
const tr = new Transform(doc);
|
|
79
|
+
|
|
80
|
+
if (this.sideEffectsHandler.table.handleAddTable(tr, this.isDelete)) {
|
|
81
|
+
return StepResult.ok(tr.doc);
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
let tableRect;
|
|
85
|
+
|
|
86
|
+
try {
|
|
87
|
+
tableRect = getTableRectFromDoc(doc, tablePos);
|
|
88
|
+
} catch (e) {
|
|
89
|
+
return StepResult.fail(e.message);
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
const column = findColumn(this.columnInfo, tableRect);
|
|
93
|
+
|
|
94
|
+
if (column === null) {
|
|
95
|
+
return StepResult.fail(`No column for this cells "${printColumnInfo(this.columnInfo)}" in table at position "${tablePos}".`);
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
if (this.sideEffectsHandler.table.handleRemoveTable(tr, this.tablePos, tableRect, column, this.isDelete)) {
|
|
99
|
+
return StepResult.ok(tr.doc);
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
this.columnInfo = this.applyCellSteps(tr, tableRect, column, this.isDelete); // Return the document modified.
|
|
103
|
+
|
|
104
|
+
return StepResult.ok(tr.doc);
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Update tablePos with the new position. If tablePos doesnt exist any more remove the step
|
|
108
|
+
* Update all the cellStep inside columnInfo. If cellStep.from position gets deleted removed it from column info
|
|
109
|
+
* if cellStep.length === 0 remove the step
|
|
110
|
+
* Create a new step with all the position updated
|
|
111
|
+
* @param mapping
|
|
112
|
+
*/
|
|
113
|
+
|
|
114
|
+
|
|
115
|
+
map(mapping) {
|
|
116
|
+
const tablePosResult = mapping.mapResult(this.tablePos);
|
|
117
|
+
|
|
118
|
+
if (tablePosResult.deleted) {
|
|
119
|
+
// If table was deleted remove the step
|
|
120
|
+
return null;
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
const cellSteps = [];
|
|
124
|
+
|
|
125
|
+
for (const oldCellStep of this.columnInfo.values()) {
|
|
126
|
+
const fromResult = mapping.mapResult(oldCellStep.from);
|
|
127
|
+
const toResult = mapping.mapResult(oldCellStep.to);
|
|
128
|
+
|
|
129
|
+
if (fromResult.deleted && toResult.deleted) {
|
|
130
|
+
continue;
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
const cellStep = { ...oldCellStep,
|
|
134
|
+
from: fromResult.pos,
|
|
135
|
+
to: toResult.pos
|
|
136
|
+
};
|
|
137
|
+
|
|
138
|
+
if (oldCellStep.mergeWith !== undefined) {
|
|
139
|
+
cellStep.mergeWith = mapping.map(oldCellStep.mergeWith);
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
cellSteps.push(cellStep);
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
if (cellSteps.length === 0) {
|
|
146
|
+
return null;
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
const sideEffects = this.sideEffectsHandler.map(mapping);
|
|
150
|
+
return new AddColumnStep(tablePosResult.pos, {
|
|
151
|
+
cells: cellSteps,
|
|
152
|
+
sideEffects
|
|
153
|
+
}, this.isDelete);
|
|
154
|
+
}
|
|
155
|
+
/**
|
|
156
|
+
* if isDelete
|
|
157
|
+
* Get the original cell node at columnInfo.cellStep[].from to columnInfo.cellStep[].to
|
|
158
|
+
* Create a copy of the node
|
|
159
|
+
* Create a new cellStep with the same positions but with the clone node as a content
|
|
160
|
+
* return new step inverted
|
|
161
|
+
* else
|
|
162
|
+
* Remove the content from each columnInfo.cellStep[].content
|
|
163
|
+
* return new step inverted
|
|
164
|
+
* @param originalDoc
|
|
165
|
+
*/
|
|
166
|
+
|
|
167
|
+
|
|
168
|
+
invert(originalDoc) {
|
|
169
|
+
const stepMap = this.getMap(); // Memoize function to be called only on delete scenarios
|
|
170
|
+
|
|
171
|
+
const getTableRectAndColumn = getTableRectAndColumnFactory(originalDoc, this.tablePos, this.columnInfo); // This is needed because the real pos of the cell in the generated document is affected by the previous operations.
|
|
172
|
+
|
|
173
|
+
const newCellSteps = Array.from(this.columnInfo.values(), oldCellStep => {
|
|
174
|
+
const newCellStep = invertCellStep(originalDoc, getTableRectAndColumn, oldCellStep, this.isDelete, stepMap);
|
|
175
|
+
return newCellStep;
|
|
176
|
+
});
|
|
177
|
+
const sideEffects = this.sideEffectsHandler.invert(originalDoc, this.isDelete, stepMap);
|
|
178
|
+
return new AddColumnStep(this.tablePos, {
|
|
179
|
+
cells: newCellSteps,
|
|
180
|
+
sideEffects
|
|
181
|
+
}, !this.isDelete);
|
|
182
|
+
}
|
|
183
|
+
/**
|
|
184
|
+
* StepMap is created based on columnInfo.
|
|
185
|
+
* ColumnInfo is created on constructor and once is applied (the document could have new cells that weren't part of the original set)
|
|
186
|
+
* if isDelete
|
|
187
|
+
* Create range array based on cell info where each range is [cellStep.from, cellStep.from - cellStep.to, 0]
|
|
188
|
+
* else
|
|
189
|
+
* Create range array base on cell info where each range is [cellStep.from, 0, cellStep.content ? cellStep.content.nodeSize : defaultEmptyCellNodeSize]
|
|
190
|
+
*
|
|
191
|
+
* Ranges in ProseMirror are represented by each 3 elements in an array.
|
|
192
|
+
* As [pos, currentSize, newSize, pos2, currentSize2, newSize2] where:
|
|
193
|
+
* pos: Position in the document
|
|
194
|
+
* currentSize: Represent the affected range, this will be pos + currentSize
|
|
195
|
+
* newSize: Represent the new values, pos + newSize
|
|
196
|
+
*/
|
|
197
|
+
|
|
198
|
+
|
|
199
|
+
getMap() {
|
|
200
|
+
const tableMap = this.sideEffectsHandler.getTableMap(this.isDelete);
|
|
201
|
+
|
|
202
|
+
if (tableMap) {
|
|
203
|
+
return tableMap;
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
let ranges = [];
|
|
207
|
+
|
|
208
|
+
for (const cellStep of this.columnInfo.values()) {
|
|
209
|
+
ranges.push(...getMapFromCellStep(cellStep, this.isDelete));
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
ranges = this.sideEffectsHandler.rows.addRowRanges(ranges, this.isDelete); // If no steps, I create am empty stepMap
|
|
213
|
+
|
|
214
|
+
return new StepMap(ranges);
|
|
215
|
+
}
|
|
216
|
+
/**
|
|
217
|
+
* Try to merge this step with another one, to be applied directly
|
|
218
|
+
* after it. Returns the merged step when possible, null if the
|
|
219
|
+
* steps can't be merged.
|
|
220
|
+
*/
|
|
221
|
+
|
|
222
|
+
|
|
223
|
+
merge(other) {
|
|
224
|
+
// We cannot merge add column step at the moment
|
|
225
|
+
return null;
|
|
226
|
+
}
|
|
227
|
+
/**
|
|
228
|
+
* Create a JSON-serializeable representation of this step. When
|
|
229
|
+
* defining this for a custom subclass, make sure the result object
|
|
230
|
+
* includes the step type's [JSON id](#transform.Step^jsonID) under
|
|
231
|
+
* the `stepType` property.
|
|
232
|
+
*/
|
|
233
|
+
|
|
234
|
+
|
|
235
|
+
toJSON() {
|
|
236
|
+
const addColumnStepJson = {
|
|
237
|
+
stepType: ADD_COLUMN_STEP,
|
|
238
|
+
tablePos: this.tablePos,
|
|
239
|
+
cells: Array.from(this.columnInfo.values(), cellStep => {
|
|
240
|
+
const cellStepJson = {
|
|
241
|
+
from: cellStep.from,
|
|
242
|
+
to: cellStep.to
|
|
243
|
+
};
|
|
244
|
+
|
|
245
|
+
if (cellStep.mergeWith !== undefined) {
|
|
246
|
+
cellStepJson.mergeWith = cellStep.mergeWith;
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
if (cellStep.newCell !== undefined) {
|
|
250
|
+
cellStepJson.newCell = cellStep.newCell.toJSON();
|
|
251
|
+
}
|
|
252
|
+
|
|
253
|
+
return cellStepJson;
|
|
254
|
+
}),
|
|
255
|
+
isDelete: this.isDelete
|
|
256
|
+
};
|
|
257
|
+
const sideEffectsJSON = this.sideEffectsHandler.toJSON();
|
|
258
|
+
|
|
259
|
+
if (sideEffectsJSON) {
|
|
260
|
+
addColumnStepJson.sideEffects = sideEffectsJSON;
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
return addColumnStepJson;
|
|
264
|
+
}
|
|
265
|
+
/**
|
|
266
|
+
* Deserialize a step from its JSON representation. Will call
|
|
267
|
+
* through to the step class' own implementation of this method.
|
|
268
|
+
*/
|
|
269
|
+
|
|
270
|
+
|
|
271
|
+
static fromJSON(schema, json) {
|
|
272
|
+
// TODO: Add validation. Return null if it is invalid. Check in review if this is necessary
|
|
273
|
+
const cells = json.cells.map(cellsJson => {
|
|
274
|
+
const cell = { ...cellsJson,
|
|
275
|
+
newCell: cellsJson.newCell ? schema.nodeFromJSON(cellsJson.newCell) : undefined
|
|
276
|
+
};
|
|
277
|
+
return cell;
|
|
278
|
+
});
|
|
279
|
+
let sideEffects;
|
|
280
|
+
|
|
281
|
+
if (json.sideEffects) {
|
|
282
|
+
sideEffects = SideEffectsHandler.fromJSON(schema, json.sideEffects);
|
|
283
|
+
}
|
|
284
|
+
|
|
285
|
+
return new AddColumnStep(json.tablePos, {
|
|
286
|
+
cells,
|
|
287
|
+
sideEffects
|
|
288
|
+
}, json.isDelete);
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
static create(doc, tablePos, column, isDelete = false) {
|
|
292
|
+
const tableRect = getTableRectFromDoc(doc, tablePos); // By default add column will rely on default behaviour (add empty cell).
|
|
293
|
+
// There is no need to add content
|
|
294
|
+
|
|
295
|
+
const cells = [];
|
|
296
|
+
const iter = cellsAtColumn(tableRect, column);
|
|
297
|
+
let next = iter.next();
|
|
298
|
+
|
|
299
|
+
while (!next.done) {
|
|
300
|
+
const cell = next.value;
|
|
301
|
+
cells.push(createCellStep(cell, column, isDelete));
|
|
302
|
+
let skipRows = 0;
|
|
303
|
+
|
|
304
|
+
if (cell.attrs && cell.attrs.rowspan) {
|
|
305
|
+
skipRows = cell.attrs.rowspan - 1;
|
|
306
|
+
}
|
|
307
|
+
|
|
308
|
+
next = iter.next(skipRows);
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
return new AddColumnStep(tablePos, {
|
|
312
|
+
cells
|
|
313
|
+
}, isDelete);
|
|
314
|
+
}
|
|
315
|
+
|
|
316
|
+
applyCellSteps(tr, tableRect, column, isDelete) {
|
|
317
|
+
const newColumnInfo = new Map();
|
|
318
|
+
const rowsHandler = this.sideEffectsHandler.rows.start(this.isDelete);
|
|
319
|
+
const iter = cellsAtColumn(tableRect, column);
|
|
320
|
+
let next = iter.next(); // Iterate for all the cells in the current document
|
|
321
|
+
|
|
322
|
+
while (!next.done) {
|
|
323
|
+
const cell = next.value;
|
|
324
|
+
const previousCellStep = this.columnInfo.get(cell.from);
|
|
325
|
+
const newCellStep = createCellStep(cell, column, isDelete, previousCellStep); // If is the last cell in the row and doesnt have colspan I need to remove the whole row.
|
|
326
|
+
|
|
327
|
+
const removeRowResult = rowsHandler.handle(tr, tableRect, cell.row, column, cell);
|
|
328
|
+
|
|
329
|
+
if (removeRowResult.handled) {
|
|
330
|
+
next = iter.next(removeRowResult.skipRows);
|
|
331
|
+
continue;
|
|
332
|
+
} // Apply the step, to the pseudo document, get rows to skip, and the cellstep (might be modified, for example, a merge cell that remove the cell instead)
|
|
333
|
+
|
|
334
|
+
|
|
335
|
+
const {
|
|
336
|
+
skipRows,
|
|
337
|
+
cellStep
|
|
338
|
+
} = applyCellStep(tr, tableRect, cell, newCellStep, isDelete, column); // Store the new cell step. This could be an existing one or a new cell.
|
|
339
|
+
|
|
340
|
+
newColumnInfo.set(newCellStep.from, cellStep);
|
|
341
|
+
next = iter.next(skipRows);
|
|
342
|
+
}
|
|
343
|
+
|
|
344
|
+
rowsHandler.end(tr, tableRect, column);
|
|
345
|
+
return newColumnInfo;
|
|
346
|
+
}
|
|
347
|
+
|
|
348
|
+
}
|
|
349
|
+
Step.jsonID(ADD_COLUMN_STEP, AddColumnStep);
|