@gnar-engine/cli 1.0.3 → 1.0.5

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 (259) hide show
  1. package/bootstrap/deploy.localdev.yml +44 -30
  2. package/bootstrap/secrets.localdev.yml +20 -14
  3. package/bootstrap/services/control/src/config.js +4 -0
  4. package/bootstrap/services/{agent → page}/Dockerfile +3 -3
  5. package/bootstrap/services/page/package.json +16 -0
  6. package/bootstrap/services/page/src/app.js +50 -0
  7. package/bootstrap/services/page/src/commands/block.handler.js +94 -0
  8. package/bootstrap/services/page/src/commands/page.handler.js +167 -0
  9. package/bootstrap/services/page/src/config.js +62 -0
  10. package/bootstrap/services/page/src/controllers/block.http.controller.js +87 -0
  11. package/bootstrap/services/page/src/controllers/message.controller.js +51 -0
  12. package/bootstrap/services/page/src/controllers/page.http.controller.js +89 -0
  13. package/bootstrap/services/page/src/policies/block.policy.js +50 -0
  14. package/bootstrap/services/page/src/policies/page.policy.js +49 -0
  15. package/bootstrap/services/page/src/schema/page.schema.js +139 -0
  16. package/bootstrap/services/page/src/services/block.service.js +83 -0
  17. package/bootstrap/services/page/src/services/page.service.js +83 -0
  18. package/bootstrap/services/portal/Dockerfile +7 -10
  19. package/bootstrap/services/portal/README.md +66 -15
  20. package/bootstrap/services/portal/index.html +13 -0
  21. package/bootstrap/services/portal/nginx.conf +5 -12
  22. package/bootstrap/services/portal/package.json +27 -53
  23. package/bootstrap/services/portal/public/vite.svg +1 -0
  24. package/bootstrap/services/portal/react-router.config.js +7 -0
  25. package/bootstrap/services/portal/src/App.jsx +16 -0
  26. package/bootstrap/services/portal/src/assets/gnar-engine-white-logo.svg +9 -0
  27. package/bootstrap/services/portal/src/assets/icon-agent.svg +6 -0
  28. package/bootstrap/services/portal/src/assets/icon-cog.svg +4 -0
  29. package/bootstrap/services/portal/src/assets/icon-delete.svg +3 -0
  30. package/bootstrap/services/portal/src/assets/icon-home.svg +3 -0
  31. package/bootstrap/services/portal/src/assets/icon-padlock.svg +3 -0
  32. package/bootstrap/services/portal/src/assets/icon-page.svg +6 -0
  33. package/bootstrap/services/portal/src/assets/icon-reports.svg +3 -0
  34. package/bootstrap/services/portal/src/assets/icon-user.svg +3 -0
  35. package/bootstrap/services/portal/src/assets/icon-users.svg +3 -0
  36. package/bootstrap/services/portal/src/assets/login-green-rad-back-1.jpg +0 -0
  37. package/bootstrap/services/portal/src/assets/react.svg +1 -0
  38. package/bootstrap/services/portal/src/components/CrudList/CrudList.jsx +85 -0
  39. package/bootstrap/services/portal/src/components/CrudList/CrudList.less +59 -0
  40. package/bootstrap/services/portal/src/{ui/customSelect → components/CustomSelect}/CustomSelect.jsx +21 -3
  41. package/bootstrap/services/portal/src/components/LoginForm/LoginForm.jsx +58 -0
  42. package/bootstrap/services/portal/src/components/PageBlockSwitch/PageBlockSwitch.jsx +129 -0
  43. package/bootstrap/services/portal/src/components/Sidebar/Sidebar.jsx +33 -0
  44. package/bootstrap/services/portal/src/components/Sidebar/Sidebar.less +37 -0
  45. package/bootstrap/services/portal/src/components/Topbar/Topbar.jsx +19 -0
  46. package/bootstrap/services/portal/src/components/Topbar/Topbar.less +22 -0
  47. package/bootstrap/services/portal/src/components/UserInfo/UserInfo.jsx +33 -0
  48. package/bootstrap/services/portal/src/components/UserInfo/UserInfo.less +21 -0
  49. package/bootstrap/services/portal/src/css/style.css +446 -742
  50. package/bootstrap/services/portal/src/data/pages.data.js +10 -0
  51. package/bootstrap/services/portal/src/elements/CustomSelect/CustomSelect.jsx +65 -0
  52. package/bootstrap/services/portal/src/{ui/customSelect/customSelect.less → elements/CustomSelect/CustomSelect.less} +17 -7
  53. package/bootstrap/services/portal/src/elements/ImageInput/ImageInput.jsx +115 -0
  54. package/bootstrap/services/portal/src/elements/ImageInput/ImageInput.less +43 -0
  55. package/bootstrap/services/portal/src/elements/ImageMultiInput/ImageMultiInput.jsx +124 -0
  56. package/bootstrap/services/portal/src/elements/ImageMultiInput/ImageMultiInput.less +0 -0
  57. package/bootstrap/services/portal/src/elements/Repeater/Repeater.jsx +52 -0
  58. package/bootstrap/services/portal/src/elements/Repeater/Repeater.less +70 -0
  59. package/bootstrap/services/portal/src/elements/RichTextInput/RichTextInput.jsx +18 -0
  60. package/bootstrap/services/portal/src/elements/RichTextInput/RichTextInput.less +37 -0
  61. package/bootstrap/services/portal/src/elements/SaveButton/SaveButton.jsx +45 -0
  62. package/bootstrap/services/portal/src/elements/SelectRepeater/SelectRepeater.jsx +63 -0
  63. package/bootstrap/services/portal/src/elements/SelectRepeater/SelectRepeater.less +23 -0
  64. package/bootstrap/services/portal/src/elements/TextInput/TextInput.jsx +17 -0
  65. package/bootstrap/services/portal/src/layouts/Card/Card.jsx +15 -0
  66. package/bootstrap/services/portal/src/layouts/PortalLayout/PortalLayout.jsx +29 -0
  67. package/bootstrap/services/portal/src/layouts/PortalLayout/PortalLayout.less +49 -0
  68. package/bootstrap/services/portal/src/main.jsx +51 -0
  69. package/bootstrap/services/portal/src/pages/BlockSinglePage/BlockSinglePage.jsx +277 -0
  70. package/bootstrap/services/portal/src/pages/BlocksPage/BlocksPage.jsx +23 -0
  71. package/bootstrap/services/portal/src/pages/DashboardPage/DashboardPage.jsx +11 -0
  72. package/bootstrap/services/portal/src/pages/DashboardPage/DashboardPage.less +0 -0
  73. package/bootstrap/services/portal/src/pages/LoginPage/LoginPage.jsx +21 -0
  74. package/bootstrap/services/portal/src/pages/LoginPage/LoginPage.less +51 -0
  75. package/bootstrap/services/portal/src/pages/PageSinglePage/PageSinglePage.jsx +338 -0
  76. package/bootstrap/services/portal/src/pages/PagesPage/PagesPage.jsx +23 -0
  77. package/bootstrap/services/portal/src/pages/UserSinglePage/UserSinglePage.jsx +9 -0
  78. package/bootstrap/services/portal/src/pages/UserSinglePage/UserSinglePage.less +0 -0
  79. package/bootstrap/services/portal/src/pages/UsersPage/UsersPage.jsx +25 -0
  80. package/bootstrap/services/portal/src/pages/UsersPage/UsersPage.less +0 -0
  81. package/bootstrap/services/portal/src/services/block.js +28 -0
  82. package/bootstrap/services/portal/src/services/client.js +67 -0
  83. package/bootstrap/services/portal/src/services/gravatar.js +14 -0
  84. package/bootstrap/services/portal/src/services/page.js +28 -0
  85. package/bootstrap/services/portal/src/services/storage.js +62 -0
  86. package/bootstrap/services/portal/src/services/user.js +41 -0
  87. package/bootstrap/services/portal/src/slices/authSlice.js +44 -14
  88. package/bootstrap/services/portal/src/store/configureStore.js +1 -3
  89. package/bootstrap/services/portal/src/style/cards.less +57 -0
  90. package/bootstrap/services/portal/src/{styles → style}/global.less +90 -45
  91. package/bootstrap/services/portal/src/style/icons.less +21 -0
  92. package/bootstrap/services/portal/src/style/inputs.less +52 -0
  93. package/bootstrap/services/portal/src/style/main.less +28 -0
  94. package/bootstrap/services/portal/src/utils/utils.js +9 -0
  95. package/bootstrap/services/portal/vite.config.js +12 -0
  96. package/bootstrap/services/user/Dockerfile +1 -1
  97. package/bootstrap/services/user/src/app.js +6 -1
  98. package/bootstrap/services/user/src/commands/user.handler.js +0 -3
  99. package/bootstrap/services/user/src/config.js +5 -1
  100. package/bootstrap/services/user/src/policies/user.policy.js +3 -1
  101. package/bootstrap/services/user/src/tests/commands/user.test.js +22 -0
  102. package/install-from-clone.sh +30 -0
  103. package/package.json +1 -1
  104. package/src/cli.js +8 -0
  105. package/src/config.js +2 -1
  106. package/src/dev/commands.js +10 -2
  107. package/src/dev/dev.service.js +167 -52
  108. package/src/provisioner/Dockerfile +27 -0
  109. package/src/provisioner/package.json +19 -0
  110. package/src/provisioner/src/app.js +56 -0
  111. package/src/provisioner/src/services/mongodb.js +58 -0
  112. package/src/provisioner/src/services/mysql.js +51 -0
  113. package/src/provisioner/src/services/secrets.js +84 -0
  114. package/src/scaffolder/commands.js +12 -5
  115. package/src/scaffolder/scaffolder.handler.js +256 -58
  116. package/templates/service/Dockerfile.hbs +4 -1
  117. package/templates/service/package.json.hbs +14 -16
  118. package/templates/service/src/app.js.hbs +53 -0
  119. package/templates/service/{commands → src/commands}/{{serviceName}}.handler.js.hbs +2 -3
  120. package/templates/service/src/mongodb.config.js.hbs +49 -0
  121. package/templates/service/{config.js.hbs → src/mysql.config.js.hbs} +10 -0
  122. package/{bootstrap/services/agent/src/schema/Agent.schema.js → templates/service/src/schema/{{serviceName}}.schema.js.hbs} +3 -3
  123. package/templates/service/src/services/mongodb.{{serviceName}}.service.js.hbs +70 -0
  124. package/bootstrap/services/agent/notes.md +0 -28
  125. package/bootstrap/services/agent/package.json +0 -16
  126. package/bootstrap/services/agent/src/app.js +0 -52
  127. package/bootstrap/services/agent/src/commands/agent.handler.js +0 -104
  128. package/bootstrap/services/agent/src/config.js +0 -52
  129. package/bootstrap/services/agent/src/controllers/http.controller.js +0 -44
  130. package/bootstrap/services/agent/src/controllers/message.controller.js +0 -51
  131. package/bootstrap/services/agent/src/db/migrations/01-init.js +0 -50
  132. package/bootstrap/services/agent/src/db/migrations/02-agent-service-init.js +0 -36
  133. package/bootstrap/services/agent/src/policies/agent.policy.js +0 -13
  134. package/bootstrap/services/agent/src/services/agent.service.js +0 -259
  135. package/bootstrap/services/agent/src/services/chatgpt.service.js +0 -46
  136. package/bootstrap/services/agent/src/services/manifest.service.js +0 -21
  137. package/bootstrap/services/portal/Dockerfile.remote +0 -40
  138. package/bootstrap/services/portal/public/favicon.ico +0 -0
  139. package/bootstrap/services/portal/public/gnar-white.png +0 -0
  140. package/bootstrap/services/portal/public/gnarengine-logo-black.png +0 -0
  141. package/bootstrap/services/portal/public/index.html +0 -43
  142. package/bootstrap/services/portal/public/logo192.png +0 -0
  143. package/bootstrap/services/portal/public/logo512.png +0 -0
  144. package/bootstrap/services/portal/public/manifest.json +0 -25
  145. package/bootstrap/services/portal/public/robots.txt +0 -3
  146. package/bootstrap/services/portal/src/App.js +0 -56
  147. package/bootstrap/services/portal/src/assets/Logo_Anchord_Black.svg +0 -1
  148. package/bootstrap/services/portal/src/assets/Logo_Anchord_Black_Green.svg +0 -1
  149. package/bootstrap/services/portal/src/assets/Logo_Anchord_White_Green.svg +0 -1
  150. package/bootstrap/services/portal/src/assets/activity.svg +0 -3
  151. package/bootstrap/services/portal/src/assets/arrow.svg +0 -3
  152. package/bootstrap/services/portal/src/assets/bin-white.svg +0 -3
  153. package/bootstrap/services/portal/src/assets/bin.svg +0 -3
  154. package/bootstrap/services/portal/src/assets/check.svg +0 -3
  155. package/bootstrap/services/portal/src/assets/chevron.svg +0 -3
  156. package/bootstrap/services/portal/src/assets/contact.svg +0 -3
  157. package/bootstrap/services/portal/src/assets/dots-vertical.svg +0 -5
  158. package/bootstrap/services/portal/src/assets/eye-off.svg +0 -3
  159. package/bootstrap/services/portal/src/assets/eye.svg +0 -4
  160. package/bootstrap/services/portal/src/assets/gnar-engine-black.svg +0 -47
  161. package/bootstrap/services/portal/src/assets/gnar-engine-white.svg +0 -47
  162. package/bootstrap/services/portal/src/assets/gnar_engine.svg +0 -3
  163. package/bootstrap/services/portal/src/assets/gnarengine-logo-black.png +0 -0
  164. package/bootstrap/services/portal/src/assets/home.svg +0 -3
  165. package/bootstrap/services/portal/src/assets/link.svg +0 -3
  166. package/bootstrap/services/portal/src/assets/lock.svg +0 -3
  167. package/bootstrap/services/portal/src/assets/package.svg +0 -4
  168. package/bootstrap/services/portal/src/assets/raffle.svg +0 -3
  169. package/bootstrap/services/portal/src/assets/settings.svg +0 -4
  170. package/bootstrap/services/portal/src/assets/shopping-bag.svg +0 -3
  171. package/bootstrap/services/portal/src/assets/user-black.svg +0 -3
  172. package/bootstrap/services/portal/src/assets/user.svg +0 -3
  173. package/bootstrap/services/portal/src/assets/users.svg +0 -3
  174. package/bootstrap/services/portal/src/assets/wallet.svg +0 -3
  175. package/bootstrap/services/portal/src/data/data.js +0 -70
  176. package/bootstrap/services/portal/src/features/attributeFormRow/AttributeFormRow.jsx +0 -32
  177. package/bootstrap/services/portal/src/features/billingShipping/BillingShipping.jsx +0 -160
  178. package/bootstrap/services/portal/src/features/crud/crudEdit.less +0 -230
  179. package/bootstrap/services/portal/src/features/crud/crudList.less +0 -134
  180. package/bootstrap/services/portal/src/features/crud/crudPage.less +0 -31
  181. package/bootstrap/services/portal/src/features/crudContact/CrudContactList.jsx +0 -108
  182. package/bootstrap/services/portal/src/features/crudContact/CrudContactSingle.jsx +0 -243
  183. package/bootstrap/services/portal/src/features/crudOrder/CrudOrderList.jsx +0 -109
  184. package/bootstrap/services/portal/src/features/crudOrder/CrudOrderSingle.jsx +0 -315
  185. package/bootstrap/services/portal/src/features/crudProducts/CrudProductList.jsx +0 -104
  186. package/bootstrap/services/portal/src/features/crudProducts/CrudProductSingle.jsx +0 -388
  187. package/bootstrap/services/portal/src/features/crudRaffles/CrudRafflesList.jsx +0 -104
  188. package/bootstrap/services/portal/src/features/crudRaffles/CrudRafflesSingle.jsx +0 -208
  189. package/bootstrap/services/portal/src/features/crudSubscription/CrudSubscriptionList.jsx +0 -110
  190. package/bootstrap/services/portal/src/features/crudSubscription/CrudSubscriptionSingle.jsx +0 -261
  191. package/bootstrap/services/portal/src/features/crudUser/CrudUserList.jsx +0 -107
  192. package/bootstrap/services/portal/src/features/crudUser/CrudUserSingle.jsx +0 -402
  193. package/bootstrap/services/portal/src/features/inventoryFormRow/InventoryFormRow.jsx +0 -30
  194. package/bootstrap/services/portal/src/features/lineItems/LineItems.jsx +0 -113
  195. package/bootstrap/services/portal/src/features/loginForm/LoginForm.jsx +0 -56
  196. package/bootstrap/services/portal/src/features/loginForm/loginForm.less +0 -56
  197. package/bootstrap/services/portal/src/features/notes/Notes.jsx +0 -18
  198. package/bootstrap/services/portal/src/features/passwordReset/PasswordResetForm.jsx +0 -96
  199. package/bootstrap/services/portal/src/features/passwordReset/PasswordResetRequestForm.jsx +0 -74
  200. package/bootstrap/services/portal/src/features/priceFormRow/PriceFormRow.jsx +0 -102
  201. package/bootstrap/services/portal/src/features/priceFormRow/priceFormRow.less +0 -24
  202. package/bootstrap/services/portal/src/features/raffleEntriesList/RaffleEntriesList.jsx +0 -99
  203. package/bootstrap/services/portal/src/features/raffleProductFormRow/RaffleProductFormRow.jsx +0 -46
  204. package/bootstrap/services/portal/src/features/sidebar/Sidebar.jsx +0 -64
  205. package/bootstrap/services/portal/src/features/sidebar/sidebar.less +0 -49
  206. package/bootstrap/services/portal/src/features/skus/Skus.jsx +0 -109
  207. package/bootstrap/services/portal/src/features/subscriptionSchedule/SubscriptionSchedule.jsx +0 -44
  208. package/bootstrap/services/portal/src/features/taxonomyFormRow/TaxonomyFormRow.jsx +0 -32
  209. package/bootstrap/services/portal/src/features/user/User.jsx +0 -54
  210. package/bootstrap/services/portal/src/features/user/user.less +0 -57
  211. package/bootstrap/services/portal/src/includes/utilities.js +0 -259
  212. package/bootstrap/services/portal/src/index.js +0 -14
  213. package/bootstrap/services/portal/src/layouts/CrudLayout.jsx +0 -50
  214. package/bootstrap/services/portal/src/layouts/LoginLayout.jsx +0 -17
  215. package/bootstrap/services/portal/src/layouts/PortalLayout.jsx +0 -48
  216. package/bootstrap/services/portal/src/layouts/loginLayout.less +0 -33
  217. package/bootstrap/services/portal/src/layouts/portalLayout.less +0 -67
  218. package/bootstrap/services/portal/src/pages/contacts/Contacts.jsx +0 -199
  219. package/bootstrap/services/portal/src/pages/dashboard/Dashboard.jsx +0 -17
  220. package/bootstrap/services/portal/src/pages/integrations/Integrations.jsx +0 -10
  221. package/bootstrap/services/portal/src/pages/login/Login.jsx +0 -15
  222. package/bootstrap/services/portal/src/pages/login/login.less +0 -10
  223. package/bootstrap/services/portal/src/pages/orders/Orders.jsx +0 -199
  224. package/bootstrap/services/portal/src/pages/passwordReset/PasswordResetPage.jsx +0 -15
  225. package/bootstrap/services/portal/src/pages/passwordResetRequest/PasswordResetRequestPage.jsx +0 -15
  226. package/bootstrap/services/portal/src/pages/payments/Payments.jsx +0 -10
  227. package/bootstrap/services/portal/src/pages/portal/Portal.jsx +0 -43
  228. package/bootstrap/services/portal/src/pages/products/Products.jsx +0 -212
  229. package/bootstrap/services/portal/src/pages/raffleEntries/RaffleEntries.jsx +0 -124
  230. package/bootstrap/services/portal/src/pages/raffles/Raffles.jsx +0 -186
  231. package/bootstrap/services/portal/src/pages/reports/Reports.jsx +0 -10
  232. package/bootstrap/services/portal/src/pages/settings/Settings.jsx +0 -10
  233. package/bootstrap/services/portal/src/pages/subscriptions/Subscriptions.jsx +0 -199
  234. package/bootstrap/services/portal/src/pages/users/Users.jsx +0 -193
  235. package/bootstrap/services/portal/src/pages/users/users.less +0 -25
  236. package/bootstrap/services/portal/src/styles/inputs.less +0 -157
  237. package/bootstrap/services/portal/src/styles/main.less +0 -26
  238. package/bootstrap/services/portal/src/ui/collapsible/Collapsible.jsx +0 -97
  239. package/bootstrap/services/portal/src/ui/collapsible/collapsible.less +0 -23
  240. package/bootstrap/services/portal/src/ui/customCheckbox/CustomCheckbox.jsx +0 -17
  241. package/bootstrap/services/portal/src/ui/customCheckbox/customCheckbox.less +0 -42
  242. package/bootstrap/services/portal/src/ui/customMultiSelect/CustomMultiSelect.jsx +0 -63
  243. package/bootstrap/services/portal/src/ui/customMultiSelect/CustomMultiSelectPeriod.jsx +0 -63
  244. package/bootstrap/services/portal/src/ui/goBack/GoBack.jsx +0 -19
  245. package/bootstrap/services/portal/src/ui/loader/Loader.jsx +0 -12
  246. package/bootstrap/services/portal/src/ui/pagination/Pagination.jsx +0 -23
  247. package/bootstrap/services/portal/src/ui/repeater/Repeater.jsx +0 -29
  248. package/bootstrap/services/portal/src/ui/saveButton/SaveButton.jsx +0 -69
  249. package/bootstrap/services/user/src/db/seeders/development/02-portal-admin-user.js +0 -27
  250. package/bootstrap/services/user/src/tests/user.test.js +0 -126
  251. package/templates/service/app.js.hbs +0 -38
  252. package/templates/service/schema/{{serviceName}}.schema.js.hbs +0 -14
  253. /package/bootstrap/services/portal/src/{ui/saveButton/saveButton.less → components/CustomSelect/CustomSelect.less} +0 -0
  254. /package/templates/service/{controllers → src/controllers}/http.controller.js.hbs +0 -0
  255. /package/templates/service/{controllers → src/controllers}/message.controller.js.hbs +0 -0
  256. /package/templates/service/{db → src/mysql.db}/migrations/01-init.js.hbs +0 -0
  257. /package/templates/service/{db → src/mysql.db}/migrations/02-{{lowerCase serviceName}}-service-init.js.hbs +0 -0
  258. /package/templates/service/{policies → src/policies}/{{serviceName}}.policy.js.hbs +0 -0
  259. /package/templates/service/{services/{{serviceName}}.service.js.hbs → src/services/mysql.{{serviceName}}.service.js.hbs} +0 -0
