@atlaskit/editor-common 74.6.0 → 74.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,11 @@
1
1
  # @atlaskit/editor-common
2
2
 
3
+ ## 74.7.0
4
+
5
+ ### Minor Changes
6
+
7
+ - [`89989e06f43`](https://bitbucket.org/atlassian/atlassian-frontend/commits/89989e06f43) - [ux] Adding initial Resizer to table plugin behind a platform feature flag, allowing tables to resize to a custom width. This change also includes the following refactors:- change calcTableWidth function to return number instead of px- allowing tables to use breakout values when allowColumnResize is disabled
8
+
3
9
  ## 74.6.0
4
10
 
5
11
  ### Minor 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.6.0";
19
+ var packageVersion = "74.7.0";
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
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.getParentNodeWidth = void 0;
6
+ exports.layoutToWidth = exports.getTableContainerWidth = exports.getParentNodeWidth = void 0;
7
7
  var _prosemirrorUtils = require("prosemirror-utils");
8
8
  var _editorSharedStyles = require("@atlaskit/editor-shared-styles");
9
9
  var _constants = require("@atlaskit/theme/constants");
@@ -12,10 +12,17 @@ var _layout = require("../styles/shared/layout");
12
12
  var _breakout = require("../utils/breakout");
13
13
  // eslint-disable-next-line @atlaskit/design-system/no-deprecated-imports
14
14
 
15
+ var layoutToWidth = {
16
+ default: _editorSharedStyles.akEditorDefaultLayoutWidth,
17
+ wide: _editorSharedStyles.akEditorWideLayoutWidth,
18
+ 'full-width': _editorSharedStyles.akEditorFullWidthLayoutWidth
19
+ };
20
+
15
21
  /**
16
22
  * Calculates width of parent node of a nested node (inside layouts, extension)
17
23
  * If current node selection is not nested will return undefined
18
24
  */
25
+ exports.layoutToWidth = layoutToWidth;
19
26
  var getParentNodeWidth = function getParentNodeWidth(pos, state, containerWidth, isFullWidthModeEnabled) {
20
27
  if (!pos) {
21
28
  return;
@@ -83,4 +90,11 @@ var getNestedParentNode = function getNestedParentNode(tablePos, state) {
83
90
  };
84
91
  var calcBreakoutNodeWidth = function calcBreakoutNodeWidth(layout, containerWidth, isFullWidthModeEnabled) {
85
92
  return isFullWidthModeEnabled ? Math.min(containerWidth.lineLength, _editorSharedStyles.akEditorFullWidthLayoutWidth) : (0, _breakout.absoluteBreakoutWidth)(layout, containerWidth.width);
86
- };
93
+ };
94
+ var getTableContainerWidth = function getTableContainerWidth(node) {
95
+ if (node.attrs.width) {
96
+ return node.attrs.width;
97
+ }
98
+ return layoutToWidth[node.attrs.layout];
99
+ };
100
+ exports.getTableContainerWidth = getTableContainerWidth;
@@ -19,7 +19,9 @@ function ResizerNext(props) {
19
19
  _props$handlerHeightS = props.handlerHeightSize,
20
20
  handlerHeightSize = _props$handlerHeightS === void 0 ? 'medium' : _props$handlerHeightS,
21
21
  _props$handleAlignmen = props.handleAlignmentMethod,
22
- handleAlignmentMethod = _props$handleAlignmen === void 0 ? 'center' : _props$handleAlignmen;
22
+ handleAlignmentMethod = _props$handleAlignmen === void 0 ? 'center' : _props$handleAlignmen,
23
+ _props$resizeRatio = props.resizeRatio,
24
+ resizeRatio = _props$resizeRatio === void 0 ? 1 : _props$resizeRatio;
23
25
  var onResizeStart = _react.default.useCallback(function (event) {
24
26
  // prevent creating a drag event on Firefox
25
27
  event.preventDefault();
@@ -90,6 +92,7 @@ function ResizerNext(props) {
90
92
  ,
91
93
  onResizeStart: onResizeStart,
92
94
  onResize: onResize,
93
- onResizeStop: onResizeStop
95
+ onResizeStop: onResizeStop,
96
+ resizeRatio: resizeRatio
94
97
  }, props.children);
95
98
  }
@@ -41,5 +41,5 @@ var resizerHandlerClassName = {
41
41
  large: resizerHandlerLargeClassName
42
42
  };
43
43
  exports.resizerHandlerClassName = resizerHandlerClassName;
44
- var resizerStyles = (0, _react.css)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2.default)(["\n .", " {\n background: ", ";\n }\n\n .", ", .", " {\n display: flex;\n flex-direction: column;\n justify-content: center;\n }\n\n .", " {\n align-items: flex-end;\n }\n\n .", " {\n align-items: flex-start;\n }\n\n .", "::after,\n .", "::after {\n content: ' ';\n display: flex;\n width: 3px;\n height: 64px;\n\n border-radius: 6px;\n }\n\n .", ":hover\n .", "::after,\n .", ":hover\n .", "::after {\n background: ", ";\n }\n\n .", "\n .", "::after,\n .", "\n .", "::after,\n .", "\n .", ":hover::after,\n .", "\n .", ":hover::after,\n .", ".is-resizing\n .", "::after,\n .", ".is-resizing\n .", "::after {\n background: ", ";\n }\n\n .", ".", "::after,\n .", ".", "::after {\n height: 64px;\n }\n\n .", ".", "::after,\n .", ".", "::after {\n height: 43px;\n }\n\n .", ".", "::after,\n .", ".", "::after {\n height: 96px;\n }\n\n .", ".", "::after,\n .", ".", "::after {\n position: sticky;\n top: 10px;\n bottom: 10px;\n }\n"])), resizerItemClassName, "var(--ds-border-focused, ".concat(_colors.B200, ")"), resizerHandleRightClassName, resizerHandleLeftClassName, resizerHandleRightClassName, resizerHandleLeftClassName, resizerHandleRightClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleRightClassName, "var(--ds-border, ".concat(_colors.N60, ")"), akEditorSelectedNodeClassName, resizerHandleRightClassName, akEditorSelectedNodeClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleRightClassName, resizerItemClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleRightClassName, resizerItemClassName, resizerHandleLeftClassName, "var(--ds-border-focused, ".concat(_colors.B200, ")"), resizerHandleRightClassName, resizerHandlerClassName.medium, resizerHandleLeftClassName, resizerHandlerClassName.medium, resizerHandleRightClassName, resizerHandlerClassName.small, resizerHandleLeftClassName, resizerHandlerClassName.small, resizerHandleRightClassName, resizerHandlerClassName.large, resizerHandleLeftClassName, resizerHandlerClassName.large, resizerHandleRightClassName, resizerHandleStickyClassName, resizerHandleLeftClassName, resizerHandleStickyClassName);
44
+ var resizerStyles = (0, _react.css)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2.default)(["\n .", ", .", " {\n display: flex;\n visibility: hidden;\n flex-direction: column;\n justify-content: center;\n }\n\n .", " {\n align-items: flex-end;\n }\n\n .", " {\n align-items: flex-start;\n }\n\n .", "::after,\n .", "::after {\n content: ' ';\n display: flex;\n width: 3px;\n height: 64px;\n\n border-radius: 6px;\n }\n\n .", ":hover\n .", ",\n .", ":hover\n .", " {\n visibility: visible;\n }\n\n .", ":hover\n .", "::after,\n .", ":hover\n .", "::after {\n background: ", ";\n }\n\n .", "\n .", "::after,\n .", "\n .", "::after,\n .", "\n .", ":hover::after,\n .", "\n .", ":hover::after,\n .", ".is-resizing\n .", "::after,\n .", ".is-resizing\n .", "::after {\n background: ", ";\n }\n\n .", ".", "::after,\n .", ".", "::after {\n height: 64px;\n }\n\n .", ".", "::after,\n .", ".", "::after {\n height: 43px;\n }\n\n .", ".", "::after,\n .", ".", "::after {\n height: 96px;\n }\n\n .", ".", "::after,\n .", ".", "::after {\n position: sticky;\n top: 10px;\n bottom: 10px;\n }\n"])), resizerHandleRightClassName, resizerHandleLeftClassName, resizerHandleRightClassName, resizerHandleLeftClassName, resizerHandleRightClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleRightClassName, resizerItemClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleRightClassName, "var(--ds-border, ".concat(_colors.N60, ")"), akEditorSelectedNodeClassName, resizerHandleRightClassName, akEditorSelectedNodeClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleRightClassName, resizerItemClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleRightClassName, resizerItemClassName, resizerHandleLeftClassName, "var(--ds-border-focused, ".concat(_colors.B200, ")"), resizerHandleRightClassName, resizerHandlerClassName.medium, resizerHandleLeftClassName, resizerHandlerClassName.medium, resizerHandleRightClassName, resizerHandlerClassName.small, resizerHandleLeftClassName, resizerHandlerClassName.small, resizerHandleRightClassName, resizerHandlerClassName.large, resizerHandleLeftClassName, resizerHandlerClassName.large, resizerHandleRightClassName, resizerHandleStickyClassName, resizerHandleLeftClassName, resizerHandleStickyClassName);
45
45
  exports.resizerStyles = resizerStyles;
