@solidstarters/solid-core-ui 1.1.44 → 1.1.46

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 (80) hide show
  1. package/dist/components/common/SolidModuleHome.d.ts +1 -5
  2. package/dist/components/common/SolidModuleHome.d.ts.map +1 -1
  3. package/dist/components/common/SolidModuleHome.js +2 -8
  4. package/dist/components/common/SolidModuleHome.js.map +1 -1
  5. package/dist/components/common/SolidThemeProvider.d.ts +2 -0
  6. package/dist/components/common/SolidThemeProvider.d.ts.map +1 -0
  7. package/dist/components/common/SolidThemeProvider.js +38 -0
  8. package/dist/components/common/SolidThemeProvider.js.map +1 -0
  9. package/dist/components/core/kanban/KanbanBoard.d.ts.map +1 -1
  10. package/dist/components/core/kanban/KanbanBoard.js +11 -11
  11. package/dist/components/core/kanban/KanbanBoard.js.map +1 -1
  12. package/dist/components/core/kanban/KanbanCard.d.ts.map +1 -1
  13. package/dist/components/core/kanban/KanbanCard.js +33 -7
  14. package/dist/components/core/kanban/KanbanCard.js.map +1 -1
  15. package/dist/components/core/kanban/KanbanColumn.d.ts.map +1 -1
  16. package/dist/components/core/kanban/KanbanColumn.js +4 -3
  17. package/dist/components/core/kanban/KanbanColumn.js.map +1 -1
  18. package/dist/components/core/kanban/SolidKanbanView.d.ts.map +1 -1
  19. package/dist/components/core/kanban/SolidKanbanView.js +34 -33
  20. package/dist/components/core/kanban/SolidKanbanView.js.map +1 -1
  21. package/dist/components/core/kanban/kanban-fields/SolidBooleanKanbanField.js +1 -1
  22. package/dist/components/core/kanban/kanban-fields/SolidBooleanKanbanField.js.map +1 -1
  23. package/dist/components/core/kanban/kanban-fields/SolidDateKanbanField.js +1 -1
  24. package/dist/components/core/kanban/kanban-fields/SolidDateKanbanField.js.map +1 -1
  25. package/dist/components/core/kanban/kanban-fields/SolidDatetimeKanbanField.js +1 -1
  26. package/dist/components/core/kanban/kanban-fields/SolidDatetimeKanbanField.js.map +1 -1
  27. package/dist/components/core/kanban/kanban-fields/SolidExternalIdKanbanField.js +1 -1
  28. package/dist/components/core/kanban/kanban-fields/SolidExternalIdKanbanField.js.map +1 -1
  29. package/dist/components/core/kanban/kanban-fields/SolidIdKanbanField.js +1 -1
  30. package/dist/components/core/kanban/kanban-fields/SolidIdKanbanField.js.map +1 -1
  31. package/dist/components/core/kanban/kanban-fields/SolidIntKanbanField.js +1 -1
  32. package/dist/components/core/kanban/kanban-fields/SolidIntKanbanField.js.map +1 -1
  33. package/dist/components/core/kanban/kanban-fields/SolidMediaMultipleKanbanField.d.ts.map +1 -1
  34. package/dist/components/core/kanban/kanban-fields/SolidMediaMultipleKanbanField.js +39 -15
  35. package/dist/components/core/kanban/kanban-fields/SolidMediaMultipleKanbanField.js.map +1 -1
  36. package/dist/components/core/kanban/kanban-fields/SolidMediaSingleKanbanField.d.ts.map +1 -1
  37. package/dist/components/core/kanban/kanban-fields/SolidMediaSingleKanbanField.js +17 -7
  38. package/dist/components/core/kanban/kanban-fields/SolidMediaSingleKanbanField.js.map +1 -1
  39. package/dist/components/core/kanban/kanban-fields/SolidSelectionDynamicKanbanField.js +1 -1
  40. package/dist/components/core/kanban/kanban-fields/SolidSelectionDynamicKanbanField.js.map +1 -1
  41. package/dist/components/core/kanban/kanban-fields/SolidSelectionStaticKanbanField.js +1 -1
  42. package/dist/components/core/kanban/kanban-fields/SolidSelectionStaticKanbanField.js.map +1 -1
  43. package/dist/components/core/kanban/kanban-fields/SolidShortTextKanbanField.d.ts.map +1 -1
  44. package/dist/components/core/kanban/kanban-fields/SolidShortTextKanbanField.js +8 -8
  45. package/dist/components/core/kanban/kanban-fields/SolidShortTextKanbanField.js.map +1 -1
  46. package/dist/components/core/kanban/kanban-fields/SolidTimeKanbanField.js +1 -1
  47. package/dist/components/core/kanban/kanban-fields/SolidTimeKanbanField.js.map +1 -1
  48. package/dist/components/core/list/SolidListViewConfigure.js +1 -1
  49. package/dist/components/core/list/SolidListViewConfigure.js.map +1 -1
  50. package/dist/components/core/list/columns/SolidMediaSingleColumn.d.ts.map +1 -1
  51. package/dist/components/core/list/columns/SolidMediaSingleColumn.js +20 -19
  52. package/dist/components/core/list/columns/SolidMediaSingleColumn.js.map +1 -1
  53. package/dist/components/core/model/FieldMetaDataForm.d.ts.map +1 -1
  54. package/dist/components/core/model/FieldMetaDataForm.js +3 -0
  55. package/dist/components/core/model/FieldMetaDataForm.js.map +1 -1
  56. package/dist/resources/globals.css +71 -22
  57. package/package.json +1 -1
  58. package/publish.js +3 -0
  59. package/src/components/common/SolidModuleHome.tsx +52 -59
  60. package/src/components/common/SolidThemeProvider.tsx +44 -0
  61. package/src/components/core/kanban/KanbanBoard.tsx +36 -34
  62. package/src/components/core/kanban/KanbanCard.tsx +37 -24
  63. package/src/components/core/kanban/KanbanColumn.tsx +10 -5
  64. package/src/components/core/kanban/SolidKanbanView.tsx +30 -42
  65. package/src/components/core/kanban/kanban-fields/SolidBooleanKanbanField.tsx +1 -1
  66. package/src/components/core/kanban/kanban-fields/SolidDateKanbanField.tsx +1 -1
  67. package/src/components/core/kanban/kanban-fields/SolidDatetimeKanbanField.tsx +1 -1
  68. package/src/components/core/kanban/kanban-fields/SolidExternalIdKanbanField.tsx +1 -1
  69. package/src/components/core/kanban/kanban-fields/SolidIdKanbanField.tsx +1 -1
  70. package/src/components/core/kanban/kanban-fields/SolidIntKanbanField.tsx +1 -1
  71. package/src/components/core/kanban/kanban-fields/SolidMediaMultipleKanbanField.tsx +106 -38
  72. package/src/components/core/kanban/kanban-fields/SolidMediaSingleKanbanField.tsx +61 -16
  73. package/src/components/core/kanban/kanban-fields/SolidSelectionDynamicKanbanField.tsx +1 -1
  74. package/src/components/core/kanban/kanban-fields/SolidSelectionStaticKanbanField.tsx +1 -1
  75. package/src/components/core/kanban/kanban-fields/SolidShortTextKanbanField.tsx +14 -13
  76. package/src/components/core/kanban/kanban-fields/SolidTimeKanbanField.tsx +1 -1
  77. package/src/components/core/list/SolidListViewConfigure.tsx +1 -1
  78. package/src/components/core/list/columns/SolidMediaSingleColumn.tsx +43 -33
  79. package/src/components/core/model/FieldMetaDataForm.tsx +5 -0
  80. package/src/resources/globals.css +71 -22
