@atlaskit/navigation-system 4.0.0 → 4.2.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,28 @@
1
1
  # @atlassian/navigation-system
2
2
 
3
+ ## 4.2.0
4
+
5
+ ### Minor Changes
6
+
7
+ - [`5ab567cfb4d29`](https://bitbucket.org/atlassian/atlassian-frontend-monorepo/commits/5ab567cfb4d29) -
8
+ Cleans up the `platform_dst_nav4_panel_splitter_guards` feature gate. Panel splitters will now use
9
+ a safe fallback default width if the provided default width is not an integer.
10
+
11
+ ### Patch Changes
12
+
13
+ - Updated dependencies
14
+
15
+ ## 4.1.0
16
+
17
+ ### Minor Changes
18
+
19
+ - [`d55bbfc88149b`](https://bitbucket.org/atlassian/atlassian-frontend-monorepo/commits/d55bbfc88149b) -
20
+ Removes type support for `@atlaskit/temp-nav-app-icons` package
21
+
22
+ ### Patch Changes
23
+
24
+ - Updated dependencies
25
+
3
26
  ## 4.0.0
4
27
 
5
28
  ### Major Changes
@@ -4,7 +4,6 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.getWidthFromDragLocation = exports.getPixelWidth = void 0;
7
- var _platformFeatureFlags = require("@atlaskit/platform-feature-flags");
8
7
  var getWidthFromDragLocation = exports.getWidthFromDragLocation = function getWidthFromDragLocation(_ref) {
9
8
  var initialWidth = _ref.initialWidth,
10
9
  location = _ref.location,
@@ -26,11 +25,6 @@ var getWidthFromDragLocation = exports.getWidthFromDragLocation = function getWi
26
25
  * Returns the computed width of an element in pixels.
27
26
  */
28
27
  var getPixelWidth = exports.getPixelWidth = function getPixelWidth(element) {
29
- if ((0, _platformFeatureFlags.fg)('platform_dst_nav4_panel_splitter_guards')) {
30
- // Always returns an integer. Returns 0 if element is hidden / removed.
31
- return element.offsetWidth;
32
- }
33
- var _window$getComputedSt = window.getComputedStyle(element),
34
- width = _window$getComputedSt.width;
35
- return parseInt(width);
28
+ // Always returns an integer. Returns 0 if element is hidden / removed.
29
+ return element.offsetWidth;
36
30
  };
@@ -4,29 +4,22 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.useSafeDefaultWidth = useSafeDefaultWidth;
7
- var _platformFeatureFlags = require("@atlaskit/platform-feature-flags");
8
7
  /**
9
- * When `platform_dst_nav4_panel_splitter_guards` is disabled,
10
- * `useSafeDefaultWidth` returns the provided `defaultWidthProp`.
11
- *
12
- * When `platform_dst_nav4_panel_splitter_guards` is enabled,
13
- * `useSafeDefaultWidth` returns the `fallbackWidth` if the provided `defaultWidthProp` is not an integer value.
8
+ * Returns the `fallbackWidth` if the provided `defaultWidthProp` is not an integer value.
14
9
  */
15
10
  function useSafeDefaultWidth(_ref) {
16
11
  var defaultWidthProp = _ref.defaultWidthProp,
17
12
  fallbackDefaultWidth = _ref.fallbackDefaultWidth,
18
13
  slotName = _ref.slotName;
19
- if ((0, _platformFeatureFlags.fg)('platform_dst_nav4_panel_splitter_guards')) {
20
- // If the provided `defaultWidth` is invalid then we use our fallback.
21
- // We are using a runtime check because some invalid numbers like `NaN` are not caught by types,
22
- // and we saw some issues in products where our experience broke due to this.
23
- if (!Number.isInteger(defaultWidthProp)) {
24
- if (process.env.NODE_ENV !== 'production') {
25
- // eslint-disable-next-line no-console
26
- console.error("The defaultWidth value must be an integer, but '".concat(defaultWidthProp, "' was provided to ").concat(slotName, ". Falling back to ").concat(fallbackDefaultWidth, "px instead."));
27
- }
28
- return fallbackDefaultWidth;
14
+ // If the provided `defaultWidth` is invalid then we use our fallback.
15
+ // We are using a runtime check because some invalid numbers like `NaN` are not caught by types,
16
+ // and we saw some issues in products where our experience broke due to this.
17
+ if (!Number.isInteger(defaultWidthProp)) {
18
+ if (process.env.NODE_ENV !== 'production') {
19
+ // eslint-disable-next-line no-console
20
+ console.error("The defaultWidth value must be an integer, but '".concat(defaultWidthProp, "' was provided to ").concat(slotName, ". Falling back to ").concat(fallbackDefaultWidth, "px instead."));
29
21
  }
22
+ return fallbackDefaultWidth;
30
23
  }
31
24
  return defaultWidthProp;
32
25
  }
@@ -1,4 +1,3 @@
1
- import { fg } from '@atlaskit/platform-feature-flags';
2
1
  export const getWidthFromDragLocation = ({
3
2
  initialWidth,
4
3
  location,
@@ -21,12 +20,6 @@ export const getWidthFromDragLocation = ({
21
20
  * Returns the computed width of an element in pixels.
22
21
  */
23
22
  export const getPixelWidth = element => {
24
- if (fg('platform_dst_nav4_panel_splitter_guards')) {
25
- // Always returns an integer. Returns 0 if element is hidden / removed.
26
- return element.offsetWidth;
27
- }
28
- const {
29
- width
30
- } = window.getComputedStyle(element);
31
- return parseInt(width);
23
+ // Always returns an integer. Returns 0 if element is hidden / removed.
24
+ return element.offsetWidth;
32
25
  };
@@ -1,28 +1,20 @@
1
- import { fg } from '@atlaskit/platform-feature-flags';
2
-
3
1
  /**
4
- * When `platform_dst_nav4_panel_splitter_guards` is disabled,
5
- * `useSafeDefaultWidth` returns the provided `defaultWidthProp`.
6
- *
7
- * When `platform_dst_nav4_panel_splitter_guards` is enabled,
8
- * `useSafeDefaultWidth` returns the `fallbackWidth` if the provided `defaultWidthProp` is not an integer value.
2
+ * Returns the `fallbackWidth` if the provided `defaultWidthProp` is not an integer value.
9
3
  */
10
4
  export function useSafeDefaultWidth({
11
5
  defaultWidthProp,
12
6
  fallbackDefaultWidth,
13
7
  slotName
14
8
  }) {
15
- if (fg('platform_dst_nav4_panel_splitter_guards')) {
16
- // If the provided `defaultWidth` is invalid then we use our fallback.
17
- // We are using a runtime check because some invalid numbers like `NaN` are not caught by types,
18
- // and we saw some issues in products where our experience broke due to this.
19
- if (!Number.isInteger(defaultWidthProp)) {
20
- if (process.env.NODE_ENV !== 'production') {
21
- // eslint-disable-next-line no-console
22
- console.error(`The defaultWidth value must be an integer, but '${defaultWidthProp}' was provided to ${slotName}. Falling back to ${fallbackDefaultWidth}px instead.`);
23
- }
24
- return fallbackDefaultWidth;
9
+ // If the provided `defaultWidth` is invalid then we use our fallback.
10
+ // We are using a runtime check because some invalid numbers like `NaN` are not caught by types,
11
+ // and we saw some issues in products where our experience broke due to this.
12
+ if (!Number.isInteger(defaultWidthProp)) {
13
+ if (process.env.NODE_ENV !== 'production') {
14
+ // eslint-disable-next-line no-console
15
+ console.error(`The defaultWidth value must be an integer, but '${defaultWidthProp}' was provided to ${slotName}. Falling back to ${fallbackDefaultWidth}px instead.`);
25
16
  }
17
+ return fallbackDefaultWidth;
26
18
  }
27
19
  return defaultWidthProp;
28
20
  }
@@ -1,4 +1,3 @@
1
- import { fg } from '@atlaskit/platform-feature-flags';
2
1
  export var getWidthFromDragLocation = function getWidthFromDragLocation(_ref) {
3
2
  var initialWidth = _ref.initialWidth,
4
3
  location = _ref.location,
@@ -20,11 +19,6 @@ export var getWidthFromDragLocation = function getWidthFromDragLocation(_ref) {
20
19
  * Returns the computed width of an element in pixels.
21
20
  */
22
21
  export var getPixelWidth = function getPixelWidth(element) {
23
- if (fg('platform_dst_nav4_panel_splitter_guards')) {
24
- // Always returns an integer. Returns 0 if element is hidden / removed.
25
- return element.offsetWidth;
26
- }
27
- var _window$getComputedSt = window.getComputedStyle(element),
28
- width = _window$getComputedSt.width;
29
- return parseInt(width);
22
+ // Always returns an integer. Returns 0 if element is hidden / removed.
23
+ return element.offsetWidth;
30
24
  };
@@ -1,27 +1,19 @@
1
- import { fg } from '@atlaskit/platform-feature-flags';
2
-
3
1
  /**
4
- * When `platform_dst_nav4_panel_splitter_guards` is disabled,
5
- * `useSafeDefaultWidth` returns the provided `defaultWidthProp`.
6
- *
7
- * When `platform_dst_nav4_panel_splitter_guards` is enabled,
8
- * `useSafeDefaultWidth` returns the `fallbackWidth` if the provided `defaultWidthProp` is not an integer value.
2
+ * Returns the `fallbackWidth` if the provided `defaultWidthProp` is not an integer value.
9
3
  */
10
4
  export function useSafeDefaultWidth(_ref) {
11
5
  var defaultWidthProp = _ref.defaultWidthProp,
12
6
  fallbackDefaultWidth = _ref.fallbackDefaultWidth,
13
7
  slotName = _ref.slotName;
14
- if (fg('platform_dst_nav4_panel_splitter_guards')) {
15
- // If the provided `defaultWidth` is invalid then we use our fallback.
16
- // We are using a runtime check because some invalid numbers like `NaN` are not caught by types,
17
- // and we saw some issues in products where our experience broke due to this.
18
- if (!Number.isInteger(defaultWidthProp)) {
19
- if (process.env.NODE_ENV !== 'production') {
20
- // eslint-disable-next-line no-console
21
- console.error("The defaultWidth value must be an integer, but '".concat(defaultWidthProp, "' was provided to ").concat(slotName, ". Falling back to ").concat(fallbackDefaultWidth, "px instead."));
22
- }
23
- return fallbackDefaultWidth;
8
+ // If the provided `defaultWidth` is invalid then we use our fallback.
9
+ // We are using a runtime check because some invalid numbers like `NaN` are not caught by types,
10
+ // and we saw some issues in products where our experience broke due to this.
11
+ if (!Number.isInteger(defaultWidthProp)) {
12
+ if (process.env.NODE_ENV !== 'production') {
13
+ // eslint-disable-next-line no-console
14
+ console.error("The defaultWidth value must be an integer, but '".concat(defaultWidthProp, "' was provided to ").concat(slotName, ". Falling back to ").concat(fallbackDefaultWidth, "px instead."));
24
15
  }
16
+ return fallbackDefaultWidth;
25
17
  }
26
18
  return defaultWidthProp;
27
19
  }
@@ -1,9 +1,5 @@
1
1
  /**
2
- * When `platform_dst_nav4_panel_splitter_guards` is disabled,
3
- * `useSafeDefaultWidth` returns the provided `defaultWidthProp`.
4
- *
5
- * When `platform_dst_nav4_panel_splitter_guards` is enabled,
6
- * `useSafeDefaultWidth` returns the `fallbackWidth` if the provided `defaultWidthProp` is not an integer value.
2
+ * Returns the `fallbackWidth` if the provided `defaultWidthProp` is not an integer value.
7
3
  */
8
4
  export declare function useSafeDefaultWidth({ defaultWidthProp, fallbackDefaultWidth, slotName, }: {
9
5
  /**
@@ -4,7 +4,6 @@
4
4
  */
5
5
  import React from 'react';
6
6
  import type { LogoProps } from '@atlaskit/logo';
7
- import type { IconProps as TempIconProps, LogoProps as TempLogoProps } from '@atlaskit/temp-nav-app-icons/types';
8
7
  /**
9
8
  * __Custom logo__
10
9
  *
@@ -25,11 +24,11 @@ export declare const CustomLogo: ({ href, logo, icon, onClick, label, }: {
25
24
  /**
26
25
  * The logo component to render. It will be used for large viewports.
27
26
  */
28
- logo: ((props: LogoProps) => JSX.Element) | ((props: TempLogoProps) => JSX.Element);
27
+ logo: (props: LogoProps) => JSX.Element;
29
28
  /**
30
29
  * The icon component to render. It will be used for small viewports.
31
30
  */
32
- icon: ((props: LogoProps) => JSX.Element) | ((props: TempIconProps) => JSX.Element);
31
+ icon: (props: LogoProps) => JSX.Element;
33
32
  /**
34
33
  * Handler called on click.
35
34
  */
@@ -4,12 +4,11 @@
4
4
  */
5
5
  import React from 'react';
6
6
  import type { LogoProps } from '@atlaskit/logo';
7
- import type { IconProps as TempIconProps, LogoProps as TempLogoProps } from '@atlaskit/temp-nav-app-icons/types';
8
7
  export declare const themedLogoIcon = "--ds-top-bar-logo-icon";
9
8
  export declare const themedLogoText = "--ds-top-bar-logo-text";
10
9
  export declare function LogoRenderer({ logoOrIcon, shouldUseNewLogoDesign, }: React.ComponentProps<typeof LogoRendererNoMemo>): JSX.Element;
11
10
  declare function LogoRendererNoMemo({ logoOrIcon: LogoOrIcon, shouldUseNewLogoDesign, }: {
12
- logoOrIcon: ((props: LogoProps) => JSX.Element) | ((props: TempLogoProps) => JSX.Element) | ((props: TempIconProps) => JSX.Element);
11
+ logoOrIcon: (props: LogoProps) => JSX.Element;
13
12
  shouldUseNewLogoDesign?: boolean;
14
13
  }): JSX.Element;
15
14
  export {};
@@ -1,9 +1,5 @@
1
1
  /**
2
- * When `platform_dst_nav4_panel_splitter_guards` is disabled,
3
- * `useSafeDefaultWidth` returns the provided `defaultWidthProp`.
4
- *
5
- * When `platform_dst_nav4_panel_splitter_guards` is enabled,
6
- * `useSafeDefaultWidth` returns the `fallbackWidth` if the provided `defaultWidthProp` is not an integer value.
2
+ * Returns the `fallbackWidth` if the provided `defaultWidthProp` is not an integer value.
7
3
  */
8
4
  export declare function useSafeDefaultWidth({ defaultWidthProp, fallbackDefaultWidth, slotName, }: {
9
5
  /**
@@ -4,7 +4,6 @@
4
4
  */
5
5
  import React from 'react';
6
6
  import type { LogoProps } from '@atlaskit/logo';
7
- import type { IconProps as TempIconProps, LogoProps as TempLogoProps } from '@atlaskit/temp-nav-app-icons/types';
8
7
  /**
9
8
  * __Custom logo__
10
9
  *
@@ -25,11 +24,11 @@ export declare const CustomLogo: ({ href, logo, icon, onClick, label, }: {
25
24
  /**
26
25
  * The logo component to render. It will be used for large viewports.
27
26
  */
28
- logo: ((props: LogoProps) => JSX.Element) | ((props: TempLogoProps) => JSX.Element);
27
+ logo: (props: LogoProps) => JSX.Element;
29
28
  /**
30
29
  * The icon component to render. It will be used for small viewports.
31
30
  */
32
- icon: ((props: LogoProps) => JSX.Element) | ((props: TempIconProps) => JSX.Element);
31
+ icon: (props: LogoProps) => JSX.Element;
33
32
  /**
34
33
  * Handler called on click.
35
34
  */
@@ -4,12 +4,11 @@
4
4
  */
5
5
  import React from 'react';
6
6
  import type { LogoProps } from '@atlaskit/logo';
7
- import type { IconProps as TempIconProps, LogoProps as TempLogoProps } from '@atlaskit/temp-nav-app-icons/types';
8
7
  export declare const themedLogoIcon = "--ds-top-bar-logo-icon";
9
8
  export declare const themedLogoText = "--ds-top-bar-logo-text";
10
9
  export declare function LogoRenderer({ logoOrIcon, shouldUseNewLogoDesign, }: React.ComponentProps<typeof LogoRendererNoMemo>): JSX.Element;
11
10
  declare function LogoRendererNoMemo({ logoOrIcon: LogoOrIcon, shouldUseNewLogoDesign, }: {
12
- logoOrIcon: ((props: LogoProps) => JSX.Element) | ((props: TempLogoProps) => JSX.Element) | ((props: TempIconProps) => JSX.Element);
11
+ logoOrIcon: (props: LogoProps) => JSX.Element;
13
12
  shouldUseNewLogoDesign?: boolean;
14
13
  }): JSX.Element;
15
14
  export {};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@atlaskit/navigation-system",
3
- "version": "4.0.0",
3
+ "version": "4.2.0",
4
4
  "description": "The latest navigation system for Atlassian apps.",
5
5
  "repository": "https://bitbucket.org/atlassian/atlassian-frontend-mirror",
6
6
  "author": "Atlassian Pty Ltd",
@@ -67,7 +67,7 @@
67
67
  },
68
68
  "dependencies": {
69
69
  "@atlaskit/analytics-next": "^11.1.0",
70
- "@atlaskit/avatar": "^25.4.0",
70
+ "@atlaskit/avatar": "^25.5.0",
71
71
  "@atlaskit/button": "^23.5.0",
72
72
  "@atlaskit/css": "^0.15.0",
73
73
  "@atlaskit/ds-lib": "^5.1.0",
@@ -113,7 +113,6 @@
113
113
  "@atlaskit/pragmatic-drag-and-drop-auto-scroll": "^2.1.0",
114
114
  "@atlaskit/select": "^21.3.0",
115
115
  "@atlaskit/skeleton": "^2.1.0",
116
- "@atlaskit/temp-nav-app-icons": "^0.14.0",
117
116
  "@atlaskit/textfield": "^8.0.0",
118
117
  "@atlassian/feature-flags-test-utils": "^1.0.0",
119
118
  "@atlassian/gemini": "^1.20.0",
@@ -165,9 +164,6 @@
165
164
  "platform_dst_nav4_flyoutmenuitem_render_to_parent": {
166
165
  "type": "boolean"
167
166
  },
168
- "platform_dst_nav4_panel_splitter_guards": {
169
- "type": "boolean"
170
- },
171
167
  "navx-full-height-sidebar": {
172
168
  "type": "boolean"
173
169
  },