@atlaskit/editor-common 76.27.0 → 76.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
+ ## 76.27.1
4
+
5
+ ### Patch Changes
6
+
7
+ - [#61320](https://stash.atlassian.com/projects/CONFCLOUD/repos/confluence-frontend/pull-requests/61320) [`faf6d59c38d3`](https://stash.atlassian.com/projects/CONFCLOUD/repos/confluence-frontend/commits/faf6d59c38d3) - [ux] Pass in media dimensions to media card when rendered through inline image card
8
+
3
9
  ## 76.27.0
4
10
 
5
11
  ### Minor Changes
@@ -10,6 +10,7 @@ var _react = require("react");
10
10
  var _react2 = require("@emotion/react");
11
11
  var _reactIntlNext = require("react-intl-next");
12
12
  var _mediaCard = require("@atlaskit/media-card");
13
+ var _typography = require("@atlaskit/theme/typography");
13
14
  var _mediaInlineCard = require("../messages/media-inline-card");
14
15
  var _inlineImageWrapper = require("./inline-image-wrapper");
15
16
  var _errorView = require("./views/error-view");
@@ -53,7 +54,7 @@ var MediaInlineImageCardInternal = exports.MediaInlineImageCardInternal = functi
53
54
  subscription.unsubscribe();
54
55
  };
55
56
  }, [identifier.collectionName, identifier.id, mediaClient.file]);
56
- var content = function content() {
57
+ var content = function content(dimensions) {
57
58
  if (subscribeError) {
58
59
  var isUploading = (fileState === null || fileState === void 0 ? void 0 : fileState.status) === 'uploading';
59
60
  var errorMessage = isUploading ? _mediaInlineCard.messages.failedToUpload : _mediaInlineCard.messages.unableToLoadContent;
@@ -84,6 +85,7 @@ var MediaInlineImageCardInternal = exports.MediaInlineImageCardInternal = functi
84
85
  mediaClientConfig: mediaClient.mediaClientConfig,
85
86
  isLazy: isLazy,
86
87
  identifier: identifier,
88
+ dimensions: dimensions,
87
89
  selectable: true,
88
90
  disableOverlay: true,
89
91
  selected: isSelected,
@@ -93,10 +95,28 @@ var MediaInlineImageCardInternal = exports.MediaInlineImageCardInternal = functi
93
95
  var aspectRatio = (0, _react.useMemo)(function () {
94
96
  return width && height ? width / height : undefined;
95
97
  }, [width, height]);
98
+
99
+ /**
100
+ * scaledDimensions is used to define the correct media size fetched from media service
101
+ * inline images will only ever be rendererd at a maximum height of H1 and so scaled dimensions
102
+ * will only ever return a width and height where the height has a maximum height of H1
103
+ */
104
+ var scaledDimension = (0, _react.useMemo)(function () {
105
+ if (!width || !height || !aspectRatio) {
106
+ return {
107
+ width: width,
108
+ height: height
109
+ };
110
+ }
111
+ return {
112
+ width: Math.round(aspectRatio * _typography.headingSizes.h800.lineHeight),
113
+ height: _typography.headingSizes.h800.lineHeight
114
+ };
115
+ }, [width, height, aspectRatio]);
96
116
  return (0, _react2.jsx)(_inlineImageWrapper.InlineImageWrapper, {
97
117
  isSelected: isSelected,
98
118
  aspectRatio: aspectRatio
99
- }, content());
119
+ }, content(scaledDimension));
100
120
  };