@@ -16,28 +16,48 @@ const SolidMediaSingleKanbanField = ({ solidKanbanViewMetaData, fieldMetadata, f
16
16
  const header = fieldMetadata.displayName;
17
17
  const url = data && data._media && data._media[fieldMetadata.name].length > 0 && data._media[fieldMetadata.name].map((i: any) => i._full_url)[0];
18
18
  const mimeType = data && data._media && data._media[fieldMetadata.name].length > 0 && data._media[fieldMetadata.name].map((i: any) => i.mimeType)[0];
19
+ const fileName = data && data._media && data._media[fieldMetadata.name][0]?.originalFileName
19
20
  // const mimeType: string = "excel";
20
21
  // const url = "http://localhost:8080/media-files-storage/Holiday List 2025.pdf";
21
22
  // const url = "http://localhost:8080/media-files-storage/PF Form.xls";
22
-
23
-
23
+
24
+
24
25
 
25
26
  return (
26
27
  <>
27
28
  {mimeType && mimeType.includes("image/") &&
28
- <img className='image-preview'
29
- src={url}
30
- onClick={(event) => {
31
- event.stopPropagation();
32
- setLightboxUrls([{ src: url }]);
33
- setOpenLightbox(true);
34
- }}
35
- alt={header} />}
36
-
29
+ <div className='my-2'>
30
+ <img className='kanban-image-preview'
31
+ src={url}
32
+ onClick={(event) => {
33
+ event.stopPropagation();
34
+ setLightboxUrls([{ src: url }]);
35
+ setOpenLightbox(true);
36
+ }}
37
+ alt={header}
38
+ />
39
+ <p className="text-sm" style={{ wordWrap: 'break-word', overflowWrap: 'break-word' }}
40
+ onClick={(event) => {
41
+ event.stopPropagation();
42
+ setLightboxUrls([{ src: url }]);
43
+ setOpenLightbox(true);
44
+ }}
45
+ >
46
+ {fileName}
47
+ </p>
48
+ </div>
49
+ }
37
50
  {/* Render PDF - Open Lightbox on Click */}
38
51
  {mimeType && mimeType.includes("pdf") && (
39
52
  <>
40
- <i className="pi pi-file-pdf" style={{ fontSize: "24px", color: "red", cursor: "pointer" }} onClick={() => setVisible(true)}></i>
53
+ <div className='flex align-items-end gap-2 my-2'>
54
+ <div onClick={() => setVisible(true)} style={{ cursor: 'pointer' }}>
55
+ <svg width="36px" height="36px" viewBox="-4 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg" stroke="#000000" stroke-width="0.0004"><g id="SVGRepo_bgCarrier" stroke-width="0"></g><g id="SVGRepo_tracerCarrier" stroke-linecap="round" stroke-linejoin="round"></g><g id="SVGRepo_iconCarrier"> <path d="M25.6686 26.0962C25.1812 26.2401 24.4656 26.2563 23.6984 26.145C22.875 26.0256 22.0351 25.7739 21.2096 25.403C22.6817 25.1888 23.8237 25.2548 24.8005 25.6009C25.0319 25.6829 25.412 25.9021 25.6686 26.0962ZM17.4552 24.7459C17.3953 24.7622 17.3363 24.7776 17.2776 24.7939C16.8815 24.9017 16.4961 25.0069 16.1247 25.1005L15.6239 25.2275C14.6165 25.4824 13.5865 25.7428 12.5692 26.0529C12.9558 25.1206 13.315 24.178 13.6667 23.2564C13.9271 22.5742 14.193 21.8773 14.468 21.1894C14.6075 21.4198 14.7531 21.6503 14.9046 21.8814C15.5948 22.9326 16.4624 23.9045 17.4552 24.7459ZM14.8927 14.2326C14.958 15.383 14.7098 16.4897 14.3457 17.5514C13.8972 16.2386 13.6882 14.7889 14.2489 13.6185C14.3927 13.3185 14.5105 13.1581 14.5869 13.0744C14.7049 13.2566 14.8601 13.6642 14.8927 14.2326ZM9.63347 28.8054C9.38148 29.2562 9.12426 29.6782 8.86063 30.0767C8.22442 31.0355 7.18393 32.0621 6.64941 32.0621C6.59681 32.0621 6.53316 32.0536 6.44015 31.9554C6.38028 31.8926 6.37069 31.8476 6.37359 31.7862C6.39161 31.4337 6.85867 30.8059 7.53527 30.2238C8.14939 29.6957 8.84352 29.2262 9.63347 28.8054ZM27.3706 26.1461C27.2889 24.9719 25.3123 24.2186 25.2928 24.2116C24.5287 23.9407 23.6986 23.8091 22.7552 23.8091C21.7453 23.8091 20.6565 23.9552 19.2582 24.2819C18.014 23.3999 16.9392 22.2957 16.1362 21.0733C15.7816 20.5332 15.4628 19.9941 15.1849 19.4675C15.8633 17.8454 16.4742 16.1013 16.3632 14.1479C16.2737 12.5816 15.5674 11.5295 14.6069 11.5295C13.948 11.5295 13.3807 12.0175 12.9194 12.9813C12.0965 14.6987 12.3128 16.8962 13.562 19.5184C13.1121 20.5751 12.6941 21.6706 12.2895 22.7311C11.7861 24.0498 11.2674 25.4103 10.6828 26.7045C9.04334 27.3532 7.69648 28.1399 6.57402 29.1057C5.8387 29.7373 4.95223 30.7028 4.90163 31.7107C4.87693 32.1854 5.03969 32.6207 5.37044 32.9695C5.72183 33.3398 6.16329 33.5348 6.6487 33.5354C8.25189 33.5354 9.79489 31.3327 10.0876 30.8909C10.6767 30.0029 11.2281 29.0124 11.7684 27.8699C13.1292 27.3781 14.5794 27.011 15.985 26.6562L16.4884 26.5283C16.8668 26.4321 17.2601 26.3257 17.6635 26.2153C18.0904 26.0999 18.5296 25.9802 18.976 25.8665C20.4193 26.7844 21.9714 27.3831 23.4851 27.6028C24.7601 27.7883 25.8924 27.6807 26.6589 27.2811C27.3486 26.9219 27.3866 26.3676 27.3706 26.1461ZM30.4755 36.2428C30.4755 38.3932 28.5802 38.5258 28.1978 38.5301H3.74486C1.60224 38.5301 1.47322 36.6218 1.46913 36.2428L1.46884 3.75642C1.46884 1.6039 3.36763 1.4734 3.74457 1.46908H20.263L20.2718 1.4778V7.92396C20.2718 9.21763 21.0539 11.6669 24.0158 11.6669H30.4203L30.4753 11.7218L30.4755 36.2428ZM28.9572 10.1976H24.0169C21.8749 10.1976 21.7453 8.29969 21.7424 7.92417V2.95307L28.9572 10.1976ZM31.9447 36.2428V11.1157L21.7424 0.871022V0.823357H21.6936L20.8742 0H3.74491C2.44954 0 0 0.785336 0 3.75711V36.2435C0 37.5427 0.782956 40 3.74491 40H28.2001C29.4952 39.9997 31.9447 39.2143 31.9447 36.2428Z" fill="#EB5757"></path> </g></svg>
56
+ </div>
57
+ <p className="text-sm" style={{ maxWidth: '70%', wordWrap: 'break-word', overflowWrap: 'break-word' }} onClick={() => setVisible(true)}>
58
+ {fileName}
59
+ </p>
60
+ </div>
41
61
  <Dialog header="PDF Preview" visible={visible} style={{ width: "" }} onHide={() => setVisible(false)} modal>
42
62
  <Document file={url}>
43
63
  <Page pageNumber={1} />
@@ -47,11 +67,36 @@ const SolidMediaSingleKanbanField = ({ solidKanbanViewMetaData, fieldMetadata, f
47
67
  )}
48
68
  {/* Excel or Other Files - Show Download Icon */}
49
69
  {mimeType && (mimeType.includes("excel") || mimeType.includes("spreadsheet")) && (
50
- <a href={url} download target="_blank" rel="noopener noreferrer">
51
- <i className="pi pi-file-excel">Download</i>
52
- </a>
70
+ <div className='flex align-items-end gap-2 my-2'>
71
+ <a href={url} download target="_blank" rel="noopener noreferrer">
72
+ <svg fill="#45B058" height="36px" width="36px" version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><g id="SVGRepo_bgCarrier" stroke-width="0"></g><g id="SVGRepo_tracerCarrier" stroke-linecap="round" stroke-linejoin="round"></g><g id="SVGRepo_iconCarrier"> <g> <g> <g> <path d="M447.168,134.56c-0.535-1.288-1.318-2.459-2.304-3.445l-128-128c-2.003-1.988-4.709-3.107-7.531-3.115H74.667 C68.776,0,64,4.776,64,10.667v490.667C64,507.224,68.776,512,74.667,512h362.667c5.891,0,10.667-4.776,10.667-10.667V138.667 C447.997,137.256,447.714,135.86,447.168,134.56z M320,36.416L411.584,128H320V36.416z M426.667,490.667H85.333V21.333h213.333 v117.333c0,5.891,4.776,10.667,10.667,10.667h117.333V490.667z"></path> <path d="M128,181.333v256c0,5.891,4.776,10.667,10.667,10.667h234.667c5.891,0,10.667-4.776,10.667-10.667v-256 c0-5.891-4.776-10.667-10.667-10.667H138.667C132.776,170.667,128,175.442,128,181.333z M320,192h42.667v42.667H320V192z M320,256h42.667v42.667H320V256z M320,320h42.667v42.667H320V320z M320,384h42.667v42.667H320V384z M213.333,192h85.333v42.667 h-85.333V192z M213.333,256h85.333v42.667h-85.333V256z M213.333,320h85.333v42.667h-85.333V320z M213.333,384h85.333v42.667 h-85.333V384z M149.333,192H192v42.667h-42.667V192z M149.333,256H192v42.667h-42.667V256z M149.333,320H192v42.667h-42.667V320z M149.333,384H192v42.667h-42.667V384z"></path> </g> </g> </g> </g></svg>
73
+ </a>
74
+ <a href={url} download target="_blank" rel="noopener noreferrer" className='text-color flex align-items-start gap-2' style={{ textDecoration: 'none' }}>
75
+ <p className="text-sm mb-1" style={{ wordWrap: 'break-word', overflowWrap: 'break-word' }}>
76
+ {fileName}
77
+ </p>
78
+ <span className='pi pi-cloud-download'></span>
79
+ </a>
80
+ </div>
53
81
  )}
54
-
82
+ {mimeType &&
83
+ !mimeType.includes("image/") &&
84
+ !mimeType.includes("pdf") &&
85
+ !mimeType.includes("excel") &&
86
+ !mimeType.includes("spreadsheet") && (
87
+ <div className='flex align-items-end gap-2 my-2'>
88
+ <a href={url} download target="_blank" rel="noopener noreferrer">
89
+ <svg width="36px" height="36px" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg" fill="#722ED1" stroke="#722ED1" stroke-width="0.00024000000000000003"><g id="SVGRepo_bgCarrier" stroke-width="0"></g><g id="SVGRepo_tracerCarrier" stroke-linecap="round" stroke-linejoin="round"></g><g id="SVGRepo_iconCarrier"><path d="M3 23h18V6.709L15.29 1H3zM15 2h.2L20 6.8V7h-5zM4 2h10v6h6v14H4z"></path><path fill="none" d="M0 0h24v24H0z"></path></g></svg>
90
+ </a>
91
+ <a href={url} download target="_blank" rel="noopener noreferrer" className='text-color flex align-items-start gap-2' style={{ textDecoration: 'none' }}>
92
+ <p className="text-sm mb-1" style={{ wordWrap: 'break-word', overflowWrap: 'break-word' }}>
93
+ {fileName}
94
+ </p>
95
+ <span className='pi pi-cloud-download'></span>
96
+ </a>
97
+ </div>
98
+ )
99
+ }
55
100
  </>
56
101
  );
57
102
 
@@ -5,7 +5,7 @@ const SolidSelectionDynamicKanbanField = ({ solidKanbanViewMetaData, fieldMetada
5
5
 
6
6
 
7
7
  return (
8
- <p>{data && data[fieldMetadata.name] ? `${data[fieldMetadata.name]}`: ""}</p>
8
+ <p className='m-0'>{data && data[fieldMetadata.name] ? `${data[fieldMetadata.name]}`: ""}</p>
9
9
  );
10
10
 
11
11
  };
@@ -7,7 +7,7 @@ const SolidSelectionStaticKanbanField = ({ solidKanbanViewMetaData, fieldMetadat
7
7
 
8
8
 
9
9
  return (
10
- <p>{data && data[fieldMetadata.name] ? `${data[fieldMetadata.name]}`: ""}</p>
10
+ <p className='m-0'>{data && data[fieldMetadata.name] ? `${data[fieldMetadata.name]}`: ""}</p>
11
11
  );
12
12
  };
13
13
 
@@ -5,23 +5,24 @@ const SolidShortTextKanbanField = ({ solidKanbanViewMetaData, fieldMetadata, fie
5
5
  const renderMode = fieldLayout?.attrs?.renderMode ? fieldLayout?.attrs?.renderMode : "text";
6
6
 
7
7
  return (
8
- <>
8
+ <div>
9
9
  {renderMode === "text" &&
10
- <p>{data && data[fieldMetadata.name] ? `${data[fieldMetadata.name]}` : ""}</p>
10
+ <p className='font-medium'>{data && data[fieldMetadata.name] ? `${data[fieldMetadata.name]}` : ""}</p>
11
11
  }
12
12
  {renderMode === "image" &&
13
- <img
14
- src={data[fieldMetadata.name]}
15
- onClick={(event) => {
16
- event.stopPropagation();
17
- setLightboxUrls([{ src: data[fieldMetadata.name] }]);
18
- setOpenLightbox(true);
19
- }}
20
- className='image-preview'
21
- ></img>
22
-
13
+ <div className='my-2'>
14
+ <img
15
+ src={data[fieldMetadata.name]}
16
+ onClick={(event) => {
17
+ event.stopPropagation();
18
+ setLightboxUrls([{ src: data[fieldMetadata.name] }]);
19
+ setOpenLightbox(true);
20
+ }}
21
+ className='kanban-image-preview'
22
+ ></img>
23
+ </div>
23
24
  }
24
- </>
25
+ </div>
25
26
  );
26
27
 
27
28
  };
@@ -4,7 +4,7 @@ import { SolidKanbanViewFieldsParams } from '../SolidKanbanViewFields';
4
4
  const SolidTimeKanbanField = ({ solidKanbanViewMetaData, fieldMetadata, fieldLayout,data }: SolidKanbanViewFieldsParams) => {
5
5
 
6
6
  return (
7
- <p>{data && data[fieldMetadata.name] ? `${data[fieldMetadata.name]}`: ""}</p>
7
+ <p className='m-0'>{data && data[fieldMetadata.name] ? `${data[fieldMetadata.name]}`: ""}</p>
8
8
  );
9
9
 
10
10
  };
@@ -234,7 +234,7 @@ export const SolidListViewConfigure = ({ listViewMetaData, setShowArchived, show
234
234
  </AccordionTab>
235
235
  <AccordionTab header="Column Selector">
236
236
  <div className="flex flex-column gap-1 p-1">
237
- <div className="flex flex-column gap-3 px-3 cogwheel-column-filter">
237
+ <div className="flex flex-column gap-3 px-3 cogwheel-column-filter" style={{maxHeight: 400, overflowY:'auto'}}>
238
238
  {solidListColumns.map((column) => {
239
239
  return (
240
240
  <div key={column.key} className="flex align-items-center gap-1">
@@ -1,43 +1,57 @@
1
1
  'use client';
2
- import React from 'react';
3
- import { Column, ColumnFilterElementTemplateOptions } from "primereact/column";
4
- import { InputTypes, SolidVarInputsFilterElement } from "../SolidVarInputsFilterElement";
2
+ import React, { useState } from 'react';
3
+ import { Column } from "primereact/column";
5
4
  import { SolidListViewColumnParams } from '../SolidListViewColumn';
6
- import { FormEvent } from "primereact/ts-helpers";
7
- import { FilterMatchMode } from 'primereact/api';
8
- import { Button } from 'primereact/button';
5
+ import { classNames } from 'primereact/utils';
9
6
 
10
- const SolidMediaSingleColumn = ({ solidListViewMetaData, fieldMetadata, column, setLightboxUrls, setOpenLightbox }: SolidListViewColumnParams) => {
11
- // const filterable = column.attrs.filterable;
7
+ const isImageFile = (url: string) => {
8
+ return /\.(jpg|jpeg|png|gif|bmp|webp)$/i.test(url);
9
+ };
12
10
 
13
- const filterable = false;
14
- const showFilterOperator = false;
15
- const columnDataType = undefined;
16
- const header = column.attrs.label ?? fieldMetadata.displayName;
17
- const imageBodyTemplate = (product: any) => {
18
- if (!product?._media?.[fieldMetadata.name]) return null;
19
- const imageUrls = product._media[fieldMetadata.name].map((i: any) => i._full_url);
11
+ const MediaWithFallback = ({ src, alt, onClick }: { src: string; alt: string; onClick: (event: React.MouseEvent) => void }) => {
12
+ const [isBroken, setIsBroken] = useState(false);
20
13
 
21
- return (
22
- imageUrls.length > 0 ?
14
+ return (
15
+ <div style={{ width: 40, height: 40, display: 'flex', alignItems: 'center', justifyContent: 'center' }}>
16
+ {!isBroken && isImageFile(src) ? (
23
17
  <img
24
- src={imageUrls[0]}
25
- alt="product-image-single"
18
+ src={src}
19
+ alt={alt}
26
20
  className="shadow-2 border-round"
27
21
  width={40}
28
22
  height={40}
29
23
  style={{ objectFit: "cover" }}
24
+ onError={() => setIsBroken(true)} // Handle broken image
25
+ onClick={onClick}
26
+ />
27
+ ) : (
28
+ <i className={classNames(isImageFile(src) ? "pi pi-image" : "pi pi-file", "text-3xl text-gray-400")}></i> // Image or file icon
29
+ )}
30
+ </div>
31
+ );
32
+ };
33
+
34
+ const SolidMediaSingleColumn = ({ solidListViewMetaData, fieldMetadata, column, setLightboxUrls, setOpenLightbox }: SolidListViewColumnParams) => {
35
+ const header = column.attrs.label ?? fieldMetadata.displayName;
36
+
37
+ const mediaBodyTemplate = (product: any) => {
38
+ if (!product?._media?.[fieldMetadata.name]) return null;
39
+ const mediaUrls = product._media[fieldMetadata.name].map((i: any) => i._full_url);
40
+
41
+ return (
42
+ mediaUrls.length > 0 ? (
43
+ <MediaWithFallback
44
+ src={mediaUrls[0]}
45
+ alt="product-media"
30
46
  onClick={(event) => {
31
47
  event.stopPropagation();
32
- setLightboxUrls([{ src: imageUrls[0], downloadUrl: imageUrls[0] }]);
48
+ setLightboxUrls([{ src: mediaUrls[0], downloadUrl: mediaUrls[0] }]);
33
49
  setOpenLightbox(true);
34
50
  }}
35
51
  />
36
- :
37
- <div
38
- style={{ height: 40, width: 40 }}
39
- >
40
- </div>
52
+ ) : (
53
+ <i className="pi pi-image text-3xl text-gray-400"></i> // Default fallback icon
54
+ )
41
55
  );
42
56
  };
43
57
 
@@ -46,18 +60,14 @@ const SolidMediaSingleColumn = ({ solidListViewMetaData, fieldMetadata, column,
46
60
  key={fieldMetadata.name}
47
61
  field={fieldMetadata.name}
48
62
  header={header}
49
- body={imageBodyTemplate}
50
- // className="text-sm"
63
+ body={mediaBodyTemplate}
51
64
  sortable={column.attrs.sortable}
52
- // filter={filterable}
53
- dataType={columnDataType}
54
- showFilterOperator={showFilterOperator}
65
+ showFilterOperator={false}
55
66
  filterPlaceholder={`Search by ${fieldMetadata.displayName}`}
56
67
  style={{ minWidth: "12rem" }}
57
68
  headerClassName="table-header-fs"
58
- ></Column>
69
+ />
59
70
  );
60
-
61
71
  };
62
72
 
63
- export default SolidMediaSingleColumn;
73
+ export default SolidMediaSingleColumn;
@@ -170,6 +170,11 @@ const fieldBasedPayloadFormating = (values: any, currentFields: string[], fieldM
170
170
  transformedPayload.relationCascade = values.relationCascade;
171
171
  }
172
172
 
173
+ if (transformedPayload.relationType == "many-to-many") {
174
+ transformedPayload.isRelationManyToManyOwner = true;
175
+ }
176
+
177
+
173
178
  return transformedPayload
174
179
 
175
180
  }
@@ -1529,21 +1529,14 @@ li.header-li-px {
1529
1529
  font-size: 0.8rem;
1530
1530
  }
1531
1531
 
1532
- .kanban-options-panel .p-overlaypanel-content {
1533
- padding: 0 !important;
1534
- }
1535
-
1536
- .kanban-options-panel .p-overlaypanel-content span {
1537
- padding: 0 !important;
1538
- font-size: 1rem;
1539
- }
1540
-
1541
1532
  .kanban-column {
1542
1533
  flex: 1;
1543
- max-width: 350px;
1544
- background: #f0f0f5;
1534
+ min-width: 270px;
1535
+ width: 100%;
1536
+ max-width: 270px;
1537
+ /* background: #f0f0f5;
1545
1538
  border: 8px;
1546
- padding: 0.2rem;
1539
+ padding: 0.2rem; */
1547
1540
  }
1548
1541
 
1549
1542
  .kanban-card {
@@ -1565,19 +1558,15 @@ li.header-li-px {
1565
1558
  color: #4b4d52;
1566
1559
  }
1567
1560
 
1568
- .kanban-group-heading {
1569
- font-size: 1rem;
1570
- font-weight: 600;
1571
- letter-spacing: 2px;
1572
- }
1573
-
1574
1561
  .kanban-column-folded {
1575
1562
  flex-grow: 0;
1576
- background: #f0f0f5;
1563
+ background: #F4F4F4;
1577
1564
  border: 8px;
1578
1565
  padding: 5px;
1579
1566
  height: 100%;
1580
- font-size: 1rem;
1567
+ min-width:fit-content;
1568
+ width: 100%;
1569
+ max-width:fit-content;
1581
1570
  }
1582
1571
 
1583
1572
  .kaban-heading-area {
@@ -2902,6 +2891,66 @@ li.header-li-px {
2902
2891
  max-width: calc(20% - 10px);
2903
2892
  }
2904
2893
 
2905
- .image-preview{
2906
- max-width: 100px;
2894
+ .solid-kanban-card {
2895
+ box-shadow: none;
2896
+ border-radius: 0.5rem;
2897
+ border: 1px solid rgba(216, 226, 234, 0.60);
2898
+ background: #FFF;
2899
+ padding: 9px;
2900
+ }
2901
+
2902
+ .kanban-group-heading {
2903
+ font-weight: 600;
2904
+ display: flex;
2905
+ align-items: center;
2906
+ gap: 10px;
2907
+ }
2908
+
2909
+ .kanban-count-badge {
2910
+ display: flex;
2911
+ width: 1.5rem;
2912
+ height: 1.5rem;
2913
+ padding: 0.125rem;
2914
+ justify-content: center;
2915
+ align-items: center;
2916
+ flex-shrink: 0;
2917
+ border-radius: 6.25rem;
2918
+ background: #F6FAFF;
2919
+ font-size: 0.75rem;
2920
+ font-weight: 600;
2921
+ color: var(--primary-color);
2922
+ }
2923
+
2924
+ .kanban-image-preview {
2925
+ /* width: 100px; */
2926
+ /* width: 240px;
2927
+ height: 120px;
2928
+ flex-shrink: 0; */
2929
+ width: 100%;
2930
+ border-radius: 8px;
2931
+ max-height: 120px;
2932
+ }
2933
+
2934
+ .solid-kanban-board-wrapper {
2935
+ border-top: 1px solid #CED0D6;
2936
+ overflow: hidden;
2937
+ height: calc(100vh - 64px) !important;
2938
+ }
2939
+
2940
+ .solid-kanban-board-scroll-context {
2941
+ overflow: auto;
2942
+ height: 100%;
2943
+ }
2944
+
2945
+ .kanban-column-cogwheel.p-button.p-button-icon-only.p-button-rounded {
2946
+ height: 2rem;
2947
+ width: 2rem;
2948
+ }
2949
+
2950
+ .kanban-column-cogwheel.p-button.p-button-secondary.p-button-text:not(:disabled):active {
2951
+ background: transparent;
2952
+ }
2953
+
2954
+ .kanban-column-cogwheel.p-button.p-button-secondary.p-button-text:not(:disabled):hover {
2955
+ background: transparent;
2907
2956
  }