@solidstarters/solid-core-ui 1.1.67 → 1.1.69

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 (71) hide show
  1. package/dist/components/auth/SolidRegister.d.ts.map +1 -1
  2. package/dist/components/auth/SolidRegister.js +7 -1
  3. package/dist/components/auth/SolidRegister.js.map +1 -1
  4. package/dist/components/core/common/SolidGlobalSearchElement.d.ts.map +1 -1
  5. package/dist/components/core/common/SolidGlobalSearchElement.js +53 -43
  6. package/dist/components/core/common/SolidGlobalSearchElement.js.map +1 -1
  7. package/dist/components/core/kanban/KanbanCard.d.ts.map +1 -1
  8. package/dist/components/core/kanban/KanbanCard.js +10 -3
  9. package/dist/components/core/kanban/KanbanCard.js.map +1 -1
  10. package/dist/components/core/kanban/SolidKanbanView.d.ts.map +1 -1
  11. package/dist/components/core/kanban/SolidKanbanView.js +6 -5
  12. package/dist/components/core/kanban/SolidKanbanView.js.map +1 -1
  13. package/dist/components/core/kanban/SolidKanbanViewConfigure.d.ts +1 -1
  14. package/dist/components/core/kanban/SolidKanbanViewConfigure.d.ts.map +1 -1
  15. package/dist/components/core/kanban/SolidKanbanViewConfigure.js +2 -2
  16. package/dist/components/core/kanban/SolidKanbanViewConfigure.js.map +1 -1
  17. package/dist/components/core/list/ListViewRowActionPopup.d.ts.map +1 -1
  18. package/dist/components/core/list/ListViewRowActionPopup.js +21 -5
  19. package/dist/components/core/list/ListViewRowActionPopup.js.map +1 -1
  20. package/dist/components/core/list/SolidListView.d.ts.map +1 -1
  21. package/dist/components/core/list/SolidListView.js +16 -15
  22. package/dist/components/core/list/SolidListView.js.map +1 -1
  23. package/dist/components/core/list/SolidListViewConfigure.d.ts +1 -1
  24. package/dist/components/core/list/SolidListViewConfigure.d.ts.map +1 -1
  25. package/dist/components/core/list/SolidListViewConfigure.js +2 -2
  26. package/dist/components/core/list/SolidListViewConfigure.js.map +1 -1
  27. package/dist/components/core/list/columns/SolidShortTextColumn.d.ts.map +1 -1
  28. package/dist/components/core/list/columns/SolidShortTextColumn.js +12 -1
  29. package/dist/components/core/list/columns/SolidShortTextColumn.js.map +1 -1
  30. package/dist/components/core/list/widgets/SolidShortTextFieldTextRenderModeWidget.d.ts +2 -0
  31. package/dist/components/core/list/widgets/SolidShortTextFieldTextRenderModeWidget.d.ts.map +1 -0
  32. package/dist/components/core/list/widgets/SolidShortTextFieldTextRenderModeWidget.js +7 -0
  33. package/dist/components/core/list/widgets/SolidShortTextFieldTextRenderModeWidget.js.map +1 -0
  34. package/dist/components/core/list/widgets/SolidUserNameAvatarWidget.d.ts +2 -0
  35. package/dist/components/core/list/widgets/SolidUserNameAvatarWidget.d.ts.map +1 -0
  36. package/dist/components/core/list/widgets/SolidUserNameAvatarWidget.js +36 -0
  37. package/dist/components/core/list/widgets/SolidUserNameAvatarWidget.js.map +1 -0
  38. package/dist/components/core/model/CreateModel.js +1 -1
  39. package/dist/components/core/model/CreateModel.js.map +1 -1
  40. package/dist/components/core/model/FieldMetaDataForm.d.ts.map +1 -1
  41. package/dist/components/core/model/FieldMetaDataForm.js +73 -50
  42. package/dist/components/core/model/FieldMetaDataForm.js.map +1 -1
  43. package/dist/components/core/model/ModelMetaData.d.ts.map +1 -1
  44. package/dist/components/core/model/ModelMetaData.js +35 -17
  45. package/dist/components/core/model/ModelMetaData.js.map +1 -1
  46. package/dist/helpers/registry.d.ts.map +1 -1
  47. package/dist/helpers/registry.js +8 -1
  48. package/dist/helpers/registry.js.map +1 -1
  49. package/dist/redux/api/modelApi.js +1 -1
  50. package/dist/redux/api/modelApi.js.map +1 -1
  51. package/dist/resources/globals.css +5 -0
  52. package/dist/resources/themes/solid-light-purple/theme.css +4 -0
  53. package/package.json +1 -1
  54. package/src/components/auth/SolidRegister.tsx +7 -1
  55. package/src/components/core/common/SolidGlobalSearchElement.tsx +29 -22
  56. package/src/components/core/kanban/KanbanCard.tsx +51 -5
  57. package/src/components/core/kanban/SolidKanbanView.tsx +3 -2
  58. package/src/components/core/kanban/SolidKanbanViewConfigure.tsx +2 -1
  59. package/src/components/core/list/ListViewRowActionPopup.tsx +9 -2
  60. package/src/components/core/list/SolidListView.tsx +4 -1
  61. package/src/components/core/list/SolidListViewConfigure.tsx +2 -1
  62. package/src/components/core/list/columns/SolidShortTextColumn.tsx +11 -2
  63. package/src/components/core/list/widgets/SolidUserNameAvatarWidget.tsx +52 -0
  64. package/src/components/core/model/CreateModel.tsx +1 -1
  65. package/src/components/core/model/FieldMetaDataForm.tsx +86 -12
  66. package/src/components/core/model/ModelMetaData.tsx +38 -11
  67. package/src/helpers/registry.ts +11 -1
  68. package/src/redux/api/modelApi.ts +1 -1
  69. package/src/resources/globals.css +5 -0
  70. package/src/resources/themes/solid-light-purple/theme.css +4 -0
  71. /package/src/components/core/list/widgets/{SolidShortTextFieldTextRenderModeWidget copy.tsx → SolidShortTextFieldTextRenderModeWidget.tsx} +0 -0
