@pega/cosmos-react-work 2.0.0-dev.2.1 → 2.0.0-dev.20.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.
Files changed (180) hide show
  1. package/lib/components/AppAnnouncement/AppAnnouncement.d.ts.map +1 -1
  2. package/lib/components/AppAnnouncement/AppAnnouncement.js +13 -17
  3. package/lib/components/AppAnnouncement/AppAnnouncement.js.map +1 -1
  4. package/lib/components/CaseHeader/CaseHeader.d.ts +5 -1
  5. package/lib/components/CaseHeader/CaseHeader.d.ts.map +1 -1
  6. package/lib/components/CaseHeader/CaseHeader.js +39 -15
  7. package/lib/components/CaseHeader/CaseHeader.js.map +1 -1
  8. package/lib/components/CasePreview/CasePreview.d.ts +5 -5
  9. package/lib/components/CasePreview/CasePreview.d.ts.map +1 -1
  10. package/lib/components/CasePreview/CasePreview.js +17 -16
  11. package/lib/components/CasePreview/CasePreview.js.map +1 -1
  12. package/lib/components/CaseSummary/CaseSummary.d.ts +20 -8
  13. package/lib/components/CaseSummary/CaseSummary.d.ts.map +1 -1
  14. package/lib/components/CaseSummary/CaseSummary.js +121 -14
  15. package/lib/components/CaseSummary/CaseSummary.js.map +1 -1
  16. package/lib/components/CaseSummaryFields/CaseSummaryFields.d.ts.map +1 -1
  17. package/lib/components/CaseSummaryFields/CaseSummaryFields.js +14 -12
  18. package/lib/components/CaseSummaryFields/CaseSummaryFields.js.map +1 -1
  19. package/lib/components/CaseView/CaseView.d.ts +6 -19
  20. package/lib/components/CaseView/CaseView.d.ts.map +1 -1
  21. package/lib/components/CaseView/CaseView.js +173 -189
  22. package/lib/components/CaseView/CaseView.js.map +1 -1
  23. package/lib/components/CaseView/CaseView.styles.d.ts +24 -0
  24. package/lib/components/CaseView/CaseView.styles.d.ts.map +1 -0
  25. package/lib/components/CaseView/CaseView.styles.js +111 -0
  26. package/lib/components/CaseView/CaseView.styles.js.map +1 -0
  27. package/lib/components/CaseView/MobileCaseView.d.ts +1 -0
  28. package/lib/components/CaseView/MobileCaseView.d.ts.map +1 -1
  29. package/lib/components/CaseView/MobileCaseView.js +3 -6
  30. package/lib/components/CaseView/MobileCaseView.js.map +1 -1
  31. package/lib/components/CaseView/UtilitiesSummary.d.ts.map +1 -1
  32. package/lib/components/CaseView/UtilitiesSummary.js +8 -10
  33. package/lib/components/CaseView/UtilitiesSummary.js.map +1 -1
  34. package/lib/components/CaseView/index.d.ts +2 -1
  35. package/lib/components/CaseView/index.d.ts.map +1 -1
  36. package/lib/components/CaseView/index.js +1 -1
  37. package/lib/components/CaseView/index.js.map +1 -1
  38. package/lib/components/ConfigurableLayout/ConfigurableLayout.d.ts +4 -0
  39. package/lib/components/ConfigurableLayout/ConfigurableLayout.d.ts.map +1 -0
  40. package/lib/components/ConfigurableLayout/ConfigurableLayout.js +93 -0
  41. package/lib/components/ConfigurableLayout/ConfigurableLayout.js.map +1 -0
  42. package/lib/components/ConfigurableLayout/ConfigurableLayout.types.d.ts +43 -0
  43. package/lib/components/ConfigurableLayout/ConfigurableLayout.types.d.ts.map +1 -0
  44. package/lib/components/ConfigurableLayout/ConfigurableLayout.types.js +2 -0
  45. package/lib/components/ConfigurableLayout/ConfigurableLayout.types.js.map +1 -0
  46. package/lib/components/ConfigurableLayout/LayoutCell.d.ts +6 -0
  47. package/lib/components/ConfigurableLayout/LayoutCell.d.ts.map +1 -0
  48. package/lib/components/ConfigurableLayout/LayoutCell.js +64 -0
  49. package/lib/components/ConfigurableLayout/LayoutCell.js.map +1 -0
  50. package/lib/components/ConfigurableLayout/defaults.d.ts +4 -0
  51. package/lib/components/ConfigurableLayout/defaults.d.ts.map +1 -0
  52. package/lib/components/ConfigurableLayout/defaults.js +4 -0
  53. package/lib/components/ConfigurableLayout/defaults.js.map +1 -0
  54. package/lib/components/ConfigurableLayout/index.d.ts +3 -0
  55. package/lib/components/ConfigurableLayout/index.d.ts.map +1 -0
  56. package/lib/components/ConfigurableLayout/index.js +3 -0
  57. package/lib/components/ConfigurableLayout/index.js.map +1 -0
  58. package/lib/components/ConfigurableLayout/options.d.ts +10 -0
  59. package/lib/components/ConfigurableLayout/options.d.ts.map +1 -0
  60. package/lib/components/ConfigurableLayout/options.js +10 -0
  61. package/lib/components/ConfigurableLayout/options.js.map +1 -0
  62. package/lib/components/ConfigurableLayout/useTrackWrappedRegions.d.ts +7 -0
  63. package/lib/components/ConfigurableLayout/useTrackWrappedRegions.d.ts.map +1 -0
  64. package/lib/components/ConfigurableLayout/useTrackWrappedRegions.js +37 -0
  65. package/lib/components/ConfigurableLayout/useTrackWrappedRegions.js.map +1 -0
  66. package/lib/components/Confirmation/Confirmation.d.ts +19 -0
  67. package/lib/components/Confirmation/Confirmation.d.ts.map +1 -0
  68. package/lib/components/Confirmation/Confirmation.js +14 -0
  69. package/lib/components/Confirmation/Confirmation.js.map +1 -0
  70. package/lib/components/Confirmation/index.d.ts +3 -0
  71. package/lib/components/Confirmation/index.d.ts.map +1 -0
  72. package/lib/components/Confirmation/index.js +2 -0
  73. package/lib/components/Confirmation/index.js.map +1 -0
  74. package/lib/components/Details/Details.d.ts +13 -0
  75. package/lib/components/Details/Details.d.ts.map +1 -0
  76. package/lib/components/Details/Details.js +38 -0
  77. package/lib/components/Details/Details.js.map +1 -0
  78. package/lib/components/Details/index.d.ts +4 -0
  79. package/lib/components/Details/index.d.ts.map +1 -0
  80. package/lib/components/Details/index.js +3 -0
  81. package/lib/components/Details/index.js.map +1 -0
  82. package/lib/components/Glimpse/Glimpse.d.ts +2 -2
  83. package/lib/components/Glimpse/Glimpse.d.ts.map +1 -1
  84. package/lib/components/Glimpse/Glimpse.js +3 -6
  85. package/lib/components/Glimpse/Glimpse.js.map +1 -1
  86. package/lib/components/SearchResults/Filter.d.ts.map +1 -1
  87. package/lib/components/SearchResults/Filter.js +15 -48
  88. package/lib/components/SearchResults/Filter.js.map +1 -1
  89. package/lib/components/SearchResults/SearchResult.d.ts.map +1 -1
  90. package/lib/components/SearchResults/SearchResult.js +2 -8
  91. package/lib/components/SearchResults/SearchResult.js.map +1 -1
  92. package/lib/components/SearchResults/SearchResults.d.ts.map +1 -1
  93. package/lib/components/SearchResults/SearchResults.js +44 -101
  94. package/lib/components/SearchResults/SearchResults.js.map +1 -1
  95. package/lib/components/SearchResults/SearchResults.styles.d.ts +8 -0
  96. package/lib/components/SearchResults/SearchResults.styles.d.ts.map +1 -0
  97. package/lib/components/SearchResults/SearchResults.styles.js +67 -0
  98. package/lib/components/SearchResults/SearchResults.styles.js.map +1 -0
  99. package/lib/components/SearchResults/SearchResults.types.d.ts +14 -4
  100. package/lib/components/SearchResults/SearchResults.types.d.ts.map +1 -1
  101. package/lib/components/SearchResults/SearchResults.types.js.map +1 -1
  102. package/lib/components/Stages/Stages.d.ts.map +1 -1
  103. package/lib/components/Stages/Stages.js +31 -36
  104. package/lib/components/Stages/Stages.js.map +1 -1
  105. package/lib/components/Stages/Stages.styles.d.ts.map +1 -1
  106. package/lib/components/Stages/Stages.styles.js +22 -28
  107. package/lib/components/Stages/Stages.styles.js.map +1 -1
  108. package/lib/components/Stages/Steps.d.ts.map +1 -1
  109. package/lib/components/Stages/Steps.js +7 -7
  110. package/lib/components/Stages/Steps.js.map +1 -1
  111. package/lib/components/Stages/StepsContainer.d.ts.map +1 -1
  112. package/lib/components/Stages/StepsContainer.js +5 -9
  113. package/lib/components/Stages/StepsContainer.js.map +1 -1
  114. package/lib/components/Stakeholders/StakeholderForm.d.ts +7 -0
  115. package/lib/components/Stakeholders/StakeholderForm.d.ts.map +1 -0
  116. package/lib/components/Stakeholders/StakeholderForm.js +47 -0
  117. package/lib/components/Stakeholders/StakeholderForm.js.map +1 -0
  118. package/lib/components/Stakeholders/Stakeholders.d.ts +6 -0
  119. package/lib/components/Stakeholders/Stakeholders.d.ts.map +1 -0
  120. package/lib/components/Stakeholders/Stakeholders.js +215 -0
  121. package/lib/components/Stakeholders/Stakeholders.js.map +1 -0
  122. package/lib/components/Stakeholders/Stakeholders.types.d.ts +78 -0
  123. package/lib/components/Stakeholders/Stakeholders.types.d.ts.map +1 -0
  124. package/lib/components/Stakeholders/Stakeholders.types.js +2 -0
  125. package/lib/components/Stakeholders/Stakeholders.types.js.map +1 -0
  126. package/lib/components/Stakeholders/index.d.ts +3 -0
  127. package/lib/components/Stakeholders/index.d.ts.map +1 -0
  128. package/lib/components/Stakeholders/index.js +2 -0
  129. package/lib/components/Stakeholders/index.js.map +1 -0
  130. package/lib/components/Tags/Tags.d.ts +34 -0
  131. package/lib/components/Tags/Tags.d.ts.map +1 -0
  132. package/lib/components/Tags/Tags.js +227 -0
  133. package/lib/components/Tags/Tags.js.map +1 -0
  134. package/lib/components/Tags/index.d.ts +3 -0
  135. package/lib/components/Tags/index.d.ts.map +1 -0
  136. package/lib/components/Tags/index.js +2 -0
  137. package/lib/components/Tags/index.js.map +1 -0
  138. package/lib/components/Tasks/TaskList.d.ts +25 -0
  139. package/lib/components/Tasks/TaskList.d.ts.map +1 -0
  140. package/lib/components/Tasks/TaskList.js +25 -0
  141. package/lib/components/Tasks/TaskList.js.map +1 -0
  142. package/lib/components/Tasks/Tasks.d.ts +2 -14
  143. package/lib/components/Tasks/Tasks.d.ts.map +1 -1
  144. package/lib/components/Tasks/Tasks.js +17 -39
  145. package/lib/components/Tasks/Tasks.js.map +1 -1
  146. package/lib/components/Tasks/index.d.ts +3 -0
  147. package/lib/components/Tasks/index.d.ts.map +1 -1
  148. package/lib/components/Tasks/index.js +1 -0
  149. package/lib/components/Tasks/index.js.map +1 -1
  150. package/lib/components/Timeline/Timeline.d.ts.map +1 -1
  151. package/lib/components/Timeline/Timeline.js +13 -29
  152. package/lib/components/Timeline/Timeline.js.map +1 -1
  153. package/lib/components/Timeline/Timeline.styles.d.ts +9 -5
  154. package/lib/components/Timeline/Timeline.styles.d.ts.map +1 -1
  155. package/lib/components/Timeline/Timeline.styles.js +107 -50
  156. package/lib/components/Timeline/Timeline.styles.js.map +1 -1
  157. package/lib/components/Timeline/Timeline.types.d.ts +18 -5
  158. package/lib/components/Timeline/Timeline.types.d.ts.map +1 -1
  159. package/lib/components/Timeline/Timeline.types.js.map +1 -1
  160. package/lib/components/Timeline/TimelineItem.d.ts +5 -3
  161. package/lib/components/Timeline/TimelineItem.d.ts.map +1 -1
  162. package/lib/components/Timeline/TimelineItem.js +15 -32
  163. package/lib/components/Timeline/TimelineItem.js.map +1 -1
  164. package/lib/components/Timeline/utils.d.ts +11 -3
  165. package/lib/components/Timeline/utils.d.ts.map +1 -1
  166. package/lib/components/Timeline/utils.js +48 -4
  167. package/lib/components/Timeline/utils.js.map +1 -1
  168. package/lib/index.d.ts +10 -2
  169. package/lib/index.d.ts.map +1 -1
  170. package/lib/index.js +10 -2
  171. package/lib/index.js.map +1 -1
  172. package/package.json +14 -14
  173. package/lib/components/CaseActions/CaseActions.d.ts +0 -12
  174. package/lib/components/CaseActions/CaseActions.d.ts.map +0 -1
  175. package/lib/components/CaseActions/CaseActions.js +0 -15
  176. package/lib/components/CaseActions/CaseActions.js.map +0 -1
  177. package/lib/components/CaseActions/index.d.ts +0 -4
  178. package/lib/components/CaseActions/index.d.ts.map +0 -1
  179. package/lib/components/CaseActions/index.js +0 -3
  180. package/lib/components/CaseActions/index.js.map +0 -1
