@atlaskit/editor-common 86.1.0 → 86.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 +14 -0
- package/dist/cjs/monitoring/error.js +1 -1
- package/dist/cjs/ui/DropList/index.js +1 -1
- package/dist/cjs/ui/WidthProvider/index.js +18 -2
- package/dist/cjs/utils/index.js +7 -0
- package/dist/cjs/utils/page-element-counts.js +44 -0
- package/dist/es2019/monitoring/error.js +1 -1
- package/dist/es2019/ui/DropList/index.js +1 -1
- package/dist/es2019/ui/WidthProvider/index.js +18 -2
- package/dist/es2019/utils/index.js +2 -1
- package/dist/es2019/utils/page-element-counts.js +38 -0
- package/dist/esm/monitoring/error.js +1 -1
- package/dist/esm/ui/DropList/index.js +1 -1
- package/dist/esm/ui/WidthProvider/index.js +18 -2
- package/dist/esm/utils/index.js +2 -1
- package/dist/esm/utils/page-element-counts.js +38 -0
- package/dist/types/utils/index.d.ts +1 -0
- package/dist/types/utils/page-element-counts.d.ts +17 -0
- package/dist/types-ts4.5/utils/index.d.ts +1 -0
- package/dist/types-ts4.5/utils/page-element-counts.d.ts +17 -0
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,19 @@
|
|
|
1
1
|
# @atlaskit/editor-common
|
|
2
2
|
|
|
3
|
+
## 86.2.0
|
|
4
|
+
|
|
5
|
+
### Minor Changes
|
|
6
|
+
|
|
7
|
+
- [`ca831efa17dd5`](https://stash.atlassian.com/projects/CONFCLOUD/repos/confluence-frontend/commits/ca831efa17dd5) -
|
|
8
|
+
[ED-23922] Added utility to count the number of unique elements, text formats, macros and layouts
|
|
9
|
+
in a JSONDocNode or JSONNode
|
|
10
|
+
|
|
11
|
+
### Patch Changes
|
|
12
|
+
|
|
13
|
+
- [#121046](https://stash.atlassian.com/projects/CONFCLOUD/repos/confluence-frontend/pull-requests/121046)
|
|
14
|
+
[`c5cbf1d63b0c8`](https://stash.atlassian.com/projects/CONFCLOUD/repos/confluence-frontend/commits/c5cbf1d63b0c8) -
|
|
15
|
+
[ED-24241] Memonize the document.body to avoid multiple Layout Reflows for the same page
|
|
16
|
+
|
|
3
17
|
## 86.1.0
|
|
4
18
|
|
|
5
19
|
### Minor Changes
|
|
@@ -17,7 +17,7 @@ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return
|
|
|
17
17
|
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
18
18
|
var SENTRY_DSN = 'https://0b10c8e02fb44d8796c047b102c9bee8@o55978.ingest.sentry.io/4505129224110080';
|
|
19
19
|
var packageName = 'editor-common'; // Sentry doesn't accept '/' in its releases https://docs.sentry.io/platforms/javascript/configuration/releases/
|
|
20
|
-
var packageVersion = "86.
|
|
20
|
+
var packageVersion = "86.2.0";
|
|
21
21
|
var sanitiseSentryEvents = function sanitiseSentryEvents(data, _hint) {
|
|
22
22
|
// Remove URL as it has UGC
|
|
23
23
|
// TODO: Sanitise the URL instead of just removing it
|
|
@@ -20,7 +20,7 @@ var _Layer = _interopRequireDefault(require("../Layer"));
|
|
|
20
20
|
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2.default)(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2.default)(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2.default)(this, result); }; }
|
|
21
21
|
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } /** @jsx jsx */ // eslint-disable-next-line @atlaskit/ui-styling-standard/use-compiled -- Ignored via go/DSP-18766
|
|
22
22
|
var packageName = "@atlaskit/editor-common";
|
|
23
|
-
var packageVersion = "86.
|
|
23
|
+
var packageVersion = "86.2.0";
|
|
24
24
|
var halfFocusRing = 1;
|
|
25
25
|
var dropOffset = '0, 8';
|
|
26
26
|
var DropList = /*#__PURE__*/function (_Component) {
|
|
@@ -11,6 +11,7 @@ exports.getBreakpoint = getBreakpoint;
|
|
|
11
11
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
12
12
|
var _react = _interopRequireWildcard(require("react"));
|
|
13
13
|
var _react2 = require("@emotion/react");
|
|
14
|
+
var _memoizeOne = _interopRequireDefault(require("memoize-one"));
|
|
14
15
|
var _rafSchd = _interopRequireDefault(require("raf-schd"));
|
|
15
16
|
var _widthDetector = require("@atlaskit/width-detector");
|
|
16
17
|
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
@@ -45,13 +46,28 @@ function createWidthContext() {
|
|
|
45
46
|
var WidthContext = exports.WidthContext = /*#__PURE__*/_react.default.createContext(createWidthContext());
|
|
46
47
|
var Provider = WidthContext.Provider,
|
|
47
48
|
Consumer = exports.WidthConsumer = WidthContext.Consumer;
|
|
48
|
-
|
|
49
|
+
/**
|
|
50
|
+
* 🧱 Internal function: Editor FE Platform
|
|
51
|
+
*
|
|
52
|
+
* Returns the width of the document body.
|
|
53
|
+
*
|
|
54
|
+
* This function is memoized to avoid forcing a layout reflow multiple times.
|
|
55
|
+
* It uses `document.body.offsetWidth` as the source of the width, which can lead to
|
|
56
|
+
* a layout reflow if accessed repeatedly. To mitigate performance issues, the result
|
|
57
|
+
* is cached using `memoizeOne`.
|
|
58
|
+
*
|
|
59
|
+
* @returns {number} The width of the document body or 0 if the document is undefined.
|
|
60
|
+
*/
|
|
61
|
+
var getBodyWidth = (0, _memoizeOne.default)(function () {
|
|
49
62
|
var _document$body$offset, _document$body;
|
|
63
|
+
return typeof document !== 'undefined' ? (_document$body$offset = (_document$body = document.body) === null || _document$body === void 0 ? void 0 : _document$body.offsetWidth) !== null && _document$body$offset !== void 0 ? _document$body$offset : 0 : 0;
|
|
64
|
+
});
|
|
65
|
+
var WidthProvider = exports.WidthProvider = function WidthProvider(_ref) {
|
|
50
66
|
var className = _ref.className,
|
|
51
67
|
shouldCheckExistingValue = _ref.shouldCheckExistingValue,
|
|
52
68
|
children = _ref.children;
|
|
53
69
|
var existingContextValue = _react.default.useContext(WidthContext);
|
|
54
|
-
var _React$useState = _react.default.useState(
|
|
70
|
+
var _React$useState = _react.default.useState(getBodyWidth),
|
|
55
71
|
_React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
|
|
56
72
|
width = _React$useState2[0],
|
|
57
73
|
setWidth = _React$useState2[1];
|
package/dist/cjs/utils/index.js
CHANGED
|
@@ -492,6 +492,12 @@ Object.defineProperty(exports, "getOrderFromOrderedListNode", {
|
|
|
492
492
|
return _list.getOrderFromOrderedListNode;
|
|
493
493
|
}
|
|
494
494
|
});
|
|
495
|
+
Object.defineProperty(exports, "getPageElementCounts", {
|
|
496
|
+
enumerable: true,
|
|
497
|
+
get: function get() {
|
|
498
|
+
return _pageElementCounts.getPageElementCounts;
|
|
499
|
+
}
|
|
500
|
+
});
|
|
495
501
|
Object.defineProperty(exports, "getPerformanceOptions", {
|
|
496
502
|
enumerable: true,
|
|
497
503
|
get: function get() {
|
|
@@ -1181,6 +1187,7 @@ var _insertNodeIntoOrderedList = require("./insert-node-into-ordered-list");
|
|
|
1181
1187
|
var _wrapSelectionIn = require("./wrap-selection-in");
|
|
1182
1188
|
var _calculateToolbarPosition = require("./calculate-toolbar-position");
|
|
1183
1189
|
var _nodesByLocalIds = require("./nodes-by-localIds");
|
|
1190
|
+
var _pageElementCounts = require("./page-element-counts");
|
|
1184
1191
|
/**
|
|
1185
1192
|
* @deprecated - [ED-23844] moving to own entry point @atlaskit/editor-common/whitespace
|
|
1186
1193
|
*/
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.getPageElementCounts = void 0;
|
|
7
|
+
var _traverse = require("@atlaskit/adf-utils/traverse");
|
|
8
|
+
/**
|
|
9
|
+
* Traverses a JSON document and counts the number of unique elements, text formatting and macros.
|
|
10
|
+
*
|
|
11
|
+
**/
|
|
12
|
+
var getPageElementCounts = exports.getPageElementCounts = function getPageElementCounts(doc) {
|
|
13
|
+
var pageElementCounts = {
|
|
14
|
+
elements: {},
|
|
15
|
+
textFormats: {},
|
|
16
|
+
macros: {}
|
|
17
|
+
};
|
|
18
|
+
(0, _traverse.reduce)(doc, function (acc, node) {
|
|
19
|
+
if (node.type === 'text') {
|
|
20
|
+
var _acc$elements$node$ty;
|
|
21
|
+
if (node.marks) {
|
|
22
|
+
node.marks.forEach(function (mark) {
|
|
23
|
+
var _acc$textFormats$mark;
|
|
24
|
+
var markType = mark.type;
|
|
25
|
+
acc.textFormats[markType] = ((_acc$textFormats$mark = acc.textFormats[markType]) !== null && _acc$textFormats$mark !== void 0 ? _acc$textFormats$mark : 0) + 1;
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
acc.elements[node.type] = ((_acc$elements$node$ty = acc.elements[node.type]) !== null && _acc$elements$node$ty !== void 0 ? _acc$elements$node$ty : 0) + 1;
|
|
29
|
+
}
|
|
30
|
+
// If the node is a 'macro'or extension
|
|
31
|
+
else if (node.type === 'extension' || node.type === 'inlineExtension' || node.type === 'bodiedExtension' || node.type === 'multiBodiedExtension' || node.type === 'extensionFrame') {
|
|
32
|
+
if ('attrs' in node && node.attrs && 'extensionKey' in node.attrs && node.attrs.extensionKey) {
|
|
33
|
+
var _acc$macros$extension;
|
|
34
|
+
var extensionKey = node.attrs.extensionKey;
|
|
35
|
+
acc.macros[extensionKey] = ((_acc$macros$extension = acc.macros[extensionKey]) !== null && _acc$macros$extension !== void 0 ? _acc$macros$extension : 0) + 1;
|
|
36
|
+
}
|
|
37
|
+
} else {
|
|
38
|
+
var _acc$elements$node$ty2;
|
|
39
|
+
acc.elements[node.type] = ((_acc$elements$node$ty2 = acc.elements[node.type]) !== null && _acc$elements$node$ty2 !== void 0 ? _acc$elements$node$ty2 : 0) + 1;
|
|
40
|
+
}
|
|
41
|
+
return acc;
|
|
42
|
+
}, pageElementCounts);
|
|
43
|
+
return pageElementCounts;
|
|
44
|
+
};
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { isFedRamp } from './environment';
|
|
2
2
|
const SENTRY_DSN = 'https://0b10c8e02fb44d8796c047b102c9bee8@o55978.ingest.sentry.io/4505129224110080';
|
|
3
3
|
const packageName = 'editor-common'; // Sentry doesn't accept '/' in its releases https://docs.sentry.io/platforms/javascript/configuration/releases/
|
|
4
|
-
const packageVersion = "86.
|
|
4
|
+
const packageVersion = "86.2.0";
|
|
5
5
|
const sanitiseSentryEvents = (data, _hint) => {
|
|
6
6
|
// Remove URL as it has UGC
|
|
7
7
|
// TODO: Sanitise the URL instead of just removing it
|
|
@@ -9,7 +9,7 @@ import { createAndFireEvent, withAnalyticsContext, withAnalyticsEvents } from '@
|
|
|
9
9
|
import { N0, N50A, N60A, N900 } from '@atlaskit/theme/colors';
|
|
10
10
|
import Layer from '../Layer';
|
|
11
11
|
const packageName = "@atlaskit/editor-common";
|
|
12
|
-
const packageVersion = "86.
|
|
12
|
+
const packageVersion = "86.2.0";
|
|
13
13
|
const halfFocusRing = 1;
|
|
14
14
|
const dropOffset = '0, 8';
|
|
15
15
|
class DropList extends Component {
|
|
@@ -3,6 +3,7 @@ import React, { Fragment } from 'react';
|
|
|
3
3
|
|
|
4
4
|
// eslint-disable-next-line @atlaskit/ui-styling-standard/use-compiled -- Ignored via go/DSP-18766
|
|
5
5
|
import { css, jsx } from '@emotion/react';
|
|
6
|
+
import memoizeOne from 'memoize-one';
|
|
6
7
|
import rafSchedule from 'raf-schd';
|
|
7
8
|
import { WidthObserver } from '@atlaskit/width-detector';
|
|
8
9
|
const styles = css({
|
|
@@ -31,14 +32,29 @@ const {
|
|
|
31
32
|
Provider,
|
|
32
33
|
Consumer
|
|
33
34
|
} = WidthContext;
|
|
35
|
+
/**
|
|
36
|
+
* 🧱 Internal function: Editor FE Platform
|
|
37
|
+
*
|
|
38
|
+
* Returns the width of the document body.
|
|
39
|
+
*
|
|
40
|
+
* This function is memoized to avoid forcing a layout reflow multiple times.
|
|
41
|
+
* It uses `document.body.offsetWidth` as the source of the width, which can lead to
|
|
42
|
+
* a layout reflow if accessed repeatedly. To mitigate performance issues, the result
|
|
43
|
+
* is cached using `memoizeOne`.
|
|
44
|
+
*
|
|
45
|
+
* @returns {number} The width of the document body or 0 if the document is undefined.
|
|
46
|
+
*/
|
|
47
|
+
const getBodyWidth = memoizeOne(() => {
|
|
48
|
+
var _document$body$offset, _document$body;
|
|
49
|
+
return typeof document !== 'undefined' ? (_document$body$offset = (_document$body = document.body) === null || _document$body === void 0 ? void 0 : _document$body.offsetWidth) !== null && _document$body$offset !== void 0 ? _document$body$offset : 0 : 0;
|
|
50
|
+
});
|
|
34
51
|
export const WidthProvider = ({
|
|
35
52
|
className,
|
|
36
53
|
shouldCheckExistingValue,
|
|
37
54
|
children
|
|
38
55
|
}) => {
|
|
39
|
-
var _document$body$offset, _document$body;
|
|
40
56
|
const existingContextValue = React.useContext(WidthContext);
|
|
41
|
-
const [width, setWidth] = React.useState(
|
|
57
|
+
const [width, setWidth] = React.useState(getBodyWidth);
|
|
42
58
|
const widthRef = React.useRef(width);
|
|
43
59
|
const isMountedRef = React.useRef(true);
|
|
44
60
|
const providerValue = React.useMemo(() => createWidthContext(width), [width]);
|
|
@@ -221,4 +221,5 @@ export { transformNodeIntoListItem } from './insert-node-into-ordered-list';
|
|
|
221
221
|
export { wrapSelectionIn } from './wrap-selection-in';
|
|
222
222
|
export { toJSON, nodeToJSON } from './nodes';
|
|
223
223
|
export { calculateToolbarPositionAboveSelection, calculateToolbarPositionTrackHead } from './calculate-toolbar-position';
|
|
224
|
-
export { findNodePosByLocalIds } from './nodes-by-localIds';
|
|
224
|
+
export { findNodePosByLocalIds } from './nodes-by-localIds';
|
|
225
|
+
export { getPageElementCounts } from './page-element-counts';
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { reduce } from '@atlaskit/adf-utils/traverse';
|
|
2
|
+
/**
|
|
3
|
+
* Traverses a JSON document and counts the number of unique elements, text formatting and macros.
|
|
4
|
+
*
|
|
5
|
+
**/
|
|
6
|
+
export const getPageElementCounts = doc => {
|
|
7
|
+
const pageElementCounts = {
|
|
8
|
+
elements: {},
|
|
9
|
+
textFormats: {},
|
|
10
|
+
macros: {}
|
|
11
|
+
};
|
|
12
|
+
reduce(doc, (acc, node) => {
|
|
13
|
+
if (node.type === 'text') {
|
|
14
|
+
var _acc$elements$node$ty;
|
|
15
|
+
if (node.marks) {
|
|
16
|
+
node.marks.forEach(mark => {
|
|
17
|
+
var _acc$textFormats$mark;
|
|
18
|
+
const markType = mark.type;
|
|
19
|
+
acc.textFormats[markType] = ((_acc$textFormats$mark = acc.textFormats[markType]) !== null && _acc$textFormats$mark !== void 0 ? _acc$textFormats$mark : 0) + 1;
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
acc.elements[node.type] = ((_acc$elements$node$ty = acc.elements[node.type]) !== null && _acc$elements$node$ty !== void 0 ? _acc$elements$node$ty : 0) + 1;
|
|
23
|
+
}
|
|
24
|
+
// If the node is a 'macro'or extension
|
|
25
|
+
else if (node.type === 'extension' || node.type === 'inlineExtension' || node.type === 'bodiedExtension' || node.type === 'multiBodiedExtension' || node.type === 'extensionFrame') {
|
|
26
|
+
if ('attrs' in node && node.attrs && 'extensionKey' in node.attrs && node.attrs.extensionKey) {
|
|
27
|
+
var _acc$macros$extension;
|
|
28
|
+
const extensionKey = node.attrs.extensionKey;
|
|
29
|
+
acc.macros[extensionKey] = ((_acc$macros$extension = acc.macros[extensionKey]) !== null && _acc$macros$extension !== void 0 ? _acc$macros$extension : 0) + 1;
|
|
30
|
+
}
|
|
31
|
+
} else {
|
|
32
|
+
var _acc$elements$node$ty2;
|
|
33
|
+
acc.elements[node.type] = ((_acc$elements$node$ty2 = acc.elements[node.type]) !== null && _acc$elements$node$ty2 !== void 0 ? _acc$elements$node$ty2 : 0) + 1;
|
|
34
|
+
}
|
|
35
|
+
return acc;
|
|
36
|
+
}, pageElementCounts);
|
|
37
|
+
return pageElementCounts;
|
|
38
|
+
};
|
|
@@ -7,7 +7,7 @@ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t =
|
|
|
7
7
|
import { isFedRamp } from './environment';
|
|
8
8
|
var SENTRY_DSN = 'https://0b10c8e02fb44d8796c047b102c9bee8@o55978.ingest.sentry.io/4505129224110080';
|
|
9
9
|
var packageName = 'editor-common'; // Sentry doesn't accept '/' in its releases https://docs.sentry.io/platforms/javascript/configuration/releases/
|
|
10
|
-
var packageVersion = "86.
|
|
10
|
+
var packageVersion = "86.2.0";
|
|
11
11
|
var sanitiseSentryEvents = function sanitiseSentryEvents(data, _hint) {
|
|
12
12
|
// Remove URL as it has UGC
|
|
13
13
|
// TODO: Sanitise the URL instead of just removing it
|
|
@@ -17,7 +17,7 @@ import { createAndFireEvent, withAnalyticsContext, withAnalyticsEvents } from '@
|
|
|
17
17
|
import { N0, N50A, N60A, N900 } from '@atlaskit/theme/colors';
|
|
18
18
|
import Layer from '../Layer';
|
|
19
19
|
var packageName = "@atlaskit/editor-common";
|
|
20
|
-
var packageVersion = "86.
|
|
20
|
+
var packageVersion = "86.2.0";
|
|
21
21
|
var halfFocusRing = 1;
|
|
22
22
|
var dropOffset = '0, 8';
|
|
23
23
|
var DropList = /*#__PURE__*/function (_Component) {
|
|
@@ -4,6 +4,7 @@ import React, { Fragment } from 'react';
|
|
|
4
4
|
|
|
5
5
|
// eslint-disable-next-line @atlaskit/ui-styling-standard/use-compiled -- Ignored via go/DSP-18766
|
|
6
6
|
import { css, jsx } from '@emotion/react';
|
|
7
|
+
import memoizeOne from 'memoize-one';
|
|
7
8
|
import rafSchedule from 'raf-schd';
|
|
8
9
|
import { WidthObserver } from '@atlaskit/width-detector';
|
|
9
10
|
var styles = css({
|
|
@@ -32,13 +33,28 @@ export function createWidthContext() {
|
|
|
32
33
|
export var WidthContext = /*#__PURE__*/React.createContext(createWidthContext());
|
|
33
34
|
var Provider = WidthContext.Provider,
|
|
34
35
|
Consumer = WidthContext.Consumer;
|
|
35
|
-
|
|
36
|
+
/**
|
|
37
|
+
* 🧱 Internal function: Editor FE Platform
|
|
38
|
+
*
|
|
39
|
+
* Returns the width of the document body.
|
|
40
|
+
*
|
|
41
|
+
* This function is memoized to avoid forcing a layout reflow multiple times.
|
|
42
|
+
* It uses `document.body.offsetWidth` as the source of the width, which can lead to
|
|
43
|
+
* a layout reflow if accessed repeatedly. To mitigate performance issues, the result
|
|
44
|
+
* is cached using `memoizeOne`.
|
|
45
|
+
*
|
|
46
|
+
* @returns {number} The width of the document body or 0 if the document is undefined.
|
|
47
|
+
*/
|
|
48
|
+
var getBodyWidth = memoizeOne(function () {
|
|
36
49
|
var _document$body$offset, _document$body;
|
|
50
|
+
return typeof document !== 'undefined' ? (_document$body$offset = (_document$body = document.body) === null || _document$body === void 0 ? void 0 : _document$body.offsetWidth) !== null && _document$body$offset !== void 0 ? _document$body$offset : 0 : 0;
|
|
51
|
+
});
|
|
52
|
+
export var WidthProvider = function WidthProvider(_ref) {
|
|
37
53
|
var className = _ref.className,
|
|
38
54
|
shouldCheckExistingValue = _ref.shouldCheckExistingValue,
|
|
39
55
|
children = _ref.children;
|
|
40
56
|
var existingContextValue = React.useContext(WidthContext);
|
|
41
|
-
var _React$useState = React.useState(
|
|
57
|
+
var _React$useState = React.useState(getBodyWidth),
|
|
42
58
|
_React$useState2 = _slicedToArray(_React$useState, 2),
|
|
43
59
|
width = _React$useState2[0],
|
|
44
60
|
setWidth = _React$useState2[1];
|
package/dist/esm/utils/index.js
CHANGED
|
@@ -224,4 +224,5 @@ export { transformNodeIntoListItem } from './insert-node-into-ordered-list';
|
|
|
224
224
|
export { wrapSelectionIn } from './wrap-selection-in';
|
|
225
225
|
export { toJSON, nodeToJSON } from './nodes';
|
|
226
226
|
export { calculateToolbarPositionAboveSelection, calculateToolbarPositionTrackHead } from './calculate-toolbar-position';
|
|
227
|
-
export { findNodePosByLocalIds } from './nodes-by-localIds';
|
|
227
|
+
export { findNodePosByLocalIds } from './nodes-by-localIds';
|
|
228
|
+
export { getPageElementCounts } from './page-element-counts';
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { reduce } from '@atlaskit/adf-utils/traverse';
|
|
2
|
+
/**
|
|
3
|
+
* Traverses a JSON document and counts the number of unique elements, text formatting and macros.
|
|
4
|
+
*
|
|
5
|
+
**/
|
|
6
|
+
export var getPageElementCounts = function getPageElementCounts(doc) {
|
|
7
|
+
var pageElementCounts = {
|
|
8
|
+
elements: {},
|
|
9
|
+
textFormats: {},
|
|
10
|
+
macros: {}
|
|
11
|
+
};
|
|
12
|
+
reduce(doc, function (acc, node) {
|
|
13
|
+
if (node.type === 'text') {
|
|
14
|
+
var _acc$elements$node$ty;
|
|
15
|
+
if (node.marks) {
|
|
16
|
+
node.marks.forEach(function (mark) {
|
|
17
|
+
var _acc$textFormats$mark;
|
|
18
|
+
var markType = mark.type;
|
|
19
|
+
acc.textFormats[markType] = ((_acc$textFormats$mark = acc.textFormats[markType]) !== null && _acc$textFormats$mark !== void 0 ? _acc$textFormats$mark : 0) + 1;
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
acc.elements[node.type] = ((_acc$elements$node$ty = acc.elements[node.type]) !== null && _acc$elements$node$ty !== void 0 ? _acc$elements$node$ty : 0) + 1;
|
|
23
|
+
}
|
|
24
|
+
// If the node is a 'macro'or extension
|
|
25
|
+
else if (node.type === 'extension' || node.type === 'inlineExtension' || node.type === 'bodiedExtension' || node.type === 'multiBodiedExtension' || node.type === 'extensionFrame') {
|
|
26
|
+
if ('attrs' in node && node.attrs && 'extensionKey' in node.attrs && node.attrs.extensionKey) {
|
|
27
|
+
var _acc$macros$extension;
|
|
28
|
+
var extensionKey = node.attrs.extensionKey;
|
|
29
|
+
acc.macros[extensionKey] = ((_acc$macros$extension = acc.macros[extensionKey]) !== null && _acc$macros$extension !== void 0 ? _acc$macros$extension : 0) + 1;
|
|
30
|
+
}
|
|
31
|
+
} else {
|
|
32
|
+
var _acc$elements$node$ty2;
|
|
33
|
+
acc.elements[node.type] = ((_acc$elements$node$ty2 = acc.elements[node.type]) !== null && _acc$elements$node$ty2 !== void 0 ? _acc$elements$node$ty2 : 0) + 1;
|
|
34
|
+
}
|
|
35
|
+
return acc;
|
|
36
|
+
}, pageElementCounts);
|
|
37
|
+
return pageElementCounts;
|
|
38
|
+
};
|
|
@@ -91,3 +91,4 @@ export { wrapSelectionIn } from './wrap-selection-in';
|
|
|
91
91
|
export { toJSON, nodeToJSON } from './nodes';
|
|
92
92
|
export { calculateToolbarPositionAboveSelection, calculateToolbarPositionTrackHead, } from './calculate-toolbar-position';
|
|
93
93
|
export { findNodePosByLocalIds } from './nodes-by-localIds';
|
|
94
|
+
export { getPageElementCounts } from './page-element-counts';
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { JSONDocNode } from '@atlaskit/editor-json-transformer';
|
|
2
|
+
export type PageElementCounts = {
|
|
3
|
+
elements: {
|
|
4
|
+
[key: string]: number;
|
|
5
|
+
};
|
|
6
|
+
textFormats: {
|
|
7
|
+
[key: string]: number;
|
|
8
|
+
};
|
|
9
|
+
macros: {
|
|
10
|
+
[key: string]: number;
|
|
11
|
+
};
|
|
12
|
+
};
|
|
13
|
+
/**
|
|
14
|
+
* Traverses a JSON document and counts the number of unique elements, text formatting and macros.
|
|
15
|
+
*
|
|
16
|
+
**/
|
|
17
|
+
export declare const getPageElementCounts: (doc: JSONDocNode) => PageElementCounts;
|
|
@@ -91,3 +91,4 @@ export { wrapSelectionIn } from './wrap-selection-in';
|
|
|
91
91
|
export { toJSON, nodeToJSON } from './nodes';
|
|
92
92
|
export { calculateToolbarPositionAboveSelection, calculateToolbarPositionTrackHead, } from './calculate-toolbar-position';
|
|
93
93
|
export { findNodePosByLocalIds } from './nodes-by-localIds';
|
|
94
|
+
export { getPageElementCounts } from './page-element-counts';
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { JSONDocNode } from '@atlaskit/editor-json-transformer';
|
|
2
|
+
export type PageElementCounts = {
|
|
3
|
+
elements: {
|
|
4
|
+
[key: string]: number;
|
|
5
|
+
};
|
|
6
|
+
textFormats: {
|
|
7
|
+
[key: string]: number;
|
|
8
|
+
};
|
|
9
|
+
macros: {
|
|
10
|
+
[key: string]: number;
|
|
11
|
+
};
|
|
12
|
+
};
|
|
13
|
+
/**
|
|
14
|
+
* Traverses a JSON document and counts the number of unique elements, text formatting and macros.
|
|
15
|
+
*
|
|
16
|
+
**/
|
|
17
|
+
export declare const getPageElementCounts: (doc: JSONDocNode) => PageElementCounts;
|
package/package.json
CHANGED