ekm-ui 0.3.95 → 0.4.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.
Files changed (141) hide show
  1. package/.turbo/turbo-build.log +87 -59
  2. package/CHANGELOG.md +18 -0
  3. package/dist/alert-banner.d.ts +4 -1
  4. package/dist/alert-banner.js +1 -1
  5. package/dist/alert.d.ts +2 -1
  6. package/dist/alert.js +1 -1
  7. package/dist/button-group-item.d.ts +2 -1
  8. package/dist/button-group-item.js +1 -1
  9. package/dist/button.d.ts +1 -1
  10. package/dist/button.js +1 -1
  11. package/dist/card-payment-block.css +1 -1
  12. package/dist/card-payment-block.css.map +1 -1
  13. package/dist/card-payment-block.js +15 -15
  14. package/dist/{chunk-BLUJNMXF.js → chunk-2I24LCEG.js} +2 -2
  15. package/dist/{chunk-BLUJNMXF.js.map → chunk-2I24LCEG.js.map} +1 -1
  16. package/dist/{chunk-ELWZ674J.js → chunk-5SEJVYKM.js} +3 -3
  17. package/dist/chunk-5SEJVYKM.js.map +1 -0
  18. package/dist/chunk-AO5TGD7T.js +7 -0
  19. package/dist/chunk-AO5TGD7T.js.map +1 -0
  20. package/dist/chunk-CHXMQ7NN.js +12 -0
  21. package/dist/chunk-CHXMQ7NN.js.map +1 -0
  22. package/dist/chunk-CX2XFI5Q.js +12 -0
  23. package/dist/chunk-CX2XFI5Q.js.map +1 -0
  24. package/dist/{chunk-F7AUKLLE.js → chunk-FOPBXPMP.js} +2 -2
  25. package/dist/{chunk-F7AUKLLE.js.map → chunk-FOPBXPMP.js.map} +1 -1
  26. package/dist/{chunk-YOHYKIR3.js → chunk-HQIKNKIV.js} +2 -2
  27. package/dist/{chunk-FPELMAZN.js → chunk-JNHB4YNM.js} +2 -2
  28. package/dist/chunk-KRMPO53Y.js +9 -0
  29. package/dist/chunk-KRMPO53Y.js.map +1 -0
  30. package/dist/chunk-MBACKGWE.js +9 -0
  31. package/dist/chunk-MBACKGWE.js.map +1 -0
  32. package/dist/{chunk-N7JQ6EAC.js → chunk-R47VIYM2.js} +2 -2
  33. package/dist/{chunk-N7JQ6EAC.js.map → chunk-R47VIYM2.js.map} +1 -1
  34. package/dist/chunk-UQFNA3OB.js +36 -0
  35. package/dist/{chunk-GGGZRFPY.js.map → chunk-UQFNA3OB.js.map} +1 -1
  36. package/dist/{chunk-X6RBGNFS.js → chunk-XKE3VK6Z.js} +2 -2
  37. package/dist/chunk-XKE3VK6Z.js.map +1 -0
  38. package/dist/chunk-XYGVDZRO.js +11 -0
  39. package/dist/chunk-XYGVDZRO.js.map +1 -0
  40. package/dist/country-picker/country-modal.css +1 -1
  41. package/dist/country-picker/country-modal.css.map +1 -1
  42. package/dist/country-picker/country-modal.d.ts +2 -2
  43. package/dist/country-picker/country-modal.js +15 -15
  44. package/dist/date-range-picker.js +2 -2
  45. package/dist/drag-and-drop.css +1 -1
  46. package/dist/drag-and-drop.css.map +1 -1
  47. package/dist/drag-and-drop.js +15 -15
  48. package/dist/drawer.js +1 -1
  49. package/dist/file-picker/file-picker.css +1 -1
  50. package/dist/file-picker/file-picker.css.map +1 -1
  51. package/dist/file-picker/file-picker.js +15 -15
  52. package/dist/fixed-alert.js +2 -2
  53. package/dist/index.css +1 -1
  54. package/dist/index.css.map +1 -1
  55. package/dist/index.js +15 -15
  56. package/dist/layout/layout.css +1 -1
  57. package/dist/layout/layout.css.map +1 -1
  58. package/dist/layout/layout.js +15 -15
  59. package/dist/loading-button.js +1 -1
  60. package/dist/nbui/nbui-card-form.d.ts +3 -0
  61. package/dist/nbui/nbui-card-form.js +8 -0
  62. package/dist/nbui/nbui-card-form.js.map +1 -0
  63. package/dist/nbui/nbui-card-image.d.ts +3 -0
  64. package/dist/nbui/nbui-card-image.js +8 -0
  65. package/dist/nbui/nbui-card-image.js.map +1 -0
  66. package/dist/nbui/nbui-card-lg.d.ts +3 -0
  67. package/dist/nbui/nbui-card-lg.js +8 -0
  68. package/dist/nbui/nbui-card-lg.js.map +1 -0
  69. package/dist/nbui/nbui-card-paragraphs-lg.d.ts +3 -0
  70. package/dist/nbui/nbui-card-paragraphs-lg.js +8 -0
  71. package/dist/nbui/nbui-card-paragraphs-lg.js.map +1 -0
  72. package/dist/nbui/nbui-card-paragraphs.d.ts +3 -0
  73. package/dist/nbui/nbui-card-paragraphs.js +8 -0
  74. package/dist/nbui/nbui-card-paragraphs.js.map +1 -0
  75. package/dist/nbui/nbui-card-sm.d.ts +3 -0
  76. package/dist/nbui/nbui-card-sm.js +8 -0
  77. package/dist/nbui/nbui-card-sm.js.map +1 -0
  78. package/dist/nbui/nbui-card-table.d.ts +3 -0
  79. package/dist/nbui/nbui-card-table.js +8 -0
  80. package/dist/nbui/nbui-card-table.js.map +1 -0
  81. package/dist/nbui/nbui-card.js +1 -1
  82. package/dist/nbui/nbui-footer.d.ts +3 -0
  83. package/dist/nbui/nbui-footer.js +8 -0
  84. package/dist/nbui/nbui-footer.js.map +1 -0
  85. package/dist/nbui/nbui-side-panel-container.d.ts +24 -0
  86. package/dist/nbui/nbui-side-panel-container.js +9 -0
  87. package/dist/nbui/nbui-side-panel-container.js.map +1 -0
  88. package/dist/pagination/pagination.js +1 -1
  89. package/dist/product-picker/product-listing.js +1 -1
  90. package/dist/product-picker/product-modal.css +1 -1
  91. package/dist/product-picker/product-modal.css.map +1 -1
  92. package/dist/product-picker/product-modal.js +15 -15
  93. package/dist/search/search.js +1 -1
  94. package/dist/spinner.js +1 -1
  95. package/dist/stacked-list-item.css +1 -1
  96. package/dist/stacked-list-item.css.map +1 -1
  97. package/dist/stacked-list-item.js +15 -15
  98. package/dist/table-result-block.css +1 -1
  99. package/dist/table-result-block.css.map +1 -1
  100. package/dist/table-result-block.js +15 -15
  101. package/package.json +1 -1
  102. package/src/alert-banner.tsx +5 -1
  103. package/src/alert.tsx +3 -1
  104. package/src/button-group-item.tsx +4 -2
  105. package/src/button.tsx +1 -1
  106. package/src/country-picker/country-modal.tsx +2 -2
  107. package/src/drag-and-drop.tsx +1 -1
  108. package/src/drawer.tsx +3 -3
  109. package/src/loading-button.tsx +25 -20
  110. package/src/nbui/nbui-card-form.tsx +35 -0
  111. package/src/nbui/nbui-card-image.tsx +10 -0
  112. package/src/nbui/nbui-card-lg.tsx +16 -0
  113. package/src/nbui/nbui-card-paragraphs-lg.tsx +23 -0
  114. package/src/nbui/nbui-card-paragraphs.tsx +16 -0
  115. package/src/nbui/nbui-card-sm.tsx +12 -0
  116. package/src/nbui/nbui-card-table.tsx +56 -0
  117. package/src/nbui/nbui-card.tsx +1 -2
  118. package/src/nbui/nbui-footer.tsx +8 -0
  119. package/src/nbui/nbui-side-panel-container.tsx +38 -0
  120. package/src/pagination/pagination.tsx +10 -3
  121. package/src/product-picker/product-listing.tsx +4 -4
  122. package/src/product-picker/product-modal.tsx +1 -1
  123. package/src/search/search.tsx +1 -1
  124. package/src/spinner.tsx +1 -1
  125. package/dist/chunk-5VOOMPCL.js +0 -12
  126. package/dist/chunk-5VOOMPCL.js.map +0 -1
  127. package/dist/chunk-EEMQBWYJ.js +0 -11
  128. package/dist/chunk-EEMQBWYJ.js.map +0 -1
  129. package/dist/chunk-ELWZ674J.js.map +0 -1
  130. package/dist/chunk-GGGZRFPY.js +0 -36
  131. package/dist/chunk-GI7QHCYX.js +0 -9
  132. package/dist/chunk-GI7QHCYX.js.map +0 -1
  133. package/dist/chunk-QKHEEDZ4.js +0 -7
  134. package/dist/chunk-QKHEEDZ4.js.map +0 -1
  135. package/dist/chunk-RHBXFO7R.js +0 -9
  136. package/dist/chunk-RHBXFO7R.js.map +0 -1
  137. package/dist/chunk-TOLCGTOY.js +0 -11
  138. package/dist/chunk-TOLCGTOY.js.map +0 -1
  139. package/dist/chunk-X6RBGNFS.js.map +0 -1
  140. /package/dist/{chunk-YOHYKIR3.js.map → chunk-HQIKNKIV.js.map} +0 -0
  141. /package/dist/{chunk-FPELMAZN.js.map → chunk-JNHB4YNM.js.map} +0 -0
