@atlaskit/editor-common 74.26.1 → 74.26.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (40) hide show
  1. package/CHANGELOG.md +13 -0
  2. package/dist/cjs/monitoring/error.js +1 -1
  3. package/dist/cjs/quick-insert/assets/datasource-assets-objects.js +54 -0
  4. package/dist/cjs/quick-insert/assets/index.js +15 -2
  5. package/dist/cjs/quick-insert/index.js +6 -0
  6. package/dist/cjs/resizer/Resizer.js +14 -2
  7. package/dist/cjs/ui/DropList/index.js +1 -1
  8. package/dist/cjs/utils/datasource.js +7 -0
  9. package/dist/cjs/version.json +1 -1
  10. package/dist/es2019/monitoring/error.js +1 -1
  11. package/dist/es2019/quick-insert/assets/datasource-assets-objects.js +46 -0
  12. package/dist/es2019/quick-insert/assets/index.js +4 -0
  13. package/dist/es2019/quick-insert/index.js +1 -1
  14. package/dist/es2019/resizer/Resizer.js +14 -2
  15. package/dist/es2019/ui/DropList/index.js +1 -1
  16. package/dist/es2019/utils/datasource.js +8 -1
  17. package/dist/es2019/version.json +1 -1
  18. package/dist/esm/monitoring/error.js +1 -1
  19. package/dist/esm/quick-insert/assets/datasource-assets-objects.js +46 -0
  20. package/dist/esm/quick-insert/assets/index.js +10 -0
  21. package/dist/esm/quick-insert/index.js +1 -1
  22. package/dist/esm/resizer/Resizer.js +15 -3
  23. package/dist/esm/ui/DropList/index.js +1 -1
  24. package/dist/esm/utils/datasource.js +8 -1
  25. package/dist/esm/version.json +1 -1
  26. package/dist/types/quick-insert/assets/datasource-assets-objects.d.ts +2 -0
  27. package/dist/types/quick-insert/assets/index.d.ts +1 -0
  28. package/dist/types/quick-insert/index.d.ts +1 -1
  29. package/dist/types/resizer/Resizer.d.ts +3 -6
  30. package/dist/types/resizer/index.d.ts +1 -1
  31. package/dist/types/resizer/types.d.ts +8 -2
  32. package/dist/types/types/datasource.d.ts +1 -1
  33. package/dist/types-ts4.5/quick-insert/assets/datasource-assets-objects.d.ts +2 -0
  34. package/dist/types-ts4.5/quick-insert/assets/index.d.ts +1 -0
  35. package/dist/types-ts4.5/quick-insert/index.d.ts +1 -1
  36. package/dist/types-ts4.5/resizer/Resizer.d.ts +3 -6
  37. package/dist/types-ts4.5/resizer/index.d.ts +1 -1
  38. package/dist/types-ts4.5/resizer/types.d.ts +8 -2
  39. package/dist/types-ts4.5/types/datasource.d.ts +1 -1
  40. package/package.json +5 -2
package/CHANGELOG.md CHANGED
@@ -1,5 +1,18 @@
1
1
  # @atlaskit/editor-common
2
2
 
