@elliemae/ds-app-picker 3.70.0-next.3 → 3.70.0-next.31

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.
Files changed (94) hide show
  1. package/dist/cjs/DSAppPicker.js +59 -132
  2. package/dist/cjs/DSAppPicker.js.map +3 -3
  3. package/dist/cjs/{utils.js → DSAppPickerCTX.js} +26 -23
  4. package/dist/cjs/DSAppPickerCTX.js.map +7 -0
  5. package/dist/cjs/config/useAppPicker.js +3 -3
  6. package/dist/cjs/config/useAppPicker.js.map +3 -3
  7. package/dist/cjs/config/useAppPickerBehavior.js +156 -0
  8. package/dist/cjs/config/useAppPickerBehavior.js.map +7 -0
  9. package/dist/cjs/config/useFocusTracker.js +115 -0
  10. package/dist/cjs/config/useFocusTracker.js.map +7 -0
  11. package/dist/cjs/config/useValidateProps.js +45 -0
  12. package/dist/cjs/config/useValidateProps.js.map +7 -0
  13. package/dist/cjs/constants/index.js +8 -1
  14. package/dist/cjs/constants/index.js.map +2 -2
  15. package/dist/cjs/index.js.map +1 -1
  16. package/dist/cjs/parts/AppPanel.js +159 -0
  17. package/dist/cjs/parts/AppPanel.js.map +7 -0
  18. package/dist/cjs/parts/AppPickerItem.js +102 -0
  19. package/dist/cjs/parts/AppPickerItem.js.map +7 -0
  20. package/dist/cjs/parts/AppSection.js +68 -0
  21. package/dist/cjs/parts/AppSection.js.map +7 -0
  22. package/dist/cjs/parts/Trigger.js +62 -0
  23. package/dist/cjs/parts/Trigger.js.map +7 -0
  24. package/dist/cjs/{styles.js → parts/style.js} +21 -9
  25. package/dist/cjs/parts/style.js.map +7 -0
  26. package/dist/cjs/react-desc-prop-types.js +6 -7
  27. package/dist/cjs/react-desc-prop-types.js.map +2 -2
  28. package/dist/cjs/typescript-testing/typescript-app-picker-valid.js +5 -0
  29. package/dist/cjs/typescript-testing/typescript-app-picker-valid.js.map +2 -2
  30. package/dist/esm/DSAppPicker.js +62 -135
  31. package/dist/esm/DSAppPicker.js.map +2 -2
  32. package/dist/esm/DSAppPickerCTX.js +28 -0
  33. package/dist/esm/DSAppPickerCTX.js.map +7 -0
  34. package/dist/esm/config/useAppPicker.js +4 -5
  35. package/dist/esm/config/useAppPicker.js.map +3 -3
  36. package/dist/esm/config/useAppPickerBehavior.js +126 -0
  37. package/dist/esm/config/useAppPickerBehavior.js.map +7 -0
  38. package/dist/esm/config/useFocusTracker.js +85 -0
  39. package/dist/esm/config/useFocusTracker.js.map +7 -0
  40. package/dist/esm/config/useValidateProps.js +15 -0
  41. package/dist/esm/config/useValidateProps.js.map +7 -0
  42. package/dist/esm/constants/index.js +8 -1
  43. package/dist/esm/constants/index.js.map +2 -2
  44. package/dist/esm/index.js.map +1 -1
  45. package/dist/esm/parts/AppPanel.js +129 -0
  46. package/dist/esm/parts/AppPanel.js.map +7 -0
  47. package/dist/esm/parts/AppPickerItem.js +72 -0
  48. package/dist/esm/parts/AppPickerItem.js.map +7 -0
  49. package/dist/esm/parts/AppSection.js +38 -0
  50. package/dist/esm/parts/AppSection.js.map +7 -0
  51. package/dist/esm/parts/Trigger.js +32 -0
  52. package/dist/esm/parts/Trigger.js.map +7 -0
  53. package/dist/esm/{styles.js → parts/style.js} +18 -6
  54. package/dist/esm/parts/style.js.map +7 -0
  55. package/dist/esm/react-desc-prop-types.js +12 -8
  56. package/dist/esm/react-desc-prop-types.js.map +2 -2
  57. package/dist/esm/typescript-testing/typescript-app-picker-valid.js +5 -0
  58. package/dist/esm/typescript-testing/typescript-app-picker-valid.js.map +2 -2
  59. package/dist/types/DSAppPicker.d.ts +0 -1
  60. package/dist/types/DSAppPickerCTX.d.ts +17 -0
  61. package/dist/types/config/useAppPicker.d.ts +5 -5
  62. package/dist/types/config/useAppPickerBehavior.d.ts +39 -0
  63. package/dist/types/config/useFocusTracker.d.ts +15 -0
  64. package/dist/types/config/useValidateProps.d.ts +3 -0
  65. package/dist/types/constants/index.d.ts +14 -7
  66. package/dist/types/parts/AppPanel.d.ts +9 -0
  67. package/dist/types/parts/AppPickerItem.d.ts +14 -0
  68. package/dist/types/parts/AppSection.d.ts +17 -0
  69. package/dist/types/parts/Trigger.d.ts +15 -0
  70. package/dist/types/{styles.d.ts → parts/style.d.ts} +3 -4
  71. package/dist/types/react-desc-prop-types.d.ts +21 -8
  72. package/dist/types/tests/app-picker.get-owner-props-arguments-18354.test.d.ts +1 -0
  73. package/dist/types/tests/app-picker.proptype-schema.test.d.ts +1 -0
  74. package/dist/types/tests/app-picker.pui-18354.test.d.ts +1 -0
  75. package/dist/types/tests/playwright/DSAppPicker.slot-contracts-dynamic.test.playwright.d.ts +1 -0
  76. package/dist/types/tests/playwright/DSAppPickerSlotContractRenderer.d.ts +1 -0
  77. package/package.json +16 -14
  78. package/dist/cjs/AppPickerImpl.js +0 -204
  79. package/dist/cjs/AppPickerImpl.js.map +0 -7
  80. package/dist/cjs/hooks/useKeepTrackButtons.js +0 -69
  81. package/dist/cjs/hooks/useKeepTrackButtons.js.map +0 -7
  82. package/dist/cjs/styles.js.map +0 -7
  83. package/dist/cjs/utils.js.map +0 -7
  84. package/dist/esm/AppPickerImpl.js +0 -174
  85. package/dist/esm/AppPickerImpl.js.map +0 -7
  86. package/dist/esm/hooks/useKeepTrackButtons.js +0 -39
  87. package/dist/esm/hooks/useKeepTrackButtons.js.map +0 -7
  88. package/dist/esm/styles.js.map +0 -7
  89. package/dist/esm/utils.js +0 -25
  90. package/dist/esm/utils.js.map +0 -7
  91. package/dist/types/AppPickerImpl.d.ts +0 -11
  92. package/dist/types/hooks/useKeepTrackButtons.d.ts +0 -13
  93. package/dist/types/utils.d.ts +0 -14
  94. /package/dist/types/tests/{app-picker.get-owner-props.test.d.ts → app-picker.api.test.d.ts} +0 -0