@@ -0,0 +1,111 @@
1
+ import styled, { css } from 'styled-components';
2
+ import { defaultThemeProp, Tabs } from '@pega/cosmos-react-core';
3
+ export const StyledCaseViewContent = styled.div(({ theme, forceMobile, isMediumOrAbove, persistentUtility }) => {
4
+ return css `
5
+ padding: calc(2 * ${theme.base.spacing});
6
+
7
+ ${persistentUtility &&
8
+ isMediumOrAbove &&
9
+ css `
10
+ margin-inline-start: calc(2 * ${theme.base.spacing});
11
+ `}
12
+
13
+ ${!forceMobile &&
14
+ isMediumOrAbove &&
15
+ css `
16
+ padding: calc(2 * ${theme.base.spacing}) 0;
17
+ `}
18
+ `;
19
+ });
20
+ export const StyledMobileTabs = styled(Tabs)(({ theme }) => {
21
+ return css `
22
+ border-bottom: 0.0625rem solid ${theme.base.palette['border-line']};
23
+ `;
24
+ });
25
+ StyledMobileTabs.defaultProps = defaultThemeProp;
26
+ export const StyledUtilToggle = styled.button(({ theme }) => {
27
+ return css `
28
+ align-self: flex-end;
29
+ color: ${theme.base.palette['foreground-color']};
30
+ margin-inline-end: 0.375rem;
31
+ `;
32
+ });
33
+ StyledUtilToggle.defaultProps = defaultThemeProp;
34
+ export const StyledCaseViewUtilities = styled.div(({ utilitiesShown, theme }) => {
35
+ return css `
36
+ width: ${utilitiesShown ? '25rem' : 'auto'};
37
+ height: max-content;
38
+ padding: calc(2 * ${theme.base.spacing}) 0 calc(2 * ${theme.base.spacing});
39
+ `;
40
+ });
41
+ StyledCaseViewUtilities.defaultProps = defaultThemeProp;
42
+ export const StyledCaseView = styled.div(({ theme, forceMobile, isMediumOrAbove, stickyOffset }) => {
43
+ return css `
44
+ --case-view-header-offset: ${stickyOffset}px;
45
+ --case-view-content-height: calc(100vh - var(--case-view-header-offset, 0rem));
46
+ min-height: calc(100vh - var(--appshell-offset, 0rem));
47
+ position: relative;
48
+ background-color: ${theme.base.palette['app-background']};
49
+
50
+ > :last-child {
51
+ ${!forceMobile &&
52
+ isMediumOrAbove &&
53
+ css `
54
+ margin-inline-end: calc(2 * ${theme.base.spacing});
55
+ `}
56
+ }
57
+ `;
58
+ });
59
+ StyledCaseView.defaultProps = defaultThemeProp;
60
+ export const StyledSummaryRegion = styled.div(({ theme, forceMobile, desktop }) => {
61
+ return css `
62
+ position: sticky;
63
+ top: var(--appshell-offset, 0);
64
+ width: 100%;
65
+ background-color: ${theme.base.palette['primary-background']};
66
+ z-index: ${theme.base['z-index'].popover};
67
+
68
+ ${!forceMobile &&
69
+ desktop &&
70
+ css `
71
+ height: var(--case-view-content-height);
72
+ `}
73
+ `;
74
+ });
75
+ StyledSummaryRegion.defaultProps = defaultThemeProp;
76
+ export const StyledCaseDrawer = styled.div(({ theme }) => {
77
+ return css `
78
+ min-width: 21.875rem;
79
+ max-width: 31.25rem;
80
+ width: calc((100vw - 31.25rem) / 10 + 21.875rem);
81
+ background-color: ${theme.base.palette['primary-background']};
82
+ height: var(--case-view-content-height);
83
+ top: var(--case-view-header-offset);
84
+ z-index: ${theme.base['z-index'].drawer - 1};
85
+ `;
86
+ });
87
+ StyledCaseDrawer.defaultProps = defaultThemeProp;
88
+ export const StyledCaseDrawerContent = styled.div(({ theme }) => {
89
+ return css `
90
+ background-color: ${theme.base.palette['app-background']};
91
+ padding: calc(2 * ${theme.base.spacing});
92
+ height: 100%;
93
+ overflow: auto;
94
+ `;
95
+ });
96
+ StyledCaseDrawerContent.defaultProps = defaultThemeProp;
97
+ export const StyledPersistentUtility = styled.div(() => {
98
+ return css `
99
+ max-width: 60ch;
100
+ overflow: auto;
101
+ position: sticky;
102
+ height: var(--case-view-content-height);
103
+ top: var(--case-view-header-offset);
104
+ `;
105
+ });
106
+ StyledPersistentUtility.defaultProps = defaultThemeProp;
107
+ export const ScrollStick = styled.div `
108
+ position: sticky;
109
+ top: 0;
110
+ `;
111
+ //# sourceMappingURL=CaseView.styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CaseView.styles.js","sourceRoot":"","sources":["../../../src/components/CaseView/CaseView.styles.ts"],"names":[],"mappings":"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","sourcesContent":["import styled, { css } from 'styled-components';\n\nimport { defaultThemeProp, Tabs } from '@pega/cosmos-react-core';\n\nexport const StyledCaseViewContent = styled.div<{\n forceMobile?: boolean;\n isMediumOrAbove?: boolean;\n persistentUtility?: boolean;\n}>(({ theme, forceMobile, isMediumOrAbove, persistentUtility }) => {\n return css`\n padding: calc(2 * ${theme.base.spacing});\n\n ${persistentUtility &&\n isMediumOrAbove &&\n css`\n margin-inline-start: calc(2 * ${theme.base.spacing});\n `}\n\n ${!forceMobile &&\n isMediumOrAbove &&\n css`\n padding: calc(2 * ${theme.base.spacing}) 0;\n `}\n `;\n});\n\nexport const StyledMobileTabs = styled(Tabs)(({ theme }) => {\n return css`\n border-bottom: 0.0625rem solid ${theme.base.palette['border-line']};\n `;\n});\n\nStyledMobileTabs.defaultProps = defaultThemeProp;\n\nexport const StyledUtilToggle = styled.button(({ theme }) => {\n return css`\n align-self: flex-end;\n color: ${theme.base.palette['foreground-color']};\n margin-inline-end: 0.375rem;\n `;\n});\n\nStyledUtilToggle.defaultProps = defaultThemeProp;\n\nexport const StyledCaseViewUtilities = styled.div<{ utilitiesShown: boolean }>(\n ({ utilitiesShown, theme }) => {\n return css`\n width: ${utilitiesShown ? '25rem' : 'auto'};\n height: max-content;\n padding: calc(2 * ${theme.base.spacing}) 0 calc(2 * ${theme.base.spacing});\n `;\n }\n);\n\nStyledCaseViewUtilities.defaultProps = defaultThemeProp;\n\nexport const StyledCaseView = styled.div<{\n forceMobile?: boolean;\n isMediumOrAbove?: boolean;\n stickyOffset: number;\n}>(({ theme, forceMobile, isMediumOrAbove, stickyOffset }) => {\n return css`\n --case-view-header-offset: ${stickyOffset}px;\n --case-view-content-height: calc(100vh - var(--case-view-header-offset, 0rem));\n min-height: calc(100vh - var(--appshell-offset, 0rem));\n position: relative;\n background-color: ${theme.base.palette['app-background']};\n\n > :last-child {\n ${!forceMobile &&\n isMediumOrAbove &&\n css`\n margin-inline-end: calc(2 * ${theme.base.spacing});\n `}\n }\n `;\n});\n\nStyledCaseView.defaultProps = defaultThemeProp;\n\nexport const StyledSummaryRegion = styled.div<{\n forceMobile?: boolean;\n desktop?: boolean;\n}>(({ theme, forceMobile, desktop }) => {\n return css`\n position: sticky;\n top: var(--appshell-offset, 0);\n width: 100%;\n background-color: ${theme.base.palette['primary-background']};\n z-index: ${theme.base['z-index'].popover};\n\n ${!forceMobile &&\n desktop &&\n css`\n height: var(--case-view-content-height);\n `}\n `;\n});\n\nStyledSummaryRegion.defaultProps = defaultThemeProp;\n\nexport const StyledCaseDrawer = styled.div(({ theme }) => {\n return css`\n min-width: 21.875rem;\n max-width: 31.25rem;\n width: calc((100vw - 31.25rem) / 10 + 21.875rem);\n background-color: ${theme.base.palette['primary-background']};\n height: var(--case-view-content-height);\n top: var(--case-view-header-offset);\n z-index: ${theme.base['z-index'].drawer - 1};\n `;\n});\n\nStyledCaseDrawer.defaultProps = defaultThemeProp;\n\nexport const StyledCaseDrawerContent = styled.div(({ theme }) => {\n return css`\n background-color: ${theme.base.palette['app-background']};\n padding: calc(2 * ${theme.base.spacing});\n height: 100%;\n overflow: auto;\n `;\n});\n\nStyledCaseDrawerContent.defaultProps = defaultThemeProp;\n\nexport const StyledPersistentUtility = styled.div(() => {\n return css`\n max-width: 60ch;\n overflow: auto;\n position: sticky;\n height: var(--case-view-content-height);\n top: var(--case-view-header-offset);\n `;\n});\n\nStyledPersistentUtility.defaultProps = defaultThemeProp;\n\nexport const ScrollStick = styled.div`\n position: sticky;\n top: 0;\n`;\n"]}
@@ -7,6 +7,7 @@ export interface MobileCaseViewProps {
7
7
  }
