@hedhog/admin 0.48.5 → 0.48.7

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 (170) hide show
  1. package/dist/admin.module.d.ts.map +1 -1
  2. package/dist/admin.module.js +2 -0
  3. package/dist/admin.module.js.map +1 -1
  4. package/dist/auth/consts/body.d.ts.map +1 -1
  5. package/dist/dashboard/dashboard/dashboard.controller.d.ts +22 -0
  6. package/dist/dashboard/dashboard/dashboard.controller.d.ts.map +1 -0
  7. package/dist/dashboard/dashboard/dashboard.controller.js +88 -0
  8. package/dist/dashboard/dashboard/dashboard.controller.js.map +1 -0
  9. package/dist/dashboard/dashboard/dashboard.module.d.ts +3 -0
  10. package/dist/dashboard/dashboard/dashboard.module.d.ts.map +1 -0
  11. package/dist/dashboard/dashboard/dashboard.module.js +26 -0
  12. package/dist/dashboard/dashboard/dashboard.module.js.map +1 -0
  13. package/dist/dashboard/dashboard/dashboard.service.d.ts +30 -0
  14. package/dist/dashboard/dashboard/dashboard.service.d.ts.map +1 -0
  15. package/dist/dashboard/dashboard/dashboard.service.js +61 -0
  16. package/dist/dashboard/dashboard/dashboard.service.js.map +1 -0
  17. package/dist/dashboard/dashboard/dto/create.dto.d.ts +5 -0
  18. package/dist/dashboard/dashboard/dto/create.dto.d.ts.map +1 -0
  19. package/dist/dashboard/dashboard/dto/create.dto.js +23 -0
  20. package/dist/dashboard/dashboard/dto/create.dto.js.map +1 -0
  21. package/dist/dashboard/dashboard/dto/update.dto.d.ts +6 -0
  22. package/dist/dashboard/dashboard/dto/update.dto.d.ts.map +1 -0
  23. package/dist/dashboard/dashboard/dto/update.dto.js +9 -0
  24. package/dist/dashboard/dashboard/dto/update.dto.js.map +1 -0
  25. package/dist/dashboard/dashboard-component/dashboard-component.controller.d.ts +22 -0
  26. package/dist/dashboard/dashboard-component/dashboard-component.controller.d.ts.map +1 -0
  27. package/dist/dashboard/dashboard-component/dashboard-component.controller.js +90 -0
  28. package/dist/dashboard/dashboard-component/dashboard-component.controller.js.map +1 -0
  29. package/dist/dashboard/dashboard-component/dashboard-component.module.d.ts +3 -0
  30. package/dist/dashboard/dashboard-component/dashboard-component.module.d.ts.map +1 -0
  31. package/dist/dashboard/dashboard-component/dashboard-component.module.js +26 -0
  32. package/dist/dashboard/dashboard-component/dashboard-component.module.js.map +1 -0
  33. package/dist/dashboard/dashboard-component/dashboard-component.service.d.ts +30 -0
  34. package/dist/dashboard/dashboard-component/dashboard-component.service.d.ts.map +1 -0
  35. package/dist/dashboard/dashboard-component/dashboard-component.service.js +59 -0
  36. package/dist/dashboard/dashboard-component/dashboard-component.service.js.map +1 -0
  37. package/dist/dashboard/dashboard-component/dto/create.dto.d.ts +13 -0
  38. package/dist/dashboard/dashboard-component/dto/create.dto.d.ts.map +1 -0
  39. package/dist/dashboard/dashboard-component/dto/create.dto.js +59 -0
  40. package/dist/dashboard/dashboard-component/dto/create.dto.js.map +1 -0
  41. package/dist/dashboard/dashboard-component/dto/update.dto.d.ts +6 -0
  42. package/dist/dashboard/dashboard-component/dto/update.dto.d.ts.map +1 -0
  43. package/dist/dashboard/dashboard-component/dto/update.dto.js +9 -0
  44. package/dist/dashboard/dashboard-component/dto/update.dto.js.map +1 -0
  45. package/dist/dashboard/dashboard-item/dashboard-item.controller.d.ts +52 -0
  46. package/dist/dashboard/dashboard-item/dashboard-item.controller.d.ts.map +1 -0
  47. package/dist/dashboard/dashboard-item/dashboard-item.controller.js +88 -0
  48. package/dist/dashboard/dashboard-item/dashboard-item.controller.js.map +1 -0
  49. package/dist/dashboard/dashboard-item/dashboard-item.module.d.ts +3 -0
  50. package/dist/dashboard/dashboard-item/dashboard-item.module.d.ts.map +1 -0
  51. package/dist/dashboard/dashboard-item/dashboard-item.module.js +26 -0
  52. package/dist/dashboard/dashboard-item/dashboard-item.module.js.map +1 -0
  53. package/dist/dashboard/dashboard-item/dashboard-item.service.d.ts +57 -0
  54. package/dist/dashboard/dashboard-item/dashboard-item.service.d.ts.map +1 -0
  55. package/dist/dashboard/dashboard-item/dashboard-item.service.js +77 -0
  56. package/dist/dashboard/dashboard-item/dashboard-item.service.js.map +1 -0
  57. package/dist/dashboard/dashboard-item/dto/create.dto.d.ts +9 -0
  58. package/dist/dashboard/dashboard-item/dto/create.dto.d.ts.map +1 -0
  59. package/dist/dashboard/dashboard-item/dto/create.dto.js +41 -0
  60. package/dist/dashboard/dashboard-item/dto/create.dto.js.map +1 -0
  61. package/dist/dashboard/dashboard-item/dto/update.dto.d.ts +6 -0
  62. package/dist/dashboard/dashboard-item/dto/update.dto.d.ts.map +1 -0
  63. package/dist/dashboard/dashboard-item/dto/update.dto.js +9 -0
  64. package/dist/dashboard/dashboard-item/dto/update.dto.js.map +1 -0
  65. package/dist/dashboard/dashboard-user/dashboard-user.controller.d.ts +52 -0
  66. package/dist/dashboard/dashboard-user/dashboard-user.controller.d.ts.map +1 -0
  67. package/dist/dashboard/dashboard-user/dashboard-user.controller.js +88 -0
  68. package/dist/dashboard/dashboard-user/dashboard-user.controller.js.map +1 -0
  69. package/dist/dashboard/dashboard-user/dashboard-user.module.d.ts +3 -0
  70. package/dist/dashboard/dashboard-user/dashboard-user.module.d.ts.map +1 -0
  71. package/dist/dashboard/dashboard-user/dashboard-user.module.js +26 -0
  72. package/dist/dashboard/dashboard-user/dashboard-user.module.js.map +1 -0
  73. package/dist/dashboard/dashboard-user/dashboard-user.service.d.ts +59 -0
  74. package/dist/dashboard/dashboard-user/dashboard-user.service.d.ts.map +1 -0
  75. package/dist/dashboard/dashboard-user/dashboard-user.service.js +83 -0
  76. package/dist/dashboard/dashboard-user/dashboard-user.service.js.map +1 -0
  77. package/dist/dashboard/dashboard-user/dto/create.dto.d.ts +10 -0
  78. package/dist/dashboard/dashboard-user/dto/create.dto.d.ts.map +1 -0
  79. package/dist/dashboard/dashboard-user/dto/create.dto.js +42 -0
  80. package/dist/dashboard/dashboard-user/dto/create.dto.js.map +1 -0
  81. package/dist/dashboard/dashboard-user/dto/update.dto.d.ts +6 -0
  82. package/dist/dashboard/dashboard-user/dto/update.dto.d.ts.map +1 -0
  83. package/dist/dashboard/dashboard-user/dto/update.dto.js +9 -0
  84. package/dist/dashboard/dashboard-user/dto/update.dto.js.map +1 -0
  85. package/dist/dashboard/dashboard.module.d.ts +3 -0
  86. package/dist/dashboard/dashboard.module.d.ts.map +1 -0
  87. package/dist/dashboard/dashboard.module.js +35 -0
  88. package/dist/dashboard/dashboard.module.js.map +1 -0
  89. package/dist/dashboard/index.d.ts +2 -0
  90. package/dist/dashboard/index.d.ts.map +1 -0
  91. package/dist/dashboard/index.js +18 -0
  92. package/dist/dashboard/index.js.map +1 -0
  93. package/dist/emails/lib.d.ts.map +1 -1
  94. package/frontend/dashboard/components/create-panel.tsx.ejs +63 -0
  95. package/frontend/dashboard/components/dashboard.screen.tsx.ejs +116 -0
  96. package/frontend/dashboard/components/update-panel.tsx.ejs +80 -0
  97. package/frontend/dashboard/locales/en/dashboard.dashboard.json +11 -0
  98. package/frontend/dashboard/locales/pt/dashboard.dashboard.json +11 -0
  99. package/frontend/dashboard/react-query/handlers.ts.ejs +28 -0
  100. package/frontend/dashboard/react-query/requests.ts.ejs +56 -0
  101. package/frontend/dashboard-component/components/create-panel.tsx.ejs +130 -0
  102. package/frontend/dashboard-component/components/dashboard-component.screen.tsx.ejs +135 -0
  103. package/frontend/dashboard-component/components/update-panel.tsx.ejs +164 -0
  104. package/frontend/dashboard-component/locales/en/dashboard.dashboard-component.json +11 -0
  105. package/frontend/dashboard-component/locales/pt/dashboard.dashboard-component.json +11 -0
  106. package/frontend/dashboard-component/react-query/handlers.ts.ejs +28 -0
  107. package/frontend/dashboard-component/react-query/requests.ts.ejs +61 -0
  108. package/frontend/dashboard-item/components/create-panel.tsx.ejs +108 -0
  109. package/frontend/dashboard-item/components/dashboard-item.screen.tsx.ejs +133 -0
  110. package/frontend/dashboard-item/components/update-panel.tsx.ejs +141 -0
  111. package/frontend/dashboard-item/locales/en/dashboard.dashboard-item.json +11 -0
  112. package/frontend/dashboard-item/locales/pt/dashboard.dashboard-item.json +11 -0
  113. package/frontend/dashboard-item/react-query/handlers.ts.ejs +28 -0
  114. package/frontend/dashboard-item/react-query/requests.ts.ejs +58 -0
  115. package/frontend/dashboard-user/components/create-panel.tsx.ejs +108 -0
  116. package/frontend/dashboard-user/components/dashboard-user.screen.tsx.ejs +131 -0
  117. package/frontend/dashboard-user/components/update-panel.tsx.ejs +138 -0
  118. package/frontend/dashboard-user/locales/en/dashboard.dashboard-user.json +11 -0
  119. package/frontend/dashboard-user/locales/pt/dashboard.dashboard-user.json +11 -0
  120. package/frontend/dashboard-user/react-query/handlers.ts.ejs +28 -0
  121. package/frontend/dashboard-user/react-query/requests.ts.ejs +58 -0
  122. package/frontend/translation/fields/en.json +23 -1
  123. package/frontend/translation/fields/pt.json +27 -1
  124. package/frontend/translation/modules/en.json +6 -1
  125. package/frontend/translation/modules/pt.json +6 -1
  126. package/hedhog.yaml +439 -0
  127. package/package.json +2 -4
  128. package/src/admin.module.ts +2 -0
  129. package/src/dashboard/dashboard/dashboard.controller.ts +49 -0
  130. package/src/dashboard/dashboard/dashboard.module.ts +13 -0
  131. package/src/dashboard/dashboard/dashboard.service.ts +71 -0
  132. package/src/dashboard/dashboard/dto/create.dto.ts +8 -0
  133. package/src/dashboard/dashboard/dto/update.dto.ts +4 -0
  134. package/src/dashboard/dashboard-component/dashboard-component.controller.ts +55 -0
  135. package/src/dashboard/dashboard-component/dashboard-component.module.ts +14 -0
  136. package/src/dashboard/dashboard-component/dashboard-component.service.ts +70 -0
  137. package/src/dashboard/dashboard-component/dto/create.dto.ts +36 -0
  138. package/src/dashboard/dashboard-component/dto/update.dto.ts +4 -0
  139. package/src/dashboard/dashboard-item/dashboard-item.controller.ts +55 -0
  140. package/src/dashboard/dashboard-item/dashboard-item.module.ts +13 -0
  141. package/src/dashboard/dashboard-item/dashboard-item.service.ts +82 -0
  142. package/src/dashboard/dashboard-item/dto/create.dto.ts +22 -0
  143. package/src/dashboard/dashboard-item/dto/update.dto.ts +4 -0
  144. package/src/dashboard/dashboard-user/dashboard-user.controller.ts +55 -0
  145. package/src/dashboard/dashboard-user/dashboard-user.module.ts +13 -0
  146. package/src/dashboard/dashboard-user/dashboard-user.service.ts +89 -0
  147. package/src/dashboard/dashboard-user/dto/create.dto.ts +22 -0
  148. package/src/dashboard/dashboard-user/dto/update.dto.ts +4 -0
  149. package/src/dashboard/dashboard.module.ts +22 -0
  150. package/src/dashboard/index.ts +1 -0
  151. package/frontend/menu-locale/locales/en/admin.menu-locale.json +0 -11
  152. package/frontend/menu-locale/locales/pt/admin.menu-locale.json +0 -11
  153. package/frontend/menu-screen/locales/en/admin.menu-screen.json +0 -11
  154. package/frontend/menu-screen/locales/pt/admin.menu-screen.json +0 -11
  155. package/frontend/multifactor-locale/locales/en/admin.multifactor-locale.json +0 -11
  156. package/frontend/multifactor-locale/locales/pt/admin.multifactor-locale.json +0 -11
  157. package/frontend/screen-locale/locales/en/admin.screen-locale.json +0 -11
  158. package/frontend/screen-locale/locales/pt/admin.screen-locale.json +0 -11
  159. package/frontend/translation/components/create-panel.tsx.ejs +0 -52
  160. package/frontend/translation/components/update-panel.tsx.ejs +0 -67
  161. package/frontend/translation/locales/en/admin.translation.json +0 -11
  162. package/frontend/translation/locales/pt/admin.translation.json +0 -11
  163. package/frontend/translation/react-query/handlers.ts.ejs +0 -28
  164. package/frontend/translation/react-query/requests.ts.ejs +0 -58
  165. package/frontend/translation-namespace/components/create-panel.tsx.ejs +0 -53
  166. package/frontend/translation-namespace/components/update-panel.tsx.ejs +0 -70
  167. package/frontend/translation-namespace/locales/en/admin.translation-namespace.json +0 -11
  168. package/frontend/translation-namespace/locales/pt/admin.translation-namespace.json +0 -11
  169. package/frontend/translation-namespace/react-query/handlers.ts.ejs +0 -28
  170. package/frontend/translation-namespace/react-query/requests.ts.ejs +0 -60
