@atlaskit/renderer 104.0.2 → 105.0.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.
- package/CHANGELOG.md +51 -0
- package/dist/cjs/actions/index.js +5 -5
- package/dist/cjs/analytics/enums.js +1 -66
- package/dist/cjs/analytics/unsupported-content.js +7 -7
- package/dist/cjs/react/index.js +11 -0
- package/dist/cjs/react/marks/alignment.js +1 -1
- package/dist/cjs/react/marks/link.js +4 -4
- package/dist/cjs/react/nodes/codeBlock/components/codeBlockContainer.js +2 -3
- package/dist/cjs/react/nodes/codeBlock/components/lightWeightCodeBlock.js +3 -1
- package/dist/cjs/react/nodes/emoji.js +4 -2
- package/dist/cjs/react/nodes/heading.js +5 -5
- package/dist/cjs/react/nodes/media.js +5 -5
- package/dist/cjs/react/nodes/orderedList.js +30 -2
- package/dist/cjs/react/nodes/panel.js +2 -2
- package/dist/cjs/react/nodes/tableCell.js +9 -8
- package/dist/cjs/react/utils/performance/RenderTracking.js +2 -2
- package/dist/cjs/react/utils/use-select-all-trap.js +7 -7
- package/dist/cjs/render-document.js +7 -7
- package/dist/cjs/text/nodes/orderedList.js +4 -1
- package/dist/cjs/ui/Expand.js +4 -4
- package/dist/cjs/ui/Renderer/ErrorBoundary.js +3 -3
- package/dist/cjs/ui/Renderer/index.js +22 -19
- package/dist/cjs/ui/annotations/hooks/use-events.js +5 -5
- package/dist/cjs/ui/annotations/selection/mounter.js +17 -17
- package/dist/cjs/ui/renderer-props.js +1 -1
- package/dist/cjs/version.json +1 -1
- package/dist/es2019/actions/index.js +1 -1
- package/dist/es2019/analytics/enums.js +1 -60
- package/dist/es2019/analytics/unsupported-content.js +1 -1
- package/dist/es2019/react/index.js +10 -0
- package/dist/es2019/react/marks/alignment.js +1 -1
- package/dist/es2019/react/marks/link.js +1 -1
- package/dist/es2019/react/nodes/codeBlock/components/codeBlockContainer.js +5 -4
- package/dist/es2019/react/nodes/codeBlock/components/lightWeightCodeBlock.js +3 -1
- package/dist/es2019/react/nodes/emoji.js +4 -2
- package/dist/es2019/react/nodes/heading.js +1 -1
- package/dist/es2019/react/nodes/media.js +1 -1
- package/dist/es2019/react/nodes/orderedList.js +26 -2
- package/dist/es2019/react/nodes/panel.js +2 -2
- package/dist/es2019/react/nodes/tableCell.js +3 -2
- package/dist/es2019/react/utils/performance/RenderTracking.js +1 -1
- package/dist/es2019/react/utils/use-select-all-trap.js +1 -1
- package/dist/es2019/render-document.js +1 -1
- package/dist/es2019/text/nodes/orderedList.js +3 -1
- package/dist/es2019/ui/Expand.js +1 -1
- package/dist/es2019/ui/Renderer/ErrorBoundary.js +1 -1
- package/dist/es2019/ui/Renderer/index.js +6 -3
- package/dist/es2019/ui/annotations/hooks/use-events.js +1 -1
- package/dist/es2019/ui/annotations/selection/mounter.js +1 -1
- package/dist/es2019/ui/renderer-props.js +1 -1
- package/dist/es2019/version.json +1 -1
- package/dist/esm/actions/index.js +1 -1
- package/dist/esm/analytics/enums.js +1 -60
- package/dist/esm/analytics/unsupported-content.js +1 -1
- package/dist/esm/react/index.js +11 -0
- package/dist/esm/react/marks/alignment.js +1 -1
- package/dist/esm/react/marks/link.js +1 -1
- package/dist/esm/react/nodes/codeBlock/components/codeBlockContainer.js +3 -3
- package/dist/esm/react/nodes/codeBlock/components/lightWeightCodeBlock.js +3 -1
- package/dist/esm/react/nodes/emoji.js +4 -2
- package/dist/esm/react/nodes/heading.js +1 -1
- package/dist/esm/react/nodes/media.js +1 -1
- package/dist/esm/react/nodes/orderedList.js +26 -2
- package/dist/esm/react/nodes/panel.js +2 -2
- package/dist/esm/react/nodes/tableCell.js +3 -2
- package/dist/esm/react/utils/performance/RenderTracking.js +1 -1
- package/dist/esm/react/utils/use-select-all-trap.js +1 -1
- package/dist/esm/render-document.js +1 -1
- package/dist/esm/text/nodes/orderedList.js +3 -1
- package/dist/esm/ui/Expand.js +1 -1
- package/dist/esm/ui/Renderer/ErrorBoundary.js +1 -1
- package/dist/esm/ui/Renderer/index.js +6 -3
- package/dist/esm/ui/annotations/hooks/use-events.js +1 -1
- package/dist/esm/ui/annotations/selection/mounter.js +1 -1
- package/dist/esm/ui/renderer-props.js +1 -1
- package/dist/esm/version.json +1 -1
- package/dist/types/analytics/enums.d.ts +0 -49
- package/dist/types/analytics/events.d.ts +2 -1
- package/dist/types/react/index.d.ts +4 -0
- package/dist/types/react/nodes/emoji.d.ts +2 -0
- package/dist/types/react/nodes/orderedList.d.ts +4 -1
- package/dist/types/react/utils/performance/RenderTracking.d.ts +1 -1
- package/dist/types/renderer-context.d.ts +1 -3
- package/dist/types/ui/renderer-props.d.ts +5 -2
- package/package.json +15 -14
- package/report.api.md +12 -100
|
@@ -55,7 +55,7 @@ var _style = require("./style");
|
|
|
55
55
|
|
|
56
56
|
var _truncatedWrapper = require("./truncated-wrapper");
|
|
57
57
|
|
|
58
|
-
var
|
|
58
|
+
var _analytics = require("@atlaskit/editor-common/analytics");
|
|
59
59
|
|
|
60
60
|
var _events = require("../../analytics/events");
|
|
61
61
|
|
|
@@ -102,7 +102,7 @@ exports.NORMAL_SEVERITY_THRESHOLD = NORMAL_SEVERITY_THRESHOLD;
|
|
|
102
102
|
var DEGRADED_SEVERITY_THRESHOLD = 3000;
|
|
103
103
|
exports.DEGRADED_SEVERITY_THRESHOLD = DEGRADED_SEVERITY_THRESHOLD;
|
|
104
104
|
var packageName = "@atlaskit/renderer";
|
|
105
|
-
var packageVersion = "
|
|
105
|
+
var packageVersion = "105.0.1";
|
|
106
106
|
|
|
107
107
|
var Renderer = /*#__PURE__*/function (_PureComponent) {
|
|
108
108
|
(0, _inherits2.default)(Renderer, _PureComponent);
|
|
@@ -217,14 +217,14 @@ var Renderer = /*#__PURE__*/function (_PureComponent) {
|
|
|
217
217
|
if (_featureFlags !== null && _featureFlags !== void 0 && _featureFlags.rendererTtiTracking) {
|
|
218
218
|
(0, _utils.measureTTI)(function (tti, ttiFromInvocation, canceled) {
|
|
219
219
|
_this.fireAnalyticsEvent({
|
|
220
|
-
action:
|
|
221
|
-
actionSubject:
|
|
220
|
+
action: _analytics.ACTION.RENDERER_TTI,
|
|
221
|
+
actionSubject: _analytics.ACTION_SUBJECT.RENDERER,
|
|
222
222
|
attributes: {
|
|
223
223
|
tti: tti,
|
|
224
224
|
ttiFromInvocation: ttiFromInvocation,
|
|
225
225
|
canceled: canceled
|
|
226
226
|
},
|
|
227
|
-
eventType:
|
|
227
|
+
eventType: _analytics.EVENT_TYPE.OPERATIONAL
|
|
228
228
|
});
|
|
229
229
|
});
|
|
230
230
|
}
|
|
@@ -244,13 +244,13 @@ var Renderer = /*#__PURE__*/function (_PureComponent) {
|
|
|
244
244
|
|
|
245
245
|
if (anchorLinkElement && this.editorRef.current.contains(anchorLinkElement)) {
|
|
246
246
|
this.fireAnalyticsEvent({
|
|
247
|
-
action:
|
|
248
|
-
actionSubject:
|
|
247
|
+
action: _analytics.ACTION.VIEWED,
|
|
248
|
+
actionSubject: _analytics.ACTION_SUBJECT.ANCHOR_LINK,
|
|
249
249
|
attributes: {
|
|
250
250
|
platform: _events.PLATFORM.WEB,
|
|
251
251
|
mode: _events.MODE.RENDERER
|
|
252
252
|
},
|
|
253
|
-
eventType:
|
|
253
|
+
eventType: _analytics.EVENT_TYPE.UI
|
|
254
254
|
});
|
|
255
255
|
}
|
|
256
256
|
}
|
|
@@ -261,12 +261,12 @@ var Renderer = /*#__PURE__*/function (_PureComponent) {
|
|
|
261
261
|
var _this2 = this;
|
|
262
262
|
|
|
263
263
|
this.fireAnalyticsEvent({
|
|
264
|
-
action:
|
|
265
|
-
actionSubject:
|
|
264
|
+
action: _analytics.ACTION.STARTED,
|
|
265
|
+
actionSubject: _analytics.ACTION_SUBJECT.RENDERER,
|
|
266
266
|
attributes: {
|
|
267
267
|
platform: _events.PLATFORM.WEB
|
|
268
268
|
},
|
|
269
|
-
eventType:
|
|
269
|
+
eventType: _analytics.EVENT_TYPE.UI
|
|
270
270
|
});
|
|
271
271
|
this.rafID = requestAnimationFrame(function () {
|
|
272
272
|
(0, _utils.stopMeasure)("Renderer Render Time: ".concat(_this2.id), function (duration) {
|
|
@@ -277,8 +277,8 @@ var Renderer = /*#__PURE__*/function (_PureComponent) {
|
|
|
277
277
|
var severity = !!forceSeverityTracking || analyticsEventSeverityTracking !== null && analyticsEventSeverityTracking !== void 0 && analyticsEventSeverityTracking.enabled ? (0, _utils.getAnalyticsEventSeverity)(duration, (_analyticsEventSeveri = analyticsEventSeverityTracking === null || analyticsEventSeverityTracking === void 0 ? void 0 : analyticsEventSeverityTracking.severityNormalThreshold) !== null && _analyticsEventSeveri !== void 0 ? _analyticsEventSeveri : NORMAL_SEVERITY_THRESHOLD, (_analyticsEventSeveri2 = analyticsEventSeverityTracking === null || analyticsEventSeverityTracking === void 0 ? void 0 : analyticsEventSeverityTracking.severityDegradedThreshold) !== null && _analyticsEventSeveri2 !== void 0 ? _analyticsEventSeveri2 : DEGRADED_SEVERITY_THRESHOLD) : undefined;
|
|
278
278
|
|
|
279
279
|
_this2.fireAnalyticsEvent({
|
|
280
|
-
action:
|
|
281
|
-
actionSubject:
|
|
280
|
+
action: _analytics.ACTION.RENDERED,
|
|
281
|
+
actionSubject: _analytics.ACTION_SUBJECT.RENDERER,
|
|
282
282
|
attributes: {
|
|
283
283
|
platform: _events.PLATFORM.WEB,
|
|
284
284
|
duration: duration,
|
|
@@ -290,7 +290,7 @@ var Renderer = /*#__PURE__*/function (_PureComponent) {
|
|
|
290
290
|
}, {}),
|
|
291
291
|
severity: severity
|
|
292
292
|
},
|
|
293
|
-
eventType:
|
|
293
|
+
eventType: _analytics.EVENT_TYPE.OPERATIONAL
|
|
294
294
|
});
|
|
295
295
|
|
|
296
296
|
_this2.renderedMeasurementDistortedDurationMonitor.cleanup();
|
|
@@ -343,6 +343,7 @@ var Renderer = /*#__PURE__*/function (_PureComponent) {
|
|
|
343
343
|
allowMediaLinking: props.media && props.media.allowLinking,
|
|
344
344
|
surroundTextNodesWithTextWrapper: allowAnnotationsDraftMode,
|
|
345
345
|
media: props.media,
|
|
346
|
+
emojiResourceConfig: props.emojiResourceConfig,
|
|
346
347
|
smartLinks: props.smartLinks,
|
|
347
348
|
allowCopyToClipboard: props.allowCopyToClipboard,
|
|
348
349
|
allowCustomPanels: props.allowCustomPanels,
|
|
@@ -468,11 +469,11 @@ var Renderer = /*#__PURE__*/function (_PureComponent) {
|
|
|
468
469
|
height: maxHeight,
|
|
469
470
|
fadeHeight: fadeOutHeight
|
|
470
471
|
}, rendererOutput) : rendererOutput;
|
|
471
|
-
var rendererRenderTracking = (_this$featureFlags2 = this.featureFlags(this.props.featureFlags)) === null || _this$featureFlags2 === void 0 ? void 0 : (_this$featureFlags2$f = _this$featureFlags2.featureFlags) === null || _this$featureFlags2$f === void 0 ? void 0 : (_this$featureFlags2$f2 = _this$featureFlags2$f.rendererRenderTracking) === null || _this$featureFlags2$f2 === void 0 ? void 0 : _this$featureFlags2$f2[
|
|
472
|
+
var rendererRenderTracking = (_this$featureFlags2 = this.featureFlags(this.props.featureFlags)) === null || _this$featureFlags2 === void 0 ? void 0 : (_this$featureFlags2$f = _this$featureFlags2.featureFlags) === null || _this$featureFlags2$f === void 0 ? void 0 : (_this$featureFlags2$f2 = _this$featureFlags2$f.rendererRenderTracking) === null || _this$featureFlags2$f2 === void 0 ? void 0 : _this$featureFlags2$f2[_analytics.ACTION_SUBJECT.RENDERER];
|
|
472
473
|
var reRenderTracking = (rendererRenderTracking === null || rendererRenderTracking === void 0 ? void 0 : rendererRenderTracking.enabled) && (0, _react2.jsx)(_RenderTracking.RenderTracking, {
|
|
473
474
|
componentProps: this.props,
|
|
474
|
-
action:
|
|
475
|
-
actionSubject:
|
|
475
|
+
action: _analytics.ACTION.RE_RENDERED,
|
|
476
|
+
actionSubject: _analytics.ACTION_SUBJECT.RENDERER,
|
|
476
477
|
handleAnalyticsEvent: this.fireAnalyticsEvent,
|
|
477
478
|
useShallow: rendererRenderTracking.useShallow
|
|
478
479
|
});
|
|
@@ -526,7 +527,7 @@ var RendererWithAnalytics = /*#__PURE__*/_react.default.memo(function (props) {
|
|
|
526
527
|
render: function render(createAnalyticsEvent) {
|
|
527
528
|
// `IntlErrorBoundary` only captures Internationalisation errors, leaving others for `ErrorBoundary`.
|
|
528
529
|
return (0, _react2.jsx)(_ErrorBoundary.ErrorBoundary, {
|
|
529
|
-
component:
|
|
530
|
+
component: _analytics.ACTION_SUBJECT.RENDERER,
|
|
530
531
|
rethrowError: true,
|
|
531
532
|
fallbackComponent: null,
|
|
532
533
|
createAnalyticsEvent: createAnalyticsEvent
|
|
@@ -602,7 +603,9 @@ var RendererWithAnnotationSelection = function RendererWithAnnotationSelection(p
|
|
|
602
603
|
annotationProvider: props.annotationProvider
|
|
603
604
|
}, (0, _react2.jsx)(RendererWithAnalytics, (0, _extends2.default)({
|
|
604
605
|
innerRef: innerRef
|
|
605
|
-
}, props
|
|
606
|
+
}, props, {
|
|
607
|
+
featureFlags: props.featureFlags
|
|
608
|
+
}))));
|
|
606
609
|
};
|
|
607
610
|
|
|
608
611
|
var _default = RendererWithAnnotationSelection;
|
|
@@ -17,7 +17,7 @@ var _types = require("@atlaskit/editor-common/types");
|
|
|
17
17
|
|
|
18
18
|
var _adfSchema = require("@atlaskit/adf-schema");
|
|
19
19
|
|
|
20
|
-
var
|
|
20
|
+
var _analytics = require("@atlaskit/editor-common/analytics");
|
|
21
21
|
|
|
22
22
|
var _analyticsListeners = require("@atlaskit/analytics-listeners");
|
|
23
23
|
|
|
@@ -127,10 +127,10 @@ var useAnnotationClickEvent = function useAnnotationClickEvent(props) {
|
|
|
127
127
|
|
|
128
128
|
if (createAnalyticsEvent) {
|
|
129
129
|
createAnalyticsEvent({
|
|
130
|
-
action:
|
|
131
|
-
actionSubject:
|
|
132
|
-
actionSubjectId:
|
|
133
|
-
eventType:
|
|
130
|
+
action: _analytics.ACTION.VIEWED,
|
|
131
|
+
actionSubject: _analytics.ACTION_SUBJECT.ANNOTATION,
|
|
132
|
+
actionSubjectId: _analytics.ACTION_SUBJECT_ID.INLINE_COMMENT,
|
|
133
|
+
eventType: _analytics.EVENT_TYPE.TRACK,
|
|
134
134
|
attributes: {
|
|
135
135
|
overlap: annotationsByType.length || 0
|
|
136
136
|
}
|
|
@@ -19,7 +19,7 @@ var _draft = require("../draft");
|
|
|
19
19
|
|
|
20
20
|
var _analyticsListeners = require("@atlaskit/analytics-listeners");
|
|
21
21
|
|
|
22
|
-
var
|
|
22
|
+
var _analytics = require("@atlaskit/editor-common/analytics");
|
|
23
23
|
|
|
24
24
|
var _RendererActionsContext = require("../../RendererActionsContext");
|
|
25
25
|
|
|
@@ -58,11 +58,11 @@ var SelectionInlineCommentMounter = /*#__PURE__*/_react.default.memo(function (p
|
|
|
58
58
|
|
|
59
59
|
if (createAnalyticsEvent) {
|
|
60
60
|
createAnalyticsEvent({
|
|
61
|
-
action:
|
|
62
|
-
actionSubject:
|
|
63
|
-
actionSubjectId:
|
|
61
|
+
action: _analytics.ACTION.INSERTED,
|
|
62
|
+
actionSubject: _analytics.ACTION_SUBJECT.ANNOTATION,
|
|
63
|
+
actionSubjectId: _analytics.ACTION_SUBJECT_ID.INLINE_COMMENT,
|
|
64
64
|
attributes: {},
|
|
65
|
-
eventType:
|
|
65
|
+
eventType: _analytics.EVENT_TYPE.TRACK
|
|
66
66
|
}).fire(_analyticsListeners.FabricChannel.editor);
|
|
67
67
|
}
|
|
68
68
|
|
|
@@ -87,11 +87,11 @@ var SelectionInlineCommentMounter = /*#__PURE__*/_react.default.memo(function (p
|
|
|
87
87
|
if (!documentPosition || !isAnnotationAllowed) {
|
|
88
88
|
if (createAnalyticsEvent) {
|
|
89
89
|
createAnalyticsEvent({
|
|
90
|
-
action:
|
|
91
|
-
actionSubject:
|
|
92
|
-
actionSubjectId:
|
|
90
|
+
action: _analytics.ACTION.CREATE_NOT_ALLOWED,
|
|
91
|
+
actionSubject: _analytics.ACTION_SUBJECT.ANNOTATION,
|
|
92
|
+
actionSubjectId: _analytics.ACTION_SUBJECT_ID.INLINE_COMMENT,
|
|
93
93
|
attributes: {},
|
|
94
|
-
eventType:
|
|
94
|
+
eventType: _analytics.EVENT_TYPE.TRACK
|
|
95
95
|
}).fire(_analyticsListeners.FabricChannel.editor);
|
|
96
96
|
}
|
|
97
97
|
|
|
@@ -104,10 +104,10 @@ var SelectionInlineCommentMounter = /*#__PURE__*/_react.default.memo(function (p
|
|
|
104
104
|
if (createAnalyticsEvent) {
|
|
105
105
|
var uniqueAnnotationsInRange = actions.getAnnotationsByPosition(range);
|
|
106
106
|
createAnalyticsEvent({
|
|
107
|
-
action:
|
|
108
|
-
actionSubject:
|
|
109
|
-
actionSubjectId:
|
|
110
|
-
eventType:
|
|
107
|
+
action: _analytics.ACTION.OPENED,
|
|
108
|
+
actionSubject: _analytics.ACTION_SUBJECT.ANNOTATION,
|
|
109
|
+
actionSubjectId: _analytics.ACTION_SUBJECT_ID.INLINE_COMMENT,
|
|
110
|
+
eventType: _analytics.EVENT_TYPE.TRACK,
|
|
111
111
|
attributes: {
|
|
112
112
|
overlap: uniqueAnnotationsInRange.length
|
|
113
113
|
}
|
|
@@ -138,10 +138,10 @@ var SelectionInlineCommentMounter = /*#__PURE__*/_react.default.memo(function (p
|
|
|
138
138
|
var onCloseCallback = (0, _react.useCallback)(function () {
|
|
139
139
|
if (createAnalyticsEvent) {
|
|
140
140
|
createAnalyticsEvent({
|
|
141
|
-
action:
|
|
142
|
-
actionSubject:
|
|
143
|
-
actionSubjectId:
|
|
144
|
-
eventType:
|
|
141
|
+
action: _analytics.ACTION.CLOSED,
|
|
142
|
+
actionSubject: _analytics.ACTION_SUBJECT.ANNOTATION,
|
|
143
|
+
actionSubjectId: _analytics.ACTION_SUBJECT_ID.INLINE_COMMENT,
|
|
144
|
+
eventType: _analytics.EVENT_TYPE.TRACK,
|
|
145
145
|
attributes: {}
|
|
146
146
|
}).fire(_analyticsListeners.FabricChannel.editor);
|
|
147
147
|
}
|
package/dist/cjs/version.json
CHANGED
|
@@ -4,7 +4,7 @@ import { canApplyAnnotationOnRange, getAnnotationIdsFromRange } from '@atlaskit/
|
|
|
4
4
|
import { AnnotationTypes } from '@atlaskit/adf-schema';
|
|
5
5
|
import { RemoveMarkStep } from 'prosemirror-transform';
|
|
6
6
|
import { createAnnotationStep, getPosFromRange } from '../steps';
|
|
7
|
-
import { ACTION, ACTION_SUBJECT, EVENT_TYPE, ACTION_SUBJECT_ID } from '
|
|
7
|
+
import { ACTION, ACTION_SUBJECT, EVENT_TYPE, ACTION_SUBJECT_ID } from '@atlaskit/editor-common/analytics';
|
|
8
8
|
import { getIndexMatch } from './matches-utils';
|
|
9
9
|
export default class RendererActions {
|
|
10
10
|
// This is our psuedo feature flag for now
|
|
@@ -1,60 +1 @@
|
|
|
1
|
-
export
|
|
2
|
-
|
|
3
|
-
(function (EVENT_TYPE) {
|
|
4
|
-
EVENT_TYPE["OPERATIONAL"] = "operational";
|
|
5
|
-
EVENT_TYPE["SCREEN"] = "screen";
|
|
6
|
-
EVENT_TYPE["TRACK"] = "track";
|
|
7
|
-
EVENT_TYPE["UI"] = "ui";
|
|
8
|
-
})(EVENT_TYPE || (EVENT_TYPE = {}));
|
|
9
|
-
|
|
10
|
-
export let ACTION;
|
|
11
|
-
|
|
12
|
-
(function (ACTION) {
|
|
13
|
-
ACTION["STARTED"] = "started";
|
|
14
|
-
ACTION["RENDERED"] = "rendered";
|
|
15
|
-
ACTION["RE_RENDERED"] = "reRendered";
|
|
16
|
-
ACTION["RENDERER_TTI"] = "tti";
|
|
17
|
-
ACTION["CRASHED"] = "unhandledErrorCaught";
|
|
18
|
-
ACTION["INVALID_PROSEMIRROR_DOCUMENT"] = "invalidProsemirrorDocument";
|
|
19
|
-
ACTION["SELECT_ALL_CAUGHT"] = "selectAllCaught";
|
|
20
|
-
ACTION["SELECT_ALL_ESCAPED"] = "selectAllEscaped";
|
|
21
|
-
ACTION["CLICKED"] = "clicked";
|
|
22
|
-
ACTION["VIEWED"] = "viewed";
|
|
23
|
-
ACTION["VISITED"] = "visited";
|
|
24
|
-
ACTION["SORT_COLUMN"] = "sortedColumn";
|
|
25
|
-
ACTION["SORT_COLUMN_NOT_ALLOWED"] = "sortColumnNotAllowed";
|
|
26
|
-
ACTION["TOGGLE_EXPAND"] = "toggleExpand";
|
|
27
|
-
ACTION["INSERTED"] = "inserted";
|
|
28
|
-
ACTION["OPENED"] = "opened";
|
|
29
|
-
ACTION["CLOSED"] = "closed";
|
|
30
|
-
ACTION["DELETED"] = "deleted";
|
|
31
|
-
ACTION["EDITED"] = "edited";
|
|
32
|
-
ACTION["RESOLVED"] = "resolved";
|
|
33
|
-
ACTION["CREATE_NOT_ALLOWED"] = "createNotAllowed";
|
|
34
|
-
ACTION["UNSUPPORTED_CONTENT_LEVELS_TRACKING_SUCCEEDED"] = "unsupportedContentLevelsTrackingSucceeded";
|
|
35
|
-
ACTION["UNSUPPORTED_CONTENT_LEVELS_TRACKING_ERRORED"] = "unsupportedContentLevelsTrackingErrored";
|
|
36
|
-
ACTION["MEDIA_LINK_TRANSFORMED"] = "mediaLinkTransformed";
|
|
37
|
-
})(ACTION || (ACTION = {}));
|
|
38
|
-
|
|
39
|
-
export let ACTION_SUBJECT;
|
|
40
|
-
|
|
41
|
-
(function (ACTION_SUBJECT) {
|
|
42
|
-
ACTION_SUBJECT["RENDERER"] = "renderer";
|
|
43
|
-
ACTION_SUBJECT["BUTTON"] = "button";
|
|
44
|
-
ACTION_SUBJECT["ANCHOR_LINK"] = "anchorLink";
|
|
45
|
-
ACTION_SUBJECT["TABLE"] = "table";
|
|
46
|
-
ACTION_SUBJECT["EXPAND"] = "expand";
|
|
47
|
-
ACTION_SUBJECT["NESTED_EXPAND"] = "nestedExpand";
|
|
48
|
-
ACTION_SUBJECT["MEDIA_SINGLE"] = "mediaSingle";
|
|
49
|
-
ACTION_SUBJECT["LINK"] = "link";
|
|
50
|
-
ACTION_SUBJECT["ANNOTATION"] = "annotation";
|
|
51
|
-
ACTION_SUBJECT["MEDIA"] = "media";
|
|
52
|
-
})(ACTION_SUBJECT || (ACTION_SUBJECT = {}));
|
|
53
|
-
|
|
54
|
-
export let ACTION_SUBJECT_ID;
|
|
55
|
-
|
|
56
|
-
(function (ACTION_SUBJECT_ID) {
|
|
57
|
-
ACTION_SUBJECT_ID["HEADING_ANCHOR_LINK"] = "headingAnchorLink";
|
|
58
|
-
ACTION_SUBJECT_ID["LINK"] = "link";
|
|
59
|
-
ACTION_SUBJECT_ID["INLINE_COMMENT"] = "inlineComment";
|
|
60
|
-
})(ACTION_SUBJECT_ID || (ACTION_SUBJECT_ID = {}));
|
|
1
|
+
export {};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { getUnsupportedContentLevelData, getAnalyticsAppearance } from '@atlaskit/editor-common/utils';
|
|
2
|
-
import { ACTION, ACTION_SUBJECT, EVENT_TYPE } from '
|
|
2
|
+
import { ACTION, ACTION_SUBJECT, EVENT_TYPE } from '@atlaskit/editor-common/analytics';
|
|
3
3
|
import { PLATFORM } from './events';
|
|
4
4
|
let rendersMap = {};
|
|
5
5
|
|
|
@@ -176,6 +176,7 @@ export default class ReactSerializer {
|
|
|
176
176
|
this.allowAnnotations = Boolean(init.allowAnnotations);
|
|
177
177
|
this.surroundTextNodesWithTextWrapper = Boolean(init.surroundTextNodesWithTextWrapper);
|
|
178
178
|
this.media = init.media;
|
|
179
|
+
this.emojiResourceConfig = init.emojiResourceConfig;
|
|
179
180
|
this.smartLinks = init.smartLinks;
|
|
180
181
|
this.allowSelectAllTrap = init.allowSelectAllTrap;
|
|
181
182
|
this.nodeComponents = init.nodeComponents;
|
|
@@ -204,6 +205,9 @@ export default class ReactSerializer {
|
|
|
204
205
|
case 'media':
|
|
205
206
|
return this.getMediaProps(node, path);
|
|
206
207
|
|
|
208
|
+
case 'emoji':
|
|
209
|
+
return this.getEmojiProps(node);
|
|
210
|
+
|
|
207
211
|
case 'mediaGroup':
|
|
208
212
|
return this.getMediaGroupProps(node);
|
|
209
213
|
|
|
@@ -403,6 +407,12 @@ export default class ReactSerializer {
|
|
|
403
407
|
};
|
|
404
408
|
}
|
|
405
409
|
|
|
410
|
+
getEmojiProps(node) {
|
|
411
|
+
return { ...this.getProps(node),
|
|
412
|
+
resourceConfig: this.emojiResourceConfig
|
|
413
|
+
};
|
|
414
|
+
}
|
|
415
|
+
|
|
406
416
|
getEmbedCardProps(node, path = []) {
|
|
407
417
|
const {
|
|
408
418
|
nodes: {
|
|
@@ -16,7 +16,7 @@ const MarkWrapper = props => {
|
|
|
16
16
|
|
|
17
17
|
export default function Alignment(props) {
|
|
18
18
|
return jsx(MarkWrapper, {
|
|
19
|
-
className: "fabric-editor-block-mark",
|
|
19
|
+
className: "fabric-editor-block-mark fabric-editor-alignment",
|
|
20
20
|
"data-align": props.align
|
|
21
21
|
}, props.children);
|
|
22
22
|
}
|
|
@@ -6,7 +6,7 @@ import { css, jsx } from '@emotion/react';
|
|
|
6
6
|
import { B400, B300, B500 } from '@atlaskit/theme/colors';
|
|
7
7
|
import { getEventHandler } from '../../utils';
|
|
8
8
|
import { PLATFORM, MODE } from '../../analytics/events';
|
|
9
|
-
import { ACTION, ACTION_SUBJECT, EVENT_TYPE } from '
|
|
9
|
+
import { ACTION, ACTION_SUBJECT, EVENT_TYPE } from '@atlaskit/editor-common/analytics';
|
|
10
10
|
import { token } from '@atlaskit/tokens';
|
|
11
11
|
const anchorStyles = css`
|
|
12
12
|
color: ${token('color.link', B400)};
|
|
@@ -6,7 +6,7 @@ import { themed } from '@atlaskit/theme/components';
|
|
|
6
6
|
import { fontSize, gridSize } from '@atlaskit/theme/constants';
|
|
7
7
|
import { CodeBlockSharedCssClassName } from '@atlaskit/editor-common/styles';
|
|
8
8
|
import CopyButton from '../../codeBlockCopyButton';
|
|
9
|
-
import { token } from '@atlaskit/tokens';
|
|
9
|
+
import { token } from '@atlaskit/tokens';
|
|
10
10
|
|
|
11
11
|
const codeBlockStyleOverrides = props => css`
|
|
12
12
|
tab-size: 4;
|
|
@@ -23,10 +23,11 @@ const codeBlockStyleOverrides = props => css`
|
|
|
23
23
|
light: token('color.background.neutral', N20),
|
|
24
24
|
dark: token('color.background.neutral', DN50)
|
|
25
25
|
})(props),
|
|
26
|
-
|
|
26
|
+
leftCoverWidth: `${gridSize() * 3}px`
|
|
27
27
|
})};
|
|
28
|
-
background-attachment: local, local, local, local, scroll, scroll
|
|
29
|
-
|
|
28
|
+
background-attachment: local, local, local, local, scroll, scroll, scroll,
|
|
29
|
+
scroll;
|
|
30
|
+
background-position: 0 0, 0 0, 100% 0, 100% 0, 100% 0, 100% 0, 0 0, 0 0;
|
|
30
31
|
}
|
|
31
32
|
`;
|
|
32
33
|
|
|
@@ -47,12 +47,14 @@ const LightWeightCodeBlock = /*#__PURE__*/forwardRef(({
|
|
|
47
47
|
css: [codeBlockSharedStyles(theme), lightWeightCodeBlockStyles]
|
|
48
48
|
}, jsx("div", {
|
|
49
49
|
className: CodeBlockSharedCssClassName.CODEBLOCK_CONTAINER
|
|
50
|
+
}, jsx("div", {
|
|
51
|
+
className: CodeBlockSharedCssClassName.CODEBLOCK_CONTENT_WRAPPER
|
|
50
52
|
}, jsx("div", {
|
|
51
53
|
className: CodeBlockSharedCssClassName.CODEBLOCK_LINE_NUMBER_GUTTER
|
|
52
54
|
}, textRows.map((_, index) => jsx("span", {
|
|
53
55
|
key: index
|
|
54
56
|
}))), jsx("div", {
|
|
55
57
|
className: CodeBlockSharedCssClassName.CODEBLOCK_CONTENT
|
|
56
|
-
}, jsx("code", null, renderBidiWarnings(text)))));
|
|
58
|
+
}, jsx("code", null, renderBidiWarnings(text))))));
|
|
57
59
|
});
|
|
58
60
|
export default LightWeightCodeBlock;
|
|
@@ -8,7 +8,8 @@ export default class EmojiItem extends PureComponent {
|
|
|
8
8
|
providers,
|
|
9
9
|
shortName,
|
|
10
10
|
text,
|
|
11
|
-
fitToHeight
|
|
11
|
+
fitToHeight,
|
|
12
|
+
resourceConfig
|
|
12
13
|
} = this.props;
|
|
13
14
|
return /*#__PURE__*/React.createElement(Emoji, {
|
|
14
15
|
allowTextFallback: true,
|
|
@@ -16,7 +17,8 @@ export default class EmojiItem extends PureComponent {
|
|
|
16
17
|
shortName: shortName,
|
|
17
18
|
fallback: text,
|
|
18
19
|
providers: providers,
|
|
19
|
-
fitToHeight: fitToHeight
|
|
20
|
+
fitToHeight: fitToHeight,
|
|
21
|
+
resourceConfig: resourceConfig
|
|
20
22
|
});
|
|
21
23
|
}
|
|
22
24
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import _extends from "@babel/runtime/helpers/extends";
|
|
2
2
|
import React from 'react';
|
|
3
3
|
import HeadingAnchor from './heading-anchor';
|
|
4
|
-
import { ACTION, ACTION_SUBJECT, ACTION_SUBJECT_ID, EVENT_TYPE } from '
|
|
4
|
+
import { ACTION, ACTION_SUBJECT, ACTION_SUBJECT_ID, EVENT_TYPE } from '@atlaskit/editor-common/analytics';
|
|
5
5
|
import AnalyticsContext from '../../analytics/analyticsContext';
|
|
6
6
|
import { copyTextToClipboard } from '../utils/clipboard';
|
|
7
7
|
|
|
@@ -9,7 +9,7 @@ import { WithProviders } from '@atlaskit/editor-common/provider-factory';
|
|
|
9
9
|
import { mediaLinkStyle } from '@atlaskit/editor-common/ui';
|
|
10
10
|
import { MediaCard } from '../../ui/MediaCard';
|
|
11
11
|
import { getEventHandler } from '../../utils';
|
|
12
|
-
import { ACTION, ACTION_SUBJECT, ACTION_SUBJECT_ID, EVENT_TYPE } from '
|
|
12
|
+
import { ACTION, ACTION_SUBJECT, ACTION_SUBJECT_ID, EVENT_TYPE } from '@atlaskit/editor-common/analytics';
|
|
13
13
|
import { MODE, PLATFORM } from '../../analytics/events';
|
|
14
14
|
export default class Media extends PureComponent {
|
|
15
15
|
constructor(...args) {
|
|
@@ -1,10 +1,34 @@
|
|
|
1
|
+
import _extends from "@babel/runtime/helpers/extends";
|
|
1
2
|
import React from 'react';
|
|
2
3
|
import { orderedListSelector } from '@atlaskit/adf-schema';
|
|
4
|
+
import { getOrderedListInlineStyles } from '@atlaskit/editor-common/styles';
|
|
5
|
+
import { getItemCounterDigitsSize, resolveOrder } from '@atlaskit/editor-common/utils';
|
|
3
6
|
import { getListIndentLevel } from '../utils/lists';
|
|
7
|
+
import { useFeatureFlags } from '../../use-feature-flags';
|
|
4
8
|
export default function OrderedList(props) {
|
|
5
|
-
|
|
9
|
+
const featureFlags = useFeatureFlags();
|
|
10
|
+
let extraProps = {};
|
|
11
|
+
|
|
12
|
+
if (featureFlags !== null && featureFlags !== void 0 && featureFlags.restartNumberedLists) {
|
|
13
|
+
var _props$content;
|
|
14
|
+
|
|
15
|
+
const itemCounterDigitsSize = getItemCounterDigitsSize({
|
|
16
|
+
order: props.order,
|
|
17
|
+
itemsCount: props === null || props === void 0 ? void 0 : (_props$content = props.content) === null || _props$content === void 0 ? void 0 : _props$content.length
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
if (itemCounterDigitsSize) {
|
|
21
|
+
extraProps.style = getOrderedListInlineStyles(itemCounterDigitsSize, 'object');
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
if (props.order !== undefined) {
|
|
25
|
+
extraProps.start = resolveOrder(props.order);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
return /*#__PURE__*/React.createElement("ol", _extends({
|
|
6
30
|
className: orderedListSelector.substr(1),
|
|
7
31
|
"data-indent-level": props.path ? getListIndentLevel(props.path) : 1,
|
|
8
32
|
start: props.start
|
|
9
|
-
}, props.children);
|
|
33
|
+
}, extraProps), props.children);
|
|
10
34
|
}
|
|
@@ -25,7 +25,7 @@ const PanelStyled = ({
|
|
|
25
25
|
})}
|
|
26
26
|
|
|
27
27
|
&[data-panel-type=${PanelType.CUSTOM}] {
|
|
28
|
-
${hasIcon ? '' : 'padding: 12px;'}
|
|
28
|
+
${hasIcon ? '' : 'padding-left: 12px;'}
|
|
29
29
|
}
|
|
30
30
|
}
|
|
31
31
|
`;
|
|
@@ -47,7 +47,7 @@ const PanelStyled = ({
|
|
|
47
47
|
|
|
48
48
|
&[data-panel-type=${PanelType.CUSTOM}] {
|
|
49
49
|
${customStyle};
|
|
50
|
-
${hasIcon ? '' : 'padding: 12px;'}
|
|
50
|
+
${hasIcon ? '' : 'padding-left: 12px;'}
|
|
51
51
|
}
|
|
52
52
|
`;
|
|
53
53
|
};
|
|
@@ -6,7 +6,7 @@ import { compose } from '@atlaskit/editor-common/utils';
|
|
|
6
6
|
import { SortOrder } from '@atlaskit/editor-common/types';
|
|
7
7
|
import SortingIcon from '../../ui/SortingIcon';
|
|
8
8
|
import { MODE, PLATFORM } from '../../analytics/events';
|
|
9
|
-
import { ACTION, ACTION_SUBJECT, EVENT_TYPE } from '
|
|
9
|
+
import { ACTION, ACTION_SUBJECT, EVENT_TYPE } from '@atlaskit/editor-common/analytics';
|
|
10
10
|
import { RendererCssClassName } from '../../consts';
|
|
11
11
|
import { injectIntl } from 'react-intl-next';
|
|
12
12
|
import { tableCellMessages } from '../../messages';
|
|
@@ -62,7 +62,8 @@ const getDataAttributes = colwidth => {
|
|
|
62
62
|
const getStyle = (background, colGroupWidth, offsetTop) => {
|
|
63
63
|
const style = {};
|
|
64
64
|
|
|
65
|
-
if (background
|
|
65
|
+
if (background && // ignore setting inline styles if ds neutral token is detected
|
|
66
|
+
!background.includes('--ds-background-neutral')) {
|
|
66
67
|
style.backgroundColor = background;
|
|
67
68
|
}
|
|
68
69
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { useMemo } from 'react';
|
|
2
2
|
import debounce from 'lodash/debounce';
|
|
3
3
|
import { useComponentRenderTracking } from '@atlaskit/editor-common/utils';
|
|
4
|
-
import { EVENT_TYPE } from '
|
|
4
|
+
import { EVENT_TYPE } from '@atlaskit/editor-common/analytics';
|
|
5
5
|
export function RenderTracking(props) {
|
|
6
6
|
const debouncedHandleAnalyticsEvent = useMemo(() => debounce(props.handleAnalyticsEvent, 500), [props.handleAnalyticsEvent]);
|
|
7
7
|
useComponentRenderTracking({
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import AnalyticsContext from '../../analytics/analyticsContext';
|
|
3
|
-
import { ACTION, ACTION_SUBJECT, EVENT_TYPE } from '
|
|
3
|
+
import { ACTION, ACTION_SUBJECT, EVENT_TYPE } from '@atlaskit/editor-common/analytics';
|
|
4
4
|
import { ElementSelection } from './element-selection';
|
|
5
5
|
export const useSelectAllTrap = () => {
|
|
6
6
|
const {
|
|
@@ -2,7 +2,7 @@ import memoizeOne from 'memoize-one';
|
|
|
2
2
|
import { defaultSchema } from '@atlaskit/adf-schema/schema-default';
|
|
3
3
|
import { getValidDocument } from '@atlaskit/editor-common/validator';
|
|
4
4
|
import { validateADFEntity, findAndTrackUnsupportedContentNodes } from '@atlaskit/editor-common/utils';
|
|
5
|
-
import { ACTION, ACTION_SUBJECT, EVENT_TYPE } from '
|
|
5
|
+
import { ACTION, ACTION_SUBJECT, EVENT_TYPE } from '@atlaskit/editor-common/analytics';
|
|
6
6
|
import { PLATFORM } from './analytics/events';
|
|
7
7
|
import { trackUnsupportedContentLevels } from './analytics/unsupported-content';
|
|
8
8
|
import { transformMediaLinkMarks } from '@atlaskit/adf-utils/transforms';
|
|
@@ -1,9 +1,11 @@
|
|
|
1
|
+
import { getOrderFromOrderedListNode } from '@atlaskit/editor-common/utils';
|
|
1
2
|
import { reduce } from './';
|
|
2
3
|
|
|
3
4
|
const orderedList = (node, schema) => {
|
|
4
5
|
const result = [];
|
|
6
|
+
const order = getOrderFromOrderedListNode(node);
|
|
5
7
|
node.forEach((n, _offset, index) => {
|
|
6
|
-
result.push(`${index +
|
|
8
|
+
result.push(`${index + order}. ${reduce(n, schema)}`);
|
|
7
9
|
});
|
|
8
10
|
return result.join('\n');
|
|
9
11
|
};
|
package/dist/es2019/ui/Expand.js
CHANGED
|
@@ -9,7 +9,7 @@ import Tooltip from '@atlaskit/tooltip';
|
|
|
9
9
|
import { expandMessages, sharedExpandStyles, WidthProvider, ExpandIconWrapper, clearNextSiblingMarginTopStyle, ExpandLayoutWrapperWithRef } from '@atlaskit/editor-common/ui';
|
|
10
10
|
import { akEditorLineHeight, relativeFontSizeToBase16 } from '@atlaskit/editor-shared-styles';
|
|
11
11
|
import { PLATFORM, MODE } from '../analytics/events';
|
|
12
|
-
import { ACTION, ACTION_SUBJECT, EVENT_TYPE } from '
|
|
12
|
+
import { ACTION, ACTION_SUBJECT, EVENT_TYPE } from '@atlaskit/editor-common/analytics';
|
|
13
13
|
import { injectIntl } from 'react-intl-next';
|
|
14
14
|
import { ActiveHeaderIdConsumer } from './active-header-id-provider';
|
|
15
15
|
import _uniqueId from 'lodash/uniqueId';
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
2
2
|
import React from 'react';
|
|
3
3
|
import { PLATFORM } from '../../analytics/events';
|
|
4
|
-
import { ACTION, EVENT_TYPE } from '
|
|
4
|
+
import { ACTION, EVENT_TYPE } from '@atlaskit/editor-common/analytics';
|
|
5
5
|
import { FabricChannel } from '@atlaskit/analytics-listeners';
|
|
6
6
|
export class ErrorBoundary extends React.Component {
|
|
7
7
|
constructor(...args) {
|
|
@@ -18,7 +18,7 @@ import uuid from 'uuid/v4';
|
|
|
18
18
|
import { ReactSerializer, renderDocument } from '../../';
|
|
19
19
|
import { rendererStyles } from './style';
|
|
20
20
|
import { TruncatedWrapper } from './truncated-wrapper';
|
|
21
|
-
import { ACTION, ACTION_SUBJECT, EVENT_TYPE } from '
|
|
21
|
+
import { ACTION, ACTION_SUBJECT, EVENT_TYPE } from '@atlaskit/editor-common/analytics';
|
|
22
22
|
import { PLATFORM, MODE } from '../../analytics/events';
|
|
23
23
|
import AnalyticsContext from '../../analytics/analyticsContext';
|
|
24
24
|
import { Provider as SmartCardStorageProvider } from '../SmartCardStorage';
|
|
@@ -36,7 +36,7 @@ import { RenderTracking } from '../../react/utils/performance/RenderTracking';
|
|
|
36
36
|
export const NORMAL_SEVERITY_THRESHOLD = 2000;
|
|
37
37
|
export const DEGRADED_SEVERITY_THRESHOLD = 3000;
|
|
38
38
|
const packageName = "@atlaskit/renderer";
|
|
39
|
-
const packageVersion = "
|
|
39
|
+
const packageVersion = "105.0.1";
|
|
40
40
|
export class Renderer extends PureComponent {
|
|
41
41
|
/**
|
|
42
42
|
* This is used in measuring the Renderer Mount time and is then
|
|
@@ -272,6 +272,7 @@ export class Renderer extends PureComponent {
|
|
|
272
272
|
allowMediaLinking: props.media && props.media.allowLinking,
|
|
273
273
|
surroundTextNodesWithTextWrapper: allowAnnotationsDraftMode,
|
|
274
274
|
media: props.media,
|
|
275
|
+
emojiResourceConfig: props.emojiResourceConfig,
|
|
275
276
|
smartLinks: props.smartLinks,
|
|
276
277
|
allowCopyToClipboard: props.allowCopyToClipboard,
|
|
277
278
|
allowCustomPanels: props.allowCustomPanels,
|
|
@@ -522,7 +523,9 @@ const RendererWithAnnotationSelection = props => {
|
|
|
522
523
|
annotationProvider: props.annotationProvider
|
|
523
524
|
}, jsx(RendererWithAnalytics, _extends({
|
|
524
525
|
innerRef: innerRef
|
|
525
|
-
}, props
|
|
526
|
+
}, props, {
|
|
527
|
+
featureFlags: props.featureFlags
|
|
528
|
+
}))));
|
|
526
529
|
};
|
|
527
530
|
|
|
528
531
|
export default RendererWithAnnotationSelection;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { useLayoutEffect, useState } from 'react';
|
|
2
2
|
import { AnnotationUpdateEvent } from '@atlaskit/editor-common/types';
|
|
3
3
|
import { AnnotationTypes } from '@atlaskit/adf-schema';
|
|
4
|
-
import { ACTION, ACTION_SUBJECT, EVENT_TYPE, ACTION_SUBJECT_ID } from '
|
|
4
|
+
import { ACTION, ACTION_SUBJECT, EVENT_TYPE, ACTION_SUBJECT_ID } from '@atlaskit/editor-common/analytics';
|
|
5
5
|
import { FabricChannel } from '@atlaskit/analytics-listeners';
|
|
6
6
|
export const useAnnotationStateByTypeEvent = ({
|
|
7
7
|
type,
|