@@ -1,14 +1,14 @@
1
- export { e as TableResultBlock } from './chunk-GGGZRFPY.js';
1
+ export { e as TableResultBlock } from './chunk-UQFNA3OB.js';
2
+ import './chunk-52VBZOHL.js';
2
3
  import './chunk-ZHMUFBQM.js';
3
4
  import './chunk-YZ2YZSNQ.js';
4
5
  import './chunk-E62SCYLR.js';
5
- import './chunk-X6RBGNFS.js';
6
6
  import './chunk-7Q6OMA2A.js';
7
- import './chunk-RHBXFO7R.js';
8
- import './chunk-5VOOMPCL.js';
9
- import './chunk-N7JQ6EAC.js';
7
+ import './chunk-KRMPO53Y.js';
8
+ import './chunk-CX2XFI5Q.js';
9
+ import './chunk-R47VIYM2.js';
10
10
  import './chunk-HVNLAQA6.js';
11
- import './chunk-52VBZOHL.js';
11
+ import './chunk-XKE3VK6Z.js';
12
12
  import './chunk-7WJGATIR.js';
13
13
  import './chunk-RTRHNOTP.js';
14
14
  import './chunk-JHGOFDVG.js';
@@ -22,39 +22,39 @@ import './chunk-3NO5IHBO.js';
22
22
  import './chunk-SFEJDNIA.js';