8
8
  export declare const StyledMobileCaseView: import("styled-components").StyledComponent<"div", import("styled-components").DefaultTheme, {}, never>;
9
9
  export declare const StyledMobileCaseViewHeader: import("styled-components").StyledComponent<"header", import("styled-components").DefaultTheme, {}, never>;
10
+ /** @deprecated */
10
11
  declare const MobileCaseView: FC<ForwardProps & MobileCaseViewProps>;
11
12
  export default MobileCaseView;
12
13
  //# sourceMappingURL=MobileCaseView.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"MobileCaseView.d.ts","sourceRoot":"","sources":["../../../src/components/CaseView/MobileCaseView.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAG7C,OAAO,EAGL,SAAS,EAGT,YAAY,EACb,MAAM,yBAAyB,CAAC;AAGjC,MAAM,WAAW,mBAAmB;IAClC,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,SAAS,CAAC;IAChB,UAAU,EAAE,SAAS,CAAC;CACvB;AAED,eAAO,MAAM,oBAAoB,yGAGhC,CAAC;AAEF,eAAO,MAAM,0BAA0B,4GAOtC,CAAC;AAKF,QAAA,MAAM,cAAc,EAAE,EAAE,CAAC,YAAY,GAAG,mBAAmB,CAgB1D,CAAC;AAEF,eAAe,cAAc,CAAC"}