@@ -394,16 +394,26 @@ const createValidationSchema = (currentFields: any, selectedType: any, allFields
394
394
  "Relation Model Singular Name is required"
395
395
  ),
396
396
  }),
397
- // ...(currentFields.includes("relationCoModelFieldName") && {
398
- // relationCoModelFieldName: Yup.string()
399
- // // .required(
400
- // // "Relation Model Field Name is required"
401
- // // ),
402
- // }),
403
-
397
+ ...(currentFields.includes("relationCoModelFieldName") && {
398
+ relationCoModelFieldName: Yup.string()
399
+ // .required(
400
+ // "Relation Model Field Name is required"
401
+ // ),
402
+ }),
404
403
  ...(currentFields.includes("relationCreateInverse") && {
405
404
  relationCreateInverse: Yup.boolean(),
406
405
  }),
406
+ ...(currentFields.includes("relationCoModelFieldName") && {
407
+ relationCoModelFieldName: Yup.string().when("relationCreateInverse", (relationCreateInverse: any, schema) => {
408
+ console.log("relationCreateInverse", relationCreateInverse);
409
+ if (relationCreateInverse.length > 0 && relationCreateInverse[0] == true) {
410
+ return schema.required("Relation Co Model Field Name is required")
411
+ } else {
412
+ return schema.notRequired();
413
+ }
414
+ }),
415
+ }),
416
+
407
417
  // ...(currentFields.includes("relationCascade") && {
408
418
  // relationCascade: Yup.string().required(
409
419
  // "Relation Cascade Value is required"
@@ -425,6 +435,11 @@ const createValidationSchema = (currentFields: any, selectedType: any, allFields
425
435
  "Relation Model Module Name Value is required"
426
436
  ),
427
437
  }),
