@quadrats/common 0.6.7 → 0.7.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/blockquote/createBlockquote.d.ts +1 -1
- package/blockquote/createBlockquote.js +33 -33
- package/blockquote/index.cjs.js +32 -34
- package/bold/createBold.d.ts +2 -1
- package/bold/createBold.js +6 -4
- package/bold/index.cjs.js +6 -6
- package/divider/createDivider.d.ts +1 -1
- package/divider/createDivider.js +29 -29
- package/divider/index.cjs.js +29 -31
- package/embed/createEmbed.js +40 -40
- package/embed/deserializeEmbedElementToData.js +6 -6
- package/embed/index.cjs.js +54 -56
- package/embed/serializeEmbedCode.js +8 -8
- package/embed/strategies/facebook/index.cjs.js +45 -47
- package/embed/strategies/facebook/index.d.ts +5 -5
- package/embed/strategies/facebook/index.js +45 -45
- package/embed/strategies/instagram/index.cjs.js +29 -31
- package/embed/strategies/instagram/index.d.ts +3 -3
- package/embed/strategies/instagram/index.js +29 -29
- package/embed/strategies/podcast-apple/index.cjs.js +16 -18
- package/embed/strategies/podcast-apple/index.d.ts +4 -4
- package/embed/strategies/podcast-apple/index.js +16 -16
- package/embed/strategies/spotify/index.cjs.js +14 -16
- package/embed/strategies/spotify/index.d.ts +4 -4
- package/embed/strategies/spotify/index.js +14 -14
- package/embed/strategies/twitter/index.cjs.js +41 -43
- package/embed/strategies/twitter/index.d.ts +4 -4
- package/embed/strategies/twitter/index.js +41 -41
- package/embed/strategies/vimeo/index.cjs.js +14 -16
- package/embed/strategies/vimeo/index.d.ts +3 -3
- package/embed/strategies/vimeo/index.js +14 -14
- package/embed/strategies/youtube/index.cjs.js +14 -16
- package/embed/strategies/youtube/index.d.ts +3 -3
- package/embed/strategies/youtube/index.js +14 -14
- package/embed/typings.d.ts +1 -1
- package/file-uploader/_virtual/_tslib.js +3 -1
- package/file-uploader/createFileUploader.js +76 -76
- package/file-uploader/getFilesFromInput.js +24 -24
- package/file-uploader/index.cjs.js +102 -102
- package/file-uploader/typings.d.ts +6 -6
- package/footnote/createFootnote.d.ts +1 -1
- package/footnote/createFootnote.js +65 -65
- package/footnote/index.cjs.js +65 -67
- package/footnote/typings.d.ts +1 -1
- package/heading/constants.js +1 -1
- package/heading/createHeading.d.ts +1 -1
- package/heading/createHeading.js +45 -45
- package/heading/index.cjs.js +46 -48
- package/heading/typings.d.ts +1 -1
- package/highlight/createHighlight.d.ts +2 -1
- package/highlight/createHighlight.js +6 -4
- package/highlight/index.cjs.js +6 -6
- package/image/constants.js +4 -4
- package/image/createImage.js +195 -195
- package/image/getImageElementCommonProps.js +6 -6
- package/image/getImageFigureElementCommonProps.js +5 -5
- package/image/index.cjs.js +211 -213
- package/image/isHostingNotRequired.js +2 -2
- package/image/typings.d.ts +8 -8
- package/input-block/createInputBlock.js +37 -37
- package/input-block/index.cjs.js +37 -39
- package/input-widget/typings.d.ts +1 -1
- package/italic/createItalic.d.ts +2 -1
- package/italic/createItalic.js +6 -4
- package/italic/index.cjs.js +6 -6
- package/link/createLink.js +147 -147
- package/link/index.cjs.js +146 -148
- package/link/typings.d.ts +2 -2
- package/list/constants.js +4 -4
- package/list/createList.js +185 -185
- package/list/index.cjs.js +188 -190
- package/list/typings.d.ts +4 -4
- package/package.json +4 -4
- package/read-more/createReadMore.d.ts +1 -1
- package/read-more/createReadMore.js +51 -51
- package/read-more/index.cjs.js +50 -52
- package/strikethrough/createStrikethrough.d.ts +2 -1
- package/strikethrough/createStrikethrough.js +6 -4
- package/strikethrough/index.cjs.js +6 -6
- package/toggle-mark/createToggleMarkCreator.d.ts +4 -4
- package/toggle-mark/createToggleMarkCreator.js +36 -36
- package/toggle-mark/index.cjs.js +36 -38
- package/underline/createUnderline.d.ts +2 -1
- package/underline/createUnderline.js +6 -4
- package/underline/index.cjs.js +6 -6
package/heading/createHeading.js
CHANGED
|
@@ -1,51 +1,51 @@
|
|
|
1
1
|
import { Element, Transforms, PARAGRAPH_TYPE, normalizeOnlyInlineOrTextInChildren, getNodes } from '@quadrats/core';
|
|
2
2
|
import { HEADING_TYPE, HEADING_LEVELS } from './constants.js';
|
|
3
3
|
|
|
4
|
-
function createHeading({ type = HEADING_TYPE, enabledLevels = HEADING_LEVELS, } = {}) {
|
|
5
|
-
const getHeadingNodes = (editor, level, options = {}) => getNodes(editor, Object.assign(Object.assign({}, options), { match: node => node.type === type && node.level === level }));
|
|
6
|
-
const isSelectionInHeading = (editor, level, options = {}) => {
|
|
7
|
-
const [match] = getHeadingNodes(editor, level, options);
|
|
8
|
-
return !!match;
|
|
9
|
-
};
|
|
10
|
-
const toggleHeadingNodes = (editor, level, defaultType = PARAGRAPH_TYPE) => {
|
|
11
|
-
if (enabledLevels.includes(level)) {
|
|
12
|
-
const isActive = isSelectionInHeading(editor, level);
|
|
13
|
-
const defaultNode = { type: defaultType };
|
|
14
|
-
const heading = { type, level, children: [] };
|
|
15
|
-
const node = isActive ? defaultNode : heading;
|
|
16
|
-
Transforms.setNodes(editor, node);
|
|
17
|
-
}
|
|
18
|
-
else {
|
|
19
|
-
throw new Error(`Only ${enabledLevels} levels are enabled.`);
|
|
20
|
-
}
|
|
21
|
-
};
|
|
22
|
-
return {
|
|
23
|
-
type,
|
|
24
|
-
enabledLevels,
|
|
25
|
-
getHeadingNodes,
|
|
26
|
-
isSelectionInHeading,
|
|
27
|
-
toggleHeadingNodes,
|
|
28
|
-
with(editor) {
|
|
29
|
-
const { normalizeNode } = editor;
|
|
30
|
-
editor.normalizeNode = (entry) => {
|
|
31
|
-
const [node, path] = entry;
|
|
32
|
-
if (Element.isElement(node) && node.type === type) {
|
|
33
|
-
/**
|
|
34
|
-
* Set invalid level elements to default.
|
|
35
|
-
*/
|
|
36
|
-
if (!enabledLevels.includes(node.level)) {
|
|
37
|
-
Transforms.setNodes(editor, { type: PARAGRAPH_TYPE }, { at: path });
|
|
38
|
-
return;
|
|
39
|
-
}
|
|
40
|
-
if (normalizeOnlyInlineOrTextInChildren(editor, entry)) {
|
|
41
|
-
return;
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
normalizeNode(entry);
|
|
45
|
-
};
|
|
46
|
-
return editor;
|
|
47
|
-
},
|
|
48
|
-
};
|
|
4
|
+
function createHeading({ type = HEADING_TYPE, enabledLevels = HEADING_LEVELS, } = {}) {
|
|
5
|
+
const getHeadingNodes = (editor, level, options = {}) => getNodes(editor, Object.assign(Object.assign({}, options), { match: node => node.type === type && node.level === level }));
|
|
6
|
+
const isSelectionInHeading = (editor, level, options = {}) => {
|
|
7
|
+
const [match] = getHeadingNodes(editor, level, options);
|
|
8
|
+
return !!match;
|
|
9
|
+
};
|
|
10
|
+
const toggleHeadingNodes = (editor, level, defaultType = PARAGRAPH_TYPE) => {
|
|
11
|
+
if (enabledLevels.includes(level)) {
|
|
12
|
+
const isActive = isSelectionInHeading(editor, level);
|
|
13
|
+
const defaultNode = { type: defaultType };
|
|
14
|
+
const heading = { type, level, children: [] };
|
|
15
|
+
const node = isActive ? defaultNode : heading;
|
|
16
|
+
Transforms.setNodes(editor, node);
|
|
17
|
+
}
|
|
18
|
+
else {
|
|
19
|
+
throw new Error(`Only ${enabledLevels} levels are enabled.`);
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
return {
|
|
23
|
+
type,
|
|
24
|
+
enabledLevels,
|
|
25
|
+
getHeadingNodes,
|
|
26
|
+
isSelectionInHeading,
|
|
27
|
+
toggleHeadingNodes,
|
|
28
|
+
with(editor) {
|
|
29
|
+
const { normalizeNode } = editor;
|
|
30
|
+
editor.normalizeNode = (entry) => {
|
|
31
|
+
const [node, path] = entry;
|
|
32
|
+
if (Element.isElement(node) && node.type === type) {
|
|
33
|
+
/**
|
|
34
|
+
* Set invalid level elements to default.
|
|
35
|
+
*/
|
|
36
|
+
if (!enabledLevels.includes(node.level)) {
|
|
37
|
+
Transforms.setNodes(editor, { type: PARAGRAPH_TYPE }, { at: path });
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
if (normalizeOnlyInlineOrTextInChildren(editor, entry)) {
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
normalizeNode(entry);
|
|
45
|
+
};
|
|
46
|
+
return editor;
|
|
47
|
+
},
|
|
48
|
+
};
|
|
49
49
|
}
|
|
50
50
|
|
|
51
51
|
export { createHeading };
|
package/heading/index.cjs.js
CHANGED
|
@@ -1,57 +1,55 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
3
|
var core = require('@quadrats/core');
|
|
6
4
|
|
|
7
|
-
const HEADING_TYPE = 'heading';
|
|
5
|
+
const HEADING_TYPE = 'heading';
|
|
8
6
|
const HEADING_LEVELS = [1, 2, 3, 4, 5, 6];
|
|
9
7
|
|
|
10
|
-
function createHeading({ type = HEADING_TYPE, enabledLevels = HEADING_LEVELS, } = {}) {
|
|
11
|
-
const getHeadingNodes = (editor, level, options = {}) => core.getNodes(editor, Object.assign(Object.assign({}, options), { match: node => node.type === type && node.level === level }));
|
|
12
|
-
const isSelectionInHeading = (editor, level, options = {}) => {
|
|
13
|
-
const [match] = getHeadingNodes(editor, level, options);
|
|
14
|
-
return !!match;
|
|
15
|
-
};
|
|
16
|
-
const toggleHeadingNodes = (editor, level, defaultType = core.PARAGRAPH_TYPE) => {
|
|
17
|
-
if (enabledLevels.includes(level)) {
|
|
18
|
-
const isActive = isSelectionInHeading(editor, level);
|
|
19
|
-
const defaultNode = { type: defaultType };
|
|
20
|
-
const heading = { type, level, children: [] };
|
|
21
|
-
const node = isActive ? defaultNode : heading;
|
|
22
|
-
core.Transforms.setNodes(editor, node);
|
|
23
|
-
}
|
|
24
|
-
else {
|
|
25
|
-
throw new Error(`Only ${enabledLevels} levels are enabled.`);
|
|
26
|
-
}
|
|
27
|
-
};
|
|
28
|
-
return {
|
|
29
|
-
type,
|
|
30
|
-
enabledLevels,
|
|
31
|
-
getHeadingNodes,
|
|
32
|
-
isSelectionInHeading,
|
|
33
|
-
toggleHeadingNodes,
|
|
34
|
-
with(editor) {
|
|
35
|
-
const { normalizeNode } = editor;
|
|
36
|
-
editor.normalizeNode = (entry) => {
|
|
37
|
-
const [node, path] = entry;
|
|
38
|
-
if (core.Element.isElement(node) && node.type === type) {
|
|
39
|
-
/**
|
|
40
|
-
* Set invalid level elements to default.
|
|
41
|
-
*/
|
|
42
|
-
if (!enabledLevels.includes(node.level)) {
|
|
43
|
-
core.Transforms.setNodes(editor, { type: core.PARAGRAPH_TYPE }, { at: path });
|
|
44
|
-
return;
|
|
45
|
-
}
|
|
46
|
-
if (core.normalizeOnlyInlineOrTextInChildren(editor, entry)) {
|
|
47
|
-
return;
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
normalizeNode(entry);
|
|
51
|
-
};
|
|
52
|
-
return editor;
|
|
53
|
-
},
|
|
54
|
-
};
|
|
8
|
+
function createHeading({ type = HEADING_TYPE, enabledLevels = HEADING_LEVELS, } = {}) {
|
|
9
|
+
const getHeadingNodes = (editor, level, options = {}) => core.getNodes(editor, Object.assign(Object.assign({}, options), { match: node => node.type === type && node.level === level }));
|
|
10
|
+
const isSelectionInHeading = (editor, level, options = {}) => {
|
|
11
|
+
const [match] = getHeadingNodes(editor, level, options);
|
|
12
|
+
return !!match;
|
|
13
|
+
};
|
|
14
|
+
const toggleHeadingNodes = (editor, level, defaultType = core.PARAGRAPH_TYPE) => {
|
|
15
|
+
if (enabledLevels.includes(level)) {
|
|
16
|
+
const isActive = isSelectionInHeading(editor, level);
|
|
17
|
+
const defaultNode = { type: defaultType };
|
|
18
|
+
const heading = { type, level, children: [] };
|
|
19
|
+
const node = isActive ? defaultNode : heading;
|
|
20
|
+
core.Transforms.setNodes(editor, node);
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
throw new Error(`Only ${enabledLevels} levels are enabled.`);
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
return {
|
|
27
|
+
type,
|
|
28
|
+
enabledLevels,
|
|
29
|
+
getHeadingNodes,
|
|
30
|
+
isSelectionInHeading,
|
|
31
|
+
toggleHeadingNodes,
|
|
32
|
+
with(editor) {
|
|
33
|
+
const { normalizeNode } = editor;
|
|
34
|
+
editor.normalizeNode = (entry) => {
|
|
35
|
+
const [node, path] = entry;
|
|
36
|
+
if (core.Element.isElement(node) && node.type === type) {
|
|
37
|
+
/**
|
|
38
|
+
* Set invalid level elements to default.
|
|
39
|
+
*/
|
|
40
|
+
if (!enabledLevels.includes(node.level)) {
|
|
41
|
+
core.Transforms.setNodes(editor, { type: core.PARAGRAPH_TYPE }, { at: path });
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
if (core.normalizeOnlyInlineOrTextInChildren(editor, entry)) {
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
normalizeNode(entry);
|
|
49
|
+
};
|
|
50
|
+
return editor;
|
|
51
|
+
},
|
|
52
|
+
};
|
|
55
53
|
}
|
|
56
54
|
|
|
57
55
|
exports.HEADING_LEVELS = HEADING_LEVELS;
|
package/heading/typings.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Editor, QuadratsElement, GetNodesOptions, Node, NodeEntry, Withable, WithElementType } from '@quadrats/core';
|
|
2
|
-
export
|
|
2
|
+
export type HeadingLevel = 1 | 2 | 3 | 4 | 5 | 6;
|
|
3
3
|
export interface HeadingElement extends QuadratsElement, WithElementType {
|
|
4
4
|
level: HeadingLevel;
|
|
5
5
|
}
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
import { Editor } from '@quadrats/core';
|
|
2
|
+
export declare function createHighlight<E extends Editor = Editor>(variant?: string): ({ type, variant }?: import("@quadrats/common/toggle-mark").CreateToggleMarkOptions | undefined) => import("@quadrats/common/toggle-mark").ToggleMark<E>;
|
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
import { createToggleMarkCreator } from '@quadrats/common/toggle-mark';
|
|
2
2
|
import { HIGHLIGHT_TYPE } from './constants.js';
|
|
3
3
|
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
4
|
+
function createHighlight(variant) {
|
|
5
|
+
return createToggleMarkCreator({
|
|
6
|
+
type: HIGHLIGHT_TYPE,
|
|
7
|
+
variant,
|
|
8
|
+
});
|
|
9
|
+
}
|
|
8
10
|
|
|
9
11
|
export { createHighlight };
|
package/highlight/index.cjs.js
CHANGED
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
3
|
var toggleMark = require('@quadrats/common/toggle-mark');
|
|
6
4
|
|
|
7
5
|
const HIGHLIGHT_TYPE = 'highlight';
|
|
8
6
|
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
7
|
+
function createHighlight(variant) {
|
|
8
|
+
return toggleMark.createToggleMarkCreator({
|
|
9
|
+
type: HIGHLIGHT_TYPE,
|
|
10
|
+
variant,
|
|
11
|
+
});
|
|
12
|
+
}
|
|
13
13
|
|
|
14
14
|
exports.HIGHLIGHT_TYPE = HIGHLIGHT_TYPE;
|
|
15
15
|
exports.createHighlight = createHighlight;
|
package/image/constants.js
CHANGED