@atlaskit/link-picker 1.48.3 → 1.49.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 +17 -0
- package/dist/cjs/common/generic-error-svg/index.compiled.css +2 -0
- package/dist/cjs/common/generic-error-svg/index.js +34 -25
- package/dist/cjs/common/generic-error-svg/old/index.js +66 -0
- package/dist/cjs/common/ui/empty-state/index.compiled.css +3 -0
- package/dist/cjs/common/ui/empty-state/index.js +26 -14
- package/dist/cjs/common/ui/empty-state/old/index.js +38 -0
- package/dist/cjs/common/ui/min-height-container/index.compiled.css +4 -0
- package/dist/cjs/common/ui/min-height-container/index.js +24 -14
- package/dist/cjs/common/ui/min-height-container/old/index.js +34 -0
- package/dist/cjs/ui/error-boundary/error-boundary-fallback/index.compiled.css +2 -0
- package/dist/cjs/ui/error-boundary/error-boundary-fallback/index.js +24 -18
- package/dist/cjs/ui/error-boundary/error-boundary-fallback/old/index.js +50 -0
- package/dist/cjs/ui/link-picker/form-footer/index.compiled.css +3 -0
- package/dist/cjs/ui/link-picker/form-footer/index.js +30 -35
- package/dist/cjs/ui/link-picker/form-footer/link-picker-submit-button/index.js +2 -8
- package/dist/cjs/ui/link-picker/form-footer/old/index.js +116 -0
- package/dist/cjs/ui/link-picker/index.compiled.css +10 -0
- package/dist/cjs/ui/link-picker/index.js +45 -59
- package/dist/cjs/ui/link-picker/old/index.js +435 -0
- package/dist/cjs/ui/link-picker/search-results/index.compiled.css +7 -0
- package/dist/cjs/ui/link-picker/search-results/index.js +33 -32
- package/dist/cjs/ui/link-picker/search-results/link-search-error/index.js +5 -11
- package/dist/cjs/ui/link-picker/search-results/link-search-list/index.compiled.css +24 -0
- package/dist/cjs/ui/link-picker/search-results/link-search-list/index.js +55 -43
- package/dist/cjs/ui/link-picker/search-results/link-search-list/link-search-no-results/no-results-svg/index.compiled.css +2 -0
- package/dist/cjs/ui/link-picker/search-results/link-search-list/link-search-no-results/no-results-svg/index.js +36 -28
- package/dist/cjs/ui/link-picker/search-results/link-search-list/link-search-no-results/no-results-svg/old/index.js +70 -0
- package/dist/cjs/ui/link-picker/search-results/link-search-list/list-item/index.compiled.css +34 -0
- package/dist/cjs/ui/link-picker/search-results/link-search-list/list-item/index.js +99 -76
- package/dist/cjs/ui/link-picker/search-results/link-search-list/list-item/old/index.js +145 -0
- package/dist/cjs/ui/link-picker/search-results/link-search-list/old/index.js +188 -0
- package/dist/cjs/ui/link-picker/search-results/old/index.js +105 -0
- package/dist/cjs/ui/link-picker/search-results/scrolling-tabs/index.compiled.css +29 -0
- package/dist/cjs/ui/link-picker/search-results/scrolling-tabs/index.js +54 -42
- package/dist/cjs/ui/link-picker/search-results/scrolling-tabs/old/index.js +163 -0
- package/dist/cjs/ui/link-picker/search-results/search-results-container/index.compiled.css +4 -0
- package/dist/cjs/ui/link-picker/search-results/search-results-container/index.js +21 -19
- package/dist/cjs/ui/link-picker/search-results/search-results-container/old/index.js +43 -0
- package/dist/cjs/ui/link-picker/text-input/index.compiled.css +11 -0
- package/dist/cjs/ui/link-picker/text-input/index.js +36 -39
- package/dist/cjs/ui/link-picker/text-input/old/index.js +125 -0
- package/dist/cjs/ui/loader-fallback/index.compiled.css +1 -0
- package/dist/cjs/ui/loader-fallback/index.js +21 -15
- package/dist/cjs/ui/loader-fallback/old/index.js +67 -0
- package/dist/cjs/ui/main.compiled.css +1 -0
- package/dist/cjs/ui/main.js +25 -24
- package/dist/cjs/ui/old/main.js +75 -0
- package/dist/es2019/common/generic-error-svg/index.compiled.css +2 -0
- package/dist/es2019/common/generic-error-svg/index.js +27 -23
- package/dist/es2019/common/generic-error-svg/old/index.js +58 -0
- package/dist/es2019/common/ui/empty-state/index.compiled.css +3 -0
- package/dist/es2019/common/ui/empty-state/index.js +18 -9
- package/dist/es2019/common/ui/empty-state/old/index.js +32 -0
- package/dist/es2019/common/ui/min-height-container/index.compiled.css +4 -0
- package/dist/es2019/common/ui/min-height-container/index.js +21 -12
- package/dist/es2019/common/ui/min-height-container/old/index.js +25 -0
- package/dist/es2019/ui/error-boundary/error-boundary-fallback/index.compiled.css +2 -0
- package/dist/es2019/ui/error-boundary/error-boundary-fallback/index.js +20 -16
- package/dist/es2019/ui/error-boundary/error-boundary-fallback/old/index.js +41 -0
- package/dist/es2019/ui/link-picker/form-footer/index.compiled.css +3 -0
- package/dist/es2019/ui/link-picker/form-footer/index.js +27 -32
- package/dist/es2019/ui/link-picker/form-footer/link-picker-submit-button/index.js +2 -7
- package/dist/es2019/ui/link-picker/form-footer/old/index.js +104 -0
- package/dist/es2019/ui/link-picker/index.compiled.css +10 -0
- package/dist/es2019/ui/link-picker/index.js +38 -58
- package/dist/es2019/ui/link-picker/old/index.js +436 -0
- package/dist/es2019/ui/link-picker/search-results/index.compiled.css +7 -0
- package/dist/es2019/ui/link-picker/search-results/index.js +29 -31
- package/dist/es2019/ui/link-picker/search-results/link-search-error/index.js +5 -10
- package/dist/es2019/ui/link-picker/search-results/link-search-list/index.compiled.css +24 -0
- package/dist/es2019/ui/link-picker/search-results/link-search-list/index.js +48 -42
- package/dist/es2019/ui/link-picker/search-results/link-search-list/link-search-no-results/no-results-svg/index.compiled.css +2 -0
- package/dist/es2019/ui/link-picker/search-results/link-search-list/link-search-no-results/no-results-svg/index.js +29 -26
- package/dist/es2019/ui/link-picker/search-results/link-search-list/link-search-no-results/no-results-svg/old/index.js +63 -0
- package/dist/es2019/ui/link-picker/search-results/link-search-list/list-item/index.compiled.css +34 -0
- package/dist/es2019/ui/link-picker/search-results/link-search-list/list-item/index.js +77 -72
- package/dist/es2019/ui/link-picker/search-results/link-search-list/list-item/old/index.js +132 -0
- package/dist/es2019/ui/link-picker/search-results/link-search-list/old/index.js +178 -0
- package/dist/es2019/ui/link-picker/search-results/old/index.js +98 -0
- package/dist/es2019/ui/link-picker/search-results/scrolling-tabs/index.compiled.css +29 -0
- package/dist/es2019/ui/link-picker/search-results/scrolling-tabs/index.js +39 -39
- package/dist/es2019/ui/link-picker/search-results/scrolling-tabs/old/index.js +130 -0
- package/dist/es2019/ui/link-picker/search-results/search-results-container/index.compiled.css +4 -0
- package/dist/es2019/ui/link-picker/search-results/search-results-container/index.js +16 -16
- package/dist/es2019/ui/link-picker/search-results/search-results-container/old/index.js +37 -0
- package/dist/es2019/ui/link-picker/text-input/index.compiled.css +11 -0
- package/dist/es2019/ui/link-picker/text-input/index.js +30 -38
- package/dist/es2019/ui/link-picker/text-input/old/index.js +121 -0
- package/dist/es2019/ui/loader-fallback/index.compiled.css +1 -0
- package/dist/es2019/ui/loader-fallback/index.js +17 -13
- package/dist/es2019/ui/loader-fallback/old/index.js +60 -0
- package/dist/es2019/ui/main.compiled.css +1 -0
- package/dist/es2019/ui/main.js +24 -22
- package/dist/es2019/ui/old/main.js +73 -0
- package/dist/esm/common/generic-error-svg/index.compiled.css +2 -0
- package/dist/esm/common/generic-error-svg/index.js +30 -23
- package/dist/esm/common/generic-error-svg/old/index.js +58 -0
- package/dist/esm/common/ui/empty-state/index.compiled.css +3 -0
- package/dist/esm/common/ui/empty-state/index.js +18 -9
- package/dist/esm/common/ui/empty-state/old/index.js +31 -0
- package/dist/esm/common/ui/min-height-container/index.compiled.css +4 -0
- package/dist/esm/common/ui/min-height-container/index.js +23 -14
- package/dist/esm/common/ui/min-height-container/old/index.js +25 -0
- package/dist/esm/ui/error-boundary/error-boundary-fallback/index.compiled.css +2 -0
- package/dist/esm/ui/error-boundary/error-boundary-fallback/index.js +20 -16
- package/dist/esm/ui/error-boundary/error-boundary-fallback/old/index.js +43 -0
- package/dist/esm/ui/link-picker/form-footer/index.compiled.css +3 -0
- package/dist/esm/ui/link-picker/form-footer/index.js +28 -34
- package/dist/esm/ui/link-picker/form-footer/link-picker-submit-button/index.js +2 -7
- package/dist/esm/ui/link-picker/form-footer/old/index.js +108 -0
- package/dist/esm/ui/link-picker/index.compiled.css +10 -0
- package/dist/esm/ui/link-picker/index.js +39 -59
- package/dist/esm/ui/link-picker/old/index.js +432 -0
- package/dist/esm/ui/link-picker/search-results/index.compiled.css +7 -0
- package/dist/esm/ui/link-picker/search-results/index.js +30 -32
- package/dist/esm/ui/link-picker/search-results/link-search-error/index.js +5 -10
- package/dist/esm/ui/link-picker/search-results/link-search-list/index.compiled.css +24 -0
- package/dist/esm/ui/link-picker/search-results/link-search-list/index.js +49 -43
- package/dist/esm/ui/link-picker/search-results/link-search-list/link-search-no-results/no-results-svg/index.compiled.css +2 -0
- package/dist/esm/ui/link-picker/search-results/link-search-list/link-search-no-results/no-results-svg/index.js +32 -26
- package/dist/esm/ui/link-picker/search-results/link-search-list/link-search-no-results/no-results-svg/old/index.js +63 -0
- package/dist/esm/ui/link-picker/search-results/link-search-list/list-item/index.compiled.css +34 -0
- package/dist/esm/ui/link-picker/search-results/link-search-list/list-item/index.js +94 -72
- package/dist/esm/ui/link-picker/search-results/link-search-list/list-item/old/index.js +136 -0
- package/dist/esm/ui/link-picker/search-results/link-search-list/old/index.js +186 -0
- package/dist/esm/ui/link-picker/search-results/old/index.js +100 -0
- package/dist/esm/ui/link-picker/search-results/scrolling-tabs/index.compiled.css +29 -0
- package/dist/esm/ui/link-picker/search-results/scrolling-tabs/index.js +52 -43
- package/dist/esm/ui/link-picker/search-results/scrolling-tabs/old/index.js +158 -0
- package/dist/esm/ui/link-picker/search-results/search-results-container/index.compiled.css +4 -0
- package/dist/esm/ui/link-picker/search-results/search-results-container/index.js +16 -16
- package/dist/esm/ui/link-picker/search-results/search-results-container/old/index.js +36 -0
- package/dist/esm/ui/link-picker/text-input/index.compiled.css +11 -0
- package/dist/esm/ui/link-picker/text-input/index.js +30 -38
- package/dist/esm/ui/link-picker/text-input/old/index.js +121 -0
- package/dist/esm/ui/loader-fallback/index.compiled.css +1 -0
- package/dist/esm/ui/loader-fallback/index.js +17 -13
- package/dist/esm/ui/loader-fallback/old/index.js +59 -0
- package/dist/esm/ui/main.compiled.css +1 -0
- package/dist/esm/ui/main.js +24 -22
- package/dist/esm/ui/old/main.js +64 -0
- package/dist/types/common/generic-error-svg/index.d.ts +3 -6
- package/dist/types/common/generic-error-svg/old/index.d.ts +6 -0
- package/dist/types/common/types.d.ts +0 -1
- package/dist/types/common/ui/empty-state/index.d.ts +3 -2
- package/dist/types/common/ui/empty-state/old/index.d.ts +9 -0
- package/dist/types/common/ui/min-height-container/index.d.ts +3 -0
- package/dist/types/common/ui/min-height-container/old/index.d.ts +8 -0
- package/dist/types/ui/error-boundary/error-boundary-fallback/index.d.ts +3 -6
- package/dist/types/ui/error-boundary/error-boundary-fallback/old/index.d.ts +6 -0
- package/dist/types/ui/link-picker/form-footer/index.d.ts +2 -5
- package/dist/types/ui/link-picker/form-footer/link-picker-submit-button/index.d.ts +2 -6
- package/dist/types/ui/link-picker/form-footer/old/index.d.ts +42 -0
- package/dist/types/ui/link-picker/index.d.ts +2 -2
- package/dist/types/ui/link-picker/old/index.d.ts +25 -0
- package/dist/types/ui/link-picker/search-results/index.d.ts +2 -2
- package/dist/types/ui/link-picker/search-results/link-search-error/index.d.ts +2 -6
- package/dist/types/ui/link-picker/search-results/link-search-list/index.d.ts +1 -0
- package/dist/types/ui/link-picker/search-results/link-search-list/link-search-no-results/no-results-svg/index.d.ts +3 -6
- package/dist/types/ui/link-picker/search-results/link-search-list/link-search-no-results/no-results-svg/old/index.d.ts +6 -0
- package/dist/types/ui/link-picker/search-results/link-search-list/list-item/index.d.ts +3 -2
- package/dist/types/ui/link-picker/search-results/link-search-list/list-item/old/index.d.ts +23 -0
- package/dist/types/ui/link-picker/search-results/link-search-list/old/index.d.ts +52 -0
- package/dist/types/ui/link-picker/search-results/old/index.d.ts +45 -0
- package/dist/types/ui/link-picker/search-results/scrolling-tabs/index.d.ts +4 -4
- package/dist/types/ui/link-picker/search-results/scrolling-tabs/old/index.d.ts +7 -0
- package/dist/types/ui/link-picker/search-results/search-results-container/index.d.ts +2 -2
- package/dist/types/ui/link-picker/search-results/search-results-container/old/index.d.ts +10 -0
- package/dist/types/ui/link-picker/text-input/index.d.ts +3 -2
- package/dist/types/ui/link-picker/text-input/old/index.d.ts +18 -0
- package/dist/types/ui/loader-fallback/index.d.ts +3 -6
- package/dist/types/ui/loader-fallback/old/index.d.ts +17 -0
- package/dist/types/ui/main.d.ts +2 -2
- package/dist/types/ui/old/main.d.ts +13 -0
- package/dist/types-ts4.5/common/generic-error-svg/index.d.ts +3 -6
- package/dist/types-ts4.5/common/generic-error-svg/old/index.d.ts +6 -0
- package/dist/types-ts4.5/common/types.d.ts +0 -1
- package/dist/types-ts4.5/common/ui/empty-state/index.d.ts +3 -2
- package/dist/types-ts4.5/common/ui/empty-state/old/index.d.ts +9 -0
- package/dist/types-ts4.5/common/ui/min-height-container/index.d.ts +3 -0
- package/dist/types-ts4.5/common/ui/min-height-container/old/index.d.ts +8 -0
- package/dist/types-ts4.5/ui/error-boundary/error-boundary-fallback/index.d.ts +3 -6
- package/dist/types-ts4.5/ui/error-boundary/error-boundary-fallback/old/index.d.ts +6 -0
- package/dist/types-ts4.5/ui/link-picker/form-footer/index.d.ts +2 -5
- package/dist/types-ts4.5/ui/link-picker/form-footer/link-picker-submit-button/index.d.ts +2 -6
- package/dist/types-ts4.5/ui/link-picker/form-footer/old/index.d.ts +42 -0
- package/dist/types-ts4.5/ui/link-picker/index.d.ts +2 -2
- package/dist/types-ts4.5/ui/link-picker/old/index.d.ts +25 -0
- package/dist/types-ts4.5/ui/link-picker/search-results/index.d.ts +2 -2
- package/dist/types-ts4.5/ui/link-picker/search-results/link-search-error/index.d.ts +2 -6
- package/dist/types-ts4.5/ui/link-picker/search-results/link-search-list/index.d.ts +1 -0
- package/dist/types-ts4.5/ui/link-picker/search-results/link-search-list/link-search-no-results/no-results-svg/index.d.ts +3 -6
- package/dist/types-ts4.5/ui/link-picker/search-results/link-search-list/link-search-no-results/no-results-svg/old/index.d.ts +6 -0
- package/dist/types-ts4.5/ui/link-picker/search-results/link-search-list/list-item/index.d.ts +3 -2
- package/dist/types-ts4.5/ui/link-picker/search-results/link-search-list/list-item/old/index.d.ts +23 -0
- package/dist/types-ts4.5/ui/link-picker/search-results/link-search-list/old/index.d.ts +52 -0
- package/dist/types-ts4.5/ui/link-picker/search-results/old/index.d.ts +45 -0
- package/dist/types-ts4.5/ui/link-picker/search-results/scrolling-tabs/index.d.ts +4 -4
- package/dist/types-ts4.5/ui/link-picker/search-results/scrolling-tabs/old/index.d.ts +7 -0
- package/dist/types-ts4.5/ui/link-picker/search-results/search-results-container/index.d.ts +2 -2
- package/dist/types-ts4.5/ui/link-picker/search-results/search-results-container/old/index.d.ts +10 -0
- package/dist/types-ts4.5/ui/link-picker/text-input/index.d.ts +3 -2
- package/dist/types-ts4.5/ui/link-picker/text-input/old/index.d.ts +18 -0
- package/dist/types-ts4.5/ui/loader-fallback/index.d.ts +3 -6
- package/dist/types-ts4.5/ui/loader-fallback/old/index.d.ts +17 -0
- package/dist/types-ts4.5/ui/main.d.ts +2 -2
- package/dist/types-ts4.5/ui/old/main.d.ts +13 -0
- package/lazy/package.json +3 -1
- package/package.json +14 -4
- package/dist/cjs/ui/link-picker/form-footer/feature-discovery/index.js +0 -69
- package/dist/cjs/ui/link-picker/form-footer/feature-discovery/styled.js +0 -25
- package/dist/es2019/ui/link-picker/form-footer/feature-discovery/index.js +0 -61
- package/dist/es2019/ui/link-picker/form-footer/feature-discovery/styled.js +0 -18
- package/dist/esm/ui/link-picker/form-footer/feature-discovery/index.js +0 -62
- package/dist/esm/ui/link-picker/form-footer/feature-discovery/styled.js +0 -18
- package/dist/types/ui/link-picker/form-footer/feature-discovery/index.d.ts +0 -15
- package/dist/types/ui/link-picker/form-footer/feature-discovery/styled.d.ts +0 -1
- package/dist/types-ts4.5/ui/link-picker/form-footer/feature-discovery/index.d.ts +0 -15
- package/dist/types-ts4.5/ui/link-picker/form-footer/feature-discovery/styled.d.ts +0 -1
- /package/dist/cjs/common/ui/min-height-container/{styled.js → old/styled.js} +0 -0
- /package/dist/cjs/ui/link-picker/search-results/link-search-list/list-item/{styled.js → old/styled.js} +0 -0
- /package/dist/cjs/ui/link-picker/search-results/link-search-list/{styled.js → old/styled.js} +0 -0
- /package/dist/cjs/ui/link-picker/search-results/scrolling-tabs/{styles.js → old/styles.js} +0 -0
- /package/dist/es2019/common/ui/min-height-container/{styled.js → old/styled.js} +0 -0
- /package/dist/es2019/ui/link-picker/search-results/link-search-list/list-item/{styled.js → old/styled.js} +0 -0
- /package/dist/es2019/ui/link-picker/search-results/link-search-list/{styled.js → old/styled.js} +0 -0
- /package/dist/es2019/ui/link-picker/search-results/scrolling-tabs/{styles.js → old/styles.js} +0 -0
- /package/dist/esm/common/ui/min-height-container/{styled.js → old/styled.js} +0 -0
- /package/dist/esm/ui/link-picker/search-results/link-search-list/list-item/{styled.js → old/styled.js} +0 -0
- /package/dist/esm/ui/link-picker/search-results/link-search-list/{styled.js → old/styled.js} +0 -0
- /package/dist/esm/ui/link-picker/search-results/scrolling-tabs/{styles.js → old/styles.js} +0 -0
- /package/dist/types/common/ui/min-height-container/{styled.d.ts → old/styled.d.ts} +0 -0
- /package/dist/types/ui/link-picker/search-results/link-search-list/list-item/{styled.d.ts → old/styled.d.ts} +0 -0
- /package/dist/types/ui/link-picker/search-results/link-search-list/{styled.d.ts → old/styled.d.ts} +0 -0
- /package/dist/types/ui/link-picker/search-results/scrolling-tabs/{styles.d.ts → old/styles.d.ts} +0 -0
- /package/dist/types-ts4.5/common/ui/min-height-container/{styled.d.ts → old/styled.d.ts} +0 -0
- /package/dist/types-ts4.5/ui/link-picker/search-results/link-search-list/list-item/{styled.d.ts → old/styled.d.ts} +0 -0
- /package/dist/types-ts4.5/ui/link-picker/search-results/link-search-list/{styled.d.ts → old/styled.d.ts} +0 -0
- /package/dist/types-ts4.5/ui/link-picker/search-results/scrolling-tabs/{styles.d.ts → old/styles.d.ts} +0 -0
|
@@ -0,0 +1,432 @@
|
|
|
1
|
+
import _extends from "@babel/runtime/helpers/extends";
|
|
2
|
+
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
3
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
4
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
5
|
+
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; }
|
|
6
|
+
/* eslint-disable @atlassian/tangerine/import/no-parent-imports */
|
|
7
|
+
/**
|
|
8
|
+
* @jsxRuntime classic
|
|
9
|
+
* @jsx jsx
|
|
10
|
+
*/
|
|
11
|
+
import { Fragment, memo, useCallback, useLayoutEffect, useMemo, useReducer } from 'react';
|
|
12
|
+
|
|
13
|
+
// eslint-disable-next-line @atlaskit/ui-styling-standard/use-compiled -- Ignored via go/DSP-18766
|
|
14
|
+
import { css, jsx } from '@emotion/react';
|
|
15
|
+
import { FormattedMessage, useIntl } from 'react-intl-next';
|
|
16
|
+
import uuid from 'uuid';
|
|
17
|
+
import { useAnalyticsEvents } from '@atlaskit/analytics-next';
|
|
18
|
+
import { isSafeUrl, normalizeUrl } from '@atlaskit/linking-common/url';
|
|
19
|
+
import { browser } from '@atlaskit/linking-common/user-agent';
|
|
20
|
+
import { Box, xcss } from '@atlaskit/primitives';
|
|
21
|
+
import VisuallyHidden from '@atlaskit/visually-hidden';
|
|
22
|
+
import { useLinkPickerAnalytics, withInputFieldTracking, withLinkPickerAnalyticsContext } from '../../../common/analytics';
|
|
23
|
+
import { ANALYTICS_CHANNEL } from '../../../common/constants';
|
|
24
|
+
import createEventPayload from '../../../common/utils/analytics/analytics.codegen';
|
|
25
|
+
import { handleNavKeyDown } from '../../../common/utils/handleNavKeyDown';
|
|
26
|
+
import { usePlugins } from '../../../services/use-plugins';
|
|
27
|
+
import { useSearchQuery } from '../../../services/use-search-query';
|
|
28
|
+
import { Announcer } from '../announcer';
|
|
29
|
+
import { FormFooter, testIds as formFooterTestIds } from '../form-footer';
|
|
30
|
+
import { LinkPickerSubmitButton } from '../form-footer/link-picker-submit-button';
|
|
31
|
+
import { formMessages, linkMessages, linkTextMessages, searchMessages } from '../messages';
|
|
32
|
+
import { SearchResults, testIds as searchTestIds } from '../search-results';
|
|
33
|
+
import { testIds as textFieldTestIds, TextInput } from '../text-input';
|
|
34
|
+
import { TrackMount } from '../track-mount';
|
|
35
|
+
import { getDataSource, getScreenReaderText } from '../utils';
|
|
36
|
+
var rootContainerStyles = css({
|
|
37
|
+
paddingLeft: 'var(--link-picker-padding-left)',
|
|
38
|
+
paddingRight: 'var(--link-picker-padding-right)',
|
|
39
|
+
paddingTop: 'var(--link-picker-padding-top)',
|
|
40
|
+
paddingBottom: 'var(--link-picker-padding-bottom)',
|
|
41
|
+
boxSizing: 'border-box',
|
|
42
|
+
// eslint-disable-next-line @atlaskit/design-system/use-tokens-typography
|
|
43
|
+
lineHeight: 'initial',
|
|
44
|
+
// eslint-disable-next-line @atlaskit/ui-styling-standard/no-important-styles
|
|
45
|
+
display: 'block !important'
|
|
46
|
+
});
|
|
47
|
+
var formFooterMargin = css({
|
|
48
|
+
marginTop: "var(--ds-space-200, 16px)"
|
|
49
|
+
});
|
|
50
|
+
export var testIds = _objectSpread(_objectSpread(_objectSpread({
|
|
51
|
+
linkPickerRoot: 'link-picker-root',
|
|
52
|
+
linkPicker: 'link-picker',
|
|
53
|
+
urlInputField: 'link-url',
|
|
54
|
+
textInputField: 'link-text'
|
|
55
|
+
}, searchTestIds), formFooterTestIds), textFieldTestIds);
|
|
56
|
+
var initState = {
|
|
57
|
+
url: '',
|
|
58
|
+
displayText: '',
|
|
59
|
+
activeIndex: -1,
|
|
60
|
+
selectedIndex: -1,
|
|
61
|
+
invalidUrl: false,
|
|
62
|
+
activeTab: 0,
|
|
63
|
+
preventHidingRecents: false
|
|
64
|
+
};
|
|
65
|
+
var FullWidthSubmitButtonStyles = xcss({
|
|
66
|
+
marginTop: 'space.200',
|
|
67
|
+
display: 'flex',
|
|
68
|
+
flexDirection: 'column'
|
|
69
|
+
});
|
|
70
|
+
function reducer(state, payload) {
|
|
71
|
+
if (payload.url && state.url !== payload.url) {
|
|
72
|
+
return _objectSpread(_objectSpread({}, state), {}, {
|
|
73
|
+
invalidUrl: false,
|
|
74
|
+
selectedIndex: isSafeUrl(payload.url) && payload.url.length ? -1 : state.selectedIndex
|
|
75
|
+
}, payload);
|
|
76
|
+
}
|
|
77
|
+
return _objectSpread(_objectSpread({}, state), payload);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
/**
|
|
81
|
+
* Bind input fields to analytics tracking
|
|
82
|
+
*/
|
|
83
|
+
|
|
84
|
+
var getLinkFieldContent = function getLinkFieldContent(value) {
|
|
85
|
+
if (!Boolean(value)) {
|
|
86
|
+
return null;
|
|
87
|
+
}
|
|
88
|
+
return isSafeUrl(value) ? 'url' : 'text_string';
|
|
89
|
+
};
|
|
90
|
+
var LinkInputField = withInputFieldTracking(TextInput, 'link', function (event, attributes) {
|
|
91
|
+
return _objectSpread(_objectSpread({}, attributes), {}, {
|
|
92
|
+
linkFieldContent: getLinkFieldContent(event.currentTarget.value)
|
|
93
|
+
});
|
|
94
|
+
});
|
|
95
|
+
var DisplayTextInputField = withInputFieldTracking(TextInput, 'displayText');
|
|
96
|
+
export var LinkPickerOld = withLinkPickerAnalyticsContext( /*#__PURE__*/memo(function (_ref) {
|
|
97
|
+
var onSubmit = _ref.onSubmit,
|
|
98
|
+
onCancel = _ref.onCancel,
|
|
99
|
+
onContentResize = _ref.onContentResize,
|
|
100
|
+
plugins = _ref.plugins,
|
|
101
|
+
isLoadingPlugins = _ref.isLoadingPlugins,
|
|
102
|
+
initUrl = _ref.url,
|
|
103
|
+
initDisplayText = _ref.displayText,
|
|
104
|
+
hideDisplayText = _ref.hideDisplayText,
|
|
105
|
+
featureFlags = _ref.featureFlags,
|
|
106
|
+
customMessages = _ref.customMessages,
|
|
107
|
+
_ref$isSubmitting = _ref.isSubmitting,
|
|
108
|
+
isSubmitting = _ref$isSubmitting === void 0 ? false : _ref$isSubmitting,
|
|
109
|
+
_ref$adaptiveHeight = _ref.adaptiveHeight,
|
|
110
|
+
adaptiveHeight = _ref$adaptiveHeight === void 0 ? false : _ref$adaptiveHeight,
|
|
111
|
+
_ref$UNSAFE_moveSubmi = _ref.UNSAFE_moveSubmitButton,
|
|
112
|
+
UNSAFE_moveSubmitButton = _ref$UNSAFE_moveSubmi === void 0 ? false : _ref$UNSAFE_moveSubmi;
|
|
113
|
+
var _useAnalyticsEvents = useAnalyticsEvents(),
|
|
114
|
+
createAnalyticsEvent = _useAnalyticsEvents.createAnalyticsEvent;
|
|
115
|
+
var _useReducer = useReducer(reducer, _objectSpread(_objectSpread({}, initState), {}, {
|
|
116
|
+
url: normalizeUrl(initUrl) || '',
|
|
117
|
+
displayText: initDisplayText || ''
|
|
118
|
+
})),
|
|
119
|
+
_useReducer2 = _slicedToArray(_useReducer, 2),
|
|
120
|
+
state = _useReducer2[0],
|
|
121
|
+
dispatch = _useReducer2[1];
|
|
122
|
+
var activeIndex = state.activeIndex,
|
|
123
|
+
selectedIndex = state.selectedIndex,
|
|
124
|
+
url = state.url,
|
|
125
|
+
displayText = state.displayText,
|
|
126
|
+
invalidUrl = state.invalidUrl,
|
|
127
|
+
activeTab = state.activeTab;
|
|
128
|
+
var intl = useIntl();
|
|
129
|
+
var queryState = useSearchQuery(state);
|
|
130
|
+
var _usePlugins = usePlugins(queryState, activeTab, plugins),
|
|
131
|
+
items = _usePlugins.items,
|
|
132
|
+
isLoadingResults = _usePlugins.isLoading,
|
|
133
|
+
isActivePlugin = _usePlugins.isActivePlugin,
|
|
134
|
+
activePlugin = _usePlugins.activePlugin,
|
|
135
|
+
tabs = _usePlugins.tabs,
|
|
136
|
+
error = _usePlugins.error,
|
|
137
|
+
retry = _usePlugins.retry,
|
|
138
|
+
pluginAction = _usePlugins.pluginAction;
|
|
139
|
+
var isEditing = !!initUrl;
|
|
140
|
+
var selectedItem = items === null || items === void 0 ? void 0 : items[selectedIndex];
|
|
141
|
+
var isSelectedItem = (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.url) === url;
|
|
142
|
+
var _useLinkPickerAnalyti = useLinkPickerAnalytics(),
|
|
143
|
+
trackAttribute = _useLinkPickerAnalyti.trackAttribute,
|
|
144
|
+
getAttributes = _useLinkPickerAnalyti.getAttributes;
|
|
145
|
+
var submitMessageId = useMemo(function () {
|
|
146
|
+
return uuid();
|
|
147
|
+
}, []);
|
|
148
|
+
useLayoutEffect(function () {
|
|
149
|
+
if (onContentResize) {
|
|
150
|
+
onContentResize();
|
|
151
|
+
}
|
|
152
|
+
}, [onContentResize, items, isLoadingResults, isActivePlugin, tabs]);
|
|
153
|
+
var handleChangeUrl = useCallback(function (e) {
|
|
154
|
+
if (isSubmitting) {
|
|
155
|
+
// Prevent changing url while submitting
|
|
156
|
+
return;
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
/** Any on change event is triggered by manual input or paste, so source is null */
|
|
160
|
+
trackAttribute('linkFieldContentInputSource', null);
|
|
161
|
+
dispatch({
|
|
162
|
+
url: e.currentTarget.value,
|
|
163
|
+
// If the last action was changing tabs, make sure we're now allowing recents to be hidden
|
|
164
|
+
preventHidingRecents: false
|
|
165
|
+
});
|
|
166
|
+
}, [dispatch, trackAttribute, isSubmitting]);
|
|
167
|
+
var handleChangeText = useCallback(function (e) {
|
|
168
|
+
dispatch({
|
|
169
|
+
displayText: e.currentTarget.value
|
|
170
|
+
});
|
|
171
|
+
}, [dispatch]);
|
|
172
|
+
var handleClear = useCallback(function (field) {
|
|
173
|
+
dispatch(_defineProperty({
|
|
174
|
+
activeIndex: -1,
|
|
175
|
+
selectedIndex: -1
|
|
176
|
+
}, field, ''));
|
|
177
|
+
}, [dispatch]);
|
|
178
|
+
var handleUrlClear = useCallback(function () {
|
|
179
|
+
if (isSubmitting) {
|
|
180
|
+
// Prevent clearing url while submitting
|
|
181
|
+
return;
|
|
182
|
+
}
|
|
183
|
+
trackAttribute('linkFieldContentInputSource', null);
|
|
184
|
+
handleClear('url');
|
|
185
|
+
}, [trackAttribute, handleClear, isSubmitting]);
|
|
186
|
+
var handleInsert = useCallback(function (url, title, inputType, data) {
|
|
187
|
+
var event = createAnalyticsEvent(createEventPayload('ui.form.submitted.linkPicker', {}));
|
|
188
|
+
|
|
189
|
+
// Clone the event so that it can be emitted for consumer usage
|
|
190
|
+
// This must happen BEFORE the original event is fired!
|
|
191
|
+
var consumerEvent = event.clone();
|
|
192
|
+
// Cloned event doesnt have the attributes that are added by
|
|
193
|
+
// the analytics listener in the LinkPickerAnalyticsContext, add them here
|
|
194
|
+
consumerEvent === null || consumerEvent === void 0 || consumerEvent.update({
|
|
195
|
+
attributes: getAttributes()
|
|
196
|
+
});
|
|
197
|
+
// Dispatch the original event to our channel
|
|
198
|
+
event.fire(ANALYTICS_CHANNEL);
|
|
199
|
+
onSubmit(_objectSpread({
|
|
200
|
+
url: url,
|
|
201
|
+
displayText: displayText || null,
|
|
202
|
+
title: title || null,
|
|
203
|
+
meta: {
|
|
204
|
+
inputMethod: inputType
|
|
205
|
+
},
|
|
206
|
+
data: data
|
|
207
|
+
}, inputType === 'manual' ? {
|
|
208
|
+
rawUrl: state.url
|
|
209
|
+
} : {}), consumerEvent);
|
|
210
|
+
}, [displayText, onSubmit, state.url, createAnalyticsEvent, getAttributes]);
|
|
211
|
+
var handleSelected = useCallback(function (objectId) {
|
|
212
|
+
if (isSubmitting) {
|
|
213
|
+
// Prevent changing selection while submitting
|
|
214
|
+
return;
|
|
215
|
+
}
|
|
216
|
+
var selectedItem = items === null || items === void 0 ? void 0 : items.find(function (item) {
|
|
217
|
+
return item.objectId === objectId;
|
|
218
|
+
});
|
|
219
|
+
if (selectedItem) {
|
|
220
|
+
var _url = selectedItem.url,
|
|
221
|
+
name = selectedItem.name;
|
|
222
|
+
/**
|
|
223
|
+
* Manually track that the url has been updated using searchResult method
|
|
224
|
+
*/
|
|
225
|
+
dispatchEvent(new Event('submit'));
|
|
226
|
+
trackAttribute('linkFieldContent', getLinkFieldContent(_url));
|
|
227
|
+
trackAttribute('linkFieldContentInputMethod', 'searchResult');
|
|
228
|
+
trackAttribute('linkFieldContentInputSource', getDataSource(selectedItem, activePlugin));
|
|
229
|
+
handleInsert(_url, name, 'typeAhead', _objectSpread({}, selectedItem));
|
|
230
|
+
}
|
|
231
|
+
}, [handleInsert, trackAttribute, items, activePlugin, isSubmitting]);
|
|
232
|
+
var handleSubmit = useCallback(function (event) {
|
|
233
|
+
event === null || event === void 0 || event.preventDefault();
|
|
234
|
+
if (isSubmitting) {
|
|
235
|
+
// Prevent submit while submitting
|
|
236
|
+
return;
|
|
237
|
+
}
|
|
238
|
+
if (isSelectedItem && selectedItem) {
|
|
239
|
+
return handleInsert(selectedItem.url, selectedItem.name, 'typeAhead');
|
|
240
|
+
}
|
|
241
|
+
var normalized = normalizeUrl(url);
|
|
242
|
+
if (normalized) {
|
|
243
|
+
return handleInsert(normalized, null, 'manual');
|
|
244
|
+
}
|
|
245
|
+
return dispatch({
|
|
246
|
+
invalidUrl: true
|
|
247
|
+
});
|
|
248
|
+
}, [dispatch, handleInsert, isSelectedItem, selectedItem, url, isSubmitting]);
|
|
249
|
+
var handleTabChange = useCallback(function (activeTab) {
|
|
250
|
+
var _plugins$activeTab$ta, _plugins$activeTab;
|
|
251
|
+
dispatch({
|
|
252
|
+
// We don't want any selection to exist after changing tab, as the selection
|
|
253
|
+
// wouldn't mean anything.
|
|
254
|
+
activeIndex: -1,
|
|
255
|
+
selectedIndex: -1,
|
|
256
|
+
// We don't want recents to be hidden, even though we don't have a selection
|
|
257
|
+
preventHidingRecents: true,
|
|
258
|
+
invalidUrl: false,
|
|
259
|
+
activeTab: activeTab
|
|
260
|
+
});
|
|
261
|
+
trackAttribute('tab', (_plugins$activeTab$ta = plugins === null || plugins === void 0 || (_plugins$activeTab = plugins[activeTab]) === null || _plugins$activeTab === void 0 ? void 0 : _plugins$activeTab.tabKey) !== null && _plugins$activeTab$ta !== void 0 ? _plugins$activeTab$ta : null);
|
|
262
|
+
}, [dispatch, plugins, trackAttribute]);
|
|
263
|
+
var handleSearchListOnChange = function handleSearchListOnChange(id) {
|
|
264
|
+
if (isSubmitting) {
|
|
265
|
+
// Prevent changing item while submitting
|
|
266
|
+
return;
|
|
267
|
+
}
|
|
268
|
+
var index = items === null || items === void 0 ? void 0 : items.findIndex(function (item) {
|
|
269
|
+
return item.objectId === id;
|
|
270
|
+
});
|
|
271
|
+
if (typeof index === 'number') {
|
|
272
|
+
var item = items === null || items === void 0 ? void 0 : items[index];
|
|
273
|
+
if (item) {
|
|
274
|
+
/**
|
|
275
|
+
* Manually track that the url has been updated using searchResult method
|
|
276
|
+
*/
|
|
277
|
+
trackAttribute('linkFieldContent', getLinkFieldContent(item.url));
|
|
278
|
+
trackAttribute('linkFieldContentInputMethod', 'searchResult');
|
|
279
|
+
trackAttribute('linkFieldContentInputSource', getDataSource(item, activePlugin));
|
|
280
|
+
dispatch({
|
|
281
|
+
activeIndex: index,
|
|
282
|
+
selectedIndex: index,
|
|
283
|
+
url: item.url,
|
|
284
|
+
invalidUrl: false
|
|
285
|
+
});
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
};
|
|
289
|
+
var handleKeyDown = useCallback(function (event) {
|
|
290
|
+
if (!(items !== null && items !== void 0 && items.length)) {
|
|
291
|
+
return;
|
|
292
|
+
}
|
|
293
|
+
var updatedIndex = activeIndex;
|
|
294
|
+
if (event.key === 'Enter') {
|
|
295
|
+
event.preventDefault();
|
|
296
|
+
if (selectedItem) {
|
|
297
|
+
handleSelected(selectedItem.objectId);
|
|
298
|
+
} else {
|
|
299
|
+
// triggers validation error message
|
|
300
|
+
handleSubmit();
|
|
301
|
+
}
|
|
302
|
+
} else {
|
|
303
|
+
updatedIndex = handleNavKeyDown(event, items.length, activeIndex);
|
|
304
|
+
}
|
|
305
|
+
var item = items[updatedIndex];
|
|
306
|
+
if (['Enter', 'ArrowDown', 'ArrowUp', 'Home', 'End'].includes(event.key) && item) {
|
|
307
|
+
/**
|
|
308
|
+
* Manually track that the url has been updated using searchResult method
|
|
309
|
+
*/
|
|
310
|
+
trackAttribute('linkFieldContent', getLinkFieldContent(item.url));
|
|
311
|
+
trackAttribute('linkFieldContentInputMethod', 'searchResult');
|
|
312
|
+
trackAttribute('linkFieldContentInputSource', getDataSource(item, activePlugin));
|
|
313
|
+
dispatch({
|
|
314
|
+
activeIndex: updatedIndex,
|
|
315
|
+
selectedIndex: updatedIndex,
|
|
316
|
+
url: item.url,
|
|
317
|
+
invalidUrl: false
|
|
318
|
+
});
|
|
319
|
+
}
|
|
320
|
+
}, [items, activeIndex, selectedItem, handleSelected, handleSubmit, trackAttribute, activePlugin]);
|
|
321
|
+
var messages = isActivePlugin ? searchMessages : linkMessages;
|
|
322
|
+
var screenReaderDescriptionId = 'search-recent-links-field-description';
|
|
323
|
+
var linkSearchListId = 'link-picker-search-list';
|
|
324
|
+
var ariaActiveDescendant = selectedIndex > -1 ? "link-search-list-item-".concat(selectedIndex) : '';
|
|
325
|
+
var a11yList = isActivePlugin || isLoadingPlugins ? {
|
|
326
|
+
role: 'combobox',
|
|
327
|
+
// When a combobox popup is not visible, the element with role combobox has aria-expanded set to false
|
|
328
|
+
// https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-expanded#combobox
|
|
329
|
+
'aria-expanded': !!(items !== null && items !== void 0 && items.length),
|
|
330
|
+
'aria-autocomplete': 'list',
|
|
331
|
+
'aria-controls': linkSearchListId,
|
|
332
|
+
'aria-activedescendant': ariaActiveDescendant,
|
|
333
|
+
'aria-describedby': screenReaderDescriptionId
|
|
334
|
+
} : undefined;
|
|
335
|
+
|
|
336
|
+
// Added workaround with a screen reader Announcer specifically for VoiceOver + Safari
|
|
337
|
+
// as the Aria design pattern for combobox does not work in this case
|
|
338
|
+
// for details: https://a11y-internal.atlassian.net/browse/AK-740
|
|
339
|
+
var screenReaderText = browser().safari && getScreenReaderText(items !== null && items !== void 0 ? items : [], selectedIndex, intl);
|
|
340
|
+
var customSubmitButtonLabel = customMessages !== null && customMessages !== void 0 && customMessages.submitButtonLabel ? customMessages.submitButtonLabel : undefined;
|
|
341
|
+
return jsx("form", {
|
|
342
|
+
"data-testid": testIds.linkPicker,
|
|
343
|
+
css: rootContainerStyles
|
|
344
|
+
// Use onSubmitCapture instead of onSubmit so that any possible parent form isn't submitted
|
|
345
|
+
,
|
|
346
|
+
onSubmitCapture: handleSubmit
|
|
347
|
+
}, jsx(TrackMount, null), isActivePlugin && jsx(Fragment, null, screenReaderText && jsx(Announcer, {
|
|
348
|
+
ariaLive: "assertive",
|
|
349
|
+
text: screenReaderText,
|
|
350
|
+
ariaRelevant: "additions",
|
|
351
|
+
delay: 250
|
|
352
|
+
}), jsx(VisuallyHidden, {
|
|
353
|
+
id: screenReaderDescriptionId
|
|
354
|
+
}, customMessages !== null && customMessages !== void 0 && customMessages.linkAriaLabel ? jsx(FormattedMessage, customMessages.linkAriaLabel) : jsx(FormattedMessage, messages.linkAriaLabel))), jsx(LinkInputField, _extends({
|
|
355
|
+
name: "url",
|
|
356
|
+
autoComplete: "off",
|
|
357
|
+
testId: testIds.urlInputField,
|
|
358
|
+
label: customMessages !== null && customMessages !== void 0 && customMessages.linkLabel ? intl.formatMessage(customMessages.linkLabel) : intl.formatMessage(messages.linkLabel),
|
|
359
|
+
placeholder: customMessages !== null && customMessages !== void 0 && customMessages.linkPlaceholder ? intl.formatMessage(customMessages === null || customMessages === void 0 ? void 0 : customMessages.linkPlaceholder) : intl.formatMessage(messages.linkPlaceholder),
|
|
360
|
+
value: url,
|
|
361
|
+
autoFocus: true,
|
|
362
|
+
clearLabel: intl.formatMessage(formMessages.clearLink),
|
|
363
|
+
error: invalidUrl ? intl.formatMessage(formMessages.linkInvalid) : null,
|
|
364
|
+
spotlightTargetName: "link-picker-search-field-spotlight-target",
|
|
365
|
+
"aria-readonly": isSubmitting
|
|
366
|
+
}, a11yList, {
|
|
367
|
+
onClear: handleUrlClear,
|
|
368
|
+
onKeyDown: handleKeyDown,
|
|
369
|
+
onChange: handleChangeUrl
|
|
370
|
+
})), !hideDisplayText && jsx(DisplayTextInputField, {
|
|
371
|
+
autoComplete: "off",
|
|
372
|
+
name: "displayText",
|
|
373
|
+
testId: testIds.textInputField,
|
|
374
|
+
value: displayText,
|
|
375
|
+
label: customMessages !== null && customMessages !== void 0 && customMessages.linkTextLabel ? intl.formatMessage(customMessages.linkTextLabel) : intl.formatMessage(linkTextMessages.linkTextLabel),
|
|
376
|
+
placeholder: customMessages !== null && customMessages !== void 0 && customMessages.linkTextPlaceholder ? intl.formatMessage(customMessages === null || customMessages === void 0 ? void 0 : customMessages.linkTextPlaceholder) : intl.formatMessage(linkTextMessages.linkTextPlaceholder),
|
|
377
|
+
clearLabel: intl.formatMessage(linkTextMessages.clearLinkText),
|
|
378
|
+
readOnly: isSubmitting,
|
|
379
|
+
onClear: handleClear,
|
|
380
|
+
onChange: handleChangeText
|
|
381
|
+
}), UNSAFE_moveSubmitButton && jsx(Box, {
|
|
382
|
+
xcss: FullWidthSubmitButtonStyles
|
|
383
|
+
}, jsx(LinkPickerSubmitButton, {
|
|
384
|
+
isEditing: isEditing,
|
|
385
|
+
isLoading: isLoadingResults || !!isLoadingPlugins,
|
|
386
|
+
isSubmitting: isSubmitting,
|
|
387
|
+
customSubmitButtonLabel: customSubmitButtonLabel,
|
|
388
|
+
error: error,
|
|
389
|
+
items: items,
|
|
390
|
+
queryState: queryState,
|
|
391
|
+
submitMessageId: submitMessageId,
|
|
392
|
+
testId: testIds.insertButton,
|
|
393
|
+
url: url
|
|
394
|
+
})), !!queryState && (isLoadingPlugins || isActivePlugin) && jsx(SearchResults, {
|
|
395
|
+
activeTab: activeTab,
|
|
396
|
+
tabs: tabs,
|
|
397
|
+
activePlugin: activePlugin,
|
|
398
|
+
isLoadingResults: isLoadingResults,
|
|
399
|
+
isLoadingPlugins: isLoadingPlugins,
|
|
400
|
+
isSubmitting: isSubmitting,
|
|
401
|
+
linkSearchListId: linkSearchListId,
|
|
402
|
+
error: error,
|
|
403
|
+
featureFlags: featureFlags,
|
|
404
|
+
activeIndex: activeIndex,
|
|
405
|
+
selectedIndex: selectedIndex,
|
|
406
|
+
items: items,
|
|
407
|
+
queryState: queryState,
|
|
408
|
+
handleKeyDown: handleKeyDown,
|
|
409
|
+
handleSelected: handleSelected,
|
|
410
|
+
handleTabChange: handleTabChange,
|
|
411
|
+
handleSearchListOnChange: handleSearchListOnChange,
|
|
412
|
+
adaptiveHeight: adaptiveHeight,
|
|
413
|
+
retry: retry
|
|
414
|
+
}), jsx(FormFooter, {
|
|
415
|
+
error: error,
|
|
416
|
+
items: items
|
|
417
|
+
/** If the results section appears to be loading, impact whether the submit button is disabled */,
|
|
418
|
+
isLoading: isLoadingResults || !!isLoadingPlugins,
|
|
419
|
+
isSubmitting: isSubmitting,
|
|
420
|
+
queryState: queryState,
|
|
421
|
+
url: url,
|
|
422
|
+
isEditing: isEditing,
|
|
423
|
+
onCancel: onCancel,
|
|
424
|
+
action: pluginAction
|
|
425
|
+
// eslint-disable-next-line @atlaskit/ui-styling-standard/no-imported-style-values -- Ignored via go/DSP-18766
|
|
426
|
+
,
|
|
427
|
+
css: !queryState || !(plugins !== null && plugins !== void 0 && plugins.length) ? formFooterMargin : undefined,
|
|
428
|
+
customSubmitButtonLabel: customSubmitButtonLabel,
|
|
429
|
+
submitMessageId: submitMessageId,
|
|
430
|
+
hideSubmitButton: UNSAFE_moveSubmitButton
|
|
431
|
+
}));
|
|
432
|
+
}));
|
|
@@ -1,39 +1,31 @@
|
|
|
1
|
+
/* index.tsx generated by @compiled/babel-plugin v0.36.0 */
|
|
1
2
|
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
3
|
+
import "./index.compiled.css";
|
|
4
|
+
import * as React from 'react';
|
|
5
|
+
import { ax, ix } from "@compiled/react/runtime";
|
|
2
6
|
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
3
7
|
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; }
|
|
4
|
-
/**
|
|
5
|
-
* @jsxRuntime classic
|
|
6
|
-
* @jsx jsx
|
|
7
|
-
*/
|
|
8
8
|
import { Fragment } from 'react';
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
import { css, jsx } from '@emotion/react';
|
|
12
|
-
import { Box, xcss } from '@atlaskit/primitives';
|
|
9
|
+
import { fg } from '@atlaskit/platform-feature-flags';
|
|
10
|
+
import { Box } from '@atlaskit/primitives/compiled';
|
|
13
11
|
import Spinner from '@atlaskit/spinner/spinner';
|
|
14
12
|
import Tabs, { Tab, TabList } from '@atlaskit/tabs';
|
|
15
13
|
import { LinkSearchError, testIds as searchErrorTestIds } from './link-search-error';
|
|
16
14
|
import { LinkSearchList, testIds as listTestIds } from './link-search-list';
|
|
15
|
+
import { SearchResultsOld } from './old';
|
|
17
16
|
import { ScrollingTabList } from './scrolling-tabs';
|
|
18
17
|
import { SearchResultsContainer } from './search-results-container';
|
|
19
18
|
import { TrackTabViewed } from './track-tab-viewed';
|
|
20
|
-
var
|
|
21
|
-
|
|
22
|
-
}
|
|
23
|
-
var spinnerContainerStyles =
|
|
24
|
-
minHeight: '80px',
|
|
25
|
-
display: 'flex',
|
|
26
|
-
alignItems: 'center',
|
|
27
|
-
justifyContent: 'center',
|
|
28
|
-
alignSelf: 'center',
|
|
29
|
-
flexGrow: 1
|
|
30
|
-
});
|
|
19
|
+
var styles = {
|
|
20
|
+
tabsWrapper: "_19pkutpp"
|
|
21
|
+
};
|
|
22
|
+
var spinnerContainerStyles = null;
|
|
31
23
|
export var testIds = _objectSpread(_objectSpread(_objectSpread({}, searchErrorTestIds), listTestIds), {}, {
|
|
32
24
|
tabsLoadingIndicator: 'link-picker.tabs-loading-indicator',
|
|
33
25
|
tabList: 'link-picker-tabs',
|
|
34
26
|
tabItem: 'link-picker-tab'
|
|
35
27
|
});
|
|
36
|
-
export var
|
|
28
|
+
export var SearchResultsNew = function SearchResultsNew(_ref) {
|
|
37
29
|
var _activePlugin$errorFa, _activePlugin$errorFa2;
|
|
38
30
|
var tabs = _ref.tabs,
|
|
39
31
|
activeTab = _ref.activeTab,
|
|
@@ -55,32 +47,32 @@ export var SearchResults = function SearchResults(_ref) {
|
|
|
55
47
|
adaptiveHeight = _ref.adaptiveHeight,
|
|
56
48
|
retry = _ref.retry;
|
|
57
49
|
var isActivePlugin = !!activePlugin;
|
|
58
|
-
var tabList =
|
|
59
|
-
return
|
|
50
|
+
var tabList = /*#__PURE__*/React.createElement(TabList, null, tabs.map(function (tab) {
|
|
51
|
+
return /*#__PURE__*/React.createElement(Tab, {
|
|
60
52
|
key: tab.tabTitle,
|
|
61
53
|
testId: testIds.tabItem
|
|
62
54
|
}, tab.tabTitle);
|
|
63
55
|
}));
|
|
64
|
-
return
|
|
56
|
+
return /*#__PURE__*/React.createElement(SearchResultsContainer, {
|
|
65
57
|
hasTabs: !!tabs.length || isLoadingPlugins,
|
|
66
58
|
adaptiveHeight: adaptiveHeight,
|
|
67
59
|
isLoadingResults: isLoadingResults
|
|
68
|
-
}, isLoadingPlugins && !!queryState &&
|
|
69
|
-
|
|
70
|
-
},
|
|
60
|
+
}, isLoadingPlugins && !!queryState && /*#__PURE__*/React.createElement("div", {
|
|
61
|
+
className: ax(["_1tkeys9h _1e0c1txw _4cvr1h6o _1bah1h6o _1wpz1h6o _16jlkb7n"])
|
|
62
|
+
}, /*#__PURE__*/React.createElement(Spinner, {
|
|
71
63
|
testId: testIds.tabsLoadingIndicator,
|
|
72
64
|
interactionName: "link-picker-tabs-loading",
|
|
73
65
|
size: "medium"
|
|
74
|
-
})), !isLoadingPlugins && isActivePlugin && !!queryState &&
|
|
75
|
-
xcss:
|
|
76
|
-
},
|
|
66
|
+
})), !isLoadingPlugins && isActivePlugin && !!queryState && /*#__PURE__*/React.createElement(Fragment, null, tabs.length > 0 && /*#__PURE__*/React.createElement(Box, {
|
|
67
|
+
xcss: styles.tabsWrapper
|
|
68
|
+
}, /*#__PURE__*/React.createElement(Tabs, {
|
|
77
69
|
id: testIds.tabList,
|
|
78
70
|
testId: testIds.tabList,
|
|
79
71
|
selected: activeTab,
|
|
80
72
|
onChange: handleTabChange
|
|
81
|
-
}, featureFlags !== null && featureFlags !== void 0 && featureFlags.scrollingTabs ?
|
|
73
|
+
}, featureFlags !== null && featureFlags !== void 0 && featureFlags.scrollingTabs ? /*#__PURE__*/React.createElement(ScrollingTabList, null, tabList) : tabList), /*#__PURE__*/React.createElement(TrackTabViewed, {
|
|
82
74
|
activePlugin: activePlugin
|
|
83
|
-
})), !error &&
|
|
75
|
+
})), !error && /*#__PURE__*/React.createElement(LinkSearchList, {
|
|
84
76
|
id: linkSearchListId,
|
|
85
77
|
role: "listbox",
|
|
86
78
|
ariaReadOnly: isSubmitting,
|
|
@@ -94,5 +86,11 @@ export var SearchResults = function SearchResults(_ref) {
|
|
|
94
86
|
hasSearchTerm: !!(queryState !== null && queryState !== void 0 && queryState.query.length),
|
|
95
87
|
activePlugin: activePlugin,
|
|
96
88
|
adaptiveHeight: adaptiveHeight
|
|
97
|
-
}), error ? (_activePlugin$errorFa = activePlugin === null || activePlugin === void 0 || (_activePlugin$errorFa2 = activePlugin.errorFallback) === null || _activePlugin$errorFa2 === void 0 ? void 0 : _activePlugin$errorFa2.call(activePlugin, error, retry)) !== null && _activePlugin$errorFa !== void 0 ? _activePlugin$errorFa :
|
|
89
|
+
}), error ? (_activePlugin$errorFa = activePlugin === null || activePlugin === void 0 || (_activePlugin$errorFa2 = activePlugin.errorFallback) === null || _activePlugin$errorFa2 === void 0 ? void 0 : _activePlugin$errorFa2.call(activePlugin, error, retry)) !== null && _activePlugin$errorFa !== void 0 ? _activePlugin$errorFa : /*#__PURE__*/React.createElement(LinkSearchError, null) : null));
|
|
90
|
+
};
|
|
91
|
+
export var SearchResults = function SearchResults(props) {
|
|
92
|
+
if (fg('platform_bandicoots-link-picker-css')) {
|
|
93
|
+
return /*#__PURE__*/React.createElement(SearchResultsNew, props);
|
|
94
|
+
}
|
|
95
|
+
return /*#__PURE__*/React.createElement(SearchResultsOld, props);
|
|
98
96
|
};
|
|
@@ -1,10 +1,5 @@
|
|
|
1
1
|
import _extends from "@babel/runtime/helpers/extends";
|
|
2
|
-
|
|
3
|
-
* @jsxRuntime classic
|
|
4
|
-
* @jsx jsx
|
|
5
|
-
*/
|
|
6
|
-
// eslint-disable-next-line @atlaskit/ui-styling-standard/use-compiled -- Ignored via go/DSP-18766
|
|
7
|
-
import { jsx } from '@emotion/react';
|
|
2
|
+
import React from 'react';
|
|
8
3
|
import { defineMessages, FormattedMessage, useIntl } from 'react-intl-next';
|
|
9
4
|
import { isFedRamp } from '@atlaskit/atlassian-context';
|
|
10
5
|
import Button from '@atlaskit/button';
|
|
@@ -29,13 +24,13 @@ export var testIds = {
|
|
|
29
24
|
};
|
|
30
25
|
export var LinkSearchError = function LinkSearchError() {
|
|
31
26
|
var intl = useIntl();
|
|
32
|
-
return
|
|
27
|
+
return /*#__PURE__*/React.createElement(EmptyState, {
|
|
33
28
|
testId: testIds.searchError,
|
|
34
29
|
header: intl.formatMessage(messages.searchErrorHeader),
|
|
35
|
-
description:
|
|
30
|
+
description: /*#__PURE__*/React.createElement(FormattedMessage, _extends({}, messages.searchErrorDescription, {
|
|
36
31
|
values: {
|
|
37
32
|
a: function a(label) {
|
|
38
|
-
return
|
|
33
|
+
return /*#__PURE__*/React.createElement(Button, {
|
|
39
34
|
appearance: "link",
|
|
40
35
|
spacing: "none",
|
|
41
36
|
href: isFedRamp() ? CONTACT_SUPPORT_LINK_FEDRAMP : CONTACT_SUPPORT_LINK,
|
|
@@ -46,7 +41,7 @@ export var LinkSearchError = function LinkSearchError() {
|
|
|
46
41
|
}
|
|
47
42
|
})),
|
|
48
43
|
renderImage: function renderImage() {
|
|
49
|
-
return
|
|
44
|
+
return /*#__PURE__*/React.createElement(GenericErrorSVG, null);
|
|
50
45
|
}
|
|
51
46
|
});
|
|
52
47
|
};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
._11c81vlj{font:var(--ds-font-body-small,normal 400 11px/1pc ui-sans-serif,-apple-system,BlinkMacSystemFont,"Segoe UI",Ubuntu,system-ui,"Helvetica Neue",sans-serif)}
|
|
2
|
+
._qtt8glyw{list-style:none}
|
|
3
|
+
._16jlkb7n{flex-grow:1}
|
|
4
|
+
._18u01mjz{margin-left:calc(var(--link-picker-padding-left)*-1)}
|
|
5
|
+
._19bvze3t{padding-left:var(--ds-space-0,0)}
|
|
6
|
+
._19pkpxbi{margin-top:var(--ds-space-200,1pc)}
|
|
7
|
+
._19pkze3t{margin-top:var(--ds-space-0,0)}
|
|
8
|
+
._1bsb1osq{width:100%}
|
|
9
|
+
._1e0c1txw{display:flex}
|
|
10
|
+
._1tkepxbi{min-height:var(--ds-space-200,1pc)}
|
|
11
|
+
._1tkeys9h{min-height:5pc}
|
|
12
|
+
._2hwxum63{margin-right:calc(var(--link-picker-padding-right)*-1)}
|
|
13
|
+
._2lx21bp4{flex-direction:column}
|
|
14
|
+
._4cvr1h6o{align-items:center}
|
|
15
|
+
._ca0qidpf{padding-top:0}
|
|
16
|
+
._ca0qze3t{padding-top:var(--ds-space-0,0)}
|
|
17
|
+
._k48pmoej{font-weight:var(--ds-font-weight-bold,700)}
|
|
18
|
+
._n3tdze3t{padding-bottom:var(--ds-space-0,0)}
|
|
19
|
+
._otyr1b66{margin-bottom:var(--ds-space-050,4px)}
|
|
20
|
+
._otyrpxbi{margin-bottom:var(--ds-space-200,1pc)}
|
|
21
|
+
._otyrze3t{margin-bottom:var(--ds-space-0,0)}
|
|
22
|
+
._syaz131l{color:var(--ds-text-subtlest,#626f86)}
|
|
23
|
+
._syaz1gjq{color:var(--ds-text-subtle,#44546f)}
|
|
24
|
+
._u5f3ze3t{padding-right:var(--ds-space-0,0)}
|