3
+ ## 74.26.3
4
+
5
+ ### Patch Changes
6
+
7
+ - [`d3851530199`](https://bitbucket.org/atlassian/atlassian-frontend/commits/d3851530199) - Update snapping logic, tests and examples
8
+ - Updated dependencies
9
+
10
+ ## 74.26.2
11
+
12
+ ### Patch Changes
13
+
14
+ - [`6255c2ad1c9`](https://bitbucket.org/atlassian/atlassian-frontend/commits/6255c2ad1c9) - [ux] Adds ability to open Assets datasource dialog using the slash command in the editor, behind a feature flag
15
+
3
16
  ## 74.26.1
4
17
 
5
18
  ### Patch Changes
@@ -16,7 +16,7 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
16
16
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
17
17
  var SENTRY_DSN = 'https://0b10c8e02fb44d8796c047b102c9bee8@o55978.ingest.sentry.io/4505129224110080';
18
18
  var packageName = 'editor-common'; // Sentry doesn't accept '/' in its releases https://docs.sentry.io/platforms/javascript/configuration/releases/
19
- var packageVersion = "74.26.1";
19
+ var packageVersion = "74.26.3";
20
20
  var sanitiseSentryEvents = function sanitiseSentryEvents(data, _hint) {
21
21
  // Remove URL as it has UGC
22
22
  // TODO: Sanitise the URL instead of just removing it
@@ -0,0 +1,54 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = IconDatasourceAssetsObjects;
8
+ var _react = _interopRequireDefault(require("react"));
9
+ // TODO: https://product-fabric.atlassian.net/browse/DSP-4138
10
+ /* eslint-disable @atlaskit/design-system/ensure-design-token-usage */
11
+
12
+ function IconDatasourceAssetsObjects() {
13
+ return /*#__PURE__*/_react.default.createElement("svg", {
14
+ width: "48",
15
+ height: "48",
16
+ viewBox: "0 0 48 48",
17
+ fill: "none",
18
+ xmlns: "http://www.w3.org/2000/svg"
19
+ }, /*#__PURE__*/_react.default.createElement("rect", {
20
+ x: "0.5",
21
+ y: "0.5",
22
+ width: "47",
23
+ height: "47",
24
+ rx: "2",
25
+ fill: "white"
26
+ }), /*#__PURE__*/_react.default.createElement("path", {
27
+ fillRule: "evenodd",
28
+ clipRule: "evenodd",
29
+ d: "M28.6665 18.6667C27.5619 18.6667 26.6665 19.5621 26.6665 20.6667V24.6667C26.6665 25.7713 27.5619 26.6667 28.6665 26.6667H32.6665C33.7711 26.6667 34.6665 25.7713 34.6665 24.6667V20.6667C34.6665 19.5621 33.7711 18.6667 32.6665 18.6667H28.6665ZM31.9998 21.3334H29.3331V24.0001H31.9998V21.3334Z",
30
+ fill: "#42526E"
31
+ }), /*#__PURE__*/_react.default.createElement("path", {
32
+ fillRule: "evenodd",
33
+ clipRule: "evenodd",
34
+ d: "M28.6665 29.3333C27.5619 29.3333 26.6665 30.2287 26.6665 31.3333V35.3333C26.6665 36.4379 27.5619 37.3333 28.6665 37.3333H32.6665C33.7711 37.3333 34.6665 36.4379 34.6665 35.3333V31.3333C34.6665 30.2287 33.7711 29.3333 32.6665 29.3333H28.6665ZM31.9998 31.9999H29.3331V34.6666H31.9998V31.9999Z",
35
+ fill: "#42526E"
36
+ }), /*#__PURE__*/_react.default.createElement("path", {
37
+ fillRule: "evenodd",
38
+ clipRule: "evenodd",
39
+ d: "M15.3335 10.6667C14.2289 10.6667 13.3335 11.5621 13.3335 12.6667V16.6667C13.3335 17.7713 14.2289 18.6667 15.3335 18.6667H19.3335C20.4381 18.6667 21.3335 17.7713 21.3335 16.6667V12.6667C21.3335 11.5621 20.4381 10.6667 19.3335 10.6667H15.3335ZM18.6669 13.3334H16.0002V16.0001H18.6669V13.3334Z",
40
+ fill: "#42526E"
41
+ }), /*#__PURE__*/_react.default.createElement("rect", {
42
+ x: "16",
43
+ y: "17.3333",
44
+ width: "2.66667",
45
+ height: "14.6667",
46
+ fill: "#42526E"
47
+ }), /*#__PURE__*/_react.default.createElement("path", {
48
+ d: "M16 32H28V34.6667H18C16.8954 34.6667 16 33.7712 16 32.6667V32Z",
49
+ fill: "#42526E"
50
+ }), /*#__PURE__*/_react.default.createElement("path", {
51
+ d: "M16 21.3333H28V24H18C16.8954 24 16 23.1046 16 22V21.3333Z",
52
+ fill: "#42526E"
53
+ }));
54
+ }
@@ -11,7 +11,7 @@ Object.defineProperty(exports, "IconCustomPanel", {
11
11
  return _customPanel.default;
12
12
  }
13
13
  });
14
- exports.IconExpand = exports.IconEmoji = exports.IconDivider = exports.IconDecision = exports.IconDate = exports.IconDatasourceJiraIssue = void 0;
14
+ exports.IconExpand = exports.IconEmoji = exports.IconDivider = exports.IconDecision = exports.IconDate = exports.IconDatasourceJiraIssue = exports.IconDatasourceAssetsObjects = void 0;
15
15
  Object.defineProperty(exports, "IconFallback", {
16
16
  enumerable: true,
17
17
  get: function get() {
@@ -382,4 +382,17 @@ var IconDatasourceJiraIssue = (0, _reactLoadable.default)({
382
382
  return null;
383
383
  }
384
384
  });
385
- exports.IconDatasourceJiraIssue = IconDatasourceJiraIssue;
385
+ exports.IconDatasourceJiraIssue = IconDatasourceJiraIssue;
386
+ var IconDatasourceAssetsObjects = (0, _reactLoadable.default)({
387
+ loader: function loader() {
388
+ return Promise.resolve().then(function () {
389
+ return _interopRequireWildcard(require( /* webpackChunkName: "@atlaskit-internal_editor-icon-datasource-assets-objects" */'./datasource-assets-objects'));
390
+ }).then(function (module) {
391
+ return module.default;
392
+ });
393
+ },
394
+ loading: function loading() {
395
+ return null;
396
+ }
397
+ });
398
+ exports.IconDatasourceAssetsObjects = IconDatasourceAssetsObjects;
@@ -21,6 +21,12 @@ Object.defineProperty(exports, "IconCustomPanel", {
21
21
  return _assets.IconCustomPanel;
22
22
  }
23
23
  });
24
+ Object.defineProperty(exports, "IconDatasourceAssetsObjects", {
25
+ enumerable: true,
26
+ get: function get() {
27
+ return _assets.IconDatasourceAssetsObjects;
28
+ }
29
+ });
24
30
  Object.defineProperty(exports, "IconDatasourceJiraIssue", {
25
31
  enumerable: true,
26
32
  get: function get() {
@@ -14,7 +14,7 @@ var _react = _interopRequireWildcard(require("react"));
14
14
  var _classnames3 = _interopRequireDefault(require("classnames"));
15
15
  var _reResizable = require("re-resizable");
16
16
  var _resizer = require("../styles/shared/resizer");
17
- var _excluded = ["width", "children", "handleClassName", "className", "handleResize", "handleResizeStart", "handleResizeStop", "handleHeightSize", "handleAlignmentMethod", "handlePositioning", "handleStyles", "resizeRatio", "innerPadding"];
17
+ var _excluded = ["width", "children", "handleClassName", "className", "handleResize", "handleResizeStart", "handleResizeStop", "handleHeightSize", "handleAlignmentMethod", "handlePositioning", "handleStyles", "resizeRatio", "innerPadding", "snap"];
18
18
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
19
19
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
20
20
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
@@ -43,6 +43,7 @@ function ResizerNext(props) {
43
43
  _props$resizeRatio = props.resizeRatio,
44
44
  resizeRatio = _props$resizeRatio === void 0 ? 1 : _props$resizeRatio,
45
45
  innerPadding = props.innerPadding,
46
+ snap = props.snap,
46
47
  otherProps = (0, _objectWithoutProperties2.default)(props, _excluded);
47
48
  var onResizeStart = _react.default.useCallback(function (event) {
48
49
  // prevent creating a drag event on Firefox
@@ -103,6 +104,15 @@ function ResizerNext(props) {
103
104
  var resizerClassName = (0, _classnames3.default)(className, _resizer.resizerItemClassName, {
104
105
  'is-resizing': isResizing
105
106
  });
107
+
108
+ // snapGap is usually a constant, if snap.x?.length is 0 and snapGap has a value resizer cannot be resized
109
+ var snapGap = (0, _react.useMemo)(function () {
110
+ var _snap$x, _snap$x2;
111
+ if (!snap || ((_snap$x = snap.x) === null || _snap$x === void 0 ? void 0 : _snap$x.length) === 0 && ((_snap$x2 = snap.x) === null || _snap$x2 === void 0 ? void 0 : _snap$x2.length) === 0) {
112
+ return undefined;
113
+ }
114
+ return props.snapGap;
115
+ }, [snap, props.snapGap]);
106
116
  return /*#__PURE__*/_react.default.createElement(_reResizable.Resizable, (0, _extends2.default)({
107
117
  ref: resizable,
108
118
  size: {
@@ -116,6 +126,8 @@ function ResizerNext(props) {
116
126
  onResizeStart: onResizeStart,
117
127
  onResize: onResize,
118
128
  onResizeStop: onResizeStop,
119
- resizeRatio: resizeRatio
129
+ resizeRatio: resizeRatio,
130
+ snapGap: snapGap,
131
+ snap: snap
120
132
  }, otherProps), children);
121
133
  }
@@ -24,7 +24,7 @@ var _templateObject, _templateObject2, _templateObject3;
24
24
  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); }; }
25
25
  function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } /** @jsx jsx */
26
26
  var packageName = "@atlaskit/editor-common";
27
- var packageVersion = "74.26.1";
27
+ var packageVersion = "74.26.3";
28
28
  var halfFocusRing = 1;
29
29
  var dropOffset = '0, 8';
30
30
  var DropList = /*#__PURE__*/function (_Component) {
@@ -10,6 +10,8 @@ var getDatasourceType = function getDatasourceType(datasourceId) {
10
10
  switch (datasourceId) {
11
11
  case _linkDatasource.JIRA_LIST_OF_LINKS_DATASOURCE_ID:
12
12
  return 'jira';
13
+ case _linkDatasource.ASSETS_LIST_OF_LINKS_DATASOURCE_ID:
14
+ return 'assets';
13
15
  default:
14
16
  return undefined;
15
17
  }
@@ -23,6 +25,11 @@ var canRenderDatasource = function canRenderDatasource(datasourceId) {
23
25
  return true;
24
26
  }
25
27
  return false;
28
+ case 'assets':
29
+ if ((0, _platformFeatureFlags.getBooleanFF)('platform.linking-platform.datasource-assets_objects')) {
30
+ return true;
31
+ }
32
+ return false;
26
33
  default:
27
34
  return defaultValue;
28
35
  }
@@ -1,5 +1,5 @@
1
1
  {
2
2
  "name": "@atlaskit/editor-common",
3
- "version": "74.26.1",
3
+ "version": "74.26.3",
4
4
  "sideEffects": false
5
5
  }
@@ -1,6 +1,6 @@
1
1
  const SENTRY_DSN = 'https://0b10c8e02fb44d8796c047b102c9bee8@o55978.ingest.sentry.io/4505129224110080';
2
2
  const packageName = 'editor-common'; // Sentry doesn't accept '/' in its releases https://docs.sentry.io/platforms/javascript/configuration/releases/
3
- const packageVersion = "74.26.1";
3
+ const packageVersion = "74.26.3";
4
4
  const sanitiseSentryEvents = (data, _hint) => {
5
5
  // Remove URL as it has UGC
6
6
  // TODO: Sanitise the URL instead of just removing it
@@ -0,0 +1,46 @@
1
+ // TODO: https://product-fabric.atlassian.net/browse/DSP-4138
2
+ /* eslint-disable @atlaskit/design-system/ensure-design-token-usage */
3
+ import React from 'react';
4
+ export default function IconDatasourceAssetsObjects() {
5
+ return /*#__PURE__*/React.createElement("svg", {
6
+ width: "48",
7
+ height: "48",
8
+ viewBox: "0 0 48 48",
9
+ fill: "none",
10
+ xmlns: "http://www.w3.org/2000/svg"
11
+ }, /*#__PURE__*/React.createElement("rect", {
12
+ x: "0.5",
13
+ y: "0.5",
14
+ width: "47",
15
+ height: "47",
16
+ rx: "2",
17
+ fill: "white"
18
+ }), /*#__PURE__*/React.createElement("path", {
19
+ fillRule: "evenodd",
20
+ clipRule: "evenodd",
21
+ d: "M28.6665 18.6667C27.5619 18.6667 26.6665 19.5621 26.6665 20.6667V24.6667C26.6665 25.7713 27.5619 26.6667 28.6665 26.6667H32.6665C33.7711 26.6667 34.6665 25.7713 34.6665 24.6667V20.6667C34.6665 19.5621 33.7711 18.6667 32.6665 18.6667H28.6665ZM31.9998 21.3334H29.3331V24.0001H31.9998V21.3334Z",
22
+ fill: "#42526E"
23
+ }), /*#__PURE__*/React.createElement("path", {
24
+ fillRule: "evenodd",
25
+ clipRule: "evenodd",
26
+ d: "M28.6665 29.3333C27.5619 29.3333 26.6665 30.2287 26.6665 31.3333V35.3333C26.6665 36.4379 27.5619 37.3333 28.6665 37.3333H32.6665C33.7711 37.3333 34.6665 36.4379 34.6665 35.3333V31.3333C34.6665 30.2287 33.7711 29.3333 32.6665 29.3333H28.6665ZM31.9998 31.9999H29.3331V34.6666H31.9998V31.9999Z",
27
+ fill: "#42526E"
28
+ }), /*#__PURE__*/React.createElement("path", {
29
+ fillRule: "evenodd",
30
+ clipRule: "evenodd",
31
+ d: "M15.3335 10.6667C14.2289 10.6667 13.3335 11.5621 13.3335 12.6667V16.6667C13.3335 17.7713 14.2289 18.6667 15.3335 18.6667H19.3335C20.4381 18.6667 21.3335 17.7713 21.3335 16.6667V12.6667C21.3335 11.5621 20.4381 10.6667 19.3335 10.6667H15.3335ZM18.6669 13.3334H16.0002V16.0001H18.6669V13.3334Z",
32
+ fill: "#42526E"
33
+ }), /*#__PURE__*/React.createElement("rect", {
34
+ x: "16",
35
+ y: "17.3333",
36
+ width: "2.66667",
37
+ height: "14.6667",
38
+ fill: "#42526E"
39
+ }), /*#__PURE__*/React.createElement("path", {
40
+ d: "M16 32H28V34.6667H18C16.8954 34.6667 16 33.7712 16 32.6667V32Z",
41
+ fill: "#42526E"
42
+ }), /*#__PURE__*/React.createElement("path", {
43
+ d: "M16 21.3333H28V24H18C16.8954 24 16 23.1046 16 22V21.3333Z",
44
+ fill: "#42526E"
45
+ }));
46
+ }
@@ -116,4 +116,8 @@ export const IconExpand = Loadable({
116
116
  export const IconDatasourceJiraIssue = Loadable({
117
117
  loader: () => import( /* webpackChunkName: "@atlaskit-internal_editor-icon-datasource-jira-issue" */'./datasource-jira-issue').then(module => module.default),
118
118
  loading: () => null
119
+ });
120
+ export const IconDatasourceAssetsObjects = Loadable({
121
+ loader: () => import( /* webpackChunkName: "@atlaskit-internal_editor-icon-datasource-assets-objects" */'./datasource-assets-objects').then(module => module.default),
122
+ loading: () => null
119
123
  });
@@ -1 +1 @@
1
- export { IconAction, IconCode, IconDate, IconDecision, IconDivider, IconEmoji, IconImages, IconLayout, IconLink, IconListNumber, IconList, IconMention, IconPanelError, IconPanelNote, IconPanelSuccess, IconPanelWarning, IconPanel, IconQuote, IconStatus, IconHeading, IconFeedback, IconExpand, IconCustomPanel, IconFallback, IconDatasourceJiraIssue } from './assets';
1
+ export { IconAction, IconCode, IconDate, IconDecision, IconDivider, IconEmoji, IconImages, IconLayout, IconLink, IconListNumber, IconList, IconMention, IconPanelError, IconPanelNote, IconPanelSuccess, IconPanelWarning, IconPanel, IconQuote, IconStatus, IconHeading, IconFeedback, IconExpand, IconCustomPanel, IconFallback, IconDatasourceJiraIssue, IconDatasourceAssetsObjects } from './assets';
@@ -1,5 +1,5 @@
1
1
  import _extends from "@babel/runtime/helpers/extends";
2
- import React, { useRef, useState } from 'react';
2
+ import React, { useMemo, useRef, useState } from 'react';
3
3
  import classnames from 'classnames';
4
4
  import { Resizable } from 're-resizable';
5
5
  import { resizerHandleLeftClassName, resizerHandlerClassName, resizerHandleRightClassName, resizerHandleStickyClassName, resizerHandleZIndex, resizerItemClassName } from '../styles/shared/resizer';
@@ -20,6 +20,7 @@ export default function ResizerNext(props) {
20
20
  handleStyles,
21
21
  resizeRatio = 1,
22
22
  innerPadding,
23
+ snap,
23
24
  ...otherProps
24
25
  } = props;
25
26
  const onResizeStart = React.useCallback(event => {
@@ -93,6 +94,15 @@ export default function ResizerNext(props) {
93
94
  const resizerClassName = classnames(className, resizerItemClassName, {
94
95
  'is-resizing': isResizing
95
96
  });
97
+
98
+ // snapGap is usually a constant, if snap.x?.length is 0 and snapGap has a value resizer cannot be resized
99
+ const snapGap = useMemo(() => {
100
+ var _snap$x, _snap$x2;
101
+ if (!snap || ((_snap$x = snap.x) === null || _snap$x === void 0 ? void 0 : _snap$x.length) === 0 && ((_snap$x2 = snap.x) === null || _snap$x2 === void 0 ? void 0 : _snap$x2.length) === 0) {
102
+ return undefined;
103
+ }
104
+ return props.snapGap;
105
+ }, [snap, props.snapGap]);
96
106
  return /*#__PURE__*/React.createElement(Resizable, _extends({
97
107
  ref: resizable,
98
108
  size: {
@@ -106,6 +116,8 @@ export default function ResizerNext(props) {
106
116
  onResizeStart: onResizeStart,
107
117
  onResize: onResize,
108
118
  onResizeStop: onResizeStop,
109
- resizeRatio: resizeRatio
119
+ resizeRatio: resizeRatio,
120
+ snapGap: snapGap,
121
+ snap: snap
110
122
  }, otherProps), children);
111
123
  }
@@ -8,7 +8,7 @@ import { themed } from '@atlaskit/theme/components';
8
8
  import { borderRadius } from '@atlaskit/theme/constants';
9
9
  import Layer from '../Layer';
10
10
  const packageName = "@atlaskit/editor-common";
11
- const packageVersion = "74.26.1";
11
+ const packageVersion = "74.26.3";
12
12
  const halfFocusRing = 1;
13
13
  const dropOffset = '0, 8';
14
14
  class DropList extends Component {
@@ -1,9 +1,11 @@
1
- import { JIRA_LIST_OF_LINKS_DATASOURCE_ID } from '@atlaskit/link-datasource';
1
+ import { ASSETS_LIST_OF_LINKS_DATASOURCE_ID, JIRA_LIST_OF_LINKS_DATASOURCE_ID } from '@atlaskit/link-datasource';
2
2
  import { getBooleanFF } from '@atlaskit/platform-feature-flags';
3
3
  const getDatasourceType = datasourceId => {
4
4
  switch (datasourceId) {
5
5
  case JIRA_LIST_OF_LINKS_DATASOURCE_ID:
6
6
  return 'jira';
7
+ case ASSETS_LIST_OF_LINKS_DATASOURCE_ID:
8
+ return 'assets';
7
9
  default:
8
10
  return undefined;
9
11
  }
@@ -16,6 +18,11 @@ export const canRenderDatasource = (datasourceId, defaultValue = true) => {
16
18
  return true;
17
19
  }
18
20
  return false;
21
+ case 'assets':
22
+ if (getBooleanFF('platform.linking-platform.datasource-assets_objects')) {
23
+ return true;
24
+ }
25
+ return false;
19
26
  default:
20
27
  return defaultValue;
21
28
  }
@@ -1,5 +1,5 @@
1
1
  {
2
2
  "name": "@atlaskit/editor-common",
3
- "version": "74.26.1",
3
+ "version": "74.26.3",
4
4
  "sideEffects": false
5
5
  }
@@ -6,7 +6,7 @@ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (O
6
6
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
7
7
  var SENTRY_DSN = 'https://0b10c8e02fb44d8796c047b102c9bee8@o55978.ingest.sentry.io/4505129224110080';
8
8
  var packageName = 'editor-common'; // Sentry doesn't accept '/' in its releases https://docs.sentry.io/platforms/javascript/configuration/releases/
9
- var packageVersion = "74.26.1";
9
+ var packageVersion = "74.26.3";
10
10
  var sanitiseSentryEvents = function sanitiseSentryEvents(data, _hint) {
11
11
  // Remove URL as it has UGC
12
12
  // TODO: Sanitise the URL instead of just removing it
@@ -0,0 +1,46 @@
1
+ // TODO: https://product-fabric.atlassian.net/browse/DSP-4138
2
+ /* eslint-disable @atlaskit/design-system/ensure-design-token-usage */
3
+ import React from 'react';
4
+ export default function IconDatasourceAssetsObjects() {
5
+ return /*#__PURE__*/React.createElement("svg", {
6
+ width: "48",
7
+ height: "48",
8
+ viewBox: "0 0 48 48",
9
+ fill: "none",
10
+ xmlns: "http://www.w3.org/2000/svg"
11
+ }, /*#__PURE__*/React.createElement("rect", {
12
+ x: "0.5",
13
+ y: "0.5",
14
+ width: "47",
15
+ height: "47",
16
+ rx: "2",
17
+ fill: "white"
18
+ }), /*#__PURE__*/React.createElement("path", {
19
+ fillRule: "evenodd",
20
+ clipRule: "evenodd",
21
+ d: "M28.6665 18.6667C27.5619 18.6667 26.6665 19.5621 26.6665 20.6667V24.6667C26.6665 25.7713 27.5619 26.6667 28.6665 26.6667H32.6665C33.7711 26.6667 34.6665 25.7713 34.6665 24.6667V20.6667C34.6665 19.5621 33.7711 18.6667 32.6665 18.6667H28.6665ZM31.9998 21.3334H29.3331V24.0001H31.9998V21.3334Z",
22
+ fill: "#42526E"
23
+ }), /*#__PURE__*/React.createElement("path", {
24
+ fillRule: "evenodd",
25
+ clipRule: "evenodd",
26
+ d: "M28.6665 29.3333C27.5619 29.3333 26.6665 30.2287 26.6665 31.3333V35.3333C26.6665 36.4379 27.5619 37.3333 28.6665 37.3333H32.6665C33.7711 37.3333 34.6665 36.4379 34.6665 35.3333V31.3333C34.6665 30.2287 33.7711 29.3333 32.6665 29.3333H28.6665ZM31.9998 31.9999H29.3331V34.6666H31.9998V31.9999Z",
27
+ fill: "#42526E"
28
+ }), /*#__PURE__*/React.createElement("path", {
29
+ fillRule: "evenodd",
30
+ clipRule: "evenodd",
31
+ d: "M15.3335 10.6667C14.2289 10.6667 13.3335 11.5621 13.3335 12.6667V16.6667C13.3335 17.7713 14.2289 18.6667 15.3335 18.6667H19.3335C20.4381 18.6667 21.3335 17.7713 21.3335 16.6667V12.6667C21.3335 11.5621 20.4381 10.6667 19.3335 10.6667H15.3335ZM18.6669 13.3334H16.0002V16.0001H18.6669V13.3334Z",
32
+ fill: "#42526E"
33
+ }), /*#__PURE__*/React.createElement("rect", {
34
+ x: "16",
35
+ y: "17.3333",
36
+ width: "2.66667",
37
+ height: "14.6667",
38
+ fill: "#42526E"
39
+ }), /*#__PURE__*/React.createElement("path", {
40
+ d: "M16 32H28V34.6667H18C16.8954 34.6667 16 33.7712 16 32.6667V32Z",
41
+ fill: "#42526E"
42
+ }), /*#__PURE__*/React.createElement("path", {
43
+ d: "M16 21.3333H28V24H18C16.8954 24 16 23.1046 16 22V21.3333Z",
44
+ fill: "#42526E"
45
+ }));
46
+ }
@@ -255,4 +255,14 @@ export var IconDatasourceJiraIssue = Loadable({
255
255
  loading: function loading() {
256
256
  return null;
257
257
  }
258
+ });
259
+ export var IconDatasourceAssetsObjects = Loadable({
260
+ loader: function loader() {
261
+ return import( /* webpackChunkName: "@atlaskit-internal_editor-icon-datasource-assets-objects" */'./datasource-assets-objects').then(function (module) {
262
+ return module.default;
263
+ });
264
+ },
265
+ loading: function loading() {
266
+ return null;
267
+ }
258
268
  });
@@ -1 +1 @@
1
- export { IconAction, IconCode, IconDate, IconDecision, IconDivider, IconEmoji, IconImages, IconLayout, IconLink, IconListNumber, IconList, IconMention, IconPanelError, IconPanelNote, IconPanelSuccess, IconPanelWarning, IconPanel, IconQuote, IconStatus, IconHeading, IconFeedback, IconExpand, IconCustomPanel, IconFallback, IconDatasourceJiraIssue } from './assets';
1
+ export { IconAction, IconCode, IconDate, IconDecision, IconDivider, IconEmoji, IconImages, IconLayout, IconLink, IconListNumber, IconList, IconMention, IconPanelError, IconPanelNote, IconPanelSuccess, IconPanelWarning, IconPanel, IconQuote, IconStatus, IconHeading, IconFeedback, IconExpand, IconCustomPanel, IconFallback, IconDatasourceJiraIssue, IconDatasourceAssetsObjects } from './assets';
@@ -2,10 +2,10 @@ import _extends from "@babel/runtime/helpers/extends";
2
2
  import _defineProperty from "@babel/runtime/helpers/defineProperty";
3
3
  import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
4
4
  import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
5
- var _excluded = ["width", "children", "handleClassName", "className", "handleResize", "handleResizeStart", "handleResizeStop", "handleHeightSize", "handleAlignmentMethod", "handlePositioning", "handleStyles", "resizeRatio", "innerPadding"];
5
+ var _excluded = ["width", "children", "handleClassName", "className", "handleResize", "handleResizeStart", "handleResizeStop", "handleHeightSize", "handleAlignmentMethod", "handlePositioning", "handleStyles", "resizeRatio", "innerPadding", "snap"];
6
6
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
7
7
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
8
- import React, { useRef, useState } from 'react';
8
+ import React, { useMemo, useRef, useState } from 'react';
9
9
  import classnames from 'classnames';
10
10
  import { Resizable } from 're-resizable';
11
11
  import { resizerHandleLeftClassName, resizerHandlerClassName, resizerHandleRightClassName, resizerHandleStickyClassName, resizerHandleZIndex, resizerItemClassName } from '../styles/shared/resizer';
@@ -33,6 +33,7 @@ export default function ResizerNext(props) {
33
33
  _props$resizeRatio = props.resizeRatio,
34
34
  resizeRatio = _props$resizeRatio === void 0 ? 1 : _props$resizeRatio,
35
35
  innerPadding = props.innerPadding,
36
+ snap = props.snap,
36
37
  otherProps = _objectWithoutProperties(props, _excluded);
37
38
  var onResizeStart = React.useCallback(function (event) {
38
39
  // prevent creating a drag event on Firefox
@@ -93,6 +94,15 @@ export default function ResizerNext(props) {
93
94
  var resizerClassName = classnames(className, resizerItemClassName, {
94
95
  'is-resizing': isResizing
95
96
  });
97
+
98
+ // snapGap is usually a constant, if snap.x?.length is 0 and snapGap has a value resizer cannot be resized
99
+ var snapGap = useMemo(function () {
100
+ var _snap$x, _snap$x2;
101
+ if (!snap || ((_snap$x = snap.x) === null || _snap$x === void 0 ? void 0 : _snap$x.length) === 0 && ((_snap$x2 = snap.x) === null || _snap$x2 === void 0 ? void 0 : _snap$x2.length) === 0) {
102
+ return undefined;
103
+ }
104
+ return props.snapGap;
105
+ }, [snap, props.snapGap]);
96
106
  return /*#__PURE__*/React.createElement(Resizable, _extends({
97
107
  ref: resizable,
98
108
  size: {
@@ -106,6 +116,8 @@ export default function ResizerNext(props) {
106
116
  onResizeStart: onResizeStart,
107
117
  onResize: onResize,
108
118
  onResizeStop: onResizeStop,
109
- resizeRatio: resizeRatio
119
+ resizeRatio: resizeRatio,
120
+ snapGap: snapGap,
121
+ snap: snap
110
122
  }, otherProps), children);
111
123
  }
@@ -18,7 +18,7 @@ import { themed } from '@atlaskit/theme/components';
18
18
  import { borderRadius } from '@atlaskit/theme/constants';
19
19
  import Layer from '../Layer';
20
20
  var packageName = "@atlaskit/editor-common";
21
- var packageVersion = "74.26.1";
21
+ var packageVersion = "74.26.3";
22
22
  var halfFocusRing = 1;
23
23
  var dropOffset = '0, 8';
24
24
  var DropList = /*#__PURE__*/function (_Component) {
@@ -1,9 +1,11 @@
1
- import { JIRA_LIST_OF_LINKS_DATASOURCE_ID } from '@atlaskit/link-datasource';
1
+ import { ASSETS_LIST_OF_LINKS_DATASOURCE_ID, JIRA_LIST_OF_LINKS_DATASOURCE_ID } from '@atlaskit/link-datasource';
2
2
  import { getBooleanFF } from '@atlaskit/platform-feature-flags';
3
3
  var getDatasourceType = function getDatasourceType(datasourceId) {
4
4
  switch (datasourceId) {
5
5
  case JIRA_LIST_OF_LINKS_DATASOURCE_ID:
6
6
  return 'jira';
7
+ case ASSETS_LIST_OF_LINKS_DATASOURCE_ID:
8
+ return 'assets';
7
9
  default:
8
10
  return undefined;
9
11
  }
@@ -17,6 +19,11 @@ export var canRenderDatasource = function canRenderDatasource(datasourceId) {
17
19
  return true;
18
20
  }
19
21
  return false;
22
+ case 'assets':
23
+ if (getBooleanFF('platform.linking-platform.datasource-assets_objects')) {
24
+ return true;
25
+ }
26
+ return false;
20
27
  default:
21
28
  return defaultValue;
22
29
  }
@@ -1,5 +1,5 @@
1
1
  {
2
2
  "name": "@atlaskit/editor-common",
3
- "version": "74.26.1",
3
+ "version": "74.26.3",
4
4
  "sideEffects": false
5
5
  }
@@ -0,0 +1,2 @@
1
+ /// <reference types="react" />
2
+ export default function IconDatasourceAssetsObjects(): JSX.Element;
@@ -29,3 +29,4 @@ export declare const IconHeading: ({ level, ...props }: HeadingProps) => JSX.Ele
29
29
  export declare const IconFeedback: React.ComponentType<IconProps> & Loadable.LoadableComponent;
30
30
  export declare const IconExpand: React.ComponentType<IconProps> & Loadable.LoadableComponent;
31
31
  export declare const IconDatasourceJiraIssue: React.ComponentType<IconProps> & Loadable.LoadableComponent;
32
+ export declare const IconDatasourceAssetsObjects: React.ComponentType<IconProps> & Loadable.LoadableComponent;
@@ -1 +1 @@
1
- export { IconAction, IconCode, IconDate, IconDecision, IconDivider, IconEmoji, IconImages, IconLayout, IconLink, IconListNumber, IconList, IconMention, IconPanelError, IconPanelNote, IconPanelSuccess, IconPanelWarning, IconPanel, IconQuote, IconStatus, IconHeading, IconFeedback, IconExpand, IconCustomPanel, IconFallback, IconDatasourceJiraIssue, } from './assets';
1
+ export { IconAction, IconCode, IconDate, IconDecision, IconDivider, IconEmoji, IconImages, IconLayout, IconLink, IconListNumber, IconList, IconMention, IconPanelError, IconPanelNote, IconPanelSuccess, IconPanelWarning, IconPanel, IconQuote, IconStatus, IconHeading, IconFeedback, IconExpand, IconCustomPanel, IconFallback, IconDatasourceJiraIssue, IconDatasourceAssetsObjects, } from './assets';
@@ -1,10 +1,10 @@
1
1
  import React, { PropsWithChildren } from 'react';
2
2
  import { HandleComponent } from 're-resizable';
3
- import { EnabledHandles, HandleAlignmentMethod, HandleHeightSizeType, HandlePositioning, HandleResize, HandleStyles } from './types';
3
+ import { EnabledHandles, HandleAlignmentMethod, HandleHeightSizeType, HandlePositioning, HandleResize, HandleResizeStart, HandleStyles, Snap } from './types';
4
4
  export type ResizerProps = {
5
5
  enable: EnabledHandles;
6
6
  width: number;
7
- handleResizeStart: () => void;
7
+ handleResizeStart: HandleResizeStart;
8
8
  handleResize: HandleResize;
9
9
  handleResizeStop: HandleResize;
10
10
  innerPadding?: number;
@@ -18,10 +18,7 @@ export type ResizerProps = {
18
18
  handlePositioning?: HandlePositioning;
19
19
  handleHeightSize?: HandleHeightSizeType;
20
20
  handleMarginTop?: number;
21
- snap?: {
22
- x?: Array<number>;
23
- y?: Array<number>;
24
- };
21
+ snap?: Snap;
25
22
  snapGap?: number;
26
23
  handleAlignmentMethod?: HandleAlignmentMethod;
27
24
  resizeRatio?: number;
@@ -1,2 +1,2 @@
1
1
  export { default as ResizerNext } from './Resizer';
2
- export type { HandleHeightSizeType, EnabledHandles, HandleResize, } from './types';
2
+ export type { HandleHeightSizeType, EnabledHandles, HandleResize, Position, Snap, HandleResizeStart, } from './types';
@@ -7,10 +7,16 @@ export type Dimensions = {
7
7
  width: number;
8
8
  height: number;
9
9
  };
10
- export type HandleResize = (newWidth: {
10
+ export type Position = {
11
11
  x: number;
12
12
  y: number;
13
- } & Dimensions, delta: Dimensions) => void;
13
+ };
14
+ export type Snap = {
15
+ x?: Array<number>;
16
+ y?: Array<number>;
17
+ };
18
+ export type HandleResize = (newWidth: Position & Dimensions, delta: Dimensions) => void;
19
+ export type HandleResizeStart = () => void;
14
20
  export type HandleStyles = {
15
21
  right?: React.CSSProperties;
16
22
  left?: React.CSSProperties;
@@ -1 +1 @@
1
- export type DatasourceModalType = 'jira';
1
+ export type DatasourceModalType = 'jira' | 'assets';
@@ -0,0 +1,2 @@
1
+ /// <reference types="react" />
2
+ export default function IconDatasourceAssetsObjects(): JSX.Element;
@@ -29,3 +29,4 @@ export declare const IconHeading: ({ level, ...props }: HeadingProps) => JSX.Ele
29
29
  export declare const IconFeedback: React.ComponentType<IconProps> & Loadable.LoadableComponent;
30
30
  export declare const IconExpand: React.ComponentType<IconProps> & Loadable.LoadableComponent;
31
31
  export declare const IconDatasourceJiraIssue: React.ComponentType<IconProps> & Loadable.LoadableComponent;
32
+ export declare const IconDatasourceAssetsObjects: React.ComponentType<IconProps> & Loadable.LoadableComponent;
@@ -1 +1 @@
1
- export { IconAction, IconCode, IconDate, IconDecision, IconDivider, IconEmoji, IconImages, IconLayout, IconLink, IconListNumber, IconList, IconMention, IconPanelError, IconPanelNote, IconPanelSuccess, IconPanelWarning, IconPanel, IconQuote, IconStatus, IconHeading, IconFeedback, IconExpand, IconCustomPanel, IconFallback, IconDatasourceJiraIssue, } from './assets';
1
+ export { IconAction, IconCode, IconDate, IconDecision, IconDivider, IconEmoji, IconImages, IconLayout, IconLink, IconListNumber, IconList, IconMention, IconPanelError, IconPanelNote, IconPanelSuccess, IconPanelWarning, IconPanel, IconQuote, IconStatus, IconHeading, IconFeedback, IconExpand, IconCustomPanel, IconFallback, IconDatasourceJiraIssue, IconDatasourceAssetsObjects, } from './assets';
@@ -1,10 +1,10 @@
1
1
  import React, { PropsWithChildren } from 'react';
2
2
  import { HandleComponent } from 're-resizable';
3
- import { EnabledHandles, HandleAlignmentMethod, HandleHeightSizeType, HandlePositioning, HandleResize, HandleStyles } from './types';
3
+ import { EnabledHandles, HandleAlignmentMethod, HandleHeightSizeType, HandlePositioning, HandleResize, HandleResizeStart, HandleStyles, Snap } from './types';
4
4
  export type ResizerProps = {
5
5
  enable: EnabledHandles;
6
6
  width: number;
7
- handleResizeStart: () => void;
7
+ handleResizeStart: HandleResizeStart;
8
8
  handleResize: HandleResize;
9
9
  handleResizeStop: HandleResize;
10
10
  innerPadding?: number;
@@ -18,10 +18,7 @@ export type ResizerProps = {
18
18
  handlePositioning?: HandlePositioning;
19
19
  handleHeightSize?: HandleHeightSizeType;
20
20
  handleMarginTop?: number;
21
- snap?: {
22
- x?: Array<number>;
23
- y?: Array<number>;
24
- };
21
+ snap?: Snap;
25
22
  snapGap?: number;
26
23
  handleAlignmentMethod?: HandleAlignmentMethod;
27
24
  resizeRatio?: number;
@@ -1,2 +1,2 @@
1
1
  export { default as ResizerNext } from './Resizer';
2
- export type { HandleHeightSizeType, EnabledHandles, HandleResize, } from './types';
2
+ export type { HandleHeightSizeType, EnabledHandles, HandleResize, Position, Snap, HandleResizeStart, } from './types';
@@ -7,10 +7,16 @@ export type Dimensions = {
7
7
  width: number;
8
8
  height: number;
9
9
  };
10
- export type HandleResize = (newWidth: {
10
+ export type Position = {
11
11
  x: number;
12
12
  y: number;
13
- } & Dimensions, delta: Dimensions) => void;
13
+ };
14
+ export type Snap = {
15
+ x?: Array<number>;
16
+ y?: Array<number>;
17
+ };
18
+ export type HandleResize = (newWidth: Position & Dimensions, delta: Dimensions) => void;
19
+ export type HandleResizeStart = () => void;
14
20
  export type HandleStyles = {
15
21
  right?: React.CSSProperties;
16
22
  left?: React.CSSProperties;
@@ -1 +1 @@
1
- export type DatasourceModalType = 'jira';
1
+ export type DatasourceModalType = 'jira' | 'assets';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@atlaskit/editor-common",
3
- "version": "74.26.1",
3
+ "version": "74.26.3",
4
4
  "description": "A package that contains common classes and components for editor and renderer",
5
5
  "publishConfig": {
6
6
  "registry": "https://registry.npmjs.org/"
@@ -87,7 +87,7 @@
87
87
  "@atlaskit/code": "^14.6.0",
88
88
  "@atlaskit/codemod-utils": "^4.2.0",
89
89
  "@atlaskit/editor-palette": "1.5.1",
90
- "@atlaskit/editor-shared-styles": "^2.4.0",
90
+ "@atlaskit/editor-shared-styles": "^2.5.0",
91
91
  "@atlaskit/emoji": "^67.4.0",
92
92
  "@atlaskit/icon": "^21.12.0",
93
93
  "@atlaskit/icon-object": "^6.3.0",
@@ -190,6 +190,9 @@
190
190
  },
191
191
  "platform.linking-platform.datasource-jira_issues": {
192
192
  "type": "boolean"
193
+ },
194
+ "platform.linking-platform.datasource-assets_objects": {
195
+ "type": "boolean"
193
196
  }
194
197
  }
195
198
  }