@@ -0,0 +1,61 @@
1
+ import { useApp } from "@/hooks/use-app";
2
+ import { Delete, PaginationParams, PaginationResult } from "@/types";
3
+ import { DashboardComponent } from "@/types/models";
4
+ import { HttpMethod } from "@/types/http-method";
5
+ import { formatDataWithLocale } from "@hedhog/utils";
6
+
7
+ export function requests() {
8
+ const { request } = useApp();
9
+
10
+ const dashboardComponentList = async (params: PaginationParams) => {
11
+ return request<PaginationResult<DashboardComponent>>({
12
+ url: "/dashboard-component",
13
+ params,
14
+ }).then((res) => res.data);
15
+ };
16
+
17
+ const dashboardComponentGet = async (id: number) => {
18
+ return request<DashboardComponent>({
19
+ url: `/dashboard-component/${id}`,
20
+ }).then((res) => res.data);
21
+ };
22
+
23
+ const dashboardComponentCreate = async (params: {
24
+ data: DashboardComponent;
25
+ }) => {
26
+ const { data } = params;
27
+ return request<DashboardComponent>({
28
+ url: "/dashboard-component",
29
+ method: HttpMethod.POST,
30
+ data: formatDataWithLocale(data),
31
+ }).then((res) => res.data);
32
+ };
33
+
34
+ const dashboardComponentDelete = async (ids: number[]) => {
35
+ return request<Delete>({
36
+ url: "/dashboard-component",
37
+ data: { ids },
38
+ method: HttpMethod.DELETE,
39
+ }).then((res) => res.data);
40
+ };
41
+
42
+ const dashboardComponentUpdate = async (params: {
43
+ id: number;
44
+ data: DashboardComponent;
45
+ }) => {
46
+ const { id, data } = params;
47
+ return request<DashboardComponent>({
48
+ url: `/dashboard-component/${id}`,
49
+ method: HttpMethod.PATCH,
50
+ data: formatDataWithLocale(data),
51
+ }).then((res) => res.data);
52
+ };
53
+
54
+ return {
55
+ dashboardComponentCreate,
56
+ dashboardComponentUpdate,
57
+ dashboardComponentDelete,
58
+ dashboardComponentList,
59
+ dashboardComponentGet,
60
+ };
61
+ }
@@ -0,0 +1,108 @@
1
+ import FormPanel, { FormPanelRef } from '@/components/panels/form-panel'
2
+ import { EnumFieldType } from '@/enums/EnumFieldType'
3
+ import { useDashboardItemCreate } from '@/features/dashboard/dashboard-item'
4
+ import { DashboardItem } from '@/types/models'
5
+ import { forwardRef, useImperativeHandle, useRef } from 'react'
6
+ import { useTranslation } from 'react-i18next'
7
+
8
+ export type DashboardItemCreatePanelRef = {
9
+ submit: () => void
10
+ }
11
+
12
+ export type DashboardItemCreatePanelProps = {
13
+ onCreated?: (data: DashboardItem) => void
14
+ }
15
+
16
+ const DashboardItemCreatePanel = forwardRef(
17
+ ({ onCreated }: DashboardItemCreatePanelProps, ref) => {
18
+ const formRef = useRef<FormPanelRef>(null)
19
+ const { t } = useTranslation(['actions', 'fields', 'translations'])
20
+ const { mutateAsync: createDashboardItem } = useDashboardItemCreate()
21
+
22
+ useImperativeHandle(
23
+ ref,
24
+ () => ({
25
+ submit: () => {
26
+ formRef.current?.submit()
27
+ },
28
+ }),
29
+ [formRef]
30
+ )
31
+
32
+ return (
33
+ <FormPanel
34
+ ref={formRef}
35
+ fields={[
36
+ {
37
+ name: 'component_id',
38
+ label: { text: t('dashboard-item.component_id', { ns: 'fields' }) },
39
+ type: EnumFieldType.COMBOBOX,
40
+ required: true,
41
+ url: '/dashboard-component',
42
+ displayName: 'component',
43
+ valueName: 'id',
44
+ },
45
+
46
+ {
47
+ name: 'dashboard_id',
48
+ label: { text: t('dashboard-item.dashboard_id', { ns: 'fields' }) },
49
+ type: EnumFieldType.COMBOBOX,
50
+ required: true,
51
+ url: '/dashboard',
52
+ displayName: 'dashboard',
53
+ valueName: 'id',
54
+ },
55
+
56
+ {
57
+ name: 'width',
58
+ label: { text: t('dashboard-user.width', { ns: 'fields' }) },
59
+ type: EnumFieldType.NUMBER,
60
+ required: true,
61
+ },
62
+
63
+ {
64
+ name: 'height',
65
+ label: { text: t('dashboard-user.height', { ns: 'fields' }) },
66
+ type: EnumFieldType.NUMBER,
67
+ required: true,
68
+ },
69
+
70
+ {
71
+ name: 'x_axis',
72
+ label: { text: t('dashboard-user.x_axis', { ns: 'fields' }) },
73
+ type: EnumFieldType.NUMBER,
74
+ required: true,
75
+ },
76
+
77
+ {
78
+ name: 'y_axis',
79
+ label: { text: t('dashboard-user.y_axis', { ns: 'fields' }) },
80
+ type: EnumFieldType.NUMBER,
81
+ required: true,
82
+ },
83
+ ]}
84
+ button={{ text: t('create', { ns: 'actions' }) }}
85
+ onSubmit={async (data) => {
86
+ const createdData = await createDashboardItem({
87
+ data: {
88
+ ...data,
89
+ component_id: Number(data.component_id),
90
+ dashboard_id: Number(data.dashboard_id),
91
+ width: Number(data.width),
92
+ height: Number(data.height),
93
+ x_axis: Number(data.x_axis),
94
+ y_axis: Number(data.y_axis),
95
+ },
96
+ })
97
+ if (typeof onCreated === 'function') {
98
+ onCreated(createdData as any)
99
+ }
100
+ }}
101
+ />
102
+ )
103
+ }
104
+ )
105
+
106
+ DashboardItemCreatePanel.displayName = 'DashboardItemCreatePanel'
107
+
108
+ export default DashboardItemCreatePanel
@@ -0,0 +1,133 @@
1
+ import { PageTitle } from '@/components/custom/page-title'
2
+ import DataPanel from '@/components/panels/data-panel'
3
+ import { useDashboardItemDelete } from '@/features/dashboard/dashboard-item'
4
+ import { useApp } from '@/hooks/use-app'
5
+ import { isPlural } from '@/lib/utils'
6
+ import { DashboardItem } from '@/types/models'
7
+ import { IconEdit, IconPlus, IconTrash } from '@tabler/icons-react'
8
+ import { useState } from 'react'
9
+ import { useTranslation } from 'react-i18next'
10
+ import DashboardItemCreatePanel from './components/dashboard-item-create-panel'
11
+ import DashboardItemUpdatePanel from './components/dashboard-item-update-panel'
12
+ import DashboardItemCard from '@/components/cards/dashboard-item-card'
13
+
14
+ export default function Page() {
15
+ const [selectedItems, setSelectedItems] = useState<DashboardItem[]>([])
16
+ const { mutate: deleteDashboarditem } = useDashboardItemDelete()
17
+ const { openSheet, confirm, closeSheet } = useApp()
18
+ const { t } = useTranslation([
19
+ 'dashboard.dashboard-item',
20
+ 'modules',
21
+ 'actions',
22
+ 'fields',
23
+ ])
24
+
25
+ const openCreate = () => {
26
+ const id = openSheet({
27
+ title: t('create', { ns: 'dashboard.dashboard-item' }),
28
+ description: t('createText', {
29
+ ns: 'dashboard.dashboard-item',
30
+ }),
31
+ children: () => (
32
+ <DashboardItemCreatePanel onCreated={() => closeSheet(id)} />
33
+ ),
34
+ })
35
+
36
+ return id
37
+ }
38
+
39
+ const openDelete = (items: DashboardItem[]) => {
40
+ return confirm({
41
+ title: `${t('delete', { ns: 'dashboard.dashboard-item' })} ${items.length} ${isPlural(items.length) ? t('items', { ns: 'actions' }) : t('item', { ns: 'actions' })}`,
42
+ description: t('deleteText', {
43
+ ns: 'dashboard.dashboard-item',
44
+ }),
45
+ })
46
+ .then(() =>
47
+ deleteDashboarditem(
48
+ items
49
+ .map((item) => (item as any).item_id)
50
+ .filter((id) => id !== undefined)
51
+ )
52
+ )
53
+ .catch(() => setSelectedItems(items))
54
+ }
55
+
56
+ const openUpdate = (item: DashboardItem) => {
57
+ const id = openSheet({
58
+ children: () => (
59
+ <DashboardItemUpdatePanel
60
+ data={item}
61
+ onUpdated={() => closeSheet(id)}
62
+ />
63
+ ),
64
+ title: t('edit', { ns: 'dashboard.dashboard-item' }),
65
+ description: t('editText', {
66
+ ns: 'dashboard.dashboard-item',
67
+ }),
68
+ })
69
+
70
+ return id
71
+ }
72
+
73
+ return (
74
+ <>
75
+ <PageTitle title={t('dashboard_item', { ns: 'modules' })} />
76
+ <DataPanel
77
+ url='/dashboard-item'
78
+ layout='grid'
79
+ id='dashboard-item'
80
+ selectable
81
+ render={(item: DashboardItem) => <DashboardItemCard item={item} />}
82
+ responsiveColumns={{
83
+ default: 1,
84
+ sm: 2,
85
+ md: 1,
86
+ lg: 2,
87
+ xl: 3,
88
+ }}
89
+ selected={selectedItems as DashboardItem[]}
90
+ multiple
91
+ hasSearch
92
+ onItemDoubleClick={(item) => openUpdate(item)}
93
+ menuActions={[
94
+ {
95
+ icon: <IconEdit className='mr-1 w-8 cursor-pointer' />,
96
+ label: t('edit', { ns: 'actions' }),
97
+ tooltip: t('editTooltip', {
98
+ ns: 'dashboard.dashboard-item',
99
+ }),
100
+ handler: (items: DashboardItem[]) => {
101
+ if (items.length === 1) openUpdate(items[0])
102
+ },
103
+ show: 'once',
104
+ },
105
+ {
106
+ icon: <IconTrash className='mr-1 w-8 cursor-pointer' />,
107
+ label: t('delete', { ns: 'actions' }),
108
+ tooltip: t('deleteTooltip', {
109
+ ns: 'dashboard.dashboard-item',
110
+ }),
111
+ variant: 'destructive',
112
+ handler: (items: DashboardItem[]) => {
113
+ openDelete(items)
114
+ },
115
+ show: 'some',
116
+ },
117
+ {
118
+ icon: <IconPlus className='mr-1 w-8 cursor-pointer' />,
119
+ label: t('create', { ns: 'actions' }),
120
+ tooltip: t('createTooltip', {
121
+ ns: 'dashboard.dashboard-item',
122
+ }),
123
+ variant: 'default',
124
+ handler: () => {
125
+ openCreate()
126
+ },
127
+ show: 'none',
128
+ },
129
+ ]}
130
+ />
131
+ </>
132
+ )
133
+ }
@@ -0,0 +1,141 @@
1
+ import FormPanel, { FormPanelRef } from '@/components/panels/form-panel'
2
+ import { Overlay } from '@/components/custom/overlay'
3
+ import { TabPanel } from '@/components/panels/tab-panel'
4
+ import {
5
+ useDashboardItemGet,
6
+ useDashboardItemUpdate,
7
+ } from '@/features/dashboard/dashboard-item'
8
+ import useEffectAfterFirstUpdate from '@/hooks/use-effect-after-first-update'
9
+ import { DashboardItem } from '@/types/models'
10
+ import { forwardRef, useImperativeHandle, useRef } from 'react'
11
+ import { useTranslation } from 'react-i18next'
12
+ import { EnumFieldType } from '@/enums/EnumFieldType'
13
+
14
+ export type DashboardItemUpdatePanelProps = {
15
+ data: DashboardItem
16
+ onUpdated?: (data: DashboardItem) => void
17
+ }
18
+
19
+ const DashboardItemUpdatePanel = forwardRef(
20
+ ({ data, onUpdated }: DashboardItemUpdatePanelProps, ref) => {
21
+ const { t } = useTranslation(['actions', 'fields', 'translations'])
22
+ const { data: item, isLoading } = useDashboardItemGet(
23
+ (data as any).id as number
24
+ )
25
+ const { mutate: dashboardItemUpdate } = useDashboardItemUpdate()
26
+ const formRef = useRef<FormPanelRef>(null)
27
+
28
+ useEffectAfterFirstUpdate(() => {
29
+ if (item && formRef.current) {
30
+ formRef.current.setValuesFromItem(item)
31
+ }
32
+ }, [item])
33
+
34
+ useImperativeHandle(ref, () => ({}))
35
+
36
+ return (
37
+ <TabPanel
38
+ activeTabIndex={0}
39
+ tabs={[
40
+ {
41
+ title: t('details', { ns: 'actions' }),
42
+ children: (
43
+ <Overlay loading={isLoading}>
44
+ <FormPanel
45
+ ref={formRef}
46
+ fields={[
47
+ {
48
+ name: 'component_id',
49
+ label: {
50
+ text: t('dashboard-item.component_id', {
51
+ ns: 'fields',
52
+ }),
53
+ },
54
+ type: EnumFieldType.COMBOBOX,
55
+ required: true,
56
+ url: '/dashboard-component',
57
+ displayName: 'component',
58
+ valueName: 'id',
59
+ },
60
+
61
+ {
62
+ name: 'dashboard_id',
63
+ label: {
64
+ text: t('dashboard-item.dashboard_id', {
65
+ ns: 'fields',
66
+ }),
67
+ },
68
+ type: EnumFieldType.COMBOBOX,
69
+ required: true,
70
+ url: '/dashboard',
71
+ displayName: 'dashboard',
72
+ valueName: 'id',
73
+ },
74
+
75
+ {
76
+ name: 'width',
77
+ label: {
78
+ text: t('dashboard-user.width', { ns: 'fields' }),
79
+ },
80
+ type: EnumFieldType.NUMBER,
81
+ required: true,
82
+ },
83
+
84
+ {
85
+ name: 'height',
86
+ label: {
87
+ text: t('dashboard-user.height', { ns: 'fields' }),
88
+ },
89
+ type: EnumFieldType.NUMBER,
90
+ required: true,
91
+ },
92
+
93
+ {
94
+ name: 'x_axis',
95
+ label: {
96
+ text: t('dashboard-user.x_axis', { ns: 'fields' }),
97
+ },
98
+ type: EnumFieldType.NUMBER,
99
+ required: true,
100
+ },
101
+
102
+ {
103
+ name: 'y_axis',
104
+ label: {
105
+ text: t('dashboard-user.y_axis', { ns: 'fields' }),
106
+ },
107
+ type: EnumFieldType.NUMBER,
108
+ required: true,
109
+ },
110
+ ]}
111
+ button={{ text: t('save', { ns: 'actions' }) }}
112
+ onSubmit={(data) => {
113
+ dashboardItemUpdate({
114
+ id: data.id,
115
+ data: {
116
+ ...data,
117
+ component_id: Number(data.component_id),
118
+ dashboard_id: Number(data.dashboard_id),
119
+ width: Number(data.width),
120
+ height: Number(data.height),
121
+ x_axis: Number(data.x_axis),
122
+ y_axis: Number(data.y_axis),
123
+ },
124
+ })
125
+ if (typeof onUpdated === 'function') {
126
+ onUpdated(data)
127
+ }
128
+ }}
129
+ />
130
+ </Overlay>
131
+ ),
132
+ },
133
+ ]}
134
+ />
135
+ )
136
+ }
137
+ )
138
+
139
+ DashboardItemUpdatePanel.displayName = 'DashboardItemUpdatePanel'
140
+
141
+ export default DashboardItemUpdatePanel
@@ -0,0 +1,11 @@
1
+ {
2
+ "create": "Create dashboard item",
3
+ "createText": "Fill the dashboard item informations.",
4
+ "createTooltip": "Create new dashboard item",
5
+ "delete": "Delete dashboard item",
6
+ "deleteText": "Are you sure to delete these dashboard item?",
7
+ "deleteTooltip": "Delete the selected dashboard item",
8
+ "edit": "Edit dashboard item",
9
+ "editText": "View and edit dashboard item information.",
10
+ "editTooltip": "Edit the selected dashboard item"
11
+ }
@@ -0,0 +1,11 @@
1
+ {
2
+ "create": "Criar item do painel",
3
+ "createText": "Preencha as informações do item do painel.",
4
+ "createTooltip": "Criar novo item do painel",
5
+ "delete": "Excluir item do painel",
6
+ "deleteText": "Você tem certeza que deseja excluir esses itens do painel?",
7
+ "deleteTooltip": "Excluir o(s) item(ns) do painel selecionado(s)",
8
+ "edit": "Editar item do painel",
9
+ "editText": "Visualizar e editar informações do item do painel.",
10
+ "editTooltip": "Editar o item do painel selecionado"
11
+ }
@@ -0,0 +1,28 @@
1
+ import { useDefaultMutation } from "@/hooks/use-default-mutation";
2
+ import { useQuery } from "@tanstack/react-query";
3
+ import { requests } from "./requests";
4
+
5
+ const scope = "dashboard-item";
6
+
7
+ export function useDashboardItemCreate() {
8
+ const { dashboardItemCreate } = requests();
9
+ return useDefaultMutation(scope, "create", dashboardItemCreate);
10
+ }
11
+
12
+ export function useDashboardItemDelete() {
13
+ const { dashboardItemDelete } = requests();
14
+ return useDefaultMutation(scope, "delete", dashboardItemDelete);
15
+ }
16
+
17
+ export function useDashboardItemUpdate() {
18
+ const { dashboardItemUpdate } = requests();
19
+ return useDefaultMutation(scope, "update", dashboardItemUpdate);
20
+ }
21
+
22
+ export function useDashboardItemGet(id: number) {
23
+ const { dashboardItemGet } = requests();
24
+ return useQuery({
25
+ queryKey: [scope, "get"],
26
+ queryFn: () => dashboardItemGet(id),
27
+ });
28
+ }
@@ -0,0 +1,58 @@
1
+ import { useApp } from "@/hooks/use-app";
2
+ import { Delete, PaginationParams, PaginationResult } from "@/types";
3
+ import { DashboardItem } from "@/types/models";
4
+ import { HttpMethod } from "@/types/http-method";
5
+
6
+ export function requests() {
7
+ const { request } = useApp();
8
+
9
+ const dashboardItemList = async (params: PaginationParams) => {
10
+ return request<PaginationResult<DashboardItem>>({
11
+ url: "/dashboard-item",
12
+ params,
13
+ }).then((res) => res.data);
14
+ };
15
+
16
+ const dashboardItemGet = async (id: number) => {
17
+ return request<DashboardItem>({
18
+ url: `/dashboard-item/${id}`,
19
+ }).then((res) => res.data);
20
+ };
21
+
22
+ const dashboardItemCreate = async (params: { data: DashboardItem }) => {
23
+ const { data } = params;
24
+ return request<DashboardItem>({
25
+ url: "/dashboard-item",
26
+ method: HttpMethod.POST,
27
+ data: data,
28
+ }).then((res) => res.data);
29
+ };
30
+
31
+ const dashboardItemDelete = async (ids: number[]) => {
32
+ return request<Delete>({
33
+ url: "/dashboard-item",
34
+ data: { ids },
35
+ method: HttpMethod.DELETE,
36
+ }).then((res) => res.data);
37
+ };
38
+
39
+ const dashboardItemUpdate = async (params: {
40
+ id: number;
41
+ data: DashboardItem;
42
+ }) => {
43
+ const { id, data } = params;
44
+ return request<DashboardItem>({
45
+ url: `/dashboard-item/${id}`,
46
+ method: HttpMethod.PATCH,
47
+ data: data,
48
+ }).then((res) => res.data);
49
+ };
50
+
51
+ return {
52
+ dashboardItemCreate,
53
+ dashboardItemUpdate,
54
+ dashboardItemDelete,
55
+ dashboardItemList,
56
+ dashboardItemGet,
57
+ };
58
+ }
@@ -0,0 +1,108 @@
1
+ import FormPanel, { FormPanelRef } from '@/components/panels/form-panel'
2
+ import { EnumFieldType } from '@/enums/EnumFieldType'
3
+ import { useDashboardUserCreate } from '@/features/dashboard/dashboard-user'
4
+ import { DashboardUser } from '@/types/models'
5
+ import { forwardRef, useImperativeHandle, useRef } from 'react'
6
+ import { useTranslation } from 'react-i18next'
7
+
8
+ export type DashboardUserCreatePanelRef = {
9
+ submit: () => void
10
+ }
11
+
12
+ export type DashboardUserCreatePanelProps = {
13
+ onCreated?: (data: DashboardUser) => void
14
+ }
15
+
16
+ const DashboardUserCreatePanel = forwardRef(
17
+ ({ onCreated }: DashboardUserCreatePanelProps, ref) => {
18
+ const formRef = useRef<FormPanelRef>(null)
19
+ const { t } = useTranslation(['actions', 'fields', 'translations'])
20
+ const { mutateAsync: createDashboardUser } = useDashboardUserCreate()
21
+
22
+ useImperativeHandle(
23
+ ref,
24
+ () => ({
25
+ submit: () => {
26
+ formRef.current?.submit()
27
+ },
28
+ }),
29
+ [formRef]
30
+ )
31
+
32
+ return (
33
+ <FormPanel
34
+ ref={formRef}
35
+ fields={[
36
+ {
37
+ name: 'item_id',
38
+ label: { text: t('dashboard-user.item_id', { ns: 'fields' }) },
39
+ type: EnumFieldType.COMBOBOX,
40
+ required: true,
41
+ url: '/dashboard-item',
42
+ displayName: 'item',
43
+ valueName: 'id',
44
+ },
45
+
46
+ {
47
+ name: 'user_id',
48
+ label: { text: t('dashboard-user.user_id', { ns: 'fields' }) },
49
+ type: EnumFieldType.COMBOBOX,
50
+ required: true,
51
+ url: '/user',
52
+ displayName: 'user',
53
+ valueName: 'id',
54
+ },
55
+
56
+ {
57
+ name: 'width',
58
+ label: { text: t('dashboard-user.width', { ns: 'fields' }) },
59
+ type: EnumFieldType.NUMBER,
60
+ required: true,
61
+ },
62
+
63
+ {
64
+ name: 'height',
65
+ label: { text: t('dashboard-user.height', { ns: 'fields' }) },
66
+ type: EnumFieldType.NUMBER,
67
+ required: true,
68
+ },
69
+
70
+ {
71
+ name: 'x_axis',
72
+ label: { text: t('dashboard-user.x_axis', { ns: 'fields' }) },
73
+ type: EnumFieldType.NUMBER,
74
+ required: true,
75
+ },
76
+
77
+ {
78
+ name: 'y_axis',
79
+ label: { text: t('dashboard-user.y_axis', { ns: 'fields' }) },
80
+ type: EnumFieldType.NUMBER,
81
+ required: true,
82
+ },
83
+ ]}
84
+ button={{ text: t('create', { ns: 'actions' }) }}
85
+ onSubmit={async (data) => {
86
+ const createdData = await createDashboardUser({
87
+ data: {
88
+ ...data,
89
+ item_id: Number(data.item_id),
90
+ user_id: Number(data.user_id),
91
+ width: Number(data.width),
92
+ height: Number(data.height),
93
+ x_axis: Number(data.x_axis),
94
+ y_axis: Number(data.y_axis),
95
+ },
96
+ })
97
+ if (typeof onCreated === 'function') {
98
+ onCreated(createdData as any)
99
+ }
100
+ }}
101
+ />
102
+ )
103
+ }
104
+ )
105
+
106
+ DashboardUserCreatePanel.displayName = 'DashboardUserCreatePanel'
107
+
108
+ export default DashboardUserCreatePanel