@@ -1,134 +0,0 @@
1
- .crud-list {
2
- width: 100%; /* Adjust width as needed */
3
- margin-bottom: 20px; /* Adjust margin as needed */
4
-
5
- .custom-table {
6
- width: 100%;
7
- border-collapse: collapse;
8
- border-spacing: 0px;
9
- border: none;
10
-
11
- .separator-row {
12
- display: inline-block;
13
- }
14
-
15
- .checkbox {
16
- display: flex;
17
- align-items: center;
18
- }
19
-
20
- th {
21
- background-color: @dark-grey-1;
22
- color: @white;
23
- text-align: left;
24
- padding: 10px;
25
- text-transform: capitalize;
26
-
27
- &:first-child {
28
- border-top-left-radius: 10px;
29
- }
30
-
31
- &:last-child {
32
- border-top-right-radius: 10px;
33
- width: 12%;
34
- }
35
- }
36
-
37
- td {
38
- padding: 5px 10px;
39
- border: none;
40
-
41
- &:last-child {
42
- border-bottom: none;
43
- }
44
-
45
- &.edit-dots {
46
- text-align: start;
47
- }
48
- }
49
-
50
- tbody {
51
-
52
- button {
53
- width: 20px;
54
- background: none;
55
- border: none;
56
- margin: 0;
57
- }
58
- tr {
59
- border-top:1px solid transparent;
60
- border-bottom:1px solid transparent;
61
-
62
- td {
63
- line-height: 1em;
64
- &:first-child {
65
- border-left: 1px solid @grey-mid-1;
66
- }
67
- &:last-child {
68
- border-right: 1px solid @grey-mid-1;
69
- }
70
- }
71
- }
72
- tr:first-of-type {
73
- td {
74
- border-top: 1px solid @grey-mid-1;
75
- &:first-child {
76
- border-left: 1px solid @grey-mid-1;
77
- }
78
- &:last-child {
79
- border-right: 1px solid @grey-mid-1;
80
- }
81
- }
82
- }
83
- tr:last-of-type {
84
- td {
85
- border-bottom: 1px solid @grey-mid-1;
86
- &:first-child {
87
- border-left: 1px solid @grey-mid-1;
88
- border-bottom-left-radius: 10px;
89
- }
90
- &:last-child {
91
- border-right: 1px solid @grey-mid-1;
92
- border-bottom-right-radius: 10px;
93
- }
94
- }
95
- }
96
-
97
- tr:nth-child(even) {
98
- td {
99
- background-color: #f1f1f1;
100
- }
101
- }
102
-
103
- // HOVER EFFECT
104
- tr:hover td {
105
- border-top: 1px solid @green-1;
106
- border-bottom: 1px solid @green-1;
107
- cursor: pointer;
108
- }
109
-
110
- tr:hover td:first-child {
111
- border-left: 1px solid @green-1;
112
- cursor: pointer;
113
- }
114
-
115
- tr:hover td:last-child {
116
- border-right: 1px solid @green-1;
117
- cursor: pointer;
118
- }
119
- }
120
- }
121
- }
122
-
123
- .pagination-labels-cont {
124
- display: flex;
125
- flex-direction: row;
126
- justify-content: space-between;
127
- align-items: center;
128
- }
129
-
130
- .pagination-count {
131
- margin-bottom: 20px;
132
- text-align: left;
133
- font-size: 12px;
134
- }
@@ -1,31 +0,0 @@
1
- .crud-page,
2
- .manage-students {
3
- position: relative;
4
-
5
- .flex-row-select-cont {
6
- margin-top: 50px;
7
- }
8
-
9
- .clear-filters-btn {
10
- position: absolute;
11
- top: 65px;
12
- right: 5px;
13
-
14
- &:hover {
15
- cursor: pointer;
16
- opacity: 0.8;
17
- }
18
- }
19
-
20
- .password-reset-btn {
21
- display: block;
22
- position: relative;
23
- color: @green-1;
24
- text-decoration: underline;
25
-
26
- &:hover {
27
- cursor: pointer;
28
- opacity: 0.8;
29
- }
30
- }
31
- }
@@ -1,108 +0,0 @@
1
- import React, { useState, useEffect } from 'react';
2
- import gnarEngine from '@gnar-engine/js-client';
3
- import CustomCheckbox from '../../ui/customCheckbox/CustomCheckbox';
4
-
5
- const CrudContactList = ({ setSelectedSingleItemId, setView, selectedContactIds, setSelectedContactIds, contacts, message}) => {
6
-
7
- const allSelected = contacts.length > 0 && selectedContactIds.size === contacts.length;
8
-
9
- const toggleContactSelection = (contactId) => {
10
- setSelectedContactIds(prev => {
11
- const newSet = new Set(prev);
12
- if (newSet.has(contactId)) {
13
- newSet.delete(contactId);
14
- } else {
15
- newSet.add(contactId);
16
- }
17
- return newSet;
18
- });
19
- };
20
-
21
-
22
- const toggleSelectAll = () => {
23
- if (allSelected) {
24
- setSelectedContactIds(new Set());
25
- } else {
26
- setSelectedContactIds(new Set(contacts.map(contact => contact.id)));
27
- }
28
- };
29
-
30
-
31
- const handleEditClick = (product) => {
32
- setSelectedSingleItemId(product.id);
33
- setView('single');
34
- };
35
-
36
- const columns = [
37
- { columnLabel: 'ID', dataKey: 'id' },,
38
- { columnLabel: 'First Name', dataKey: 'firstName' },
39
- { columnLabel: 'Last Name', dataKey: 'lastName' },
40
- { columnLabel: 'Email', dataKey: 'email' },
41
- { columnLabel: 'Date Added', dataKey: 'createdAt' }
42
- ];
43
-
44
-
45
- return (
46
- <div className="">
47
- <div className='pagination-labels-cont'>
48
- <div className='pagination-count'>
49
- Showing {contacts.length} of {contacts.length} contact{contacts.length !== 1 ? 's' : ''}
50
- </div>
51
- <div className="pagination-count">
52
- {selectedContactIds.size} of {contacts.length} user{contacts.length !== 1 ? 's' : ''} selected
53
- </div>
54
- </div>
55
- <div className='crud-list'>
56
- <table className='custom-table'>
57
- <thead>
58
- <tr>
59
- <th className="checkbox">
60
- <CustomCheckbox
61
- name="selectAll"
62
- checked={allSelected}
63
- setChecked={toggleSelectAll}
64
- />
65
- </th>
66
- {columns.map(column => (
67
- <th key={column.columnLabel}>{column.columnLabel}</th>
68
- ))}
69
- </tr>
70
- </thead>
71
-
72
- <tbody>
73
- {message ? (
74
- <tr>
75
- <td colSpan={columns.length + 1}>{message}</td>
76
- </tr>
77
- ) : (
78
- contacts.length > 0 ? (
79
- contacts.map(contact => (
80
- <tr key={contact.id} onClick={() => handleEditClick(contact)}>
81
- <td>
82
- <CustomCheckbox
83
- name={`checkbox-${contact.id}`}
84
- checked={selectedContactIds.has(contact.id)}
85
- setChecked={() => toggleContactSelection(contact.id)}
86
- />
87
- </td>
88
- {columns.map(column => (
89
- <td key={column.dataKey}>{contact[column.dataKey]}</td>
90
- ))}
91
- </tr>
92
- ))
93
- ) : (
94
- <tr>
95
- <td colSpan={columns.length + 1}>No contacts found</td>
96
- </tr>
97
- )
98
- )}
99
- </tbody>
100
- </table>
101
- </div>
102
- </div>
103
-
104
- );
105
-
106
- };
107
-
108
- export default CrudContactList;
@@ -1,243 +0,0 @@
1
- import { useEffect, useState } from "react";
2
- import gnarEngine from '@gnar-engine/js-client';
3
- import DatePicker from "react-datepicker";
4
- import SaveButton from "../../ui/saveButton/SaveButton";
5
-
6
- const CrudContactSingle = ({ loading, setLoading, contact, setView, refreshSelectedContact, setContact, fetchContacts, formatDate, setSelectedSingleItemId }) => {
7
-
8
- const [formData, setFormData] = useState({
9
- firstName: '',
10
- lastName: '',
11
- email: '',
12
- phone: '',
13
- dateOfBirth: '',
14
- marketingOptIn: false,
15
- });
16
- const [validationErrors, setValidationErrors] = useState([]);
17
-
18
-
19
- // Load contact details if editing
20
- useEffect(() => {
21
- if (contact) {
22
- setFormData({
23
- firstName: contact.firstName,
24
- lastName: contact.lastName,
25
- email: contact.email,
26
- phone: contact.phone,
27
- dateOfBirth: contact.dateOfBirth,
28
- marketingOptIn: contact.marketingOptIn || false,
29
- });
30
- }
31
- }, [contact]);
32
-
33
-
34
-
35
- const handleSubmit = async (e) => {
36
- e.preventDefault();
37
- setLoading('loading');
38
- setValidationErrors([]);
39
-
40
- try {
41
-
42
- if (contact) {
43
- const response = await gnarEngine.contacts.update(contact._id, formData);
44
- console.log('response:', response);
45
-
46
- setLoading('success');
47
- setTimeout(() => {
48
- setLoading(null);
49
- fetchContacts();
50
- refreshSelectedContact();
51
- }, 3000);
52
-
53
- refreshSelectedContact();
54
- } else {
55
-
56
- const response = await gnarEngine.contacts.createContact({
57
- contacts : [formData]
58
- });
59
- console.log('response:', response);
60
-
61
- if (response.error) {
62
- setValidationErrors(response.error);
63
- } else {
64
-
65
- setLoading('success');
66
- setTimeout(() => {
67
- setLoading(null);
68
- fetchContacts();
69
- setView('list');
70
- }, 3000);
71
-
72
- }
73
- }
74
- }
75
- catch (error) {
76
- console.error('Error updating contact:', error);
77
- setValidationErrors(['Error updating contact']);
78
- setTimeout(() => {
79
- setLoading(null);
80
- }, 3000);
81
- }
82
-
83
-
84
- }
85
-
86
- // handle delete user
87
- const handleDelete = async () => {
88
- if (window.confirm('Are you sure you want to delete this contact?')) {
89
- try {
90
- setLoading('loading');
91
-
92
- await gnarEngine.contacts.delete(contact._id);
93
-
94
- setLoading('success');
95
- setTimeout(() => {
96
- setLoading(null);
97
- }, 3000);
98
-
99
- refreshSelectedContact();
100
- setView('list');
101
-
102
- } catch (error) {
103
-
104
- setLoading('error');
105
- console.error('Error deleting contact:', error);
106
- }
107
- } else {
108
- console.log('Deletion canceled');
109
- }
110
- };
111
-
112
-
113
-
114
-
115
-
116
- return (
117
-
118
- <div className="single-edit contact">
119
- {validationErrors.length > 0 &&
120
- <div className="error-messages">
121
- {validationErrors.map((error, index) => {
122
- return <p key={index}>{error}</p>
123
- })}
124
- </div>
125
- }
126
-
127
- <div className='single-edit-header'>
128
- <div className='single-edit-header-left'>
129
- <h2>{contact ? 'Edit Contact' : 'Add New Contact'}</h2>
130
- </div>
131
- <div className='single-edit-header-right'>
132
- <div className="flex-row-buttons-cont">
133
- <button onClick={() => {
134
- setView('list');
135
- setContact(null);
136
- setSelectedSingleItemId(null);
137
- }} className="secondaryButton">
138
- Back
139
- </button>
140
- <button onClick={handleDelete} className="secondaryButton">Delete</button>
141
- <SaveButton
142
- save={handleSubmit}
143
- loading={loading}
144
- textCreate="Add Contact"
145
- textCreateLoading="Saving..."
146
- textCreateSuccess="Saved"
147
- textCreateError="Error"
148
- textUpdate="Save"
149
- textUpdateLoading="Updating..."
150
- textUpdateSuccess="Updated"
151
- textUpdateError="Error"
152
- isUpdating={!!contact}
153
- />
154
- </div>
155
- </div>
156
- </div>
157
- <div className="card">
158
- <div className='card-header'>
159
- <h2>Contact Details</h2>
160
- </div>
161
- <div className='card-content'>
162
- <form onSubmit={handleSubmit}>
163
- <div className="form-group">
164
- <label htmlFor="firstName">First Name</label>
165
- <input
166
- type="text"
167
- id="firstName"
168
- name="firstName"
169
- value={formData.firstName}
170
- onChange={(e) => setFormData({ ...formData, firstName: e.target.value })}
171
- />
172
- </div>
173
- <div className="form-group">
174
- <label htmlFor="lastName">Last Name</label>
175
- <input
176
- type="text"
177
- id="lastName"
178
- name="lastName"
179
- value={formData.lastName}
180
- onChange={(e) => setFormData({ ...formData, lastName: e.target.value })}
181
- />
182
- </div>
183
- <div className="form-group">
184
- <label htmlFor="email">Email</label>
185
- <input
186
- type="email"
187
- id="email"
188
- name="email"
189
- value={formData.email}
190
- onChange={(e) => setFormData({ ...formData, email: e.target.value })}
191
- />
192
- </div>
193
- <div className="form-group">
194
- <label htmlFor="phone">Phone</label>
195
- <input
196
- type="text"
197
- id="phone"
198
- name="phone"
199
- value={formData.phone}
200
- onChange={(e) => setFormData({ ...formData, phone: e.target.value })}
201
- />
202
- </div>
203
- <div className="form-group">
204
- <label htmlFor="dateOfBirth">Date of Birth (DD/MM/YYYY)</label>
205
- <DatePicker
206
- selected={formData.dateOfBirth ? new Date(formData.dateOfBirth) : null}
207
- onChange={(date) => {
208
- const formattedDate = date.toISOString().split('T')[0]; // Convert to YYYY-MM-DD format
209
- setFormData({ ...formData, dateOfBirth: formattedDate });
210
- }}
211
- dateFormat="dd/MM/yyyy"
212
- />
213
- </div>
214
- {/* marketingOptIn */}
215
- <div className="form-group">
216
- <label htmlFor="marketingOptIn">
217
- <input
218
- type="checkbox"
219
- id="marketingOptIn"
220
- name="marketingOptIn"
221
- checked={formData.marketingOptIn}
222
- onChange={(e) => setFormData({ ...formData, marketingOptIn: e.target.checked })}
223
- />
224
- Marketing Opt-In
225
- </label>
226
-
227
- </div>
228
- </form>
229
- <div>
230
- <p><strong>Date Added: </strong>{formatDate(contact?.createdAt)}</p>
231
- </div>
232
- </div>
233
-
234
-
235
-
236
- </div>
237
- </div>
238
-
239
- );
240
-
241
- };
242
-
243
- export default CrudContactSingle;
@@ -1,109 +0,0 @@
1
- import React, { useState, useEffect } from 'react';
2
- import gnarEngine from '@gnar-engine/js-client';
3
- import CustomCheckbox from '../../ui/customCheckbox/CustomCheckbox';
4
-
5
- const CrudOrderList = ({ setSelectedSingleItemId, setView, selectedOrderIds, setSelectedOrderIds, orders, message }) => {
6
-
7
- const allSelected = orders.length > 0 && selectedOrderIds.size === orders.length;
8
-
9
- const toggleContactSelection = (orderId) => {
10
- setSelectedOrderIds(prev => {
11
- const newSet = new Set(prev);
12
- if (newSet.has(orderId)) {
13
- newSet.delete(orderId);
14
- } else {
15
- newSet.add(orderId);
16
- }
17
- return newSet;
18
- });
19
- };
20
-
21
-
22
- const toggleSelectAll = () => {
23
- if (allSelected) {
24
- setSelectedOrderIds(new Set());
25
- } else {
26
- setSelectedOrderIds(new Set(orders.map(order => order.id)));
27
- }
28
- };
29
-
30
- const handleEditClick = (product) => {
31
- setSelectedSingleItemId(product.id);
32
- setView('single');
33
- };
34
-
35
- const columns = [
36
- { columnLabel: 'Order', dataKey: 'id' },
37
- { columnLabel: 'Type', dataKey: 'type' },
38
- { columnLabel: 'First Name', dataKey: 'firstName' },
39
- { columnLabel: 'Last Name', dataKey: 'lastName' },
40
- { columnLabel: 'Status', dataKey: 'status' },
41
- { columnLabel: 'Total', dataKey: 'total' },
42
- { columnLabel: 'Date added', dataKey: 'createdAt' },
43
- ];
44
-
45
-
46
- return (
47
- <div className="">
48
- <div className='pagination-labels-cont'>
49
- <div className='pagination-count'>
50
- Showing {orders.length} of {orders.length} order{orders.length !== 1 ? 's' : ''}
51
- </div>
52
- <div className="pagination-count">
53
- {selectedOrderIds.size} of {orders.length} order{orders.length !== 1 ? 's' : ''} selected
54
- </div>
55
- </div>
56
- <div className='crud-list'>
57
- <table className='custom-table'>
58
- <thead>
59
- <tr>
60
- <th className="checkbox">
61
- <CustomCheckbox
62
- name="selectAll"
63
- checked={allSelected}
64
- setChecked={toggleSelectAll}
65
- />
66
- </th>
67
- {columns.map(column => (
68
- <th key={column.columnLabel}>{column.columnLabel}</th>
69
- ))}
70
- </tr>
71
- </thead>
72
-
73
- <tbody>
74
- {message ? (
75
- <tr>
76
- <td colSpan={columns.length + 1}>{message}</td>
77
- </tr>
78
- ) : (
79
- orders.length > 0 ? (
80
- orders.map(order => (
81
- <tr key={order.id} onClick={() => handleEditClick(order)}>
82
- <td>
83
- <CustomCheckbox
84
- name={`checkbox-${order.id}`}
85
- checked={selectedOrderIds.has(order.id)}
86
- setChecked={() => toggleContactSelection(order.id)}
87
- />
88
- </td>
89
- {columns.map(column => (
90
- <td key={column.dataKey}>{order[column.dataKey]}</td>
91
- ))}
92
- </tr>
93
- ))
94
- ) : (
95
- <tr>
96
- <td colSpan={columns.length + 1}>No orders found</td>
97
- </tr>
98
- )
99
- )}
100
- </tbody>
101
- </table>
102
- </div>
103
- </div>
104
-
105
- );
106
-
107
- };
108
-
109
- export default CrudOrderList;