23
23
  import './chunk-E5KIDP3Z.js';
24
24
  import './chunk-TBJGGVSZ.js';
25
- import './chunk-QKHEEDZ4.js';
25
+ import './chunk-AO5TGD7T.js';
26
26
  import './chunk-WVAVR5V6.js';
27
27
  import './chunk-CNJDESTL.js';
28
28
  import './chunk-TXDBBVCI.js';
29
29
  import './chunk-HTXOCBXA.js';
30
- import './chunk-EEMQBWYJ.js';
30
+ import './chunk-CHXMQ7NN.js';
31
31
  import './chunk-ESJIQMQJ.js';
32
32
  import './chunk-IY6WVOAI.js';
33
33
  import './chunk-VGGEDWFD.js';
34
34
  import './chunk-AVTJXS4U.js';
35
- import './chunk-F7AUKLLE.js';
35
+ import './chunk-FOPBXPMP.js';
36
36
  import './chunk-QMOPWIA3.js';
37
37
  import './chunk-SLIZ4TDR.js';
38
- import './chunk-FPELMAZN.js';
38
+ import './chunk-JNHB4YNM.js';
39
39
  import './chunk-WTBH4TDX.js';
40
40
  import './chunk-6YBVKGQW.js';
41
41
  import './chunk-ISA6E23B.js';
42
42
  import './chunk-7Z2AKRKU.js';
43
43
  import './chunk-WSRPB5OU.js';
44
- import './chunk-YOHYKIR3.js';
44
+ import './chunk-HQIKNKIV.js';
45
45
  import './chunk-DSJ5TRZW.js';
46
46
  import './chunk-E4USZ2Q3.js';
47
47
  import './chunk-F47A36U7.js';
48
48
  import './chunk-M4UBHZDH.js';
49
49
  import './chunk-TMO76FWT.js';
50
50
  import './chunk-YDCYBJPC.js';
51
- import './chunk-ELWZ674J.js';
52
- import './chunk-GI7QHCYX.js';
51
+ import './chunk-5SEJVYKM.js';
52
+ import './chunk-MBACKGWE.js';
53
53
  import './chunk-2OPJLYW6.js';
54
54
  import './chunk-P5IM3T4M.js';
55
55
  import './chunk-TRVGXTCI.js';
56
- import './chunk-TOLCGTOY.js';
57
- import './chunk-BLUJNMXF.js';
56
+ import './chunk-XYGVDZRO.js';
57
+ import './chunk-2I24LCEG.js';
58
58
  import './chunk-TJMI4DH2.js';
59
59
  import './chunk-6LHL364H.js';
60
60
  import './chunk-Z4LPO673.js';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ekm-ui",
3
- "version": "0.3.95",
3
+ "version": "0.4.1",
4
4
  "sideEffects": [
5
5
  "**/*.css"
6
6
  ],
@@ -62,6 +62,7 @@ type AlertBannerProps = {
62
62
  showIcon: boolean;
63
63
  onDismiss: () => void;
64
64
  rounded: boolean;
65
+ id:string;
65
66
  };
66
67
 