438
+
439
+ ...(currentFields.includes("relationFieldFixedFilter") && {
440
+ relationFieldFixedFilter: Yup.string().nullable(),
441
+ }),
442
+
428
443
  ...(currentFields.includes("selectionDynamicProvider") && {
429
444
  selectionDynamicProvider: Yup.string().required(
430
445
  "Selection Dynamic Provider Value is required"
@@ -898,6 +913,7 @@ const FieldMetaDataForm = ({ setIsDirty, modelMetaData, fieldMetaData, setFieldM
898
913
  relationCreateInverse: fieldMetaData ? fieldMetaData?.relationCreateInverse : false,
899
914
  relationCascade: fieldMetaData ? fieldMetaData?.relationCascade : 'cascade',
900
915
  relationModelModuleName: fieldMetaData ? fieldMetaData?.relationModelModuleName : modelMetaData?.module.name,
916
+ relationFieldFixedFilter: fieldMetaData ? fieldMetaData?.relationFieldFixedFilter : "",
901
917
  selectionDynamicProvider: fieldMetaData ? fieldMetaData?.selectionDynamicProvider : null,
902
918
  selectionDynamicProviderCtxt: fieldMetaData ? fieldMetaData?.selectionDynamicProviderCtxt : "",
903
919
  selectionStaticValues: fieldMetaData ? fieldMetaData?.selectionStaticValues : [""],
@@ -1705,8 +1721,12 @@ const FieldMetaDataForm = ({ setIsDirty, modelMetaData, fieldMetaData, setFieldM
1705
1721
  <SelectButton
1706
1722
  value={formik.values.relationType}
1707
1723
  options={fieldDefaultMetaData.data.relationTypes}
1708
- onChange={(e) =>
1709
- formik.setFieldValue("relationType", e.value)
1724
+ onChange={(e) => {
1725
+ formik.setFieldValue("relationType", e.value);
1726
+ if (e.value === "one-to-many") {
1727
+ formik.setFieldValue("relationCreateInverse", true);
1728
+ }
1729
+ }
1710
1730
  }
1711
1731
  className={classNames("", {
1712
1732
  "p-invalid": isFormFieldValid(formik, "relationType"),
@@ -1869,6 +1889,56 @@ const FieldMetaDataForm = ({ setIsDirty, modelMetaData, fieldMetaData, setFieldM
1869
1889
  </div>
1870
1890
  )}
1871
1891
 
1892
+ {currentFields.includes(
1893
+ "relationFieldFixedFilter"
1894
+ ) && (
1895
+ <div className="field col-6 flex-flex-column gap-2 mt-3">
1896
+ <label
1897
+ htmlFor="relationFieldFixedFilter"
1898
+ className="form-field-label"
1899
+ >
1900
+ Relation Field Fixed Filter
1901
+ </label>
1902
+
1903
+ <InputTextarea
1904
+ aria-describedby="Fixed Filter"
1905
+ id="relationFieldFixedFilter"
1906
+ name="relationFieldFixedFilter"
1907
+ onChange={formik.handleChange}
1908
+ value={formik.values.relationFieldFixedFilter}
1909
+ rows={5}
1910
+ cols={30}
1911
+ className={classNames("", {
1912
+ "p-invalid": isFormFieldValid(
1913
+ formik,
1914
+ "relationFieldFixedFilter"
1915
+ ),
1916
+ })}
1917
+ />
1918
+ {/*
1919
+ <InputText
1920
+ type="text"
1921
+ id="relationFieldFixedFilter"
1922
+ name="relationFieldFixedFilter"
1923
+ onChange={formik.handleChange}
1924
+ disabled={fieldMetaData?.id}
1925
+ value={formik.values.relationFieldFixedFilter}
1926
+ className={classNames("", {
1927
+ "p-invalid": isFormFieldValid(
1928
+ formik,
1929
+ "relationFieldFixedFilter"
1930
+ ),
1931
+ })}
1932
+ /> */}
1933
+ {isFormFieldValid(formik, "relationFieldFixedFilter") && (
1934
+ <Message
1935
+ severity="error"
1936
+ text={formik?.errors?.relationFieldFixedFilter?.toString()}
1937
+ />
1938
+ )}
1939
+
1940
+ </div>
1941
+ )}
1872
1942
  {isUserKeyFields && (
1873
1943
  <div className="field col-6 flex-flex-column gap-2 mt-3">
1874
1944
  <label
@@ -1902,7 +1972,7 @@ const FieldMetaDataForm = ({ setIsDirty, modelMetaData, fieldMetaData, setFieldM
1902
1972
  </div>
1903
1973
  )}
1904
1974
 
1905
- {currentFields.includes("relationCreateInverse") && (formik.values.relationType === "many-to-many" || formik.values.relationType === "many-to-one") && (
1975
+ {currentFields.includes("relationCreateInverse") && (
1906
1976
  <div className="field col-6 flex flex-column gap-2 mt-3">
1907
1977
  <label htmlFor="relationCreateInverse" className="form-field-label">
1908
1978
  Relation Create Inverse
@@ -1912,6 +1982,7 @@ const FieldMetaDataForm = ({ setIsDirty, modelMetaData, fieldMetaData, setFieldM
1912
1982
  inputId="relationCreateInverse"
1913
1983
  name="relationCreateInverse"
1914
1984
  checked={formik.values.relationCreateInverse}
1985
+ disabled={formik.values.relationType === "one-to-many" ? true : false}
1915
1986
  onChange={(e) => formik.setFieldValue("relationCreateInverse", e.checked)}
1916
1987
  />
1917
1988
  <label htmlFor="relationCreateInverse" className="ml-2">Create Inverse</label>
@@ -1935,6 +2006,7 @@ const FieldMetaDataForm = ({ setIsDirty, modelMetaData, fieldMetaData, setFieldM
1935
2006
  id="relationCoModelFieldName"
1936
2007
  name="relationCoModelFieldName"
1937
2008
  onChange={formik.handleChange}
2009
+ disabled={fieldMetaData?.id}
1938
2010
  value={formik.values.relationCoModelFieldName}
1939
2011
  className={classNames("", {
1940
2012
  "p-invalid": isFormFieldValid(
@@ -1997,6 +2069,7 @@ const FieldMetaDataForm = ({ setIsDirty, modelMetaData, fieldMetaData, setFieldM
1997
2069
  id="relationCoModelColumnName"
1998
2070
  name="relationCoModelColumnName"
1999
2071
  onChange={formik.handleChange}
2072
+ disabled={fieldMetaData?.id}
2000
2073
  value={formik.values.relationCoModelColumnName}
2001
2074
  className={classNames("", {
2002
2075
  "p-invalid": isFormFieldValid(
@@ -2028,6 +2101,7 @@ const FieldMetaDataForm = ({ setIsDirty, modelMetaData, fieldMetaData, setFieldM
2028
2101
  id="relationJoinTableName"
2029
2102
  name="relationJoinTableName"
2030
2103
  onChange={formik.handleChange}
2104
+ disabled={fieldMetaData?.id}
2031
2105
  value={formik.values.relationJoinTableName}
2032
2106
  className={classNames("", {
2033
2107
  "p-invalid": isFormFieldValid(
@@ -2927,10 +3001,10 @@ const FieldMetaDataForm = ({ setIsDirty, modelMetaData, fieldMetaData, setFieldM
2927
3001
  </TabView>
2928
3002
  <div className="flex gap-3">
2929
3003
  <div>
2930
- <Button label="Finish" size="small" onClick={() => showError()} type="submit" />
3004
+ <Button label="Finish" size="small" onClick={() => showError()} type="submit" />
2931
3005
  </div>
2932
3006
  <div>
2933
- <Button label="Cancel" size="small" severity="secondary" type="reset" onClick={() => setVisiblePopup(false)} outlined />
3007
+ <Button label="Cancel" size="small" severity="secondary" type="reset" onClick={() => setVisiblePopup(false)} outlined />
2934
3008
  </div>
2935
3009
  </div>
2936
3010
  </div>
@@ -56,7 +56,7 @@ const ModelMetaData = React.forwardRef(({ modelMetaData, setModelMetaData, allMo
56
56
  enableSoftDelete: modelMetaData ? modelMetaData?.enableSoftDelete : "",
57
57
  enableAuditTracking: modelMetaData ? modelMetaData?.enableAuditTracking : "",
58
58
  internationalisation: modelMetaData ? modelMetaData?.internationalisation : "",
59
- isChild: modelMetaData ? modelMetaData?.isChild : false,
59
+ isChild: modelMetaData ? modelMetaData?.isChild : "",
60
60
  parentModelId: modelMetaData ? modelMetaData?.parentModel?.id : "",
61
61
  parentModel: modelMetaData ? modelMetaData?.parentModel : "",
62
62
 
@@ -104,8 +104,22 @@ const ModelMetaData = React.forwardRef(({ modelMetaData, setModelMetaData, allMo
104
104
  enableAuditTracking: Yup.boolean(),
105
105
  internationalisation: Yup.boolean(),
106
106
  isChild: Yup.boolean(),
107
- parentModelId: Yup.number(),
108
- parentModel: Yup.object()
107
+ parentModelId: Yup.number().when("isChild", (isChild: any, schema) => {
108
+ console.log("relationCreateInverse", isChild);
109
+ if (isChild.length > 0 && isChild[0] == true) {
110
+ return schema.required("Parent Model Id is required")
111
+ } else {
112
+ return schema.notRequired().nullable();
113
+ }
114
+ }),
115
+ parentModel: Yup.object().when("isChild", (isChild: any, schema) => {
116
+ console.log("relationCreateInverse", isChild);
117
+ if (isChild.length > 0 && isChild[0] == true) {
118
+ return schema.required("Parent Model is required")
119
+ } else {
120
+ return schema.notRequired().nullable();
121
+ }
122
+ }),
109
123
 
110
124
  });
111
125
 
@@ -138,7 +152,7 @@ const ModelMetaData = React.forwardRef(({ modelMetaData, setModelMetaData, allMo
138
152
  enableSoftDelete: values.enableSoftDelete === true ? true : '',
139
153
  enableAuditTracking: values.enableAuditTracking === true ? true : '',
140
154
  internationalisation: values.internationalisation === true ? true : '',
141
- isChild: values.isChild ? values.isChild === true : '',
155
+ isChild: values.isChild === true ? true : '',
142
156
  ...(values.isChild == true && {
143
157
  parentModelId: values.parentModelId,
144
158
  parentModel: values.parentModel,
@@ -455,14 +469,27 @@ const ModelMetaData = React.forwardRef(({ modelMetaData, setModelMetaData, allMo
455
469
  />
456
470
  )}
457
471
 
458
- <div className="mt-4">
459
- <div className="flex align-items-center gap-2">
460
- <Checkbox onChange={e => { setShowParentModel(e.checked) }} checked={showParentModel} disabled={params.id !== 'new'}></Checkbox>
461
- <label htmlFor="ingredient1" className="form-field-label">
462
- isChild
463
- </label>
464
- </div>
472
+ <div className="flex align-items-center gap-2 mt-3">
473
+ <Checkbox
474
+ name="isChild"
475
+ onChange={(e) => {
476
+ formik.setFieldValue("isChild", e.checked);
477
+ }}
478
+ disabled={params.id !== 'new'}
479
+ checked={formik.values.isChild}
480
+ ></Checkbox>
481
+ <label htmlFor="isChild" className="form-field-label">
482
+ Is Child
483
+ </label>
465
484
  </div>
485
+ {params.id !== 'new' && <p className="form-field-label mt-1 text-sm">Is Current Model child of another Model</p>}
486
+ {(isFormFieldValid(formik, "isChild") || (formErrors["isChild"])) && (
487
+ <Message
488
+ severity="error"
489
+ text={formik?.errors?.isChild?.toString()}
490
+ className="mt-2"
491
+ />
492
+ )}
466
493
  {showParentModel &&
467
494
  <div className="flex flex-column gap-2 mt-3">
468
495
  <label htmlFor="type" className="form-field-label">
@@ -9,7 +9,7 @@ import { SolidBooleanFieldCheckboxWidget } from "@/components/core/form/fields/w
9
9
  import { SolidBooleanFieldSelectWidget } from "@/components/core/form/fields/widgets/SolidBooleanSelectFieldWidget";
10
10
  import { SolidSelectionStaticAutocompleteWidget } from "@/components/core/form/fields/widgets/SolidSelectionStaticAutocompleteFieldWidget";
11
11
  import { SolidSelectionStaticRadioWidget } from "@/components/core/form/fields/widgets/SolidSelectionStaticRadioFieldWidget";
12
- import { SolidShortTextFieldTextRenderModeWidget } from "@/components/core/list/widgets/SolidShortTextFieldTextRenderModeWidget copy";
12
+ import { SolidShortTextFieldTextRenderModeWidget } from "@/components/core/list/widgets/SolidShortTextFieldTextRenderModeWidget";
13
13
  import { SolidShortTextFieldImageRenderModeWidget } from "@/components/core/list/widgets/SolidShortTextFieldImageRenderModeWidget";
14
14
  import { SolidFormFieldViewModeWidget } from "@/components/core/form/fields/widgets/SolidFormFieldViewModeWidget";
15
15
  import { SolidFormFieldJsonViewModeWidget } from "@/components/core/form/fields/widgets/SolidFormFieldJsonViewModeWidget";
@@ -19,6 +19,9 @@ import { SolidFormFieldMediaViewModeWidget } from "@/components/core/form/fields
19
19
  import { SolidFormFieldRelationViewModeWidget } from "@/components/core/form/fields/widgets/SolidFormFieldRelationViewModeWidget";
20
20
  import { SolidFormFieldViewMediaSingleWidget } from "@/components/core/form/fields/widgets/SolidFormFieldViewMediaSingleWidget";
21
21
  import { SolidFormFieldViewMediaMultipleWidget } from "@/components/core/form/fields/widgets/SolidFormFieldViewMediaMultipleWidget";
22
+ import { SolidUserNameAvatarWidget } from "@/components/core/list/widgets/SolidUserNameAvatarWidget";
23
+ import GenerateModelCodeRowAction from "@/components/core/extension/solid-core/modelMetadata/list/GenerateModelCodeRowAction";
24
+ import GenerateModuleCodeRowAction from "@/components/core/extension/solid-core/moduleMetadata/list/GenerateModuleCodeRowAction";
22
25
 
23
26
  type ExtensionRegistry = {
24
27
  components: Record<string, React.ComponentType<any>>;
@@ -79,6 +82,11 @@ export const getExtensionFunction = (name: string) => {
79
82
  // Register all the dynamic widget & functions from inside solid-core-ui
80
83
  // Common
81
84
  registerExtensionComponent("CustomHtml", CustomHtml, []);
85
+
86
+
87
+
88
+ registerExtensionComponent("GenerateModelCodeRowAction", GenerateModelCodeRowAction, []);
89
+ registerExtensionComponent("GenerateModuleCodeRowAction", GenerateModuleCodeRowAction, []);
82
90
  registerExtensionComponent("SolidRelationManyToManyCheckboxWidget", SolidRelationManyToManyCheckboxWidget, ["checkbox"]);
83
91
  registerExtensionComponent("SolidRelationManyToManyAutocompleteWidget", SolidRelationManyToManyAutocompleteWidget, ["autocomplete"]);
84
92
  registerExtensionComponent("SolidBooleanFieldCheckboxWidget", SolidBooleanFieldCheckboxWidget, ["field-checkbox"]);
@@ -95,6 +103,8 @@ registerExtensionComponent("SolidFormFieldMediaViewModeWidget", SolidFormFieldMe
95
103
  registerExtensionComponent("SolidFormFieldRelationViewModeWidget", SolidFormFieldRelationViewModeWidget, []);
96
104
  registerExtensionComponent("SolidFormFieldViewMediaSingleWidget", SolidFormFieldViewMediaSingleWidget, []);
97
105
  registerExtensionComponent("SolidFormFieldViewMediaMultipleWidget", SolidFormFieldViewMediaMultipleWidget, []);
106
+ registerExtensionComponent("SolidFormFieldViewMediaMultipleWidget", SolidFormFieldViewMediaMultipleWidget, []);
107
+ registerExtensionComponent("SolidUserNameAvatarWidget", SolidUserNameAvatarWidget, []);
98
108
 
99
109
 
100
110
  // ModuleMetadata
@@ -20,7 +20,7 @@ export const modelsApi = createApi({
20
20
  }
21
21
  }),
22
22
  getmodelById: builder.query({
23
- query: (id) => `/model-metadata/${id}?populate[0]=fields&populate[1]=module&populate[2]=fields.mediaStorageProvider`,
23
+ query: (id) => `/model-metadata/${id}?populate[0]=fields&populate[1]=module&&populate[2]=fields.mediaStorageProvider&populate[3]=parentModel`,
24
24
  }),
25
25
  createmodel: builder.mutation({
26
26
  query: (model) => ({
@@ -2938,6 +2938,11 @@ li.header-li-px {
2938
2938
  max-width: calc(20% - 20px);
2939
2939
  }
2940
2940
 
2941
+ .solid-kanban-action {
2942
+ position: absolute;
2943
+ right: 5px;
2944
+ }
2945
+
2941
2946
  .solid-kanban-card {
2942
2947
  box-shadow: none;
2943
2948
  border-radius: 0.5rem;
@@ -6205,6 +6205,10 @@
6205
6205
  background-color: #EFF1F4;
6206
6206
  }
6207
6207
 
6208
+ .solid-kanban-board-wrapper {
6209
+ border-top: 1px solid var(--primary-light-color);
6210
+ }
6211
+
6208
6212
  .solid-kanban-card,
6209
6213
  .solid-media-card {
6210
6214
  border: 1px solid var(--solid-kanban-wrapper);