@@ -49,7 +49,8 @@ var TableSharedCssClassName = {
49
49
  TABLE_CELL_WRAPPER: _adfSchema.tableCellSelector,
50
50
  TABLE_HEADER_CELL_WRAPPER: _adfSchema.tableHeaderSelector,
51
51
  TABLE_ROW_CONTROLS_WRAPPER: "".concat(_adfSchema.tablePrefixSelector, "-row-controls-wrapper"),
52
- TABLE_COLUMN_CONTROLS_DECORATIONS: "".concat(_adfSchema.tablePrefixSelector, "-column-controls-decoration")
52
+ TABLE_COLUMN_CONTROLS_DECORATIONS: "".concat(_adfSchema.tablePrefixSelector, "-column-controls-decoration"),
53
+ TABLE_RESIZER_CONTAINER: "".concat(_adfSchema.tablePrefixSelector, "-resizer-container")
53
54
  };
54
55
  exports.TableSharedCssClassName = TableSharedCssClassName;
55
56
  var tableSharedStyle = function tableSharedStyle(props) {
@@ -98,12 +99,12 @@ var calcTableWidth = function calcTableWidth(layout, containerWidth) {
98
99
  var addControllerPadding = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;
99
100
  switch (layout) {
100
101
  case 'full-width':
101
- return containerWidth ? "".concat(Math.min(containerWidth - (addControllerPadding ? _editorSharedStyles.akEditorBreakoutPadding : 0), _editorSharedStyles.akEditorFullWidthLayoutWidth), "px") : "".concat(_editorSharedStyles.akEditorFullWidthLayoutWidth, "px");
102
+ return containerWidth ? Math.min(containerWidth - (addControllerPadding ? _editorSharedStyles.akEditorBreakoutPadding : 0), _editorSharedStyles.akEditorFullWidthLayoutWidth) : _editorSharedStyles.akEditorFullWidthLayoutWidth;
102
103
  case 'wide':
103
104
  if (containerWidth) {
104
- return "".concat(Math.min(containerWidth - (addControllerPadding ? _editorSharedStyles.akEditorBreakoutPadding : 0), _editorSharedStyles.akEditorWideLayoutWidth), "px");
105
+ return Math.min(containerWidth - (addControllerPadding ? _editorSharedStyles.akEditorBreakoutPadding : 0), _editorSharedStyles.akEditorWideLayoutWidth);
105
106
  }
106
- return "".concat(_editorSharedStyles.akEditorWideLayoutWidth, "px");
107
+ return _editorSharedStyles.akEditorWideLayoutWidth;
107
108
  default:
108
109
  return 'inherit';
109
110
  }
@@ -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.6.0";
27
+ var packageVersion = "74.7.0";
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.6.0",
3
+ "version": "74.7.0",
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.6.0";
3
+ const packageVersion = "74.7.0";
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
@@ -1,10 +1,15 @@
1
1
  import { findParentNodeOfTypeClosestToPos } from 'prosemirror-utils';
2
- import { akEditorFullWidthLayoutWidth, akLayoutGutterOffset, gridMediumMaxWidth } from '@atlaskit/editor-shared-styles';
2
+ import { akEditorDefaultLayoutWidth, akEditorFullWidthLayoutWidth, akEditorWideLayoutWidth, akLayoutGutterOffset, gridMediumMaxWidth } from '@atlaskit/editor-shared-styles';
3
3
  // eslint-disable-next-line @atlaskit/design-system/no-deprecated-imports
4
4
  import { gridSize } from '@atlaskit/theme/constants';
5
5
  import { BODIED_EXT_PADDING } from '../styles/shared/extension';
6
6
  import { LAYOUT_COLUMN_PADDING, LAYOUT_SECTION_MARGIN } from '../styles/shared/layout';
7
7
  import { absoluteBreakoutWidth } from '../utils/breakout';
8
+ export const layoutToWidth = {
9
+ default: akEditorDefaultLayoutWidth,
10
+ wide: akEditorWideLayoutWidth,
11
+ 'full-width': akEditorFullWidthLayoutWidth
12
+ };
8
13
 
9
14
  /**
10
15
  * Calculates width of parent node of a nested node (inside layouts, extension)
@@ -78,4 +83,10 @@ const getNestedParentNode = (tablePos, state) => {
78
83
  };
79
84
  const calcBreakoutNodeWidth = (layout, containerWidth, isFullWidthModeEnabled) => {
80
85
  return isFullWidthModeEnabled ? Math.min(containerWidth.lineLength, akEditorFullWidthLayoutWidth) : absoluteBreakoutWidth(layout, containerWidth.width);
86
+ };
87
+ export const getTableContainerWidth = node => {
88
+ if (node.attrs.width) {
89
+ return node.attrs.width;
90
+ }
91
+ return layoutToWidth[node.attrs.layout];
81
92
  };
@@ -9,7 +9,8 @@ export default function ResizerNext(props) {
9
9
  handleResizeStart,
10
10
  handleResizeStop,
11
11
  handlerHeightSize = 'medium',
12
- handleAlignmentMethod = 'center'
12
+ handleAlignmentMethod = 'center',
13
+ resizeRatio = 1
13
14
  } = props;
14
15
  const onResizeStart = React.useCallback(event => {
15
16
  // prevent creating a drag event on Firefox
@@ -91,6 +92,7 @@ export default function ResizerNext(props) {
91
92
  ,
92
93
  onResizeStart: onResizeStart,
93
94
  onResize: onResize,
94
- onResizeStop: onResizeStop
95
+ onResizeStop: onResizeStop,
96
+ resizeRatio: resizeRatio
95
97
  }, props.children);
96
98
  }
@@ -23,12 +23,9 @@ export const resizerHandlerClassName = {
23
23
  large: resizerHandlerLargeClassName
24
24
  };
25
25
  export const resizerStyles = css`
26
- .${resizerItemClassName} {
27
- background: ${`var(--ds-border-focused, ${B200})`};
28
- }
29
-
30
26
  .${resizerHandleRightClassName}, .${resizerHandleLeftClassName} {
31
27
  display: flex;
28
+ visibility: hidden;
32
29
  flex-direction: column;
33
30
  justify-content: center;
34
31
  }
@@ -51,6 +48,13 @@ export const resizerStyles = css`
51
48
  border-radius: 6px;
52
49
  }
53
50
 
51
+ .${resizerItemClassName}:hover
52
+ .${resizerHandleLeftClassName},
53
+ .${resizerItemClassName}:hover
54
+ .${resizerHandleRightClassName} {
55
+ visibility: visible;
56
+ }
57
+
54
58
  .${resizerItemClassName}:hover
55
59
  .${resizerHandleLeftClassName}::after,
56
60
  .${resizerItemClassName}:hover
@@ -32,7 +32,8 @@ export const TableSharedCssClassName = {
32
32
  TABLE_CELL_WRAPPER: tableCellSelector,
33
33
  TABLE_HEADER_CELL_WRAPPER: tableHeaderSelector,
34
34
  TABLE_ROW_CONTROLS_WRAPPER: `${tablePrefixSelector}-row-controls-wrapper`,
35
- TABLE_COLUMN_CONTROLS_DECORATIONS: `${tablePrefixSelector}-column-controls-decoration`
35
+ TABLE_COLUMN_CONTROLS_DECORATIONS: `${tablePrefixSelector}-column-controls-decoration`,
36
+ TABLE_RESIZER_CONTAINER: `${tablePrefixSelector}-resizer-container`
36
37
  };
37
38
  const tableSharedStyle = props => css`
38
39
  ${tableCellBackgroundStyleOverride()}
@@ -206,12 +207,12 @@ const tableSharedStyle = props => css`
206
207
  export const calcTableWidth = (layout, containerWidth, addControllerPadding = true) => {
207
208
  switch (layout) {
208
209
  case 'full-width':
209
- return containerWidth ? `${Math.min(containerWidth - (addControllerPadding ? akEditorBreakoutPadding : 0), akEditorFullWidthLayoutWidth)}px` : `${akEditorFullWidthLayoutWidth}px`;
210
+ return containerWidth ? Math.min(containerWidth - (addControllerPadding ? akEditorBreakoutPadding : 0), akEditorFullWidthLayoutWidth) : akEditorFullWidthLayoutWidth;
210
211
  case 'wide':
211
212
  if (containerWidth) {
212
- return `${Math.min(containerWidth - (addControllerPadding ? akEditorBreakoutPadding : 0), akEditorWideLayoutWidth)}px`;
213
+ return Math.min(containerWidth - (addControllerPadding ? akEditorBreakoutPadding : 0), akEditorWideLayoutWidth);
213
214
  }
214
- return `${akEditorWideLayoutWidth}px`;
215
+ return akEditorWideLayoutWidth;
215
216
  default:
216
217
  return 'inherit';
217
218
  }
@@ -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.6.0";
11
+ const packageVersion = "74.7.0";
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.6.0",
3
+ "version": "74.7.0",
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.6.0";
9
+ var packageVersion = "74.7.0";
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
@@ -1,10 +1,15 @@
1
1
  import { findParentNodeOfTypeClosestToPos } from 'prosemirror-utils';
2
- import { akEditorFullWidthLayoutWidth, akLayoutGutterOffset, gridMediumMaxWidth } from '@atlaskit/editor-shared-styles';
2
+ import { akEditorDefaultLayoutWidth, akEditorFullWidthLayoutWidth, akEditorWideLayoutWidth, akLayoutGutterOffset, gridMediumMaxWidth } from '@atlaskit/editor-shared-styles';
3
3
  // eslint-disable-next-line @atlaskit/design-system/no-deprecated-imports
4
4
  import { gridSize } from '@atlaskit/theme/constants';
5
5
  import { BODIED_EXT_PADDING } from '../styles/shared/extension';
6
6
  import { LAYOUT_COLUMN_PADDING, LAYOUT_SECTION_MARGIN } from '../styles/shared/layout';
7
7
  import { absoluteBreakoutWidth } from '../utils/breakout';
8
+ export var layoutToWidth = {
9
+ default: akEditorDefaultLayoutWidth,
10
+ wide: akEditorWideLayoutWidth,
11
+ 'full-width': akEditorFullWidthLayoutWidth
12
+ };
8
13
 
9
14
  /**
10
15
  * Calculates width of parent node of a nested node (inside layouts, extension)
@@ -76,4 +81,10 @@ var getNestedParentNode = function getNestedParentNode(tablePos, state) {
76
81
  };
77
82
  var calcBreakoutNodeWidth = function calcBreakoutNodeWidth(layout, containerWidth, isFullWidthModeEnabled) {
78
83
  return isFullWidthModeEnabled ? Math.min(containerWidth.lineLength, akEditorFullWidthLayoutWidth) : absoluteBreakoutWidth(layout, containerWidth.width);
84
+ };
85
+ export var getTableContainerWidth = function getTableContainerWidth(node) {
86
+ if (node.attrs.width) {
87
+ return node.attrs.width;
88
+ }
89
+ return layoutToWidth[node.attrs.layout];
79
90
  };
@@ -12,7 +12,9 @@ export default function ResizerNext(props) {
12
12
  _props$handlerHeightS = props.handlerHeightSize,
13
13
  handlerHeightSize = _props$handlerHeightS === void 0 ? 'medium' : _props$handlerHeightS,
14
14
  _props$handleAlignmen = props.handleAlignmentMethod,
15
- handleAlignmentMethod = _props$handleAlignmen === void 0 ? 'center' : _props$handleAlignmen;
15
+ handleAlignmentMethod = _props$handleAlignmen === void 0 ? 'center' : _props$handleAlignmen,
16
+ _props$resizeRatio = props.resizeRatio,
17
+ resizeRatio = _props$resizeRatio === void 0 ? 1 : _props$resizeRatio;
16
18
  var onResizeStart = React.useCallback(function (event) {
17
19
  // prevent creating a drag event on Firefox
18
20
  event.preventDefault();
@@ -83,6 +85,7 @@ export default function ResizerNext(props) {
83
85
  ,
84
86
  onResizeStart: onResizeStart,
85
87
  onResize: onResize,
86
- onResizeStop: onResizeStop
88
+ onResizeStop: onResizeStop,
89
+ resizeRatio: resizeRatio
87
90
  }, props.children);
88
91
  }
@@ -24,4 +24,4 @@ export var resizerHandlerClassName = {
24
24
  medium: resizerHandlerMediumClassName,
25
25
  large: resizerHandlerLargeClassName
26
26
  };
27
- export var resizerStyles = css(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n .", " {\n background: ", ";\n }\n\n .", ", .", " {\n display: flex;\n flex-direction: column;\n justify-content: center;\n }\n\n .", " {\n align-items: flex-end;\n }\n\n .", " {\n align-items: flex-start;\n }\n\n .", "::after,\n .", "::after {\n content: ' ';\n display: flex;\n width: 3px;\n height: 64px;\n\n border-radius: 6px;\n }\n\n .", ":hover\n .", "::after,\n .", ":hover\n .", "::after {\n background: ", ";\n }\n\n .", "\n .", "::after,\n .", "\n .", "::after,\n .", "\n .", ":hover::after,\n .", "\n .", ":hover::after,\n .", ".is-resizing\n .", "::after,\n .", ".is-resizing\n .", "::after {\n background: ", ";\n }\n\n .", ".", "::after,\n .", ".", "::after {\n height: 64px;\n }\n\n .", ".", "::after,\n .", ".", "::after {\n height: 43px;\n }\n\n .", ".", "::after,\n .", ".", "::after {\n height: 96px;\n }\n\n .", ".", "::after,\n .", ".", "::after {\n position: sticky;\n top: 10px;\n bottom: 10px;\n }\n"])), resizerItemClassName, "var(--ds-border-focused, ".concat(B200, ")"), resizerHandleRightClassName, resizerHandleLeftClassName, resizerHandleRightClassName, resizerHandleLeftClassName, resizerHandleRightClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleRightClassName, "var(--ds-border, ".concat(N60, ")"), akEditorSelectedNodeClassName, resizerHandleRightClassName, akEditorSelectedNodeClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleRightClassName, resizerItemClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleRightClassName, resizerItemClassName, resizerHandleLeftClassName, "var(--ds-border-focused, ".concat(B200, ")"), resizerHandleRightClassName, resizerHandlerClassName.medium, resizerHandleLeftClassName, resizerHandlerClassName.medium, resizerHandleRightClassName, resizerHandlerClassName.small, resizerHandleLeftClassName, resizerHandlerClassName.small, resizerHandleRightClassName, resizerHandlerClassName.large, resizerHandleLeftClassName, resizerHandlerClassName.large, resizerHandleRightClassName, resizerHandleStickyClassName, resizerHandleLeftClassName, resizerHandleStickyClassName);
27
+ export var resizerStyles = css(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n .", ", .", " {\n display: flex;\n visibility: hidden;\n flex-direction: column;\n justify-content: center;\n }\n\n .", " {\n align-items: flex-end;\n }\n\n .", " {\n align-items: flex-start;\n }\n\n .", "::after,\n .", "::after {\n content: ' ';\n display: flex;\n width: 3px;\n height: 64px;\n\n border-radius: 6px;\n }\n\n .", ":hover\n .", ",\n .", ":hover\n .", " {\n visibility: visible;\n }\n\n .", ":hover\n .", "::after,\n .", ":hover\n .", "::after {\n background: ", ";\n }\n\n .", "\n .", "::after,\n .", "\n .", "::after,\n .", "\n .", ":hover::after,\n .", "\n .", ":hover::after,\n .", ".is-resizing\n .", "::after,\n .", ".is-resizing\n .", "::after {\n background: ", ";\n }\n\n .", ".", "::after,\n .", ".", "::after {\n height: 64px;\n }\n\n .", ".", "::after,\n .", ".", "::after {\n height: 43px;\n }\n\n .", ".", "::after,\n .", ".", "::after {\n height: 96px;\n }\n\n .", ".", "::after,\n .", ".", "::after {\n position: sticky;\n top: 10px;\n bottom: 10px;\n }\n"])), resizerHandleRightClassName, resizerHandleLeftClassName, resizerHandleRightClassName, resizerHandleLeftClassName, resizerHandleRightClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleRightClassName, resizerItemClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleRightClassName, "var(--ds-border, ".concat(N60, ")"), akEditorSelectedNodeClassName, resizerHandleRightClassName, akEditorSelectedNodeClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleRightClassName, resizerItemClassName, resizerHandleLeftClassName, resizerItemClassName, resizerHandleRightClassName, resizerItemClassName, resizerHandleLeftClassName, "var(--ds-border-focused, ".concat(B200, ")"), resizerHandleRightClassName, resizerHandlerClassName.medium, resizerHandleLeftClassName, resizerHandlerClassName.medium, resizerHandleRightClassName, resizerHandlerClassName.small, resizerHandleLeftClassName, resizerHandlerClassName.small, resizerHandleRightClassName, resizerHandlerClassName.large, resizerHandleLeftClassName, resizerHandlerClassName.large, resizerHandleRightClassName, resizerHandleStickyClassName, resizerHandleLeftClassName, resizerHandleStickyClassName);
@@ -34,7 +34,8 @@ export var TableSharedCssClassName = {
34
34
  TABLE_CELL_WRAPPER: tableCellSelector,
35
35
  TABLE_HEADER_CELL_WRAPPER: tableHeaderSelector,
36
36
  TABLE_ROW_CONTROLS_WRAPPER: "".concat(tablePrefixSelector, "-row-controls-wrapper"),
37
- TABLE_COLUMN_CONTROLS_DECORATIONS: "".concat(tablePrefixSelector, "-column-controls-decoration")
37
+ TABLE_COLUMN_CONTROLS_DECORATIONS: "".concat(tablePrefixSelector, "-column-controls-decoration"),
38
+ TABLE_RESIZER_CONTAINER: "".concat(tablePrefixSelector, "-resizer-container")
38
39
  };
39
40
  var tableSharedStyle = function tableSharedStyle(props) {
40
41
  return css(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n ", "\n .", " {\n position: relative;\n margin: 0 auto ", "px;\n box-sizing: border-box;\n\n /**\n * Fix block top alignment inside table cells.\n */\n .decisionItemView-content-wrap:first-of-type > div {\n margin-top: 0;\n }\n }\n .", "[data-number-column='true'] {\n padding-left: ", "px;\n clear: both;\n }\n .", " > table {\n margin: ", "px 0 0 0;\n }\n\n .", " > table,\n .", " > table {\n margin: ", "px ", "px 0 0;\n }\n\n /* avoid applying styles to nested tables (possible via extensions) */\n .", " > table,\n .", " > table,\n .", " > table {\n border-collapse: collapse;\n border: ", "px solid\n ", ";\n table-layout: fixed;\n font-size: 1em;\n width: 100%;\n\n &[data-autosize='true'] {\n table-layout: auto;\n }\n\n & {\n * {\n box-sizing: border-box;\n }\n hr {\n box-sizing: content-box;\n }\n\n tbody {\n border-bottom: none;\n }\n th td {\n background-color: ", ";\n }\n th,\n td {\n min-width: ", "px;\n font-weight: normal;\n vertical-align: top;\n border: 1px solid\n ", ";\n border-right-width: 0;\n border-bottom-width: 0;\n padding: ", "px;\n /* https://stackoverflow.com/questions/7517127/borders-not-shown-in-firefox-with-border-collapse-on-table-position-relative-o */\n ", "\n\n ", ";\n\n > :first-child:not(style),\n > style:first-child + * {\n margin-top: 0;\n }\n\n > .ProseMirror-gapcursor:first-child + *,\n > style:first-child + .ProseMirror-gapcursor + * {\n margin-top: 0;\n }\n\n > .ProseMirror-gapcursor:first-child + span + *,\n > style:first-child + .ProseMirror-gapcursor + span + * {\n margin-top: 0;\n }\n\n th p:not(:first-of-type),\n td p:not(:first-of-type) {\n margin-top: 12px;\n }\n }\n th {\n background-color: ", ";\n text-align: left;\n\n /* only apply this styling to codeblocks in default background headercells */\n /* TODO this needs to be overhauled as it relies on unsafe selectors */\n &:not([style]):not(.danger) {\n .", ":not(.danger) {\n background-color: ", ";\n\n :not(.", ") {\n box-shadow: 0px 0px 0px 1px\n ", ";\n }\n\n .", " {\n background-image: ", ";\n\n background-color: ", ";\n }\n\n .", " {\n background-color: ", ";\n }\n\n /* this is only relevant to the element taken care of by renderer */\n > [data-ds--code--code-block] {\n background-image: ", "!important;\n\n background-color: ", "!important;\n\n // selector lives inside @atlaskit/code\n --ds--code--line-number-bg-color: ", ";\n }\n }\n }\n }\n }\n }\n"])), tableCellBackgroundStyleOverride(), TableSharedCssClassName.TABLE_CONTAINER, tableMarginBottom, TableSharedCssClassName.TABLE_CONTAINER, akEditorTableNumberColumnWidth - 1, TableSharedCssClassName.TABLE_NODE_WRAPPER, tableMarginTop, TableSharedCssClassName.TABLE_CONTAINER, TableSharedCssClassName.TABLE_STICKY_WRAPPER, tableMarginTop, tableMarginSides, TableSharedCssClassName.TABLE_CONTAINER, TableSharedCssClassName.TABLE_NODE_WRAPPER, TableSharedCssClassName.TABLE_STICKY_WRAPPER, tableCellBorderWidth, themed({
@@ -81,12 +82,12 @@ export var calcTableWidth = function calcTableWidth(layout, containerWidth) {
81
82
  var addControllerPadding = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;
82
83
  switch (layout) {
83
84
  case 'full-width':
84
- return containerWidth ? "".concat(Math.min(containerWidth - (addControllerPadding ? akEditorBreakoutPadding : 0), akEditorFullWidthLayoutWidth), "px") : "".concat(akEditorFullWidthLayoutWidth, "px");
85
+ return containerWidth ? Math.min(containerWidth - (addControllerPadding ? akEditorBreakoutPadding : 0), akEditorFullWidthLayoutWidth) : akEditorFullWidthLayoutWidth;
85
86
  case 'wide':
86
87
  if (containerWidth) {
87
- return "".concat(Math.min(containerWidth - (addControllerPadding ? akEditorBreakoutPadding : 0), akEditorWideLayoutWidth), "px");
88
+ return Math.min(containerWidth - (addControllerPadding ? akEditorBreakoutPadding : 0), akEditorWideLayoutWidth);
88
89
  }
89
- return "".concat(akEditorWideLayoutWidth, "px");
90
+ return akEditorWideLayoutWidth;
90
91
  default:
91
92
  return 'inherit';
92
93
  }
@@ -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.6.0";
21
+ var packageVersion = "74.7.0";
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.6.0",
3
+ "version": "74.7.0",
4
4
  "sideEffects": false
5
5
  }
@@ -1,7 +1,14 @@
1
+ import { Node as PMNode } from 'prosemirror-model';
1
2
  import { EditorState } from 'prosemirror-state';
2
3
  import type { EditorContainerWidth } from '../types/editor-container-width';
4
+ export declare const layoutToWidth: {
5
+ default: number;
6
+ wide: number;
7
+ 'full-width': number;
8
+ };
3
9
  /**
4
10
  * Calculates width of parent node of a nested node (inside layouts, extension)
5
11
  * If current node selection is not nested will return undefined
6
12
  */
7
13
  export declare const getParentNodeWidth: (pos: number | undefined, state: EditorState, containerWidth: EditorContainerWidth, isFullWidthModeEnabled?: boolean) => any;
14
+ export declare const getTableContainerWidth: (node: PMNode) => number;
@@ -20,5 +20,6 @@ export type ResizerProps = {
20
20
  handleComponent?: HandleComponent;
21
21
  handlerHeightSize?: HandlerHeightSizeType;
22
22
  handleAlignmentMethod?: HandleAlignmentMethod;
23
+ resizeRatio?: number;
23
24
  };
24
25
  export default function ResizerNext(props: PropsWithChildren<ResizerProps>): JSX.Element;
@@ -25,7 +25,8 @@ export declare const TableSharedCssClassName: {
25
25
  TABLE_HEADER_CELL_WRAPPER: string;
26
26
  TABLE_ROW_CONTROLS_WRAPPER: string;
27
27
  TABLE_COLUMN_CONTROLS_DECORATIONS: string;
28
+ TABLE_RESIZER_CONTAINER: string;
28
29
  };
29
30
  declare const tableSharedStyle: (props: ThemeProps) => import("@emotion/react").SerializedStyles;
30
- export declare const calcTableWidth: (layout: TableLayout, containerWidth?: number, addControllerPadding?: boolean) => string;
31
+ export declare const calcTableWidth: (layout: TableLayout, containerWidth?: number, addControllerPadding?: boolean) => number | 'inherit';
31
32
  export { tableSharedStyle };
@@ -1,7 +1,14 @@
1
+ import { Node as PMNode } from 'prosemirror-model';
1
2
  import { EditorState } from 'prosemirror-state';
2
3
  import type { EditorContainerWidth } from '../types/editor-container-width';
4
+ export declare const layoutToWidth: {
5
+ default: number;
6
+ wide: number;
7
+ 'full-width': number;
8
+ };
3
9
  /**
4
10
  * Calculates width of parent node of a nested node (inside layouts, extension)
5
11
  * If current node selection is not nested will return undefined
6
12
  */
7
13
  export declare const getParentNodeWidth: (pos: number | undefined, state: EditorState, containerWidth: EditorContainerWidth, isFullWidthModeEnabled?: boolean) => any;
14
+ export declare const getTableContainerWidth: (node: PMNode) => number;
@@ -20,5 +20,6 @@ export type ResizerProps = {
20
20
  handleComponent?: HandleComponent;
21
21
  handlerHeightSize?: HandlerHeightSizeType;
22
22
  handleAlignmentMethod?: HandleAlignmentMethod;
23
+ resizeRatio?: number;
23
24
  };
24
25
  export default function ResizerNext(props: PropsWithChildren<ResizerProps>): JSX.Element;
@@ -25,7 +25,8 @@ export declare const TableSharedCssClassName: {
25
25
  TABLE_HEADER_CELL_WRAPPER: string;
26
26
  TABLE_ROW_CONTROLS_WRAPPER: string;
27
27
  TABLE_COLUMN_CONTROLS_DECORATIONS: string;
28
+ TABLE_RESIZER_CONTAINER: string;
28
29
  };
29
30
  declare const tableSharedStyle: (props: ThemeProps) => import("@emotion/react").SerializedStyles;
30
- export declare const calcTableWidth: (layout: TableLayout, containerWidth?: number, addControllerPadding?: boolean) => string;
31
+ export declare const calcTableWidth: (layout: TableLayout, containerWidth?: number, addControllerPadding?: boolean) => number | 'inherit';
31
32
  export { tableSharedStyle };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@atlaskit/editor-common",
3
- "version": "74.6.0",
3
+ "version": "74.7.0",
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/"
@@ -71,7 +71,7 @@
71
71
  "dependencies": {
72
72
  "@atlaskit/activity-provider": "^2.4.0",
73
73
  "@atlaskit/adf-schema": "^25.8.0",
74
- "@atlaskit/adf-utils": "^18.3.0",
74
+ "@atlaskit/adf-utils": "^18.4.0",
75
75
  "@atlaskit/analytics-listeners": "^8.7.0",
76
76
  "@atlaskit/analytics-namespaced-context": "^6.7.0",
77
77
  "@atlaskit/analytics-next": "^9.1.0",
@@ -142,14 +142,13 @@
142
142
  "@atlaskit/editor-plugin-decorations": "^0.1.0",
143
143
  "@atlaskit/editor-plugin-feature-flags": "^0.1.0",
144
144
  "@atlaskit/editor-plugin-grid": "^0.1.0",
145
- "@atlaskit/editor-plugin-table": "^1.5.0",
145
+ "@atlaskit/editor-plugin-table": "^1.6.0",
146
146
  "@atlaskit/editor-plugin-width": "^0.1.0",
147
147
  "@atlaskit/editor-test-helpers": "^18.6.0",
148
148
  "@atlaskit/media-core": "^34.1.0",
149
149
  "@atlaskit/media-test-helpers": "^33.0.0",
150
150
  "@atlaskit/util-data-test": "^17.8.0",
151
151
  "@atlaskit/visual-regression": "*",
152
- "@atlaskit/webdriver-runner": "*",
153
152
  "@atlassian/atlassian-frontend-prettier-config-1.0.1": "npm:@atlassian/atlassian-frontend-prettier-config@1.0.1",
154
153
  "@sentry/types": "^6.18.2",
155
154
  "@testing-library/jest-dom": "^5.16.5",