1
+ {"version":3,"file":"MobileCaseView.d.ts","sourceRoot":"","sources":["../../../src/components/CaseView/MobileCaseView.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAGtC,OAAO,EAGL,SAAS,EAGT,YAAY,EACb,MAAM,yBAAyB,CAAC;AAGjC,MAAM,WAAW,mBAAmB;IAClC,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,SAAS,CAAC;IAChB,UAAU,EAAE,SAAS,CAAC;CACvB;AAED,eAAO,MAAM,oBAAoB,yGAGhC,CAAC;AAEF,eAAO,MAAM,0BAA0B,4GAOtC,CAAC;AAKF,kBAAkB;AAClB,QAAA,MAAM,cAAc,EAAE,EAAE,CAAC,YAAY,GAAG,mBAAmB,CAgB1D,CAAC;AAEF,eAAe,cAAc,CAAC"}
@@ -1,4 +1,4 @@
1
- import React from 'react';
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import styled from 'styled-components';
3
3
  import { Flex, Tabs, Text, defaultThemeProp } from '@pega/cosmos-react-core';
4
4
  import { StyledText } from '@pega/cosmos-react-core/lib/components/Text/Text';
@@ -16,13 +16,10 @@ export const StyledMobileCaseViewHeader = styled.header `
16
16
  `;
17
17
  StyledMobileCaseView.defaultProps = defaultThemeProp;
18
18
  StyledMobileCaseViewHeader.defaultProps = defaultThemeProp;
19
+ /** @deprecated */
19
20
  const MobileCaseView = (props) => {
20
21
  const { tabs, tabContent, title, ...restProps } = props;
21
- return (React.createElement(Flex, { container: { direction: 'column' }, as: StyledMobileCaseView, ...restProps },
22
- React.createElement(Flex, { container: { direction: 'column' }, item: { shrink: 0 }, as: StyledMobileCaseViewHeader },
23
- React.createElement(Text, { as: 'h1' }, title),
24
- React.createElement(Tabs, { ...tabs, type: 'horizontal', inverted: true })),
25
- tabContent));
22
+ return (_jsxs(Flex, { container: { direction: 'column' }, as: StyledMobileCaseView, ...restProps, children: [_jsxs(Flex, { container: { direction: 'column' }, item: { shrink: 0 }, as: StyledMobileCaseViewHeader, children: [_jsx(Text, { as: 'h1', children: title }, void 0), _jsx(Tabs, { ...tabs, type: 'horizontal', inverted: true }, void 0)] }, void 0), tabContent] }, void 0));
26
23
  };
27
24
  export default MobileCaseView;
28
25
  //# sourceMappingURL=MobileCaseView.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"MobileCaseView.js","sourceRoot":"","sources":["../../../src/components/CaseView/MobileCaseView.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAwB,MAAM,OAAO,CAAC;AAC7C,OAAO,MAAM,MAAM,mBAAmB,CAAC;AAEvC,OAAO,EACL,IAAI,EACJ,IAAI,EAEJ,IAAI,EACJ,gBAAgB,EAEjB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,UAAU,EAAE,MAAM,kDAAkD,CAAC;AAQ9E,MAAM,CAAC,MAAM,oBAAoB,GAAG,MAAM,CAAC,GAAG,CAAA;;;CAG7C,CAAC;AAEF,MAAM,CAAC,MAAM,0BAA0B,GAAG,MAAM,CAAC,MAAM,CAAA;WAC5C,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK;sBAC5B,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW;;IAE/D,UAAU;eACC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO;;CAE/C,CAAC;AAEF,oBAAoB,CAAC,YAAY,GAAG,gBAAgB,CAAC;AACrD,0BAA0B,CAAC,YAAY,GAAG,gBAAgB,CAAC;AAE3D,MAAM,cAAc,GAA2C,CAAC,KAA0B,EAAE,EAAE;IAC5F,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,GAAG,SAAS,EAAE,GAAG,KAAK,CAAC;IAExD,OAAO,CACL,oBAAC,IAAI,IAAC,SAAS,EAAE,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE,EAAE,oBAAoB,KAAM,SAAS;QAC/E,oBAAC,IAAI,IACH,SAAS,EAAE,EAAE,SAAS,EAAE,QAAQ,EAAE,EAClC,IAAI,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,EACnB,EAAE,EAAE,0BAA0B;YAE9B,oBAAC,IAAI,IAAC,EAAE,EAAC,IAAI,IAAE,KAAK,CAAQ;YAC5B,oBAAC,IAAI,OAAK,IAAI,EAAE,IAAI,EAAC,YAAY,EAAC,QAAQ,SAAG,CACxC;QACN,UAAU,CACN,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,cAAc,CAAC","sourcesContent":["import React, { FC, ReactNode } from 'react';\nimport styled from 'styled-components';\n\nimport {\n Flex,\n Tabs,\n TabsProps,\n Text,\n defaultThemeProp,\n ForwardProps\n} from '@pega/cosmos-react-core';\nimport { StyledText } from '@pega/cosmos-react-core/lib/components/Text/Text';\n\nexport interface MobileCaseViewProps {\n title: string;\n tabs: TabsProps;\n tabContent: ReactNode;\n}\n\nexport const StyledMobileCaseView = styled.div`\n min-height: 100vh;\n background-color: #e9eef3;\n`;\n\nexport const StyledMobileCaseViewHeader = styled.header`\n color: ${props => props.theme.base.palette.light};\n background-color: ${props => props.theme.base.palette.interactive};\n\n ${StyledText} {\n padding: ${props => props.theme.base.spacing};\n }\n`;\n\nStyledMobileCaseView.defaultProps = defaultThemeProp;\nStyledMobileCaseViewHeader.defaultProps = defaultThemeProp;\n\nconst MobileCaseView: FC<ForwardProps & MobileCaseViewProps> = (props: MobileCaseViewProps) => {\n const { tabs, tabContent, title, ...restProps } = props;\n\n return (\n <Flex container={{ direction: 'column' }} as={StyledMobileCaseView} {...restProps}>\n <Flex\n container={{ direction: 'column' }}\n item={{ shrink: 0 }}\n as={StyledMobileCaseViewHeader}\n >\n <Text as='h1'>{title}</Text>\n <Tabs {...tabs} type='horizontal' inverted />\n </Flex>\n {tabContent}\n </Flex>\n );\n};\n\nexport default MobileCaseView;\n"]}
1
+ {"version":3,"file":"MobileCaseView.js","sourceRoot":"","sources":["../../../src/components/CaseView/MobileCaseView.tsx"],"names":[],"mappings":";AACA,OAAO,MAAM,MAAM,mBAAmB,CAAC;AAEvC,OAAO,EACL,IAAI,EACJ,IAAI,EAEJ,IAAI,EACJ,gBAAgB,EAEjB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,UAAU,EAAE,MAAM,kDAAkD,CAAC;AAQ9E,MAAM,CAAC,MAAM,oBAAoB,GAAG,MAAM,CAAC,GAAG,CAAA;;;CAG7C,CAAC;AAEF,MAAM,CAAC,MAAM,0BAA0B,GAAG,MAAM,CAAC,MAAM,CAAA;WAC5C,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK;sBAC5B,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW;;IAE/D,UAAU;eACC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO;;CAE/C,CAAC;AAEF,oBAAoB,CAAC,YAAY,GAAG,gBAAgB,CAAC;AACrD,0BAA0B,CAAC,YAAY,GAAG,gBAAgB,CAAC;AAE3D,kBAAkB;AAClB,MAAM,cAAc,GAA2C,CAAC,KAA0B,EAAE,EAAE;IAC5F,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,GAAG,SAAS,EAAE,GAAG,KAAK,CAAC;IAExD,OAAO,CACL,MAAC,IAAI,IAAC,SAAS,EAAE,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE,EAAE,oBAAoB,KAAM,SAAS,aAC/E,MAAC,IAAI,IACH,SAAS,EAAE,EAAE,SAAS,EAAE,QAAQ,EAAE,EAClC,IAAI,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,EACnB,EAAE,EAAE,0BAA0B,aAE9B,KAAC,IAAI,IAAC,EAAE,EAAC,IAAI,YAAE,KAAK,WAAQ,EAC5B,KAAC,IAAI,OAAK,IAAI,EAAE,IAAI,EAAC,YAAY,EAAC,QAAQ,iBAAG,YACxC,EACN,UAAU,YACN,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,cAAc,CAAC","sourcesContent":["import { FC, ReactNode } from 'react';\nimport styled from 'styled-components';\n\nimport {\n Flex,\n Tabs,\n TabsProps,\n Text,\n defaultThemeProp,\n ForwardProps\n} from '@pega/cosmos-react-core';\nimport { StyledText } from '@pega/cosmos-react-core/lib/components/Text/Text';\n\nexport interface MobileCaseViewProps {\n title: string;\n tabs: TabsProps;\n tabContent: ReactNode;\n}\n\nexport const StyledMobileCaseView = styled.div`\n min-height: 100vh;\n background-color: #e9eef3;\n`;\n\nexport const StyledMobileCaseViewHeader = styled.header`\n color: ${props => props.theme.base.palette.light};\n background-color: ${props => props.theme.base.palette.interactive};\n\n ${StyledText} {\n padding: ${props => props.theme.base.spacing};\n }\n`;\n\nStyledMobileCaseView.defaultProps = defaultThemeProp;\nStyledMobileCaseViewHeader.defaultProps = defaultThemeProp;\n\n/** @deprecated */\nconst MobileCaseView: FC<ForwardProps & MobileCaseViewProps> = (props: MobileCaseViewProps) => {\n const { tabs, tabContent, title, ...restProps } = props;\n\n return (\n <Flex container={{ direction: 'column' }} as={StyledMobileCaseView} {...restProps}>\n <Flex\n container={{ direction: 'column' }}\n item={{ shrink: 0 }}\n as={StyledMobileCaseViewHeader}\n >\n <Text as='h1'>{title}</Text>\n <Tabs {...tabs} type='horizontal' inverted />\n </Flex>\n {tabContent}\n </Flex>\n );\n};\n\nexport default MobileCaseView;\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"UtilitiesSummary.d.ts","sourceRoot":"","sources":["../../../src/components/CaseView/UtilitiesSummary.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAC;AAGjD,OAAO,EAA2B,YAAY,EAAW,MAAM,yBAAyB,CAAC;AAEzF,MAAM,WAAW,qBAAqB;IACpC,KAAK,EAAE;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;CAC/C;AAED,eAAO,MAAM,sBAAsB,yGAKjC,CAAC;AAEH,QAAA,MAAM,gBAAgB,EAAE,iBAAiB,CAAC,qBAAqB,GAAG,YAAY,CAiC7E,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
1
+ {"version":3,"file":"UtilitiesSummary.d.ts","sourceRoot":"","sources":["../../../src/components/CaseView/UtilitiesSummary.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAC;AAG1C,OAAO,EAA2B,YAAY,EAAW,MAAM,yBAAyB,CAAC;AAEzF,MAAM,WAAW,qBAAqB;IACpC,KAAK,EAAE;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;CAC/C;AAED,eAAO,MAAM,sBAAsB,yGAKjC,CAAC;AAEH,QAAA,MAAM,gBAAgB,EAAE,iBAAiB,CAAC,qBAAqB,GAAG,YAAY,CAiC7E,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
@@ -1,4 +1,4 @@
1
- import React from 'react';
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import styled, { css } from 'styled-components';
3
3
  import { Card, Count, Flex, Icon, useI18n } from '@pega/cosmos-react-core';
4
4
  export const StyledUtilitiesSummary = styled.div(({ theme }) => {
@@ -9,15 +9,13 @@ export const StyledUtilitiesSummary = styled.div(({ theme }) => {
9
9
  });
10
10
  const UtilitiesSummary = ({ items = [], ...restProps }) => {
11
11
  const t = useI18n();
12
- return items.length ? (React.createElement(Card, { ...restProps, interactive: true, tabIndex: 0, role: 'button', container: { direction: 'column', alignItems: 'center', itemGap: 3 }, "aria-label": `${t('utilities_summary')} ${t('expand_noun', t('utilities_panel'))}`, as: StyledUtilitiesSummary }, items.map(item => {
13
- return (React.createElement(Flex, { container: {
14
- direction: 'column',
15
- alignItems: 'center',
16
- itemGap: 0.5
17
- }, item: { grow: 1 }, key: item.iconName },
18
- React.createElement(Icon, { name: item.iconName }),
19
- item.count !== undefined && React.createElement(Count, { variant: 'default' }, item.count)));
20
- }))) : null;
12
+ return items.length ? (_jsx(Card, { ...restProps, interactive: true, tabIndex: 0, role: 'button', container: { direction: 'column', alignItems: 'center', gap: 3 }, "aria-label": `${t('utilities_summary')}, ${t('expand_noun', [t('utilities_panel')])}`, as: StyledUtilitiesSummary, children: items.map(item => {
13
+ return (_jsxs(Flex, { container: {
14
+ direction: 'column',
15
+ alignItems: 'center',
16
+ gap: 0.5
17
+ }, item: { grow: 1 }, children: [_jsx(Icon, { name: item.iconName }, void 0), item.count !== undefined && _jsx(Count, { variant: 'default', children: item.count }, void 0)] }, item.iconName));
18
+ }) }, void 0)) : null;
21
19
  };
22
20
  export default UtilitiesSummary;
23
21
  //# sourceMappingURL=UtilitiesSummary.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"UtilitiesSummary.js","sourceRoot":"","sources":["../../../src/components/CaseView/UtilitiesSummary.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA4B,MAAM,OAAO,CAAC;AACjD,OAAO,MAAM,EAAE,EAAE,GAAG,EAAE,MAAM,mBAAmB,CAAC;AAEhD,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAgB,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAMzF,MAAM,CAAC,MAAM,sBAAsB,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE;IAC7D,OAAO,GAAG,CAAA;;eAEG,KAAK,CAAC,IAAI,CAAC,OAAO;GAC9B,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,MAAM,gBAAgB,GAA4D,CAAC,EACjF,KAAK,GAAG,EAAE,EACV,GAAG,SAAS,EACU,EAAE,EAAE;IAC1B,MAAM,CAAC,GAAG,OAAO,EAAE,CAAC;IACpB,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CACpB,oBAAC,IAAI,OACC,SAAS,EACb,WAAW,QACX,QAAQ,EAAE,CAAC,EACX,IAAI,EAAC,QAAQ,EACb,SAAS,EAAE,EAAE,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,EAAE,gBACxD,GAAG,CAAC,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,CAAC,CAAC,iBAAiB,CAAC,CAAC,EAAE,EACjF,EAAE,EAAE,sBAAsB,IAEzB,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;QAChB,OAAO,CACL,oBAAC,IAAI,IACH,SAAS,EAAE;gBACT,SAAS,EAAE,QAAQ;gBACnB,UAAU,EAAE,QAAQ;gBACpB,OAAO,EAAE,GAAG;aACb,EACD,IAAI,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,EACjB,GAAG,EAAE,IAAI,CAAC,QAAQ;YAElB,oBAAC,IAAI,IAAC,IAAI,EAAE,IAAI,CAAC,QAAQ,GAAI;YAC5B,IAAI,CAAC,KAAK,KAAK,SAAS,IAAI,oBAAC,KAAK,IAAC,OAAO,EAAC,SAAS,IAAE,IAAI,CAAC,KAAK,CAAS,CACrE,CACR,CAAC;IACJ,CAAC,CAAC,CACG,CACR,CAAC,CAAC,CAAC,IAAI,CAAC;AACX,CAAC,CAAC;AAEF,eAAe,gBAAgB,CAAC","sourcesContent":["import React, { FunctionComponent } from 'react';\nimport styled, { css } from 'styled-components';\n\nimport { Card, Count, Flex, Icon, ForwardProps, useI18n } from '@pega/cosmos-react-core';\n\nexport interface UtilitiesSummaryProps {\n items: { iconName: string; count?: number }[];\n}\n\nexport const StyledUtilitiesSummary = styled.div(({ theme }) => {\n return css`\n width: 2.75rem;\n padding: ${theme.base.spacing} 0;\n `;\n});\n\nconst UtilitiesSummary: FunctionComponent<UtilitiesSummaryProps & ForwardProps> = ({\n items = [],\n ...restProps\n}: UtilitiesSummaryProps) => {\n const t = useI18n();\n return items.length ? (\n <Card\n {...restProps}\n interactive\n tabIndex={0}\n role='button'\n container={{ direction: 'column', alignItems: 'center', itemGap: 3 }}\n aria-label={`${t('utilities_summary')} ${t('expand_noun', t('utilities_panel'))}`}\n as={StyledUtilitiesSummary}\n >\n {items.map(item => {\n return (\n <Flex\n container={{\n direction: 'column',\n alignItems: 'center',\n itemGap: 0.5\n }}\n item={{ grow: 1 }}\n key={item.iconName}\n >\n <Icon name={item.iconName} />\n {item.count !== undefined && <Count variant='default'>{item.count}</Count>}\n </Flex>\n );\n })}\n </Card>\n ) : null;\n};\n\nexport default UtilitiesSummary;\n"]}
1
+ {"version":3,"file":"UtilitiesSummary.js","sourceRoot":"","sources":["../../../src/components/CaseView/UtilitiesSummary.tsx"],"names":[],"mappings":";AACA,OAAO,MAAM,EAAE,EAAE,GAAG,EAAE,MAAM,mBAAmB,CAAC;AAEhD,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAgB,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAMzF,MAAM,CAAC,MAAM,sBAAsB,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE;IAC7D,OAAO,GAAG,CAAA;;eAEG,KAAK,CAAC,IAAI,CAAC,OAAO;GAC9B,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,MAAM,gBAAgB,GAA4D,CAAC,EACjF,KAAK,GAAG,EAAE,EACV,GAAG,SAAS,EACU,EAAE,EAAE;IAC1B,MAAM,CAAC,GAAG,OAAO,EAAE,CAAC;IACpB,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CACpB,KAAC,IAAI,OACC,SAAS,EACb,WAAW,QACX,QAAQ,EAAE,CAAC,EACX,IAAI,EAAC,QAAQ,EACb,SAAS,EAAE,EAAE,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,EAAE,gBACpD,GAAG,CAAC,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,EACpF,EAAE,EAAE,sBAAsB,YAEzB,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;YAChB,OAAO,CACL,MAAC,IAAI,IACH,SAAS,EAAE;oBACT,SAAS,EAAE,QAAQ;oBACnB,UAAU,EAAE,QAAQ;oBACpB,GAAG,EAAE,GAAG;iBACT,EACD,IAAI,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,aAGjB,KAAC,IAAI,IAAC,IAAI,EAAE,IAAI,CAAC,QAAQ,WAAI,EAC5B,IAAI,CAAC,KAAK,KAAK,SAAS,IAAI,KAAC,KAAK,IAAC,OAAO,EAAC,SAAS,YAAE,IAAI,CAAC,KAAK,WAAS,KAHrE,IAAI,CAAC,QAAQ,CAIb,CACR,CAAC;QACJ,CAAC,CAAC,WACG,CACR,CAAC,CAAC,CAAC,IAAI,CAAC;AACX,CAAC,CAAC;AAEF,eAAe,gBAAgB,CAAC","sourcesContent":["import { FunctionComponent } from 'react';\nimport styled, { css } from 'styled-components';\n\nimport { Card, Count, Flex, Icon, ForwardProps, useI18n } from '@pega/cosmos-react-core';\n\nexport interface UtilitiesSummaryProps {\n items: { iconName: string; count?: number }[];\n}\n\nexport const StyledUtilitiesSummary = styled.div(({ theme }) => {\n return css`\n width: 2.75rem;\n padding: ${theme.base.spacing} 0;\n `;\n});\n\nconst UtilitiesSummary: FunctionComponent<UtilitiesSummaryProps & ForwardProps> = ({\n items = [],\n ...restProps\n}: UtilitiesSummaryProps) => {\n const t = useI18n();\n return items.length ? (\n <Card\n {...restProps}\n interactive\n tabIndex={0}\n role='button'\n container={{ direction: 'column', alignItems: 'center', gap: 3 }}\n aria-label={`${t('utilities_summary')}, ${t('expand_noun', [t('utilities_panel')])}`}\n as={StyledUtilitiesSummary}\n >\n {items.map(item => {\n return (\n <Flex\n container={{\n direction: 'column',\n alignItems: 'center',\n gap: 0.5\n }}\n item={{ grow: 1 }}\n key={item.iconName}\n >\n <Icon name={item.iconName} />\n {item.count !== undefined && <Count variant='default'>{item.count}</Count>}\n </Flex>\n );\n })}\n </Card>\n ) : null;\n};\n\nexport default UtilitiesSummary;\n"]}
@@ -1,5 +1,6 @@
1
1
  export { default } from './CaseView';
2
- export { CaseViewProps, StyledCaseView, StyledCaseViewContent, StyledCaseDrawer, StyledCaseDrawerContent, StyledSummaryRegion } from './CaseView';
2
+ export { CaseViewProps } from './CaseView';
3
+ export { StyledCaseView, StyledCaseViewContent, StyledCaseDrawer, StyledCaseDrawerContent, StyledSummaryRegion } from './CaseView.styles';
3
4
  export { default as MobileCaseView } from './MobileCaseView';
4
5
  export { MobileCaseViewProps } from './MobileCaseView';
5
6
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/CaseView/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AACrC,OAAO,EACL,aAAa,EACb,cAAc,EACd,qBAAqB,EACrB,gBAAgB,EAChB,uBAAuB,EACvB,mBAAmB,EACpB,MAAM,YAAY,CAAC;AACpB,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAC7D,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/CaseView/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AACrC,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,EACL,cAAc,EACd,qBAAqB,EACrB,gBAAgB,EAChB,uBAAuB,EACvB,mBAAmB,EACpB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAC7D,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC"}
@@ -1,4 +1,4 @@
1
1
  export { default } from './CaseView';
2
- export { StyledCaseView, StyledCaseViewContent, StyledCaseDrawer, StyledCaseDrawerContent, StyledSummaryRegion } from './CaseView';
2
+ export { StyledCaseView, StyledCaseViewContent, StyledCaseDrawer, StyledCaseDrawerContent, StyledSummaryRegion } from './CaseView.styles';
3
3
  export { default as MobileCaseView } from './MobileCaseView';
4
4
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/CaseView/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AACrC,OAAO,EAEL,cAAc,EACd,qBAAqB,EACrB,gBAAgB,EAChB,uBAAuB,EACvB,mBAAmB,EACpB,MAAM,YAAY,CAAC;AACpB,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAC","sourcesContent":["export { default } from './CaseView';\nexport {\n CaseViewProps,\n StyledCaseView,\n StyledCaseViewContent,\n StyledCaseDrawer,\n StyledCaseDrawerContent,\n StyledSummaryRegion\n} from './CaseView';\nexport { default as MobileCaseView } from './MobileCaseView';\nexport { MobileCaseViewProps } from './MobileCaseView';\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/CaseView/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAErC,OAAO,EACL,cAAc,EACd,qBAAqB,EACrB,gBAAgB,EAChB,uBAAuB,EACvB,mBAAmB,EACpB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAC","sourcesContent":["export { default } from './CaseView';\nexport { CaseViewProps } from './CaseView';\nexport {\n StyledCaseView,\n StyledCaseViewContent,\n StyledCaseDrawer,\n StyledCaseDrawerContent,\n StyledSummaryRegion\n} from './CaseView.styles';\nexport { default as MobileCaseView } from './MobileCaseView';\nexport { MobileCaseViewProps } from './MobileCaseView';\n"]}
@@ -0,0 +1,4 @@
1
+ import type { ConfigurableLayoutProps } from './ConfigurableLayout.types';
2
+ declare const ConfigurableLayout: import("react").ForwardRefExoticComponent<ConfigurableLayoutProps & import("react").RefAttributes<HTMLElement>>;
3
+ export default ConfigurableLayout;
4
+ //# sourceMappingURL=ConfigurableLayout.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConfigurableLayout.d.ts","sourceRoot":"","sources":["../../../src/components/ConfigurableLayout/ConfigurableLayout.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,4BAA4B,CAAC;AA+B1E,QAAA,MAAM,kBAAkB,iHAsFvB,CAAC;AAEF,eAAe,kBAAkB,CAAC"}
@@ -0,0 +1,93 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { forwardRef, useState, useEffect, useRef, useMemo } from 'react';
3
+ import styled, { css } from 'styled-components';
4
+ import { Flex, defaultThemeProp } from '@pega/cosmos-react-core';
5
+ import { containerMinWidth, cellGap } from './defaults';
6
+ import LayoutCell from './LayoutCell';
7
+ const StyledConfigurableLayout = styled.div(() => {
8
+ return css `
9
+ overflow: hidden;
10
+ `;
11
+ });
12
+ const StyledCellGrid = styled.div(({ theme }) => {
13
+ return css `
14
+ /* Note: inset position used to negate "column" inline margin on items */
15
+ position: relative;
16
+ width: calc(100% + ${cellGap * 2} * ${theme.base.spacing});
17
+ max-width: calc(100% + ${cellGap * 2} * ${theme.base.spacing});
18
+ inset-inline: calc(-${cellGap} * ${theme.base.spacing});
19
+ margin-block-end: calc(-2 * ${cellGap} * ${theme.base.spacing});
20
+ `;
21
+ });
22
+ StyledCellGrid.defaultProps = defaultThemeProp;
23
+ const StyledContainerRuler = styled.div(({ theme }) => {
24
+ return css `
25
+ margin-inline: calc(${cellGap} * ${theme.base.spacing});
26
+ width: calc(100% - ${cellGap * 2} * ${theme.base.spacing});
27
+ `;
28
+ });
29
+ StyledContainerRuler.defaultProps = defaultThemeProp;
30
+ const ConfigurableLayout = forwardRef(({ items, arrangement }, ref) => {
31
+ const [renderMode, setRenderMode] = useState('direct');
32
+ const containerRulerRef = useRef(null);
33
+ // Update render mode when arrangement wraps
34
+ useEffect(() => {
35
+ const activeArrangement = arrangement?.hasWrapped !== undefined && !arrangement.hasWrapped;
36
+ if (activeArrangement) {
37
+ switch (arrangement.size) {
38
+ case 'main':
39
+ setRenderMode('direct');
40
+ break;
41
+ case 'half':
42
+ setRenderMode('double');
43
+ break;
44
+ case 'narrow':
45
+ setRenderMode('full');
46
+ break;
47
+ default:
48
+ setRenderMode('direct');
49
+ break;
50
+ }
51
+ return;
52
+ }
53
+ // Use direct by default
54
+ setRenderMode('direct');
55
+ }, [arrangement?.hasWrapped]);
56
+ const content = useMemo(() => {
57
+ if (items && !!items.length) {
58
+ return items.map(itemConfig => {
59
+ const config = {
60
+ ...itemConfig,
61
+ layoutConfig: { ...itemConfig.layoutConfig }
62
+ };
63
+ if (renderMode !== 'direct') {
64
+ switch (renderMode) {
65
+ case 'double': {
66
+ const doubleWidth = {
67
+ '1/4': '1/2',
68
+ '1/3': '2/3',
69
+ '1/2': 'full',
70
+ '2/3': 'full',
71
+ '3/4': 'full',
72
+ full: 'full'
73
+ };
74
+ config.layoutConfig.width = doubleWidth[config.layoutConfig.width];
75
+ break;
76
+ }
77
+ case 'full':
78
+ config.layoutConfig.width = 'full';
79
+ break;
80
+ default:
81
+ config.layoutConfig.width = 'full';
82
+ break;
83
+ }
84
+ }
85
+ return _jsx(LayoutCell, { config: config }, `${itemConfig.id}--${renderMode}`);
86
+ });
87
+ }
88
+ return null;
89
+ }, [items, renderMode]);
90
+ return (_jsx(StyledConfigurableLayout, { children: _jsxs(Flex, { as: StyledCellGrid, container: { wrap: 'wrap', justify: 'stretch', alignItems: 'stretch' }, item: { basis: containerMinWidth, grow: 1 }, ref: ref, children: [_jsx(StyledContainerRuler, { ref: containerRulerRef }, void 0), content] }, void 0) }, void 0));
91
+ });
92
+ export default ConfigurableLayout;
93
+ //# sourceMappingURL=ConfigurableLayout.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConfigurableLayout.js","sourceRoot":"","sources":["../../../src/components/ConfigurableLayout/ConfigurableLayout.tsx"],"names":[],"mappings":"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","sourcesContent":["import { forwardRef, PropsWithoutRef, Ref, useState, useEffect, useRef, useMemo } from 'react';\nimport styled, { css } from 'styled-components';\n\nimport { Flex, defaultThemeProp } from '@pega/cosmos-react-core';\n\nimport type { ConfigurableLayoutProps } from './ConfigurableLayout.types';\nimport { containerMinWidth, cellGap } from './defaults';\nimport widthConfigOptions from './options';\nimport LayoutCell from './LayoutCell';\n\nconst StyledConfigurableLayout = styled.div(() => {\n return css`\n overflow: hidden;\n `;\n});\n\nconst StyledCellGrid = styled.div(({ theme }) => {\n return css`\n /* Note: inset position used to negate \"column\" inline margin on items */\n position: relative;\n width: calc(100% + ${cellGap * 2} * ${theme.base.spacing});\n max-width: calc(100% + ${cellGap * 2} * ${theme.base.spacing});\n inset-inline: calc(-${cellGap} * ${theme.base.spacing});\n margin-block-end: calc(-2 * ${cellGap} * ${theme.base.spacing});\n `;\n});\nStyledCellGrid.defaultProps = defaultThemeProp;\n\nconst StyledContainerRuler = styled.div(({ theme }) => {\n return css`\n margin-inline: calc(${cellGap} * ${theme.base.spacing});\n width: calc(100% - ${cellGap * 2} * ${theme.base.spacing});\n `;\n});\nStyledContainerRuler.defaultProps = defaultThemeProp;\n\nconst ConfigurableLayout = forwardRef(\n ({ items, arrangement }: PropsWithoutRef<ConfigurableLayoutProps>, ref: Ref<HTMLElement>) => {\n const [renderMode, setRenderMode] = useState<'direct' | 'double' | 'full'>('direct');\n const containerRulerRef = useRef<HTMLDivElement>(null);\n\n // Update render mode when arrangement wraps\n useEffect(() => {\n const activeArrangement = arrangement?.hasWrapped !== undefined && !arrangement.hasWrapped;\n\n if (activeArrangement) {\n switch (arrangement.size) {\n case 'main':\n setRenderMode('direct');\n break;\n case 'half':\n setRenderMode('double');\n break;\n case 'narrow':\n setRenderMode('full');\n break;\n default:\n setRenderMode('direct');\n break;\n }\n\n return;\n }\n\n // Use direct by default\n setRenderMode('direct');\n }, [arrangement?.hasWrapped]);\n\n const content = useMemo(() => {\n if (items && !!items.length) {\n return items.map(itemConfig => {\n const config = {\n ...itemConfig,\n layoutConfig: { ...itemConfig.layoutConfig }\n };\n\n if (renderMode !== 'direct') {\n switch (renderMode) {\n case 'double': {\n const doubleWidth: { [key: string]: keyof typeof widthConfigOptions } = {\n '1/4': '1/2',\n '1/3': '2/3',\n '1/2': 'full',\n '2/3': 'full',\n '3/4': 'full',\n full: 'full'\n };\n\n config.layoutConfig.width = doubleWidth[config.layoutConfig.width];\n\n break;\n }\n case 'full':\n config.layoutConfig.width = 'full';\n break;\n default:\n config.layoutConfig.width = 'full';\n break;\n }\n }\n\n return <LayoutCell key={`${itemConfig.id}--${renderMode}`} config={config} />;\n });\n }\n\n return null;\n }, [items, renderMode]);\n\n return (\n <StyledConfigurableLayout>\n <Flex\n as={StyledCellGrid}\n container={{ wrap: 'wrap', justify: 'stretch', alignItems: 'stretch' }}\n item={{ basis: containerMinWidth, grow: 1 }}\n ref={ref}\n >\n <StyledContainerRuler ref={containerRulerRef} />\n {content}\n </Flex>\n </StyledConfigurableLayout>\n );\n }\n);\n\nexport default ConfigurableLayout;\n"]}
@@ -0,0 +1,43 @@
1
+ import type widthConfigOptions from './options';
2
+ /**
3
+ * Type for config of a single ConfigurableLayout item.
4
+ */
5
+ export interface Config {
6
+ /** Unique identifier in render region */
7
+ id: string;
8
+ /** Element to render */
9
+ content: JSX.Element;
10
+ /** Config for element */
11
+ layoutConfig: {
12
+ /** Responsive width option */
13
+ width: keyof typeof widthConfigOptions;
14
+ /**
15
+ * Fills remaining space if true, else does not grow beyond `width` value.
16
+ * @default true
17
+ */
18
+ fillAvailable?: boolean;
19
+ /** Flex basis (minimum fixed width) of element as:
20
+ * - a numeric value to be applied in __pixels__
21
+ * - a tuple of a numeric value and string unit
22
+ */
23
+ minWidth?: number | [number, 'px' | 'ch' | 'rem' | 'em'];
24
+ };
25
+ }
26
+ export interface ConfigurableLayoutProps {
27
+ /** Array of configs for individual layout cells */
28
+ items: Config[];
29
+ /** Arrangement properties */
30
+ arrangement?: {
31
+ /** Defines the arrangement size of the given ConfigurableLayout.
32
+ * Used to determine what width to apply to the given item when the arrangement is applied,
33
+ * with the following mapping:
34
+ * - 'narrow' --> applies 'full' width
35
+ * - 'main' --> applies configured width
36
+ * - 'half' --> applies double the configured width, or 'full' width (whichever is smaller)
37
+ */
38
+ size: 'narrow' | 'main' | 'half';
39
+ /** Indicates when the ConfigurableLayout has wrapped to the full width of it's container */
40
+ hasWrapped: boolean;
41
+ };
42
+ }
43
+ //# sourceMappingURL=ConfigurableLayout.types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConfigurableLayout.types.d.ts","sourceRoot":"","sources":["../../../src/components/ConfigurableLayout/ConfigurableLayout.types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,kBAAkB,MAAM,WAAW,CAAC;AAEhD;;GAEG;AACH,MAAM,WAAW,MAAM;IACrB,yCAAyC;IACzC,EAAE,EAAE,MAAM,CAAC;IACX,wBAAwB;IACxB,OAAO,EAAE,GAAG,CAAC,OAAO,CAAC;IACrB,yBAAyB;IACzB,YAAY,EAAE;QACZ,8BAA8B;QAC9B,KAAK,EAAE,MAAM,OAAO,kBAAkB,CAAC;QACvC;;;WAGG;QACH,aAAa,CAAC,EAAE,OAAO,CAAC;QACxB;;;WAGG;QACH,QAAQ,CAAC,EAAE,MAAM,GAAG,CAAC,MAAM,EAAE,IAAI,GAAG,IAAI,GAAG,KAAK,GAAG,IAAI,CAAC,CAAC;KAC1D,CAAC;CACH;AAED,MAAM,WAAW,uBAAuB;IACtC,mDAAmD;IACnD,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,6BAA6B;IAC7B,WAAW,CAAC,EAAE;QACZ;;;;;;WAMG;QACH,IAAI,EAAE,QAAQ,GAAG,MAAM,GAAG,MAAM,CAAC;QACjC,4FAA4F;QAC5F,UAAU,EAAE,OAAO,CAAC;KACrB,CAAC;CACH"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=ConfigurableLayout.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConfigurableLayout.types.js","sourceRoot":"","sources":["../../../src/components/ConfigurableLayout/ConfigurableLayout.types.ts"],"names":[],"mappings":"","sourcesContent":["import type widthConfigOptions from './options';\n\n/**\n * Type for config of a single ConfigurableLayout item.\n */\nexport interface Config {\n /** Unique identifier in render region */\n id: string;\n /** Element to render */\n content: JSX.Element;\n /** Config for element */\n layoutConfig: {\n /** Responsive width option */\n width: keyof typeof widthConfigOptions;\n /**\n * Fills remaining space if true, else does not grow beyond `width` value.\n * @default true\n */\n fillAvailable?: boolean;\n /** Flex basis (minimum fixed width) of element as:\n * - a numeric value to be applied in __pixels__\n * - a tuple of a numeric value and string unit\n */\n minWidth?: number | [number, 'px' | 'ch' | 'rem' | 'em'];\n };\n}\n\nexport interface ConfigurableLayoutProps {\n /** Array of configs for individual layout cells */\n items: Config[];\n /** Arrangement properties */\n arrangement?: {\n /** Defines the arrangement size of the given ConfigurableLayout.\n * Used to determine what width to apply to the given item when the arrangement is applied,\n * with the following mapping:\n * - 'narrow' --> applies 'full' width\n * - 'main' --> applies configured width\n * - 'half' --> applies double the configured width, or 'full' width (whichever is smaller)\n */\n size: 'narrow' | 'main' | 'half';\n /** Indicates when the ConfigurableLayout has wrapped to the full width of it's container */\n hasWrapped: boolean;\n };\n}\n"]}
@@ -0,0 +1,6 @@
1
+ import type { Config } from './ConfigurableLayout.types';
2
+ declare const LayoutCell: ({ config }: {
3
+ config: Config;
4
+ }) => JSX.Element | null;
5
+ export default LayoutCell;
6
+ //# sourceMappingURL=LayoutCell.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LayoutCell.d.ts","sourceRoot":"","sources":["../../../src/components/ConfigurableLayout/LayoutCell.tsx"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAC;AAoDzD,QAAA,MAAM,UAAU;YAA0B,MAAM;wBAoC/C,CAAC;AAEF,eAAe,UAAU,CAAC"}
@@ -0,0 +1,64 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useMemo } from 'react';
3
+ import styled, { css } from 'styled-components';
4
+ import { Flex, defaultThemeProp } from '@pega/cosmos-react-core';
5
+ import { StyledAppAnnouncement } from '../AppAnnouncement/AppAnnouncement';
6
+ import widthConfigOptions from './options';
7
+ import { itemMinWidth, cellGap } from './defaults';
8
+ const StyledCell = styled.div(({ fillAvailable = true, percentageWidth, minWidth, theme }) => {
9
+ return css `
10
+ /* variables */
11
+ --marginGap: calc(${cellGap} * ${theme.base.spacing});
12
+ --totalMargin: calc(2 * var(--marginGap));
13
+ --percentageBasis: calc(${percentageWidth} - var(--totalMargin));
14
+ --maxWidth: calc(100% - var(--totalMargin));
15
+
16
+ /* styles */
17
+ flex-wrap: wrap;
18
+ flex-basis: var(--percentageBasis);
19
+ min-width: min(var(--maxWidth), ${minWidth || itemMinWidth});
20
+ max-width: var(--maxWidth);
21
+ margin-block-end: var(--totalMargin);
22
+ margin-inline: var(--marginGap);
23
+
24
+ ${!fillAvailable &&
25
+ css `
26
+ flex-grow: 0;
27
+ `}
28
+
29
+ ${StyledAppAnnouncement} {
30
+ align-self: stretch;
31
+ }
32
+
33
+ > * {
34
+ width: 100%;
35
+ height: auto;
36
+ overflow-x: auto;
37
+ }
38
+ `;
39
+ });
40
+ StyledCell.defaultProps = defaultThemeProp;
41
+ const validWidthUnits = ['px', 'ch', 'rem', 'em'];
42
+ const LayoutCell = ({ config }) => {
43
+ const layoutConfig = useMemo(() => config.layoutConfig, [config]);
44
+ const percentageWidth = useMemo(() => {
45
+ return widthConfigOptions[layoutConfig.width] || '100%';
46
+ }, [layoutConfig.width]);
47
+ const minWidth = useMemo(() => {
48
+ const value = layoutConfig.minWidth;
49
+ if (typeof value === 'number') {
50
+ return `${value}px`;
51
+ }
52
+ if (Array.isArray(value) &&
53
+ value.length >= 2 &&
54
+ typeof value[0] === 'number' &&
55
+ validWidthUnits.includes(value[1])) {
56
+ return `${value[0]}${value[1]}`;
57
+ }
58
+ }, [layoutConfig.minWidth]);
59
+ return config?.content ? (_jsx(Flex, { as: StyledCell, item: {
60
+ grow: 1
61
+ }, container: { justify: 'stretch', alignItems: 'start' }, fillAvailable: layoutConfig.fillAvailable, percentageWidth: percentageWidth, minWidth: minWidth, children: config.content }, void 0)) : null;
62
+ };
63
+ export default LayoutCell;
64
+ //# sourceMappingURL=LayoutCell.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LayoutCell.js","sourceRoot":"","sources":["../../../src/components/ConfigurableLayout/LayoutCell.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAChC,OAAO,MAAM,EAAE,EAAE,GAAG,EAAgB,MAAM,mBAAmB,CAAC;AAE9D,OAAO,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAEjE,OAAO,EAAE,qBAAqB,EAAE,MAAM,oCAAoC,CAAC;AAG3E,OAAO,kBAAkB,MAAM,WAAW,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAEnD,MAAM,UAAU,GAAG,MAAM,CAAC,GAAG,CAC3B,CAAC,EACC,aAAa,GAAG,IAAI,EACpB,eAAe,EACf,QAAQ,EACR,KAAK,EAMN,EAAE,EAAE;IACH,OAAO,GAAG,CAAA;;0BAEY,OAAO,MAAM,KAAK,CAAC,IAAI,CAAC,OAAO;;gCAEzB,eAAe;;;;;;wCAMP,QAAQ,IAAI,YAAY;;;;;QAKxD,CAAC,aAAa;QAChB,GAAG,CAAA;;OAEF;;QAEC,qBAAqB;;;;;;;;;KASxB,CAAC;AACJ,CAAC,CACF,CAAC;AACF,UAAU,CAAC,YAAY,GAAG,gBAAgB,CAAC;AAE3C,MAAM,eAAe,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;AAElD,MAAM,UAAU,GAAG,CAAC,EAAE,MAAM,EAAsB,EAAE,EAAE;IACpD,MAAM,YAAY,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;IAClE,MAAM,eAAe,GAAG,OAAO,CAAC,GAAG,EAAE;QACnC,OAAO,kBAAkB,CAAC,YAAY,CAAC,KAAwC,CAAC,IAAI,MAAM,CAAC;IAC7F,CAAC,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC;IACzB,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,EAAE;QAC5B,MAAM,KAAK,GAAG,YAAY,CAAC,QAAQ,CAAC;QAEpC,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YAC7B,OAAO,GAAG,KAAK,IAAI,CAAC;SACrB;QAED,IACE,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;YACpB,KAAK,CAAC,MAAM,IAAI,CAAC;YACjB,OAAO,KAAK,CAAC,CAAC,CAAC,KAAK,QAAQ;YAC5B,eAAe,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAClC;YACA,OAAO,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;SACjC;IACH,CAAC,EAAE,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC;IAE5B,OAAO,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,CACvB,KAAC,IAAI,IACH,EAAE,EAAE,UAAU,EACd,IAAI,EAAE;YACJ,IAAI,EAAE,CAAC;SACR,EACD,SAAS,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,EACtD,aAAa,EAAE,YAAY,CAAC,aAAa,EACzC,eAAe,EAAE,eAAe,EAChC,QAAQ,EAAE,QAAQ,YAEjB,MAAM,CAAC,OAAO,WACV,CACR,CAAC,CAAC,CAAC,IAAI,CAAC;AACX,CAAC,CAAC;AAEF,eAAe,UAAU,CAAC","sourcesContent":["import { useMemo } from 'react';\nimport styled, { css, DefaultTheme } from 'styled-components';\n\nimport { Flex, defaultThemeProp } from '@pega/cosmos-react-core';\n\nimport { StyledAppAnnouncement } from '../AppAnnouncement/AppAnnouncement';\n\nimport type { Config } from './ConfigurableLayout.types';\nimport widthConfigOptions from './options';\nimport { itemMinWidth, cellGap } from './defaults';\n\nconst StyledCell = styled.div(\n ({\n fillAvailable = true,\n percentageWidth,\n minWidth,\n theme\n }: {\n fillAvailable: boolean;\n percentageWidth?: string;\n minWidth?: string | undefined;\n theme: DefaultTheme;\n }) => {\n return css`\n /* variables */\n --marginGap: calc(${cellGap} * ${theme.base.spacing});\n --totalMargin: calc(2 * var(--marginGap));\n --percentageBasis: calc(${percentageWidth} - var(--totalMargin));\n --maxWidth: calc(100% - var(--totalMargin));\n\n /* styles */\n flex-wrap: wrap;\n flex-basis: var(--percentageBasis);\n min-width: min(var(--maxWidth), ${minWidth || itemMinWidth});\n max-width: var(--maxWidth);\n margin-block-end: var(--totalMargin);\n margin-inline: var(--marginGap);\n\n ${!fillAvailable &&\n css`\n flex-grow: 0;\n `}\n\n ${StyledAppAnnouncement} {\n align-self: stretch;\n }\n\n > * {\n width: 100%;\n height: auto;\n overflow-x: auto;\n }\n `;\n }\n);\nStyledCell.defaultProps = defaultThemeProp;\n\nconst validWidthUnits = ['px', 'ch', 'rem', 'em'];\n\nconst LayoutCell = ({ config }: { config: Config }) => {\n const layoutConfig = useMemo(() => config.layoutConfig, [config]);\n const percentageWidth = useMemo(() => {\n return widthConfigOptions[layoutConfig.width as keyof typeof widthConfigOptions] || '100%';\n }, [layoutConfig.width]);\n const minWidth = useMemo(() => {\n const value = layoutConfig.minWidth;\n\n if (typeof value === 'number') {\n return `${value}px`;\n }\n\n if (\n Array.isArray(value) &&\n value.length >= 2 &&\n typeof value[0] === 'number' &&\n validWidthUnits.includes(value[1])\n ) {\n return `${value[0]}${value[1]}`;\n }\n }, [layoutConfig.minWidth]);\n\n return config?.content ? (\n <Flex\n as={StyledCell}\n item={{\n grow: 1\n }}\n container={{ justify: 'stretch', alignItems: 'start' }}\n fillAvailable={layoutConfig.fillAvailable}\n percentageWidth={percentageWidth}\n minWidth={minWidth}\n >\n {config.content}\n </Flex>\n ) : null;\n};\n\nexport default LayoutCell;\n"]}
@@ -0,0 +1,4 @@
1
+ export declare const cellGap = 1;
2
+ export declare const containerMinWidth = "450px";
3
+ export declare const itemMinWidth = "225px";
4
+ //# sourceMappingURL=defaults.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"defaults.d.ts","sourceRoot":"","sources":["../../../src/components/ConfigurableLayout/defaults.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,OAAO,IAAI,CAAC;AACzB,eAAO,MAAM,iBAAiB,UAAU,CAAC;AACzC,eAAO,MAAM,YAAY,UAAU,CAAC"}
@@ -0,0 +1,4 @@
1
+ export const cellGap = 1;
2
+ export const containerMinWidth = '450px';
3
+ export const itemMinWidth = '225px';
4
+ //# sourceMappingURL=defaults.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"defaults.js","sourceRoot":"","sources":["../../../src/components/ConfigurableLayout/defaults.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,OAAO,GAAG,CAAC,CAAC;AACzB,MAAM,CAAC,MAAM,iBAAiB,GAAG,OAAO,CAAC;AACzC,MAAM,CAAC,MAAM,YAAY,GAAG,OAAO,CAAC","sourcesContent":["export const cellGap = 1;\nexport const containerMinWidth = '450px';\nexport const itemMinWidth = '225px';\n"]}
@@ -0,0 +1,3 @@
1
+ export { default } from './ConfigurableLayout';
2
+ export { default as useTrackWrappedRegions } from './useTrackWrappedRegions';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/ConfigurableLayout/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC/C,OAAO,EAAE,OAAO,IAAI,sBAAsB,EAAE,MAAM,0BAA0B,CAAC"}
@@ -0,0 +1,3 @@
1
+ export { default } from './ConfigurableLayout';
2
+ export { default as useTrackWrappedRegions } from './useTrackWrappedRegions';
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/ConfigurableLayout/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC/C,OAAO,EAAE,OAAO,IAAI,sBAAsB,EAAE,MAAM,0BAA0B,CAAC","sourcesContent":["export { default } from './ConfigurableLayout';\nexport { default as useTrackWrappedRegions } from './useTrackWrappedRegions';\n"]}
@@ -0,0 +1,10 @@
1
+ declare const widthConfigOptions: {
2
+ readonly '1/4': "25%";
3
+ readonly '1/3': "33.3%";
4
+ readonly '1/2': "50%";
5
+ readonly '2/3': "66.6%";
6
+ readonly '3/4': "75%";
7
+ readonly full: "100%";
8
+ };
9
+ export default widthConfigOptions;
10
+ //# sourceMappingURL=options.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"options.d.ts","sourceRoot":"","sources":["../../../src/components/ConfigurableLayout/options.ts"],"names":[],"mappings":"AAAA,QAAA,MAAM,kBAAkB;;;;;;;CAOd,CAAC;AAEX,eAAe,kBAAkB,CAAC"}
@@ -0,0 +1,10 @@
1
+ const widthConfigOptions = {
2
+ '1/4': '25%',
3
+ '1/3': '33.3%',
4
+ '1/2': '50%',
5
+ '2/3': '66.6%',
6
+ '3/4': '75%',
7
+ full: '100%'
8
+ };
9
+ export default widthConfigOptions;
10
+ //# sourceMappingURL=options.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"options.js","sourceRoot":"","sources":["../../../src/components/ConfigurableLayout/options.ts"],"names":[],"mappings":"AAAA,MAAM,kBAAkB,GAAG;IACzB,KAAK,EAAE,KAAK;IACZ,KAAK,EAAE,OAAO;IACd,KAAK,EAAE,KAAK;IACZ,KAAK,EAAE,OAAO;IACd,KAAK,EAAE,KAAK;IACZ,IAAI,EAAE,MAAM;CACJ,CAAC;AAEX,eAAe,kBAAkB,CAAC","sourcesContent":["const widthConfigOptions = {\n '1/4': '25%',\n '1/3': '33.3%',\n '1/2': '50%',\n '2/3': '66.6%',\n '3/4': '75%',\n full: '100%'\n} as const;\n\nexport default widthConfigOptions;\n"]}