67
68
  export function AlertBanner({
@@ -70,6 +71,7 @@ export function AlertBanner({
70
71
  showIcon,
71
72
  onDismiss,
72
73
  rounded,
74
+ id,
73
75
  }: AlertBannerProps) {
74
76
  const renderIcon = () => {
75
77
  switch (type) {
@@ -87,7 +89,7 @@ export function AlertBanner({
87
89
  };
88
90
 
89
91
  return (
90
- <div {...alertProps({ type, rounded, size: "md" })} role="alert">
92
+ <div id={id || undefined} {...alertProps({ type, rounded, size: "md" })} role="alert">
91
93
  {showIcon && (
92
94
  <div className="mr-3 mt-1 inline h-4 w-4 flex-shrink-0">
93
95
  {renderIcon()}
@@ -128,6 +130,8 @@ AlertBanner.propTypes = {
128
130
  rounded: PropTypes.bool,
129
131
  /** Components to be rendered as Part of the Compound Component*/
130
132
  children: PropTypes.node.isRequired,
133
+ /** Id for alert banner */
134
+ id: PropTypes.string,
131
135
  };
132
136
 
133
137
  AlertBanner.displayName = "AlertBanner";
package/src/alert.tsx CHANGED
@@ -6,11 +6,13 @@ type Props = {
6
6
  type: "warning" | "info";
7
7
  hasBackground: boolean;
8
8
  centerText: boolean;
9
+ id: string;
9
10
  };
10
11
 
11
- export function Alert({ text, type, hasBackground, centerText }: Props) {
12
+ export function Alert({ text, type, hasBackground, centerText, id }: Props) {
12
13
  return (
13
14
  <div
15
+ id={id || undefined}
14
16
  className={clsx(
15
17
  `flex items-center ${centerText ? "justify-center" : null}`,
16
18
  {
@@ -2,15 +2,17 @@ type Props = {
2
2
  text: string;
3
3
  className: string;
4
4
  active?: boolean;
5
+ id: string;
5
6
  onclick?: () => void;
6
7
  };
7
8
 
8
- export function ButtonGroupItem({ text, className, active, onclick }: Props) {
9
+ export function ButtonGroupItem({ text, className, active, id, onclick }: Props) {
9
10
  return (
10
11
  <button
12
+ id={id || undefined}
11
13
  type="button"
12
14
  onClick={onclick}
13
- className={`"rounded-l-lg dark:focus:ring-blue-500" border border-gray-200 px-4 py-2 text-sm font-medium text-blue-700 hover:bg-gray-100 focus:z-10 focus:text-blue-700 focus:ring-2 focus:ring-blue-700 dark:border-gray-600 dark:bg-gray-700 dark:text-white dark:hover:bg-gray-600 dark:hover:text-white dark:focus:text-white
15
+ className={`dark:focus:ring-blue-500" border border-gray-200 px-4 py-2 text-sm font-medium text-blue-700 hover:bg-gray-100 focus:z-10 focus:text-blue-700 focus:ring-2 focus:ring-blue-700 dark:border-gray-600 dark:bg-gray-700 dark:text-white dark:hover:bg-gray-600 dark:hover:text-white dark:focus:text-white
14
16
  ${className ? className : ""}
15
17
  ${
16
18
  active
package/src/button.tsx CHANGED
@@ -171,7 +171,7 @@ Button.propTypes = {
171
171
  /** Bool to disable button */
172
172
  disabled: PropTypes.bool,
173
173
  /** Bool to outline button */
174
- outlined: PropTypes.bool,
174
+ outline: PropTypes.bool,
175
175
  /** element for addon on button */
176
176
  addon: PropTypes.element,
177
177
  /** element for icon on button */
@@ -222,9 +222,9 @@ const NoResultsView =({title, msg, blockHeight="h-[500px]", showSpinner = false}
222
222
  }
223
223
 
224
224
  CountryPicker.propTypes = {
225
- /** Boolean to indicate that the load of the country data this is passed to this component has been completed */
225
+ /** Boolean to indicate that the load of the country data that is passed to this component has been completed */
226
226
  initialLoadComplete: PropTypes.bool.isRequired,
227
- /** Array of all the country data in the form { Id: 383, CountryCode 'CN': Country: 'China'} */
227
+ /** Array of all the country data in the form { ID: 383, CountryCode 'CN': Country: 'China'} */
228
228
  allCountryData: PropTypes.array.isRequired,
229
229
  /** Array of preselected countries in the form { Id: 383, CountryCode 'CN': Country: 'China'} */
230
230
  preSelected: PropTypes.array.isRequired,
@@ -108,7 +108,7 @@ export function DragAndDrop({
108
108
  </p>
109
109
  <p className="text-xs text-gray-500 dark:text-gray-400">{subtitle}</p>
110
110
  {pickerCallback && (
111
- <div className="mt-5">
111
+ <div className="mt-3 mb-3">
112
112
  <Button color="default" onClick={handleLaunchFilePicker}>
113
113
  <BiSearch className="mr-2" />
114
114
  Browse File Manager
package/src/drawer.tsx CHANGED
@@ -55,7 +55,7 @@ export function Drawer({ show, onClose, children, title }: Props) {
55
55
  <div className="absolute w-full bg-white">
56
56
  <h5
57
57
  id="drawer-js-label"
58
- className="inline-flex w-full items-center border-b-2 p-4 text-lg font-semibold text-gray-900 dark:border-gray-900 dark:bg-gray-900 dark:text-white"
58
+ className="inline-flex w-full items-center border-b-2 p-4 text-lg font-semibold text-gray-900 dark:border-gray-900 dark:bg-gray-900 dark:text-white"
59
59
  >
60
60
  {title}
61
61
  </h5>
@@ -64,13 +64,13 @@ export function Drawer({ show, onClose, children, title }: Props) {
64
64
  id="drawer-hide-button"
65
65
  type="button"
66
66
  aria-controls="drawer-example"
67
- className="absolute right-2.5 top-2.5 inline-flex items-center rounded-lg bg-transparent p-1.5 text-sm text-gray-400 hover:bg-gray-200 hover:text-gray-900 dark:hover:bg-gray-600 dark:hover:text-white"
67
+ className="absolute right-2.5 top-2.5 inline-flex items-center rounded-lg bg-transparent p-2 text-sm text-gray-400 hover:bg-gray-200 hover:text-gray-900 dark:hover:bg-gray-600 dark:hover:text-white"
68
68
  >
69
69
  <HiXMark className="h-auto w-6" />
70
70
  <span className="sr-only">Close menu</span>
71
71
  </button>
72
72
  </div>
73
- <div className="flex h-full flex-col p-4 pt-20">{children}</div>
73
+ <div className="flex h-full flex-col pt-20 pb-4 pl-4 pr-4 mt-4">{children}</div>
74
74
  </div>
75
75
  );
76
76
  }
@@ -3,24 +3,36 @@ import PropTypes from "prop-types";
3
3
 
4
4
  const buttonColors = Object.freeze({
5
5
  success:
6
- " text-white bg-green-700 border border-transparent enabled:hover:bg-green-800 focus:ring-green-300 dark:bg-green-600 dark:enabled:hover:bg-green-700 dark:focus:ring-green-800 rounded-lg focus:ring-2",
6
+ {
7
+ buttonStyle: " text-white bg-green-700 border border-transparent enabled:hover:bg-green-800 focus:ring-green-300 dark:bg-green-600 dark:enabled:hover:bg-green-700 dark:focus:ring-green-800 rounded-lg focus:ring-2",
8
+ spinnerStyle: "text-white",
9
+ },
7
10
  danger:
8
- " text-white bg-red-700 border border-transparent enabled:hover:bg-red-800 focus:ring-red-300 dark:bg-red-600 dark:enabled:hover:bg-red-700 dark:focus:ring-red-900 rounded-lg focus:ring-2",
9
- });
10
-
11
- const disabledButtonColors = Object.freeze({
12
- success:
13
- " cursor-not-allowed opacity-50 text-white bg-green-700 border border-transparent enabled:hover:bg-green-800 focus:ring-green-300 dark:bg-green-600 dark:enabled:hover:bg-green-700 dark:focus:ring-green-800 rounded-lg focus:ring-2",
14
- danger:
15
- " cursor-not-allowed opacity-50 text-white bg-red-700 border border-transparent enabled:hover:bg-red-800 focus:ring-red-300 dark:bg-red-600 dark:enabled:hover:bg-red-700 dark:focus:ring-red-900 rounded-lg focus:ring-2",
11
+ {
12
+ buttonStyle: " text-white bg-red-700 border border-transparent enabled:hover:bg-red-800 focus:ring-red-300 dark:bg-red-600 dark:enabled:hover:bg-red-700 dark:focus:ring-red-900 rounded-lg focus:ring-2",
13
+ spinnerStyle: "text-white",
14
+ },
15
+ successOutline:
16
+ {
17
+ buttonStyle: " text-green-700 border border-green-700 enabled:hover:text-white enabled:hover:bg-green-800 focus:ring-green-300 dark:bg-green-600 dark:enabled:hover:bg-green-700 dark:focus:ring-green-800 rounded-lg focus:ring-2",
18
+ spinnerStyle: "text-green-700",
19
+ },
20
+ dangerOutline:
21
+ {
22
+ buttonStyle: " text-red-700 border border-red-700 enabled:hover:text-white enabled:hover:bg-red-800 focus:ring-red-300 dark:bg-red-600 dark:enabled:hover:bg-red-500 dark:focus:ring-red-900 rounded-lg focus:ring-2",
23
+ spinnerStyle: "text-red-700",
24
+ },
16
25
  });
17
26
 
18
27
  export function LoadingButton({ children, isLoading = false, ...props }) {
28
+
29
+ const style = props.color ? buttonColors[props.color]: buttonColors.success
30
+
19
31
  const renderLoader = () => (
20
32
  <svg
21
33
  aria-hidden="true"
22
34
  role="status"
23
- className="mr-3 inline h-4 w-4 animate-spin text-white"
35
+ className={`mr-3 inline h-4 w-4 animate-spin ${style.spinnerStyle}`}
24
36
  viewBox="0 0 100 101"
25
37
  fill="none"
26
38
  xmlns="http://www.w3.org/2000/svg"
@@ -39,16 +51,9 @@ export function LoadingButton({ children, isLoading = false, ...props }) {
39
51
  return (
40
52
  <button
41
53
  className={`group relative flex items-center justify-center p-0.5 text-center font-medium focus:z-10 focus:outline-none
42
- ${
43
- props.color
44
- ? isLoading
45
- ? disabledButtonColors[props.color]
46
- : buttonColors[props.color]
47
- : isLoading
48
- ? disabledButtonColors.success
49
- : buttonColors.success
50
- }
51
- `}
54
+ ${style.buttonStyle}
55
+ ${isLoading ? ' cursor-not-allowed opacity': ''}
56
+ `}
52
57
  {...props}
53
58
  disabled={isLoading}
54
59
  >
@@ -0,0 +1,35 @@
1
+ export function NBUI_Card_Form() {
2
+ return (
3
+ <div className="flex flex-col rounded-lg border border-gray-200 bg-white px-5 py-4 shadow-sm dark:border-gray-700 dark:bg-gray-800">
4
+ <div className="flex h-full flex-col justify-center gap-4">
5
+ <div className="w-1/4 h-6 bg-gray-400 rounded-md" />
6
+ <div className="w-2/4 h-4 bg-gray-400 rounded-md" />
7
+ <div className="flex gap-2">
8
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
9
+ <div className="mt-4 w-2/4 h-6 bg-gray-200 rounded-md" />
10
+ </div>
11
+ <div className="flex gap-2">
12
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
13
+ <div className="mt-4 w-2/4 h-6 bg-gray-200 rounded-md" />
14
+ </div>
15
+ <div className="flex gap-2">
16
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
17
+ <div className="mt-4 w-2/4 h-6 bg-gray-200 rounded-md" />
18
+ </div>
19
+ <div className="w-2/4 h-4 bg-gray-400 rounded-md" />
20
+ <div className="flex gap-2">
21
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
22
+ <div className="mt-4 w-2/4 h-6 bg-gray-200 rounded-md" />
23
+ </div>
24
+ <div className="flex gap-2">
25
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
26
+ <div className="mt-4 w-2/4 h-6 bg-gray-200 rounded-md" />
27
+ </div>
28
+ <div className="flex gap-2">
29
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
30
+ <div className="mt-4 w-2/4 h-6 bg-gray-200 rounded-md" />
31
+ </div>
32
+ </div>
33
+ </div>
34
+ )
35
+ }
@@ -0,0 +1,10 @@
1
+ export function NBUI_Card_Image() {
2
+ <div className="flex flex-col rounded-lg border border-gray-200 bg-white px-5 py-4 shadow-sm dark:border-gray-700 dark:bg-gray-800">
3
+ <div className="flex h-full flex-col justify-center gap-4">
4
+ <div className="w-2/4 h-6 bg-gray-400 rounded-md" />
5
+ <div className="flex items-center">
6
+ <div className="mt-2 w-60 h-40 bg-gray-200 rounded-md" />
7
+ </div>
8
+ </div>
9
+ </div>
10
+ }
@@ -0,0 +1,16 @@
1
+ export function NBUI_Card_Lg() {
2
+ return (
3
+ <div className="flex flex-col rounded-lg border border-gray-200 bg-white px-5 py-4 shadow-sm dark:border-gray-700 dark:bg-gray-800">
4
+ <div className="flex h-full flex-col justify-center gap-4">
5
+ <div className="w-1/4 h-6 bg-gray-400 rounded-md" />
6
+ <div className="w-2/4 h-4 bg-gray-400 rounded-md" />
7
+ <div className="mt-2 w-2/4 h-4 bg-gray-200 rounded-md" />
8
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
9
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
10
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
11
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
12
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
13
+ </div>
14
+ </div>
15
+ )
16
+ }
@@ -0,0 +1,23 @@
1
+ export function NBUI_Card_Paragraphs_Lg() {
2
+ return (
3
+ <div className="flex flex-col rounded-lg border border-gray-200 bg-white px-5 py-4 shadow-sm dark:border-gray-700 dark:bg-gray-800">
4
+ <div className="flex h-full flex-col justify-center gap-4">
5
+ <div className="w-1/4 h-6 bg-gray-400 rounded-md" />
6
+ <div className="w-2/4 h-4 bg-gray-400 rounded-md" />
7
+ <div className="mt-2 w-2/4 h-4 bg-gray-200 rounded-md" />
8
+ <div className="mt-1 w-2/4 h-4 bg-gray-200 rounded-md" />
9
+ <div className="mt-1 w-2/4 h-4 bg-gray-200 rounded-md" />
10
+ <div className="mt-1 w-2/4 h-4 bg-gray-200 rounded-md" />
11
+ <div className="mt-1 w-2/4 h-4 bg-gray-200 rounded-md" />
12
+ <div className="mt-1 w-2/4 h-4 bg-gray-200 rounded-md" />
13
+ <div className="w-2/4 h-4 bg-gray-400 rounded-md" />
14
+ <div className="mt-1 w-2/4 h-4 bg-gray-200 rounded-md" />
15
+ <div className="mt-1 w-2/4 h-4 bg-gray-200 rounded-md" />
16
+ <div className="mt-1 w-2/4 h-4 bg-gray-200 rounded-md" />
17
+ <div className="mt-1 w-2/4 h-4 bg-gray-200 rounded-md" />
18
+ <div className="mt-1 w-2/4 h-4 bg-gray-200 rounded-md" />
19
+ <div className="mt-1 w-2/4 h-4 bg-gray-200 rounded-md" />
20
+ </div>
21
+ </div>
22
+ )
23
+ }
@@ -0,0 +1,16 @@
1
+ export function NBUI_Card_Paragraphs() {
2
+ return (
3
+ <div className="flex flex-col rounded-lg border border-gray-200 bg-white px-5 py-4 shadow-sm dark:border-gray-700 dark:bg-gray-800">
4
+ <div className="flex h-full flex-col justify-center gap-4">
5
+ <div className="w-1/4 h-6 bg-gray-400 rounded-md" />
6
+ <div className="w-2/4 h-4 bg-gray-400 rounded-md" />
7
+ <div className="mt-2 w-2/4 h-4 bg-gray-200 rounded-md" />
8
+ <div className="mt-1 w-3/4 h-4 bg-gray-200 rounded-md" />
9
+ <div className="mt-1 w-2/4 h-4 bg-gray-200 rounded-md" />
10
+ <div className="mt-1 w-3/4 h-4 bg-gray-200 rounded-md" />
11
+ <div className="mt-1 w-2/4 h-4 bg-gray-200 rounded-md" />
12
+ <div className="mt-1 w-3/4 h-4 bg-gray-200 rounded-md" />
13
+ </div>
14
+ </div>
15
+ )
16
+ }
@@ -0,0 +1,12 @@
1
+ export function NBUI_Card_Sm() {
2
+ return (
3
+ <div className="flex flex-col rounded-lg border border-gray-200 bg-white px-5 py-4 shadow-sm dark:border-gray-700 dark:bg-gray-800">
4
+ <div className="flex h-full flex-col justify-center gap-4">
5
+ <div className="w-1/4 h-6 bg-gray-400 rounded-md" />
6
+ <div className="w-2/4 h-4 bg-gray-400 rounded-md" />
7
+ <div className="mt-2 w-2/4 h-4 bg-gray-200 rounded-md" />
8
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
9
+ </div>
10
+ </div>
11
+ )
12
+ }
@@ -0,0 +1,56 @@
1
+ export function NBUI_Card_Table() {
2
+ return (
3
+ <div className="flex flex-col rounded-lg border border-gray-200 bg-white px-5 py-4 shadow-sm dark:border-gray-700 dark:bg-gray-800">
4
+ <div className="flex h-full flex-col justify-center gap-4">
5
+ <div className="w-1/4 h-6 bg-gray-400 rounded-md" />
6
+ <div className="flex gap-2">
7
+ <div className="mt-4 w-1/3 h-6 bg-gray-200 rounded-md" />
8
+ <div className="mt-4 w-40 h-6 bg-gray-300 rounded-md" />
9
+ <div className="mt-4 w-40 h-6 bg-gray-300 rounded-md" />
10
+ </div>
11
+ <div className="flex gap-2">
12
+ <div className="mt-4 w-1/4 h-6 bg-gray-300 rounded-md" />
13
+ <div className="mt-4 w-2/4 h-6 bg-gray-300 rounded-md" />
14
+ <div className="mt-4 w-2/4 h-6 bg-gray-300 rounded-md" />
15
+ <div className="mt-4 w-2/4 h-6 bg-gray-300 rounded-md" />
16
+ </div>
17
+ <div className="flex gap-2">
18
+ <div className="mt-4 w-1/4 h-4 bg-gray-200 rounded-md" />
19
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
20
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
21
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
22
+ </div>
23
+ <div className="flex gap-2">
24
+ <div className="mt-4 w-1/4 h-4 bg-gray-200 rounded-md" />
25
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
26
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
27
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
28
+ </div>
29
+ <div className="flex gap-2">
30
+ <div className="mt-4 w-1/4 h-4 bg-gray-200 rounded-md" />
31
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
32
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
33
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
34
+ </div>
35
+ <div className="flex gap-2">
36
+ <div className="mt-4 w-1/4 h-4 bg-gray-200 rounded-md" />
37
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
38
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
39
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
40
+ </div>
41
+ <div className="flex gap-2">
42
+ <div className="mt-4 w-1/4 h-4 bg-gray-200 rounded-md" />
43
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
44
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
45
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
46
+ </div>
47
+ <div className="flex gap-2">
48
+ <div className="mt-4 w-1/4 h-4 bg-gray-200 rounded-md" />
49
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
50
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
51
+ <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
52
+ </div>
53
+ </div>
54
+ </div>
55
+ )
56
+ }
@@ -3,12 +3,11 @@ export function NBUI_Card() {
3
3
  <div className="flex flex-col rounded-lg border border-gray-200 bg-white px-5 py-4 shadow-sm dark:border-gray-700 dark:bg-gray-800">
4
4
  <div className="flex h-full flex-col justify-center gap-4">
5
5
  <div className="w-1/4 h-6 bg-gray-400 rounded-md" />
6
+ <div className="w-2/4 h-4 bg-gray-400 rounded-md" />
6
7
  <div className="mt-2 w-2/4 h-4 bg-gray-200 rounded-md" />
7
8
  <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
8
9
  <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
9
10
  <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
10
- <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
11
- <div className="mt-4 w-2/4 h-4 bg-gray-200 rounded-md" />
12
11
  </div>
13
12
  </div>
14
13
  )
@@ -0,0 +1,8 @@
1
+ export function NBUI_Footer() {
2
+ return (
3
+ <div className="flex justify-between gap-2">
4
+ <div className="mt-2 w-40 h-8 bg-gray-200 rounded-md" />
5
+ <div className="mt-2 w-40 h-8 bg-green-700 rounded-md" />
6
+ </div>
7
+ )
8
+ }
@@ -0,0 +1,38 @@
1
+ import PropTypes from 'prop-types';
2
+
3
+ export function NBUI_Page_Layout({ children }: { children: React.ReactElement }) {
4
+ return (
5
+ <div className="px-4">
6
+ <div className="mb-4 md:flex gap-4">
7
+ {children}
8
+ </div>
9
+ </div>
10
+ );
11
+ }
12
+
13
+ export function NBUI_Page_Layout_Side_Panel({ children }: { children: React.ReactElement }) {
14
+ return (
15
+ <aside className="flex w-full md:max-w-[320px] shrink-0 flex-col gap-4">
16
+ {children}
17
+ </aside>
18
+ );
19
+ }
20
+
21
+ export function NBUI_Side_Panel_Main({ children }: { children: React.ReactElement }) {
22
+ return (
23
+ <div className="flex flex-grow flex-col gap-4 mb-4 md:mb-0">
24
+ {children}
25
+ </div>
26
+ );
27
+ }
28
+
29
+ NBUI_Page_Layout.Side_Panel = NBUI_Page_Layout_Side_Panel;
30
+ NBUI_Page_Layout.Main = NBUI_Side_Panel_Main;
31
+
32
+ NBUI_Page_Layout.propTypes = {
33
+ children: PropTypes.oneOfType([
34
+ PropTypes.shape({ type: PropTypes.oneOf([NBUI_Page_Layout_Side_Panel]) }),
35
+ PropTypes.shape({ type: PropTypes.oneOf([NBUI_Side_Panel_Main]) }),
36
+ ]).isRequired,
37
+ };
38
+
@@ -44,7 +44,7 @@ export function Pagination({
44
44
  }
45
45
 
46
46
  return (
47
- <div className="w-full">
47
+ <div id="paginationControl" className="w-full">
48
48
  <div className="relative overflow-hidden rounded-b-lg bg-white dark:bg-gray-800">
49
49
  <nav
50
50
  className=" flex flex-wrap items-start justify-between gap-x-4 gap-y-2 md:items-center"
@@ -52,6 +52,7 @@ export function Pagination({
52
52
  >
53
53
  <div className="flex w-full justify-between md:hidden">
54
54
  <button
55
+ id="btnPreviousM"
55
56
  disabled={current === 1}
56
57
  className={clsx(
57
58
  current === 1 && "cursor-not-allowed",
@@ -76,6 +77,7 @@ export function Pagination({
76
77
  </button>
77
78
 
78
79
  <button
80
+ id="btnNextM"
79
81
  disabled={current === totalPages}
80
82
  className={clsx(
81
83
  current === totalPages && "cursor-not-allowed",
@@ -99,7 +101,7 @@ export function Pagination({
99
101
  </svg>
100
102
  </button>
101
103
  </div>
102
- <div className="hidden items-center space-x-3 md:flex">
104
+ <div id="rowsPerPageSection" className="hidden items-center space-x-3 md:flex">
103
105
  <label
104
106
  htmlFor="rows"
105
107
  className="text-sm font-normal text-gray-500 dark:text-gray-400"
@@ -134,6 +136,7 @@ export function Pagination({
134
136
  <ul className="hidden items-stretch -space-x-px md:inline-flex">
135
137
  <li>
136
138
  <button
139
+ id="btnPrevious"
137
140
  disabled={current === 1}
138
141
  className={clsx(
139
142
  current === 1 && "cursor-not-allowed",
@@ -161,6 +164,7 @@ export function Pagination({
161
164
  <>
162
165
  <li>
163
166
  <button
167
+ id="btnLast"
164
168
  className={clsx(
165
169
  current === 1 && "cursor-not-allowed",
166
170
  "flex items-center justify-center border border-gray-300 bg-white px-3 py-2 text-sm leading-tight text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white"
@@ -178,11 +182,12 @@ export function Pagination({
178
182
  {pages.map((page) => (
179
183
  <li key={page}>
180
184
  <button
185
+ id={`btnPage${page}`}
181
186
  onClick={() => onChange(page, pageSize)}
182
187
  className={clsx(
183
188
  "flex items-center justify-center border px-3 py-2 text-sm leading-tight",
184
189
  page === current
185
- ? "z-10 border-primary-300 bg-primary-50 text-primary-600 hover:bg-primary-100 hover:text-primary-700 dark:border-gray-700 dark:bg-gray-700 dark:text-white"
190
+ ? "z-10 border-primary-300 bg-primary-50 text-primary-600 hover:bg-primary-100 hover:text-primary-700 dark:border-gray-700 dark:bg-gray-700 dark:text-white st-pageCurrent"
186
191
  : "border-gray-300 bg-white text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white"
187
192
  )}
188
193
  >
@@ -197,6 +202,7 @@ export function Pagination({
197
202
  </li>
198
203
  <li>
199
204
  <button
205
+ id="btnLast"
200
206
  className="flex items-center justify-center border border-gray-300 bg-white px-3 py-2 text-sm leading-tight text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white"
201
207
  onClick={() => onChange(totalPages, pageSize)}
202
208
  >
@@ -207,6 +213,7 @@ export function Pagination({
207
213
  )}
208
214
  <li>
209
215
  <button
216
+ id="btnNext"
210
217
  disabled={current === totalPages}
211
218
  onClick={() => onChange(current + 1, pageSize)}
212
219
  className={clsx(
@@ -6,7 +6,7 @@ import { Checkbox } from "../checkbox";
6
6
  // FOR USE WITH THE PRODUCT PICKER COMPONENT - ONLY
7
7
 
8
8
  function BuildImageUrl(imageUrl) {
9
- return `${window.resourceSettings.imageBasePath}${imageUrl}?v=${window.resourceSettings.version}`;
9
+ return `${window.resourceSettings?.imageBasePath || ''}${imageUrl}?v=${window.resourceSettings?.version || ''}`;
10
10
  }
11
11
 
12
12
  export function Listing({
@@ -90,7 +90,7 @@ function ProductRow({ product, selected, callback }) {
90
90
  />
91
91
  </div>
92
92
  <div className="ml-4">
93
- {product.Image && product.IamgeName !== "[URL-DownloadRequested]" ? (
93
+ {product.Image && product.ImageName !== "[URL-DownloadRequested]" ? (
94
94
  <img
95
95
  className="h-10 w-10 rounded-sm"
96
96
  src={product.Image}
@@ -123,9 +123,9 @@ function ProductRow({ product, selected, callback }) {
123
123
  </div>
124
124
  <div className="ml-4 flex-shrink-0">
125
125
  <span className="mr-3 text-sm text-gray-500">{`${
126
- globalThis.globalSettings.CurrencySymbol
126
+ globalThis.globalSettings?.CurrencySymbol ?? '£'
127
127
  }${product.Price.toFixed(
128
- globalThis.globalSettings.CurrencyExponent ?? 2
128
+ globalThis.globalSettings?.CurrencyExponent ?? 2
129
129
  )}`}</span>
130
130
  </div>
131
131
  </div>
@@ -324,7 +324,7 @@ ProductPicker.propTypes = {
324
324
  productCodeEnabled: PropTypes.bool,
325
325
  /** Callback to request a refresh of the displayed products */
326
326
  requestCallback: PropTypes.func.isRequired,
327
- /** Callback to return the selected products {orig - preselected, add - newly added, remove -items removed from pre-selected} */
327
+ /** Callback to return the selected products ids in an array */
328
328
  callback: PropTypes.func.isRequired,
329
329
  };
330
330