@atlaskit/primitives 14.7.0 → 14.7.2

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,23 @@
1
1
  # @atlaskit/primitives
2
2
 
3
+ ## 14.7.2
4
+
5
+ ### Patch Changes
6
+
7
+ - [#152840](https://bitbucket.org/atlassian/atlassian-frontend-monorepo/pull-requests/152840)
8
+ [`c6830ce5e4911`](https://bitbucket.org/atlassian/atlassian-frontend-monorepo/commits/c6830ce5e4911) -
9
+ Fix bug in `compiled-fork-stage1` codemod in which deprecated Pressable props were not being moved
10
+ into the `xcss` prop.
11
+
12
+ ## 14.7.1
13
+
14
+ ### Patch Changes
15
+
16
+ - [#148964](https://bitbucket.org/atlassian/atlassian-frontend-monorepo/pull-requests/148964)
17
+ [`79dddcb8a67c0`](https://bitbucket.org/atlassian/atlassian-frontend-monorepo/commits/79dddcb8a67c0) -
18
+ Add tabindex="0" to Pressable for Safari so that click events are fired
19
+ - Updated dependencies
20
+
3
21
  ## 14.7.0
4
22
 
5
23
  ### Minor Changes
@@ -1,6 +1,6 @@
1
1
  import type { API, FileInfo, JSXAttribute } from 'jscodeshift';
2
2
 
3
- const ANCHOR_XCSS_PROPS = [
3
+ const ANCHOR_PRESSABLE_XCSS_PROPS = [
4
4
  'backgroundColor',
5
5
  'padding',
6
6
  'paddingBlock',
@@ -56,21 +56,21 @@ function transform(file: FileInfo, { jscodeshift: j }: API) {
56
56
  }
57
57
  }
58
58
 
59
- // Find JSX elements for Grid and Anchor
59
+ // Find JSX elements for Grid, Anchor and Pressable
60
60
  root.find(j.JSXElement).forEach((path) => {
61
61
  if (!j.JSXIdentifier.check(path.node.openingElement.name)) {
62
62
  return;
63
63
  }
64
64
 
65
65
  const elementName = path.node.openingElement.name.name;
66
- if (elementName !== 'Grid' && elementName !== 'Anchor') {
66
+ if (elementName !== 'Grid' && elementName !== 'Anchor' && elementName !== 'Pressable') {
67
67
  return;
68
68
  }
69
69
 
70
70
  const attributes = path.node.openingElement.attributes || [];
71
71
  const props = attributes.filter((attr) => j.JSXAttribute.check(attr)) as Array<JSXAttribute>;
72
72
 
73
- const xcssProps = elementName === 'Grid' ? GRID_XCSS_PROPS : ANCHOR_XCSS_PROPS;
73
+ const xcssProps = elementName === 'Grid' ? GRID_XCSS_PROPS : ANCHOR_PRESSABLE_XCSS_PROPS;
74
74
  const propsToTransform = props.filter(
75
75
  (prop) => j.JSXIdentifier.check(prop.name) && xcssProps.includes(prop.name.name),
76
76
  );
@@ -70,7 +70,7 @@ var AnchorNoRef = function AnchorNoRef(_ref, ref) {
70
70
  action: 'clicked',
71
71
  componentName: componentName || 'Anchor',
72
72
  packageName: "@atlaskit/primitives",
73
- packageVersion: "14.7.0",
73
+ packageVersion: "14.7.2",
74
74
  analyticsData: analyticsContext,
75
75
  actionSubject: 'link'
76
76
  });
@@ -15,10 +15,11 @@ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")
15
15
  var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
16
16
  var _react2 = require("@compiled/react");
17
17
  var _analyticsNext = require("@atlaskit/analytics-next");
18
+ var _deviceCheck = require("@atlaskit/ds-lib/device-check");
18
19
  var _noop = _interopRequireDefault(require("@atlaskit/ds-lib/noop"));
19
20
  var _interactionContext = _interopRequireDefault(require("@atlaskit/interaction-context"));
20
21
  var _focusable = _interopRequireDefault(require("./focusable"));
21
- var _excluded = ["children", "isDisabled", "type", "onClick", "interactionName", "componentName", "analyticsContext", "style", "testId", "xcss"],
22
+ var _excluded = ["children", "isDisabled", "type", "onClick", "interactionName", "componentName", "analyticsContext", "style", "testId", "xcss", "tabIndex"],
22
23
  _excluded2 = ["className"];
23
24
  function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
24
25
  function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
@@ -49,6 +50,7 @@ var Pressable = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
49
50
  style = _ref.style,
50
51
  testId = _ref.testId,
51
52
  xcss = _ref.xcss,
53
+ tabIndex = _ref.tabIndex,
52
54
  htmlAttributes = (0, _objectWithoutProperties2.default)(_ref, _excluded);
53
55
  var interactionContext = (0, _react.useContext)(_interactionContext.default);
54
56
  var handleClick = (0, _react.useCallback)(function (e, analyticsEvent) {
@@ -60,7 +62,7 @@ var Pressable = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
60
62
  action: 'clicked',
61
63
  componentName: componentName || 'Pressable',
62
64
  packageName: "@atlaskit/primitives",
63
- packageVersion: "14.7.0",
65
+ packageVersion: "14.7.2",
64
66
  analyticsData: analyticsContext,
65
67
  actionSubject: 'button'
66
68
  });
@@ -73,6 +75,11 @@ var Pressable = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
73
75
  // @ts-expect-error we don't allow `button` on Focusable for makers as they should use Pressable instead
74
76
  , (0, _extends2.default)({
75
77
  as: "button"
78
+ // Safari does not apply focus to buttons on click like other browsers, which means click events will not be fired.
79
+ // Adding a tabIndex of 0 to the button will allow it to be focused on click.
80
+ // This is a known issue in Safari that is meant to be "intended", see https://bugs.webkit.org/show_bug.cgi?id=22261
81
+ ,
82
+ tabIndex: tabIndex !== null && tabIndex !== void 0 ? tabIndex : (0, _deviceCheck.isSafari)() && !isDisabled ? 0 : undefined
76
83
  // eslint-disable-next-line @atlaskit/ui-styling-standard/enforce-style-prop -- TODO: Properly type this and allow pass-through if we can determine the type
77
84
  ,
78
85
  style: style
@@ -100,7 +100,7 @@ var AnchorNoRef = function AnchorNoRef(_ref, ref) {
100
100
  action: 'clicked',
101
101
  componentName: componentName || 'Anchor',
102
102
  packageName: "@atlaskit/primitives",
103
- packageVersion: "14.7.0",
103
+ packageVersion: "14.7.2",
104
104
  analyticsData: analyticsContext,
105
105
  actionSubject: 'link'
106
106
  });
@@ -95,7 +95,7 @@ var Pressable = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
95
95
  action: 'clicked',
96
96
  componentName: componentName || 'Pressable',
97
97
  packageName: "@atlaskit/primitives",
98
- packageVersion: "14.7.0",
98
+ packageVersion: "14.7.2",
99
99
  analyticsData: analyticsContext,
100
100
  actionSubject: 'button'
101
101
  });
@@ -55,7 +55,7 @@ const AnchorNoRef = ({
55
55
  action: 'clicked',
56
56
  componentName: componentName || 'Anchor',
57
57
  packageName: "@atlaskit/primitives",
58
- packageVersion: "14.7.0",
58
+ packageVersion: "14.7.2",
59
59
  analyticsData: analyticsContext,
60
60
  actionSubject: 'link'
61
61
  });
@@ -6,6 +6,7 @@ import { ax, ix } from "@compiled/react/runtime";
6
6
  import { forwardRef, useCallback, useContext } from 'react';
7
7
  import { cx } from '@compiled/react';
8
8
  import { usePlatformLeafEventHandler } from '@atlaskit/analytics-next';
9
+ import { isSafari } from '@atlaskit/ds-lib/device-check';
9
10
  import noop from '@atlaskit/ds-lib/noop';
10
11
  import InteractionContext from '@atlaskit/interaction-context';
11
12
  import Focusable from './focusable';
@@ -34,6 +35,7 @@ const Pressable = /*#__PURE__*/forwardRef(({
34
35
  style,
35
36
  testId,
36
37
  xcss,
38
+ tabIndex,
37
39
  ...htmlAttributes
38
40
  }, ref) => {
39
41
  const interactionContext = useContext(InteractionContext);
@@ -46,7 +48,7 @@ const Pressable = /*#__PURE__*/forwardRef(({
46
48
  action: 'clicked',
47
49
  componentName: componentName || 'Pressable',
48
50
  packageName: "@atlaskit/primitives",
49
- packageVersion: "14.7.0",
51
+ packageVersion: "14.7.2",
50
52
  analyticsData: analyticsContext,
51
53
  actionSubject: 'button'
52
54
  });
@@ -61,6 +63,11 @@ const Pressable = /*#__PURE__*/forwardRef(({
61
63
  // @ts-expect-error we don't allow `button` on Focusable for makers as they should use Pressable instead
62
64
  , _extends({
63
65
  as: "button"
66
+ // Safari does not apply focus to buttons on click like other browsers, which means click events will not be fired.
67
+ // Adding a tabIndex of 0 to the button will allow it to be focused on click.
68
+ // This is a known issue in Safari that is meant to be "intended", see https://bugs.webkit.org/show_bug.cgi?id=22261
69
+ ,
70
+ tabIndex: tabIndex !== null && tabIndex !== void 0 ? tabIndex : isSafari() && !isDisabled ? 0 : undefined
64
71
  // eslint-disable-next-line @atlaskit/ui-styling-standard/enforce-style-prop -- TODO: Properly type this and allow pass-through if we can determine the type
65
72
  ,
66
73
  style: style
@@ -90,7 +90,7 @@ const AnchorNoRef = ({
90
90
  action: 'clicked',
91
91
  componentName: componentName || 'Anchor',
92
92
  packageName: "@atlaskit/primitives",
93
- packageVersion: "14.7.0",
93
+ packageVersion: "14.7.2",
94
94
  analyticsData: analyticsContext,
95
95
  actionSubject: 'link'
96
96
  });
@@ -85,7 +85,7 @@ const Pressable = /*#__PURE__*/forwardRef(({
85
85
  action: 'clicked',
86
86
  componentName: componentName || 'Pressable',
87
87
  packageName: "@atlaskit/primitives",
88
- packageVersion: "14.7.0",
88
+ packageVersion: "14.7.2",
89
89
  analyticsData: analyticsContext,
90
90
  actionSubject: 'button'
91
91
  });
@@ -60,7 +60,7 @@ var AnchorNoRef = function AnchorNoRef(_ref, ref) {
60
60
  action: 'clicked',
61
61
  componentName: componentName || 'Anchor',
62
62
  packageName: "@atlaskit/primitives",
63
- packageVersion: "14.7.0",
63
+ packageVersion: "14.7.2",
64
64
  analyticsData: analyticsContext,
65
65
  actionSubject: 'link'
66
66
  });
@@ -1,7 +1,7 @@
1
1
  /* pressable.tsx generated by @compiled/babel-plugin v0.36.1 */
2
2
  import _extends from "@babel/runtime/helpers/extends";
3
3
  import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
4
- var _excluded = ["children", "isDisabled", "type", "onClick", "interactionName", "componentName", "analyticsContext", "style", "testId", "xcss"],
4
+ var _excluded = ["children", "isDisabled", "type", "onClick", "interactionName", "componentName", "analyticsContext", "style", "testId", "xcss", "tabIndex"],
5
5
  _excluded2 = ["className"];
6
6
  import "./pressable.compiled.css";
7
7
  import * as React from 'react';
@@ -9,6 +9,7 @@ import { ax, ix } from "@compiled/react/runtime";
9
9
  import { forwardRef, useCallback, useContext } from 'react';
10
10
  import { cx } from '@compiled/react';
11
11
  import { usePlatformLeafEventHandler } from '@atlaskit/analytics-next';
12
+ import { isSafari } from '@atlaskit/ds-lib/device-check';
12
13
  import noop from '@atlaskit/ds-lib/noop';
13
14
  import InteractionContext from '@atlaskit/interaction-context';
14
15
  import Focusable from './focusable';
@@ -39,6 +40,7 @@ var Pressable = /*#__PURE__*/forwardRef(function (_ref, ref) {
39
40
  style = _ref.style,
40
41
  testId = _ref.testId,
41
42
  xcss = _ref.xcss,
43
+ tabIndex = _ref.tabIndex,
42
44
  htmlAttributes = _objectWithoutProperties(_ref, _excluded);
43
45
  var interactionContext = useContext(InteractionContext);
44
46
  var handleClick = useCallback(function (e, analyticsEvent) {
@@ -50,7 +52,7 @@ var Pressable = /*#__PURE__*/forwardRef(function (_ref, ref) {
50
52
  action: 'clicked',
51
53
  componentName: componentName || 'Pressable',
52
54
  packageName: "@atlaskit/primitives",
53
- packageVersion: "14.7.0",
55
+ packageVersion: "14.7.2",
54
56
  analyticsData: analyticsContext,
55
57
  actionSubject: 'button'
56
58
  });
@@ -63,6 +65,11 @@ var Pressable = /*#__PURE__*/forwardRef(function (_ref, ref) {
63
65
  // @ts-expect-error we don't allow `button` on Focusable for makers as they should use Pressable instead
64
66
  , _extends({
65
67
  as: "button"
68
+ // Safari does not apply focus to buttons on click like other browsers, which means click events will not be fired.
69
+ // Adding a tabIndex of 0 to the button will allow it to be focused on click.
70
+ // This is a known issue in Safari that is meant to be "intended", see https://bugs.webkit.org/show_bug.cgi?id=22261
71
+ ,
72
+ tabIndex: tabIndex !== null && tabIndex !== void 0 ? tabIndex : isSafari() && !isDisabled ? 0 : undefined
66
73
  // eslint-disable-next-line @atlaskit/ui-styling-standard/enforce-style-prop -- TODO: Properly type this and allow pass-through if we can determine the type
67
74
  ,
68
75
  style: style
@@ -94,7 +94,7 @@ var AnchorNoRef = function AnchorNoRef(_ref, ref) {
94
94
  action: 'clicked',
95
95
  componentName: componentName || 'Anchor',
96
96
  packageName: "@atlaskit/primitives",
97
- packageVersion: "14.7.0",
97
+ packageVersion: "14.7.2",
98
98
  analyticsData: analyticsContext,
99
99
  actionSubject: 'link'
100
100
  });
@@ -89,7 +89,7 @@ var Pressable = /*#__PURE__*/forwardRef(function (_ref, ref) {
89
89
  action: 'clicked',
90
90
  componentName: componentName || 'Pressable',
91
91
  packageName: "@atlaskit/primitives",
92
- packageVersion: "14.7.0",
92
+ packageVersion: "14.7.2",
93
93
  analyticsData: analyticsContext,
94
94
  actionSubject: 'button'
95
95
  });
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@atlaskit/primitives",
3
- "version": "14.7.0",
3
+ "version": "14.7.2",
4
4
  "description": "Primitives are token-backed low-level building blocks.",
5
5
  "publishConfig": {
6
6
  "registry": "https://registry.npmjs.org/"
@@ -155,7 +155,7 @@
155
155
  "@atlaskit/flag": "^17.1.0",
156
156
  "@atlaskit/form": "^12.0.0",
157
157
  "@atlaskit/heading": "^5.2.0",
158
- "@atlaskit/icon": "^25.6.0",
158
+ "@atlaskit/icon": "^26.0.0",
159
159
  "@atlaskit/icon-object": "^7.1.0",
160
160
  "@atlaskit/image": "^3.0.0",
161
161
  "@atlaskit/link": "^3.1.0",
@@ -173,6 +173,7 @@
173
173
  "@atlassian/ssr-tests": "^0.2.0",
174
174
  "@testing-library/react": "^13.4.0",
175
175
  "@testing-library/react-hooks": "^8.0.1",
176
+ "@testing-library/user-event": "^14.4.3",
176
177
  "csstype": "^3.1.0",
177
178
  "jscodeshift": "^17.0.0",
178
179
  "react-dom": "^18.2.0",