@atlaskit/editor-common 74.27.0 → 74.27.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 CHANGED
@@ -1,5 +1,11 @@
1
1
  # @atlaskit/editor-common
2
2
 
3
+ ## 74.27.1
4
+
5
+ ### Patch Changes
6
+
7
+ - [`dbf78a2ac7f`](https://bitbucket.org/atlassian/atlassian-frontend/commits/dbf78a2ac7f) - Added snapping utils and tests to editor-common
8
+
3
9
  ## 74.27.0
4
10
 
5
11
  ### Minor Changes
@@ -3,6 +3,12 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
+ Object.defineProperty(exports, "MEDIA_DYNAMIC_GUIDELINE_PREFIX", {
7
+ enumerable: true,
8
+ get: function get() {
9
+ return _constants.MEDIA_DYNAMIC_GUIDELINE_PREFIX;
10
+ }
11
+ });
6
12
  Object.defineProperty(exports, "createFixedGuidelinesFromLengths", {
7
13
  enumerable: true,
8
14
  get: function get() {
@@ -36,4 +42,5 @@ Object.defineProperty(exports, "isVerticalPosition", {
36
42
  var _dynamicGuideline = require("./dynamicGuideline");
37
43
  var _fixedGuideline = require("./fixedGuideline");
38
44
  var _updateGuideline = require("./updateGuideline");
45
+ var _constants = require("./constants");
39
46
  var _utils = require("./utils");
@@ -0,0 +1,75 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.getSnapWidth = exports.findClosestSnap = void 0;
7
+ var _mediaSingle = require("../media-single");
8
+ var _constants = require("./constants");
9
+ /**
10
+ * Returns keys of guidelines that are closest to the image and withthin the snapGap.
11
+ * If both default and dynamic guidelines present, only returns default guidelines
12
+ */
13
+ var findClosestSnap = function findClosestSnap(mediaSingleWidth, snapArray, snapTo) {
14
+ var snapGap = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0;
15
+ var closestGapIndex = snapArray.reduce(function (prev, curr, index) {
16
+ return Math.abs(curr - mediaSingleWidth) < Math.abs(snapArray[prev] - mediaSingleWidth) ? index : prev;
17
+ }, 0);
18
+ var gap = Math.abs(snapArray[closestGapIndex] - mediaSingleWidth);
19
+ if (gap < snapGap) {
20
+ var snappingWidth = Math.round(snapTo[closestGapIndex].width);
21
+ var guidelineKeys = [];
22
+ snapTo.forEach(function (s) {
23
+ if (Math.round(Math.abs(s.width)) === snappingWidth) {
24
+ guidelineKeys.push(s.guidelineKey);
25
+ }
26
+ });
27
+ var defaultGuidelineKeys = guidelineKeys.filter(function (guidelineKey) {
28
+ return !guidelineKey.startsWith(_constants.MEDIA_DYNAMIC_GUIDELINE_PREFIX);
29
+ });
30
+ return {
31
+ gap: gap,
32
+ // only highlight default guidelines
33
+ // when there are both default and dynamic guidelines to be highlighted
34
+ keys: defaultGuidelineKeys.length && defaultGuidelineKeys.length < guidelineKeys.length ? defaultGuidelineKeys : guidelineKeys
35
+ };
36
+ }
37
+ return {
38
+ gap: gap,
39
+ keys: []
40
+ };
41
+ };
42
+
43
+ /**
44
+ * Get snapping widths and respective guideline keys
45
+ */
46
+ exports.findClosestSnap = findClosestSnap;
47
+ var getSnapWidth = function getSnapWidth(guidelines, mediaSingleWidth, snap, layout) {
48
+ return guidelines.map(function (guideline) {
49
+ var _guideline$position;
50
+ var positionX = (_guideline$position = guideline.position) !== null && _guideline$position !== void 0 && _guideline$position.x && typeof guideline.position.x === 'number' ? guideline.position.x : 0;
51
+ if (layout === _mediaSingle.MediaSingleLayout.CENTER || layout === _mediaSingle.MediaSingleLayout.WIDE || layout === _mediaSingle.MediaSingleLayout.FULL_WIDTH) {
52
+ return {
53
+ guidelineKey: guideline.key,
54
+ width: mediaSingleWidth + (snap - positionX) * 2
55
+ };
56
+ } else if (layout === _mediaSingle.MediaSingleLayout.ALIGN_END || layout === _mediaSingle.MediaSingleLayout.WRAP_RIGHT) {
57
+ return {
58
+ guidelineKey: guideline.key,
59
+ width: mediaSingleWidth + (snap - positionX)
60
+ };
61
+ } else if (layout === _mediaSingle.MediaSingleLayout.ALIGN_START || layout === _mediaSingle.MediaSingleLayout.WRAP_LEFT) {
62
+ return {
63
+ guidelineKey: guideline.key,
64
+ width: mediaSingleWidth + positionX - snap
65
+ };
66
+ }
67
+ return {
68
+ guidelineKey: '',
69
+ width: 0
70
+ };
71
+ }).filter(function (guideline) {
72
+ return guideline.guidelineKey !== '';
73
+ });
74
+ };
75
+ exports.getSnapWidth = getSnapWidth;
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.MEDIA_SINGLE_SNAP_GAP = exports.MEDIA_SINGLE_MIN_PIXEL_WIDTH = exports.MEDIA_SINGLE_HIGHLIGHT_GAP = exports.MEDIA_SINGLE_HANDLE_MARGIN = exports.MEDIA_SINGLE_GUTTER_SIZE = void 0;
6
+ exports.MEDIA_SINGLE_SNAP_GAP = exports.MEDIA_SINGLE_MIN_PIXEL_WIDTH = exports.MEDIA_SINGLE_HIGHLIGHT_GAP = exports.MEDIA_SINGLE_HANDLE_MARGIN = exports.MEDIA_SINGLE_GUTTER_SIZE = exports.Layout = void 0;
7
7
  var MEDIA_SINGLE_MIN_PIXEL_WIDTH = 24;
8
8
  exports.MEDIA_SINGLE_MIN_PIXEL_WIDTH = MEDIA_SINGLE_MIN_PIXEL_WIDTH;
9
9
  var MEDIA_SINGLE_SNAP_GAP = 3;
@@ -13,4 +13,15 @@ exports.MEDIA_SINGLE_HIGHLIGHT_GAP = MEDIA_SINGLE_HIGHLIGHT_GAP;
13
13
  var MEDIA_SINGLE_HANDLE_MARGIN = 12;
14
14
  exports.MEDIA_SINGLE_HANDLE_MARGIN = MEDIA_SINGLE_HANDLE_MARGIN;
15
15
  var MEDIA_SINGLE_GUTTER_SIZE = MEDIA_SINGLE_HANDLE_MARGIN * 2;
16
- exports.MEDIA_SINGLE_GUTTER_SIZE = MEDIA_SINGLE_GUTTER_SIZE;
16
+ exports.MEDIA_SINGLE_GUTTER_SIZE = MEDIA_SINGLE_GUTTER_SIZE;
17
+ var Layout = /*#__PURE__*/function (Layout) {
18
+ Layout["FULL_WIDTH"] = "full-width";
19
+ Layout["WIDE"] = "wide";
20
+ Layout["CENTER"] = "center";
21
+ Layout["ALIGN_START"] = "align-start";
22
+ Layout["ALIGN_END"] = "align-end";
23
+ Layout["WRAP_RIGHT"] = "wrap-right";
24
+ Layout["WRAP_LEFT"] = "wrap-left";
25
+ return Layout;
26
+ }({});
27
+ exports.Layout = Layout;
@@ -21,6 +21,12 @@ Object.defineProperty(exports, "MEDIA_SINGLE_SNAP_GAP", {
21
21
  return _constants.MEDIA_SINGLE_SNAP_GAP;
22
22
  }
23
23
  });
24
+ Object.defineProperty(exports, "MediaSingleLayout", {
25
+ enumerable: true,
26
+ get: function get() {
27
+ return _constants.Layout;
28
+ }
29
+ });
24
30
  Object.defineProperty(exports, "getMediaSinglePixelWidth", {
25
31
  enumerable: true,
26
32
  get: function get() {
@@ -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.27.0";
19
+ var packageVersion = "74.27.1";
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
@@ -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.27.0";
27
+ var packageVersion = "74.27.1";
28
28
  var halfFocusRing = 1;
29
29
  var dropOffset = '0, 8';
30
30
  var DropList = /*#__PURE__*/function (_Component) {
@@ -1,5 +1,5 @@
1
1
  {
2
2
  "name": "@atlaskit/editor-common",
3
- "version": "74.27.0",
3
+ "version": "74.27.1",
4
4
  "sideEffects": false
5
5
  }
@@ -1,4 +1,5 @@
1
1
  export { generateDynamicGuidelines } from './dynamicGuideline';
2
2
  export { createFixedGuidelinesFromLengths, createGuidesFromLengths } from './fixedGuideline';
3
3
  export { getGuidelinesWithHighlights } from './updateGuideline';
4
+ export { MEDIA_DYNAMIC_GUIDELINE_PREFIX } from './constants';
4
5
  export { isVerticalPosition } from './utils';
@@ -0,0 +1,60 @@
1
+ import { MediaSingleLayout } from '../media-single';
2
+ import { MEDIA_DYNAMIC_GUIDELINE_PREFIX } from './constants';
3
+ /**
4
+ * Returns keys of guidelines that are closest to the image and withthin the snapGap.
5
+ * If both default and dynamic guidelines present, only returns default guidelines
6
+ */
7
+ export const findClosestSnap = (mediaSingleWidth, snapArray, snapTo, snapGap = 0) => {
8
+ const closestGapIndex = snapArray.reduce((prev, curr, index) => Math.abs(curr - mediaSingleWidth) < Math.abs(snapArray[prev] - mediaSingleWidth) ? index : prev, 0);
9
+ const gap = Math.abs(snapArray[closestGapIndex] - mediaSingleWidth);
10
+ if (gap < snapGap) {
11
+ const snappingWidth = Math.round(snapTo[closestGapIndex].width);
12
+ let guidelineKeys = [];
13
+ snapTo.forEach(s => {
14
+ if (Math.round(Math.abs(s.width)) === snappingWidth) {
15
+ guidelineKeys.push(s.guidelineKey);
16
+ }
17
+ });
18
+ const defaultGuidelineKeys = guidelineKeys.filter(guidelineKey => !guidelineKey.startsWith(MEDIA_DYNAMIC_GUIDELINE_PREFIX));
19
+ return {
20
+ gap,
21
+ // only highlight default guidelines
22
+ // when there are both default and dynamic guidelines to be highlighted
23
+ keys: defaultGuidelineKeys.length && defaultGuidelineKeys.length < guidelineKeys.length ? defaultGuidelineKeys : guidelineKeys
24
+ };
25
+ }
26
+ return {
27
+ gap,
28
+ keys: []
29
+ };
30
+ };
31
+
32
+ /**
33
+ * Get snapping widths and respective guideline keys
34
+ */
35
+ export const getSnapWidth = (guidelines, mediaSingleWidth, snap, layout) => {
36
+ return guidelines.map(guideline => {
37
+ var _guideline$position;
38
+ const positionX = (_guideline$position = guideline.position) !== null && _guideline$position !== void 0 && _guideline$position.x && typeof guideline.position.x === 'number' ? guideline.position.x : 0;
39
+ if (layout === MediaSingleLayout.CENTER || layout === MediaSingleLayout.WIDE || layout === MediaSingleLayout.FULL_WIDTH) {
40
+ return {
41
+ guidelineKey: guideline.key,
42
+ width: mediaSingleWidth + (snap - positionX) * 2
43
+ };
44
+ } else if (layout === MediaSingleLayout.ALIGN_END || layout === MediaSingleLayout.WRAP_RIGHT) {
45
+ return {
46
+ guidelineKey: guideline.key,
47
+ width: mediaSingleWidth + (snap - positionX)
48
+ };
49
+ } else if (layout === MediaSingleLayout.ALIGN_START || layout === MediaSingleLayout.WRAP_LEFT) {
50
+ return {
51
+ guidelineKey: guideline.key,
52
+ width: mediaSingleWidth + positionX - snap
53
+ };
54
+ }
55
+ return {
56
+ guidelineKey: '',
57
+ width: 0
58
+ };
59
+ }).filter(guideline => guideline.guidelineKey !== '');
60
+ };
@@ -2,4 +2,14 @@ export const MEDIA_SINGLE_MIN_PIXEL_WIDTH = 24;
2
2
  export const MEDIA_SINGLE_SNAP_GAP = 3;
3
3
  export const MEDIA_SINGLE_HIGHLIGHT_GAP = 10;
4
4
  export const MEDIA_SINGLE_HANDLE_MARGIN = 12;
5
- export const MEDIA_SINGLE_GUTTER_SIZE = MEDIA_SINGLE_HANDLE_MARGIN * 2;
5
+ export const MEDIA_SINGLE_GUTTER_SIZE = MEDIA_SINGLE_HANDLE_MARGIN * 2;
6
+ export let Layout = /*#__PURE__*/function (Layout) {
7
+ Layout["FULL_WIDTH"] = "full-width";
8
+ Layout["WIDE"] = "wide";
9
+ Layout["CENTER"] = "center";
10
+ Layout["ALIGN_START"] = "align-start";
11
+ Layout["ALIGN_END"] = "align-end";
12
+ Layout["WRAP_RIGHT"] = "wrap-right";
13
+ Layout["WRAP_LEFT"] = "wrap-left";
14
+ return Layout;
15
+ }({});
@@ -1,2 +1,2 @@
1
- export { MEDIA_SINGLE_MIN_PIXEL_WIDTH, MEDIA_SINGLE_SNAP_GAP, MEDIA_SINGLE_HIGHLIGHT_GAP } from './constants';
1
+ export { MEDIA_SINGLE_MIN_PIXEL_WIDTH, MEDIA_SINGLE_SNAP_GAP, MEDIA_SINGLE_HIGHLIGHT_GAP, Layout as MediaSingleLayout } from './constants';
2
2
  export { getMediaSinglePixelWidth } from './utils';
@@ -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.27.0";
3
+ const packageVersion = "74.27.1";
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
@@ -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.27.0";
11
+ const packageVersion = "74.27.1";
12
12
  const halfFocusRing = 1;
13
13
  const dropOffset = '0, 8';
14
14
  class DropList extends Component {
@@ -1,5 +1,5 @@
1
1
  {
2
2
  "name": "@atlaskit/editor-common",
3
- "version": "74.27.0",
3
+ "version": "74.27.1",
4
4
  "sideEffects": false
5
5
  }
@@ -1,4 +1,5 @@
1
1
  export { generateDynamicGuidelines } from './dynamicGuideline';
2
2
  export { createFixedGuidelinesFromLengths, createGuidesFromLengths } from './fixedGuideline';
3
3
  export { getGuidelinesWithHighlights } from './updateGuideline';
4
+ export { MEDIA_DYNAMIC_GUIDELINE_PREFIX } from './constants';
4
5
  export { isVerticalPosition } from './utils';
@@ -0,0 +1,67 @@
1
+ import { MediaSingleLayout } from '../media-single';
2
+ import { MEDIA_DYNAMIC_GUIDELINE_PREFIX } from './constants';
3
+ /**
4
+ * Returns keys of guidelines that are closest to the image and withthin the snapGap.
5
+ * If both default and dynamic guidelines present, only returns default guidelines
6
+ */
7
+ export var findClosestSnap = function findClosestSnap(mediaSingleWidth, snapArray, snapTo) {
8
+ var snapGap = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0;
9
+ var closestGapIndex = snapArray.reduce(function (prev, curr, index) {
10
+ return Math.abs(curr - mediaSingleWidth) < Math.abs(snapArray[prev] - mediaSingleWidth) ? index : prev;
11
+ }, 0);
12
+ var gap = Math.abs(snapArray[closestGapIndex] - mediaSingleWidth);
13
+ if (gap < snapGap) {
14
+ var snappingWidth = Math.round(snapTo[closestGapIndex].width);
15
+ var guidelineKeys = [];
16
+ snapTo.forEach(function (s) {
17
+ if (Math.round(Math.abs(s.width)) === snappingWidth) {
18
+ guidelineKeys.push(s.guidelineKey);
19
+ }
20
+ });
21
+ var defaultGuidelineKeys = guidelineKeys.filter(function (guidelineKey) {
22
+ return !guidelineKey.startsWith(MEDIA_DYNAMIC_GUIDELINE_PREFIX);
23
+ });
24
+ return {
25
+ gap: gap,
26
+ // only highlight default guidelines
27
+ // when there are both default and dynamic guidelines to be highlighted
28
+ keys: defaultGuidelineKeys.length && defaultGuidelineKeys.length < guidelineKeys.length ? defaultGuidelineKeys : guidelineKeys
29
+ };
30
+ }
31
+ return {
32
+ gap: gap,
33
+ keys: []
34
+ };
35
+ };
36
+
37
+ /**
38
+ * Get snapping widths and respective guideline keys
39
+ */
40
+ export var getSnapWidth = function getSnapWidth(guidelines, mediaSingleWidth, snap, layout) {
41
+ return guidelines.map(function (guideline) {
42
+ var _guideline$position;
43
+ var positionX = (_guideline$position = guideline.position) !== null && _guideline$position !== void 0 && _guideline$position.x && typeof guideline.position.x === 'number' ? guideline.position.x : 0;
44
+ if (layout === MediaSingleLayout.CENTER || layout === MediaSingleLayout.WIDE || layout === MediaSingleLayout.FULL_WIDTH) {
45
+ return {
46
+ guidelineKey: guideline.key,
47
+ width: mediaSingleWidth + (snap - positionX) * 2
48
+ };
49
+ } else if (layout === MediaSingleLayout.ALIGN_END || layout === MediaSingleLayout.WRAP_RIGHT) {
50
+ return {
51
+ guidelineKey: guideline.key,
52
+ width: mediaSingleWidth + (snap - positionX)
53
+ };
54
+ } else if (layout === MediaSingleLayout.ALIGN_START || layout === MediaSingleLayout.WRAP_LEFT) {
55
+ return {
56
+ guidelineKey: guideline.key,
57
+ width: mediaSingleWidth + positionX - snap
58
+ };
59
+ }
60
+ return {
61
+ guidelineKey: '',
62
+ width: 0
63
+ };
64
+ }).filter(function (guideline) {
65
+ return guideline.guidelineKey !== '';
66
+ });
67
+ };
@@ -2,4 +2,14 @@ export var MEDIA_SINGLE_MIN_PIXEL_WIDTH = 24;
2
2
  export var MEDIA_SINGLE_SNAP_GAP = 3;
3
3
  export var MEDIA_SINGLE_HIGHLIGHT_GAP = 10;
4
4
  export var MEDIA_SINGLE_HANDLE_MARGIN = 12;
5
- export var MEDIA_SINGLE_GUTTER_SIZE = MEDIA_SINGLE_HANDLE_MARGIN * 2;
5
+ export var MEDIA_SINGLE_GUTTER_SIZE = MEDIA_SINGLE_HANDLE_MARGIN * 2;
6
+ export var Layout = /*#__PURE__*/function (Layout) {
7
+ Layout["FULL_WIDTH"] = "full-width";
8
+ Layout["WIDE"] = "wide";
9
+ Layout["CENTER"] = "center";
10
+ Layout["ALIGN_START"] = "align-start";
11
+ Layout["ALIGN_END"] = "align-end";
12
+ Layout["WRAP_RIGHT"] = "wrap-right";
13
+ Layout["WRAP_LEFT"] = "wrap-left";
14
+ return Layout;
15
+ }({});
@@ -1,2 +1,2 @@
1
- export { MEDIA_SINGLE_MIN_PIXEL_WIDTH, MEDIA_SINGLE_SNAP_GAP, MEDIA_SINGLE_HIGHLIGHT_GAP } from './constants';
1
+ export { MEDIA_SINGLE_MIN_PIXEL_WIDTH, MEDIA_SINGLE_SNAP_GAP, MEDIA_SINGLE_HIGHLIGHT_GAP, Layout as MediaSingleLayout } from './constants';
2
2
  export { getMediaSinglePixelWidth } from './utils';
@@ -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.27.0";
9
+ var packageVersion = "74.27.1";
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
@@ -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.27.0";
21
+ var packageVersion = "74.27.1";
22
22
  var halfFocusRing = 1;
23
23
  var dropOffset = '0, 8';
24
24
  var DropList = /*#__PURE__*/function (_Component) {
@@ -1,5 +1,5 @@
1
1
  {
2
2
  "name": "@atlaskit/editor-common",
3
- "version": "74.27.0",
3
+ "version": "74.27.1",
4
4
  "sideEffects": false
5
5
  }
@@ -1,5 +1,6 @@
1
1
  export { generateDynamicGuidelines } from './dynamicGuideline';
2
2
  export { createFixedGuidelinesFromLengths, createGuidesFromLengths, } from './fixedGuideline';
3
3
  export { getGuidelinesWithHighlights } from './updateGuideline';
4
+ export { MEDIA_DYNAMIC_GUIDELINE_PREFIX } from './constants';
4
5
  export type { WidthTypes, Position, GuidelineConfig, GuidelinePluginState, GuidelinePluginOptions, DisplayGuideline, DisplayGrid, VerticalPosition, HorizontalPosition, } from './types';
5
6
  export { isVerticalPosition } from './utils';
@@ -0,0 +1,18 @@
1
+ import { RichMediaLayout } from '@atlaskit/adf-schema';
2
+ import type { GuidelineConfig } from './types';
3
+ export type SnapTo = {
4
+ guidelineKey: string;
5
+ width: number;
6
+ };
7
+ /**
8
+ * Returns keys of guidelines that are closest to the image and withthin the snapGap.
9
+ * If both default and dynamic guidelines present, only returns default guidelines
10
+ */
11
+ export declare const findClosestSnap: (mediaSingleWidth: number, snapArray: number[], snapTo: SnapTo[], snapGap?: number) => {
12
+ gap: number;
13
+ keys: string[];
14
+ };
15
+ /**
16
+ * Get snapping widths and respective guideline keys
17
+ */
18
+ export declare const getSnapWidth: (guidelines: GuidelineConfig[], mediaSingleWidth: number, snap: number, layout: RichMediaLayout | null) => SnapTo[];
@@ -3,3 +3,12 @@ export declare const MEDIA_SINGLE_SNAP_GAP = 3;
3
3
  export declare const MEDIA_SINGLE_HIGHLIGHT_GAP = 10;
4
4
  export declare const MEDIA_SINGLE_HANDLE_MARGIN = 12;
5
5
  export declare const MEDIA_SINGLE_GUTTER_SIZE: number;
6
+ export declare enum Layout {
7
+ FULL_WIDTH = "full-width",
8
+ WIDE = "wide",
9
+ CENTER = "center",
10
+ ALIGN_START = "align-start",
11
+ ALIGN_END = "align-end",
12
+ WRAP_RIGHT = "wrap-right",
13
+ WRAP_LEFT = "wrap-left"
14
+ }
@@ -1,2 +1,2 @@
1
- export { MEDIA_SINGLE_MIN_PIXEL_WIDTH, MEDIA_SINGLE_SNAP_GAP, MEDIA_SINGLE_HIGHLIGHT_GAP, } from './constants';
1
+ export { MEDIA_SINGLE_MIN_PIXEL_WIDTH, MEDIA_SINGLE_SNAP_GAP, MEDIA_SINGLE_HIGHLIGHT_GAP, Layout as MediaSingleLayout, } from './constants';
2
2
  export { getMediaSinglePixelWidth } from './utils';
@@ -1,5 +1,6 @@
1
1
  export { generateDynamicGuidelines } from './dynamicGuideline';
2
2
  export { createFixedGuidelinesFromLengths, createGuidesFromLengths, } from './fixedGuideline';
3
3
  export { getGuidelinesWithHighlights } from './updateGuideline';
4
+ export { MEDIA_DYNAMIC_GUIDELINE_PREFIX } from './constants';
4
5
  export type { WidthTypes, Position, GuidelineConfig, GuidelinePluginState, GuidelinePluginOptions, DisplayGuideline, DisplayGrid, VerticalPosition, HorizontalPosition, } from './types';
5
6
  export { isVerticalPosition } from './utils';
@@ -0,0 +1,18 @@
1
+ import { RichMediaLayout } from '@atlaskit/adf-schema';
2
+ import type { GuidelineConfig } from './types';
3
+ export type SnapTo = {
4
+ guidelineKey: string;
5
+ width: number;
6
+ };
7
+ /**
8
+ * Returns keys of guidelines that are closest to the image and withthin the snapGap.
9
+ * If both default and dynamic guidelines present, only returns default guidelines
10
+ */
11
+ export declare const findClosestSnap: (mediaSingleWidth: number, snapArray: number[], snapTo: SnapTo[], snapGap?: number) => {
12
+ gap: number;
13
+ keys: string[];
14
+ };
15
+ /**
16
+ * Get snapping widths and respective guideline keys
17
+ */
18
+ export declare const getSnapWidth: (guidelines: GuidelineConfig[], mediaSingleWidth: number, snap: number, layout: RichMediaLayout | null) => SnapTo[];
@@ -3,3 +3,12 @@ export declare const MEDIA_SINGLE_SNAP_GAP = 3;
3
3
  export declare const MEDIA_SINGLE_HIGHLIGHT_GAP = 10;
4
4
  export declare const MEDIA_SINGLE_HANDLE_MARGIN = 12;
5
5
  export declare const MEDIA_SINGLE_GUTTER_SIZE: number;
6
+ export declare enum Layout {
7
+ FULL_WIDTH = "full-width",
8
+ WIDE = "wide",
9
+ CENTER = "center",
10
+ ALIGN_START = "align-start",
11
+ ALIGN_END = "align-end",
12
+ WRAP_RIGHT = "wrap-right",
13
+ WRAP_LEFT = "wrap-left"
14
+ }
@@ -1,2 +1,2 @@
1
- export { MEDIA_SINGLE_MIN_PIXEL_WIDTH, MEDIA_SINGLE_SNAP_GAP, MEDIA_SINGLE_HIGHLIGHT_GAP, } from './constants';
1
+ export { MEDIA_SINGLE_MIN_PIXEL_WIDTH, MEDIA_SINGLE_SNAP_GAP, MEDIA_SINGLE_HIGHLIGHT_GAP, Layout as MediaSingleLayout, } from './constants';
2
2
  export { getMediaSinglePixelWidth } from './utils';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@atlaskit/editor-common",
3
- "version": "74.27.0",
3
+ "version": "74.27.1",
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/"