101
121
  var MediaInlineImageCard = exports.MediaInlineImageCard = (0, _reactIntlNext.injectIntl)(MediaInlineImageCardInternal, {
102
122
  enforceContext: false
@@ -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 = "76.27.0";
19
+ var packageVersion = "76.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 = "76.27.0";
27
+ var packageVersion = "76.27.1";
28
28
  var halfFocusRing = 1;
29
29
  var dropOffset = '0, 8';
30
30
  var DropList = /*#__PURE__*/function (_Component) {
@@ -4,6 +4,7 @@ import { useEffect, useMemo, useState } from 'react';
4
4
  import { jsx } from '@emotion/react';
5
5
  import { createIntl, injectIntl } from 'react-intl-next';
6
6
  import { Card } from '@atlaskit/media-card';
7
+ import { headingSizes } from '@atlaskit/theme/typography';
7
8
  import { messages } from '../messages/media-inline-card';
8
9
  import { InlineImageWrapper } from './inline-image-wrapper';
9
10
  import { InlineImageCardErrorView } from './views/error-view';
@@ -41,7 +42,7 @@ export const MediaInlineImageCardInternal = ({
41
42
  subscription.unsubscribe();
42
43
  };
43
44
  }, [identifier.collectionName, identifier.id, mediaClient.file]);
44
- const content = () => {
45
+ const content = dimensions => {
45
46
  if (subscribeError) {
46
47
  const isUploading = (fileState === null || fileState === void 0 ? void 0 : fileState.status) === 'uploading';
47
48
  const errorMessage = isUploading ? messages.failedToUpload : messages.unableToLoadContent;
@@ -72,6 +73,7 @@ export const MediaInlineImageCardInternal = ({
72
73
  mediaClientConfig: mediaClient.mediaClientConfig,
73
74
  isLazy: isLazy,
74
75
  identifier: identifier,
76
+ dimensions: dimensions,
75
77
  selectable: true,
76
78
  disableOverlay: true,
77
79
  selected: isSelected,
@@ -79,10 +81,28 @@ export const MediaInlineImageCardInternal = ({
79
81
  });
80
82
  };
81
83
  const aspectRatio = useMemo(() => width && height ? width / height : undefined, [width, height]);
84
+
85
+ /**
86
+ * scaledDimensions is used to define the correct media size fetched from media service
87
+ * inline images will only ever be rendererd at a maximum height of H1 and so scaled dimensions
88
+ * will only ever return a width and height where the height has a maximum height of H1
89
+ */
90
+ const scaledDimension = useMemo(() => {
91
+ if (!width || !height || !aspectRatio) {
92
+ return {
93
+ width,
94
+ height
95
+ };
96
+ }
97
+ return {
98
+ width: Math.round(aspectRatio * headingSizes.h800.lineHeight),
99
+ height: headingSizes.h800.lineHeight
100
+ };
101
+ }, [width, height, aspectRatio]);
82
102
  return jsx(InlineImageWrapper, {
83
103
  isSelected: isSelected,
84
104
  aspectRatio: aspectRatio
85
- }, content());
105
+ }, content(scaledDimension));
86
106
  };
87
107
  export const MediaInlineImageCard = injectIntl(MediaInlineImageCardInternal, {
88
108
  enforceContext: false
@@ -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 = "76.27.0";
3
+ const packageVersion = "76.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
@@ -9,7 +9,7 @@ import { themed } from '@atlaskit/theme/components';
9
9
  import { borderRadius } from '@atlaskit/theme/constants';
10
10
  import Layer from '../Layer';
11
11
  const packageName = "@atlaskit/editor-common";
12
- const packageVersion = "76.27.0";
12
+ const packageVersion = "76.27.1";
13
13
  const halfFocusRing = 1;
14
14
  const dropOffset = '0, 8';
15
15
  class DropList extends Component {
@@ -5,6 +5,7 @@ import { useEffect, useMemo, useState } from 'react';
5
5
  import { jsx } from '@emotion/react';
6
6
  import { createIntl, injectIntl } from 'react-intl-next';
7
7
  import { Card } from '@atlaskit/media-card';
8
+ import { headingSizes } from '@atlaskit/theme/typography';
8
9
  import { messages } from '../messages/media-inline-card';
9
10
  import { InlineImageWrapper } from './inline-image-wrapper';
10
11
  import { InlineImageCardErrorView } from './views/error-view';
@@ -46,7 +47,7 @@ export var MediaInlineImageCardInternal = function MediaInlineImageCardInternal(
46
47
  subscription.unsubscribe();
47
48
  };
48
49
  }, [identifier.collectionName, identifier.id, mediaClient.file]);
49
- var content = function content() {
50
+ var content = function content(dimensions) {
50
51
  if (subscribeError) {
51
52
  var isUploading = (fileState === null || fileState === void 0 ? void 0 : fileState.status) === 'uploading';
52
53
  var errorMessage = isUploading ? messages.failedToUpload : messages.unableToLoadContent;
@@ -77,6 +78,7 @@ export var MediaInlineImageCardInternal = function MediaInlineImageCardInternal(
77
78
  mediaClientConfig: mediaClient.mediaClientConfig,
78
79
  isLazy: isLazy,
79
80
  identifier: identifier,
81
+ dimensions: dimensions,
80
82
  selectable: true,
81
83
  disableOverlay: true,
82
84
  selected: isSelected,
@@ -86,10 +88,28 @@ export var MediaInlineImageCardInternal = function MediaInlineImageCardInternal(
86
88
  var aspectRatio = useMemo(function () {
87
89
  return width && height ? width / height : undefined;
88
90
  }, [width, height]);
91
+
92
+ /**
93
+ * scaledDimensions is used to define the correct media size fetched from media service
94
+ * inline images will only ever be rendererd at a maximum height of H1 and so scaled dimensions
95
+ * will only ever return a width and height where the height has a maximum height of H1
96
+ */
97
+ var scaledDimension = useMemo(function () {
98
+ if (!width || !height || !aspectRatio) {
99
+ return {
100
+ width: width,
101
+ height: height
102
+ };
103
+ }
104
+ return {
105
+ width: Math.round(aspectRatio * headingSizes.h800.lineHeight),
106
+ height: headingSizes.h800.lineHeight
107
+ };
108
+ }, [width, height, aspectRatio]);
89
109
  return jsx(InlineImageWrapper, {
90
110
  isSelected: isSelected,
91
111
  aspectRatio: aspectRatio
92
- }, content());
112
+ }, content(scaledDimension));
93
113
  };
94
114
  export var MediaInlineImageCard = injectIntl(MediaInlineImageCardInternal, {
95
115
  enforceContext: false
@@ -6,7 +6,7 @@ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbol
6
6
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
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 = "76.27.0";
9
+ var packageVersion = "76.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
@@ -19,7 +19,7 @@ import { themed } from '@atlaskit/theme/components';
19
19
  import { borderRadius } from '@atlaskit/theme/constants';
20
20
  import Layer from '../Layer';
21
21
  var packageName = "@atlaskit/editor-common";
22
- var packageVersion = "76.27.0";
22
+ var packageVersion = "76.27.1";
23
23
  var halfFocusRing = 1;
24
24
  var dropOffset = '0, 8';
25
25
  var DropList = /*#__PURE__*/function (_Component) {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@atlaskit/editor-common",
3
- "version": "76.27.0",
3
+ "version": "76.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/"
@@ -94,7 +94,7 @@
94
94
  "@atlaskit/analytics-namespaced-context": "^6.7.0",
95
95
  "@atlaskit/analytics-next": "^9.1.0",
96
96
  "@atlaskit/analytics-next-stable-react-context": "1.0.1",
97
- "@atlaskit/button": "^17.0.0",
97
+ "@atlaskit/button": "^17.1.0",
98
98
  "@atlaskit/code": "^15.1.0",
99
99
  "@atlaskit/codemod-utils": "^4.2.0",
100
100
  "@atlaskit/custom-steps": "^0.0.9",