@@ -1,39 +0,0 @@
1
- import * as React from "react";
2
- import { useEffect, useRef, useState } from "react";
3
- import { focusSelectedOrFirstAvailable } from "../utils.js";
4
- const useKeepTrackButtons = ({
5
- wrapperRef,
6
- wasOpenedByKeyboardRef,
7
- actionRef,
8
- triggerIsInternal
9
- }) => {
10
- const [allFocusableButtons, setAllFocusableButtons] = useState([]);
11
- const selectedButton = useRef(null);
12
- useEffect(() => {
13
- if (actionRef && actionRef.current) {
14
- actionRef.current.focusSelectedOrFirstAvailable = () => setTimeout(() => {
15
- focusSelectedOrFirstAvailable(wrapperRef, allFocusableButtons, selectedButton);
16
- });
17
- }
18
- }, [actionRef, allFocusableButtons, wrapperRef]);
19
- useEffect(() => {
20
- wrapperRef?.current?.querySelectorAll("button").forEach((e, index) => {
21
- if (!e.hasAttribute("disabled")) setAllFocusableButtons((prev) => [...prev, e]);
22
- if (e.getAttribute("aria-selected") === "true") {
23
- selectedButton.current = index;
24
- }
25
- });
26
- }, [wasOpenedByKeyboardRef, wrapperRef, triggerIsInternal]);
27
- useEffect(() => {
28
- if (wasOpenedByKeyboardRef?.current || !triggerIsInternal) {
29
- focusSelectedOrFirstAvailable(wrapperRef, allFocusableButtons, selectedButton);
30
- } else {
31
- wrapperRef.current?.focus();
32
- }
33
- }, [wasOpenedByKeyboardRef, wrapperRef, triggerIsInternal, allFocusableButtons]);
34
- return { allFocusableButtons, selectedButton };
35
- };
36
- export {
37
- useKeepTrackButtons
38
- };
39
- //# sourceMappingURL=useKeepTrackButtons.js.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../../../../scripts/build/transpile/react-shim.js", "../../../src/hooks/useKeepTrackButtons.tsx"],
4
- "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "import type React from 'react';\nimport { useEffect, useRef, useState } from 'react';\nimport type { DSAppPickerT } from '../react-desc-prop-types.js';\nimport { focusSelectedOrFirstAvailable } from '../utils.js';\n\ninterface UseKeepTrackButtonsT {\n wrapperRef: React.RefObject<HTMLDivElement>;\n wasOpenedByKeyboardRef: React.MutableRefObject<boolean>;\n actionRef?: DSAppPickerT.ActionRef;\n triggerIsInternal?: boolean;\n}\n\nexport const useKeepTrackButtons = ({\n wrapperRef,\n wasOpenedByKeyboardRef,\n actionRef,\n triggerIsInternal,\n}: UseKeepTrackButtonsT) => {\n const [allFocusableButtons, setAllFocusableButtons] = useState<HTMLButtonElement[]>([]);\n const selectedButton = useRef<number | null>(null);\n\n useEffect(() => {\n if (actionRef && actionRef.current) {\n actionRef.current.focusSelectedOrFirstAvailable = () =>\n setTimeout(() => {\n focusSelectedOrFirstAvailable(wrapperRef, allFocusableButtons, selectedButton);\n });\n }\n }, [actionRef, allFocusableButtons, wrapperRef]);\n\n useEffect(() => {\n wrapperRef?.current?.querySelectorAll('button').forEach((e, index) => {\n if (!e.hasAttribute('disabled')) setAllFocusableButtons((prev) => [...prev, e]);\n if (e.getAttribute('aria-selected') === 'true') {\n selectedButton.current = index;\n }\n });\n }, [wasOpenedByKeyboardRef, wrapperRef, triggerIsInternal]);\n\n useEffect(() => {\n if (wasOpenedByKeyboardRef?.current || !triggerIsInternal) {\n focusSelectedOrFirstAvailable(wrapperRef, allFocusableButtons, selectedButton);\n } else {\n wrapperRef.current?.focus();\n }\n }, [wasOpenedByKeyboardRef, wrapperRef, triggerIsInternal, allFocusableButtons]);\n\n return { allFocusableButtons, selectedButton };\n};\n"],
5
- "mappings": "AAAA,YAAY,WAAW;ACCvB,SAAS,WAAW,QAAQ,gBAAgB;AAE5C,SAAS,qCAAqC;AASvC,MAAM,sBAAsB,CAAC;AAAA,EAClC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAA4B;AAC1B,QAAM,CAAC,qBAAqB,sBAAsB,IAAI,SAA8B,CAAC,CAAC;AACtF,QAAM,iBAAiB,OAAsB,IAAI;AAEjD,YAAU,MAAM;AACd,QAAI,aAAa,UAAU,SAAS;AAClC,gBAAU,QAAQ,gCAAgC,MAChD,WAAW,MAAM;AACf,sCAA8B,YAAY,qBAAqB,cAAc;AAAA,MAC/E,CAAC;AAAA,IACL;AAAA,EACF,GAAG,CAAC,WAAW,qBAAqB,UAAU,CAAC;AAE/C,YAAU,MAAM;AACd,gBAAY,SAAS,iBAAiB,QAAQ,EAAE,QAAQ,CAAC,GAAG,UAAU;AACpE,UAAI,CAAC,EAAE,aAAa,UAAU,EAAG,wBAAuB,CAAC,SAAS,CAAC,GAAG,MAAM,CAAC,CAAC;AAC9E,UAAI,EAAE,aAAa,eAAe,MAAM,QAAQ;AAC9C,uBAAe,UAAU;AAAA,MAC3B;AAAA,IACF,CAAC;AAAA,EACH,GAAG,CAAC,wBAAwB,YAAY,iBAAiB,CAAC;AAE1D,YAAU,MAAM;AACd,QAAI,wBAAwB,WAAW,CAAC,mBAAmB;AACzD,oCAA8B,YAAY,qBAAqB,cAAc;AAAA,IAC/E,OAAO;AACL,iBAAW,SAAS,MAAM;AAAA,IAC5B;AAAA,EACF,GAAG,CAAC,wBAAwB,YAAY,mBAAmB,mBAAmB,CAAC;AAE/E,SAAO,EAAE,qBAAqB,eAAe;AAC/C;",
6
- "names": []
7
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../src/styles.tsx"],
4
- "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable @typescript-eslint/no-unsafe-assignment */\n/* eslint-disable max-lines */\nimport { styled } from '@elliemae/ds-system';\nimport { Grid } from '@elliemae/ds-grid';\nimport { DSAppPickerName, DSAppPickerSlots } from './constants/index.js';\n\nexport const StyledWrapper = styled(Grid, { name: DSAppPickerName, slot: DSAppPickerSlots.ROOT })<{\n isOverflow: boolean;\n}>`\n min-width: 308px;\n min-height: 110px;\n max-height: 449px;\n width: 308px;\n overflow-y: auto;\n overflow-x: hidden;\n margin: 0;\n padding: ${({ isOverflow }) => (isOverflow ? '0 0 8px 16px' : '0 16px 8px 16px')};\n &:focus {\n outline: none;\n }\n`;\n\nexport const StyledListItem = styled('li', { name: DSAppPickerName, slot: DSAppPickerSlots.ITEM })`\n list-style: none;\n`;\n\nexport const StyledListItemFullRow = styled('li', { name: DSAppPickerName, slot: DSAppPickerSlots.ROW })`\n list-style: none;\n grid-column: 1/4;\n`;\n\nexport const StyledTitle = styled('h3', { name: DSAppPickerName, slot: DSAppPickerSlots.TITLE })`\n color: ${({ theme }) => theme.colors.neutral[700]};\n font-size: ${({ theme }) => theme.fontSizes.value[400]};\n font-weight: ${({ theme }) => theme.fontWeights.semibold};\n margin: 12px 0 8px 0;\n line-height: 1.385;\n text-transform: uppercase;\n`;\n\nexport const StyledSeparator = styled('hr', { name: DSAppPickerName, slot: DSAppPickerSlots.SEPARATOR })`\n border-top: 1px solid ${({ theme }) => theme.colors.neutral[100]};\n border-bottom: none;\n width: 99%;\n margin: 8px 0 0 0;\n`;\n"],
5
- "mappings": "AAAA,YAAY,WAAW;ACEvB,SAAS,cAAc;AACvB,SAAS,YAAY;AACrB,SAAS,iBAAiB,wBAAwB;AAE3C,MAAM,gBAAgB,OAAO,MAAM,EAAE,MAAM,iBAAiB,MAAM,iBAAiB,KAAK,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,aAUnF,CAAC,EAAE,WAAW,MAAO,aAAa,iBAAiB,iBAAkB;AAAA;AAAA;AAAA;AAAA;AAM3E,MAAM,iBAAiB,OAAO,MAAM,EAAE,MAAM,iBAAiB,MAAM,iBAAiB,KAAK,CAAC;AAAA;AAAA;AAI1F,MAAM,wBAAwB,OAAO,MAAM,EAAE,MAAM,iBAAiB,MAAM,iBAAiB,IAAI,CAAC;AAAA;AAAA;AAAA;AAKhG,MAAM,cAAc,OAAO,MAAM,EAAE,MAAM,iBAAiB,MAAM,iBAAiB,MAAM,CAAC;AAAA,WACpF,CAAC,EAAE,MAAM,MAAM,MAAM,OAAO,QAAQ,GAAG,CAAC;AAAA,eACpC,CAAC,EAAE,MAAM,MAAM,MAAM,UAAU,MAAM,GAAG,CAAC;AAAA,iBACvC,CAAC,EAAE,MAAM,MAAM,MAAM,YAAY,QAAQ;AAAA;AAAA;AAAA;AAAA;AAMnD,MAAM,kBAAkB,OAAO,MAAM,EAAE,MAAM,iBAAiB,MAAM,iBAAiB,UAAU,CAAC;AAAA,0BAC7E,CAAC,EAAE,MAAM,MAAM,MAAM,OAAO,QAAQ,GAAG,CAAC;AAAA;AAAA;AAAA;AAAA;",
6
- "names": []
7
- }
package/dist/esm/utils.js DELETED
@@ -1,25 +0,0 @@
1
- import * as React from "react";
2
- const keys = {
3
- LEFT: "ArrowLeft",
4
- UP: "ArrowUp",
5
- RIGHT: "ArrowRight",
6
- DOWN: "ArrowDown",
7
- ENTER: "Enter",
8
- SPACE: "",
9
- TAB: "Tab",
10
- ESC: "Escape",
11
- HOME: "Home",
12
- END: "End"
13
- };
14
- const focusSelectedOrFirstAvailable = (wrapperRef, allFocusableButtonsRef, selectedButtonRef) => {
15
- if (selectedButtonRef.current !== null) {
16
- wrapperRef?.current?.querySelectorAll("button")[selectedButtonRef.current].focus();
17
- } else {
18
- allFocusableButtonsRef?.[0]?.focus();
19
- }
20
- };
21
- export {
22
- focusSelectedOrFirstAvailable,
23
- keys
24
- };
25
- //# sourceMappingURL=utils.js.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../src/utils.tsx"],
4
- "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "import type React from 'react';\n\nexport const keys = {\n LEFT: 'ArrowLeft',\n UP: 'ArrowUp',\n RIGHT: 'ArrowRight',\n DOWN: 'ArrowDown',\n ENTER: 'Enter',\n SPACE: '',\n TAB: 'Tab',\n ESC: 'Escape',\n HOME: 'Home',\n END: 'End',\n};\n\nexport const focusSelectedOrFirstAvailable = (\n wrapperRef: React.RefObject<HTMLDivElement>,\n allFocusableButtonsRef: HTMLButtonElement[],\n selectedButtonRef: React.MutableRefObject<number | null>,\n) => {\n if (selectedButtonRef.current !== null) {\n wrapperRef?.current?.querySelectorAll('button')[selectedButtonRef.current].focus();\n } else {\n allFocusableButtonsRef?.[0]?.focus();\n }\n};\n"],
5
- "mappings": "AAAA,YAAY,WAAW;ACEhB,MAAM,OAAO;AAAA,EAClB,MAAM;AAAA,EACN,IAAI;AAAA,EACJ,OAAO;AAAA,EACP,MAAM;AAAA,EACN,OAAO;AAAA,EACP,OAAO;AAAA,EACP,KAAK;AAAA,EACL,KAAK;AAAA,EACL,MAAM;AAAA,EACN,KAAK;AACP;AAEO,MAAM,gCAAgC,CAC3C,YACA,wBACA,sBACG;AACH,MAAI,kBAAkB,YAAY,MAAM;AACtC,gBAAY,SAAS,iBAAiB,QAAQ,EAAE,kBAAkB,OAAO,EAAE,MAAM;AAAA,EACnF,OAAO;AACL,6BAAyB,CAAC,GAAG,MAAM;AAAA,EACrC;AACF;",
6
- "names": []
7
- }
@@ -1,11 +0,0 @@
1
- import React from 'react';
2
- import type { DSAppPickerT } from './react-desc-prop-types.js';
3
- interface AppPickerImplProps extends Omit<DSAppPickerT.InternalProps, 'onClose' | 'icon' | 'onClick' | 'onClickOutside' | 'renderTrigger' | 'isOpen'> {
4
- close: () => void;
5
- wrapperRef: React.RefObject<HTMLDivElement>;
6
- isOverflow: boolean;
7
- wasOpenedByKeyboardRef: React.MutableRefObject<boolean>;
8
- triggerIsInternal: boolean;
9
- }
10
- declare const AppPickerImpl: React.ComponentType<AppPickerImplProps>;
11
- export default AppPickerImpl;
@@ -1,13 +0,0 @@
1
- import type React from 'react';
2
- import type { DSAppPickerT } from '../react-desc-prop-types.js';
3
- interface UseKeepTrackButtonsT {
4
- wrapperRef: React.RefObject<HTMLDivElement>;
5
- wasOpenedByKeyboardRef: React.MutableRefObject<boolean>;
6
- actionRef?: DSAppPickerT.ActionRef;
7
- triggerIsInternal?: boolean;
8
- }
9
- export declare const useKeepTrackButtons: ({ wrapperRef, wasOpenedByKeyboardRef, actionRef, triggerIsInternal, }: UseKeepTrackButtonsT) => {
10
- allFocusableButtons: HTMLButtonElement[];
11
- selectedButton: React.MutableRefObject<number | null>;
12
- };
13
- export {};
@@ -1,14 +0,0 @@
1
- import type React from 'react';
2
- export declare const keys: {
3
- LEFT: string;
4
- UP: string;
5
- RIGHT: string;
6
- DOWN: string;
7
- ENTER: string;
8
- SPACE: string;
9
- TAB: string;
10
- ESC: string;
11
- HOME: string;
12
- END: string;
13
- };
14
- export declare const focusSelectedOrFirstAvailable: (wrapperRef: React.RefObject<HTMLDivElement>, allFocusableButtonsRef: HTMLButtonElement[], selectedButtonRef: React.MutableRefObject<number | null>) => void;