@bigbinary/neeto-team-members-frontend 4.6.0 → 4.6.2

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 (51) hide show
  1. package/app/javascript/src/translations/ar.json +251 -0
  2. package/app/javascript/src/translations/bg.json +251 -0
  3. package/app/javascript/src/translations/ca.json +251 -0
  4. package/app/javascript/src/translations/cs.json +251 -0
  5. package/app/javascript/src/translations/da.json +251 -0
  6. package/app/javascript/src/translations/de.json +18 -4
  7. package/app/javascript/src/translations/es-MX.json +251 -0
  8. package/app/javascript/src/translations/es.json +18 -4
  9. package/app/javascript/src/translations/et.json +251 -0
  10. package/app/javascript/src/translations/fi.json +251 -0
  11. package/app/javascript/src/translations/fil.json +251 -0
  12. package/app/javascript/src/translations/fr.json +18 -4
  13. package/app/javascript/src/translations/hi.json +251 -0
  14. package/app/javascript/src/translations/hr.json +251 -0
  15. package/app/javascript/src/translations/id.json +251 -0
  16. package/app/javascript/src/translations/it.json +251 -0
  17. package/app/javascript/src/translations/ja.json +251 -0
  18. package/app/javascript/src/translations/ko.json +251 -0
  19. package/app/javascript/src/translations/nl.json +251 -0
  20. package/app/javascript/src/translations/pl.json +251 -0
  21. package/app/javascript/src/translations/pt-BR.json +251 -0
  22. package/app/javascript/src/translations/pt.json +251 -0
  23. package/app/javascript/src/translations/ro.json +251 -0
  24. package/app/javascript/src/translations/ru.json +251 -0
  25. package/app/javascript/src/translations/sk.json +251 -0
  26. package/app/javascript/src/translations/sl.json +251 -0
  27. package/app/javascript/src/translations/sv.json +251 -0
  28. package/app/javascript/src/translations/th.json +251 -0
  29. package/app/javascript/src/translations/uk.json +251 -0
  30. package/app/javascript/src/translations/vi.json +251 -0
  31. package/app/javascript/src/translations/zh-CN.json +251 -0
  32. package/app/javascript/src/translations/zh-TW.json +251 -0
  33. package/dist/ManageMember.js +1 -1
  34. package/dist/TeamMembers.js +12 -11
  35. package/dist/TeamMembers.js.map +1 -1
  36. package/dist/cjs/ManageMember.js +1 -1
  37. package/dist/cjs/TeamMembers.js +11 -10
  38. package/dist/cjs/TeamMembers.js.map +1 -1
  39. package/dist/cjs/constants.js +12 -0
  40. package/dist/cjs/constants.js.map +1 -1
  41. package/dist/cjs/index.js +2 -2
  42. package/dist/constants.js +12 -1
  43. package/dist/constants.js.map +1 -1
  44. package/dist/{index-DJpeKjXZ.js → index-CIJAgXY8.js} +2 -3
  45. package/dist/index-CIJAgXY8.js.map +1 -0
  46. package/dist/{index-B8N3ZtZe.js → index-mZihjizm.js} +1 -3
  47. package/dist/index-mZihjizm.js.map +1 -0
  48. package/dist/index.js +2 -2
  49. package/package.json +13 -11
  50. package/dist/index-B8N3ZtZe.js.map +0 -1
  51. package/dist/index-DJpeKjXZ.js.map +0 -1
@@ -0,0 +1,251 @@
1
+ {
2
+ "neetoTeamMembers": {
3
+ "alerts": {
4
+ "messages": {
5
+ "activateMember_one": "您正在激活 {{taxonomies.member.singular}} <strong>{{person, anyCase}}</strong>。",
6
+ "activateMember_other": "您正在激活 <strong>{{count}}</strong> {{taxonomies.member.plural}}。",
7
+ "changeRole_one": "您正在將 <strong>{{person, anyCase}}</strong> 的角色更改為 <strong>{{role, anyCase}}</strong>。",
8
+ "changeRole_other": "您正在將 <strong>{{count}}</strong> {{metaName}} 的角色更改為 <strong>{{role, anyCase}}</strong>。",
9
+ "delete": "您將永久刪除 {{resource}} <strong>{{name, anyCase}}</strong>。此操作無法撤消。",
10
+ "deletingRole": "您將永久刪除角色 <strong>{{name, anyCase}}</strong>。此操作無法撤消。",
11
+ "removeMember": "您正在將 <strong>{{member, anyCase}}</strong> 從此組中刪除。",
12
+ "removeMember_one": "您正在刪除 {{taxonomies.member.singular}} <strong>{{person, anyCase}}</strong>。",
13
+ "removeMember_other": "您正在刪除 <strong>{{count}}</strong> {{taxonomies.member.plural}}。",
14
+ "inviteLink": "邀請鏈接可以與最多 <strong>{{inviteLimit}} 人</strong> 共享,他們將以 <strong>{{role, anyCase}}</strong> 角色添加到 <strong>{{appName, anyCase}}</strong> 中。它將在 <strong>{{expiryDays}} 天</strong> 後過期,並限制於具有 <strong>{{emailDomain}}</strong> 電子郵件域的用戶。",
15
+ "expiredTitle": "邀請鏈接已過期",
16
+ "expiredMessage": "邀請鏈接不再有效。請聯繫管理員獲取新鏈接。",
17
+ "domainTitle": "邀請鏈接錯誤:您的電子郵件域未被授權加入此團隊",
18
+ "domainMessage": "此邀請僅限於 <strong>@{{allowedDomain}}</strong> 電子郵件域。您嘗試使用 <strong>{{email}}</strong> 加入。請使用您的 <strong>@{{allowedDomain}}</strong> 電子郵件再次嘗試或聯繫管理員。",
19
+ "generateLink": "生成邀請鏈接"
20
+ }
21
+ },
22
+ "buttons": {
23
+ "activate": "激活",
24
+ "back": "返回",
25
+ "cancel": "取消",
26
+ "changeRole": "更改角色",
27
+ "continue": "繼續",
28
+ "delete": "刪除",
29
+ "download": "下載",
30
+ "editBasicInfo": "編輯基本信息",
31
+ "manageBillingAndSubscriptions": "管理計費和訂閱",
32
+ "remove": "移除",
33
+ "reset": "重置",
34
+ "saveChanges": "保存更改",
35
+ "updateEmail": "更新電子郵件",
36
+ "inviteLink": "通過鏈接邀請",
37
+ "copyLink": "複製鏈接",
38
+ "regenerateLink": "重新生成鏈接",
39
+ "acceptInvitation": "接受邀請",
40
+ "generateLink": "生成鏈接"
41
+ },
42
+ "columns": {
43
+ "noColumnsFound": "未找到列。",
44
+ "search": "搜索列"
45
+ },
46
+ "common": {
47
+ "activate": "激活",
48
+ "activate_": "要激活 {{what}}?",
49
+ "active": "啟用",
50
+ "active_": "啟用 {{what}}",
51
+ "addNew_": "添加新 {{what}}",
52
+ "all": "全部",
53
+ "all_": "所有 {{what}}",
54
+ "changeRole": "更改角色?",
55
+ "deactivated": "移除",
56
+ "delete": "刪除",
57
+ "description": "描述",
58
+ "edit": "編輯",
59
+ "edit_": "編輯 {{what}}",
60
+ "email_one": "電子郵件",
61
+ "email_other": "電子郵件",
62
+ "format": "格式",
63
+ "free": "免費",
64
+ "loading": "加載中...",
65
+ "name": "名稱",
66
+ "notFound_": "沒有 {{what}} 可以顯示。",
67
+ "notFoundWithKind_": "沒有 {{kind}} {{what}} 可以顯示。",
68
+ "permission_one": "權限",
69
+ "permission_other": "權限",
70
+ "productName": "產品名稱",
71
+ "remove": "移除",
72
+ "remove_": "要移除 {{what}}?",
73
+ "removed_": "已移除 {{what}}",
74
+ "role_one": "角色",
75
+ "role_other": "角色",
76
+ "search_": "搜索 {{what}}",
77
+ "subscriptionType": "{{subscription}} 計劃",
78
+ "takeAction": "採取行動",
79
+ "timeZone": "Etc/UTC",
80
+ "inviteViaLink": "通過鏈接邀請"
81
+ },
82
+ "downloadPane": {
83
+ "description": {
84
+ "allMembers": "下載全部 {{taxonomies.member.plural}}",
85
+ "selectedMembers_one": "下載所選 {{taxonomies.member.singular}}",
86
+ "selectedMembers_other": "下載 {{count}} 所選 {{taxonomies.member.plural}}"
87
+ },
88
+ "title": "下載 {{taxonomies.member.plural}}"
89
+ },
90
+ "helpers": {
91
+ "addMembersToNeetoProducts": "將 {{- emails, boldList}} 添加到以下 neeto 產品。",
92
+ "configPermissions": "配置模塊的權限。",
93
+ "emptyTable": "沒有 {{entity}} 可以顯示。",
94
+ "enterMultipleEmails": "按空格、逗號、TAB 鍵或回車鍵以添加多個電子郵件地址。",
95
+ "manageProducts": "產品太多了? <button>禁用一些</button> 這些產品。",
96
+ "memberCreationStatus_one": "邀請 {{taxonomies.member.singular}}",
97
+ "memberCreationStatus_other": "邀請 {{taxonomies.member.plural}}",
98
+ "metaNameWithCount_one": "{{totalCount}} {{taxonomies.member.singular}}",
99
+ "metaNameWithCount_other": "{{totalCount}} {{taxonomies.member.plural}}",
100
+ "multipleProductInvitation": "{{- emails, boldList}} 將被邀請到以下 neeto 產品與旁邊給出的角色。",
101
+ "noRecords": "未找到記錄",
102
+ "noRolesFound": "未找到角色。",
103
+ "selectAll": "選擇所有 {{count}} 團隊成員",
104
+ "selectedMembers": "本頁上的所有 {{count}} 團隊成員已選擇",
105
+ "selectedMembersCount_one": "{{count}} {{taxonomies.member.singular}} 已選擇,總計 <span>{{totalCount}}</span>",
106
+ "selectedMembersCount_other": "{{count}} {{taxonomies.member.plural}} 已選擇,總計 <span>{{totalCount}}</span>",
107
+ "singleProductInvitation": "{{- emails, boldList}} 將被邀請到 <strong>{{product, anyCase}}</strong>,角色為 <strong>{{role, anyCase}}</strong>。",
108
+ "themeSelector": "主題選擇器",
109
+ "whyIsItDisabled": "為什麼它被禁用?",
110
+ "invitationTitle": "您被邀請了!",
111
+ "invitationMessage": "您已被邀請加入 <strong>{{organization, anyCase}}</strong>。請輸入您的電子郵件以接受邀請。"
112
+ },
113
+ "labels": {
114
+ "addNewRole": "添加新角色",
115
+ "billingAndSubscriptions": "計費和訂閱",
116
+ "country": "國家",
117
+ "deleteRole": "刪除角色?",
118
+ "deleteTitle": "刪除 {{resource}}?",
119
+ "downloadAs": "下載為 {{format, anyCase}}",
120
+ "downloads": {
121
+ "csv": "CSV",
122
+ "pdf": "PDF",
123
+ "xlsx": "Excel"
124
+ },
125
+ "editRole": "編輯角色",
126
+ "firstName": "名字",
127
+ "groupName": "{{taxonomies.group.singular, anyCase}} 名稱",
128
+ "lastName": "姓氏",
129
+ "manageMember_one": "管理成員",
130
+ "manageMember_other": "管理成員",
131
+ "manageRole_one": "管理角色",
132
+ "manageRole_other": "管理角色",
133
+ "neeto_": "Neeto{{product, anyCase}}",
134
+ "permissionsNotFound": "沒有權限可以顯示。",
135
+ "preferredDateFormat": "首選日期格式",
136
+ "preferredTimeFormat": "首選時間格式",
137
+ "removeMember": "要移除 {{member}}?",
138
+ "roleNotFound_one": "沒有角色可以顯示。",
139
+ "roleNotFound_other": "沒有角色可以顯示。",
140
+ "timeZone": "時區",
141
+ "totalMembers": "總計 {{taxonomies.member.plural}}",
142
+ "upgradeToProPlan": "將上述添加的成員升級到PRO"
143
+ },
144
+ "placeholders": {
145
+ "email": "請輸入電子郵件地址",
146
+ "enterDescription": "請輸入描述",
147
+ "enterName": "請輸入名稱",
148
+ "search": "搜索",
149
+ "searchEntity": "搜索 {{entity}}",
150
+ "searchPermission_one": "搜索權限",
151
+ "searchPermission_other": "搜索權限",
152
+ "searchRole_one": "搜索角色",
153
+ "searchRole_other": "搜索角色"
154
+ },
155
+ "profile": {
156
+ "avatar": {
157
+ "changeProfilePicture": "更改個人資料圖片",
158
+ "profilePicture": "個人資料圖片",
159
+ "profilePictureUploadMessage": "僅支持 JPEG、PNG 文件。最大允許文件大小為 <strong>{{limit}}MB</strong>。",
160
+ "uploadProfilePicture": "上傳個人資料圖片"
161
+ },
162
+ "common": {
163
+ "ddmmyy": "DD/MM/YYYY",
164
+ "mmddyy": "MM/DD/YYYY",
165
+ "myProfile": "我的資料",
166
+ "neetoAuth": "NeetoAuth",
167
+ "timeZoneOption": "{{timeZone, anyCase}} - {{currentTime}}",
168
+ "toUpdateProfile": "要更改您的電子郵件、計費和訂閱 <button>訪問 NeetoAuth。</button>",
169
+ "yymmdd": "YYYY/MM/DD"
170
+ },
171
+ "file": {
172
+ "corrupted": "提交的文件為空或損壞。請選擇有效的文件。",
173
+ "invalidType": {
174
+ "image": "無效的文件類型。請選擇 JPG、JPEG 或 PNG 文件並重試。"
175
+ },
176
+ "limitExceeded": "文件大小超過,最大允許大小為 {{maxSize}} MB。請選擇較小的文件並重試。"
177
+ },
178
+ "form": {
179
+ "dotsNotAllowed": "不允許使用點",
180
+ "invalidName": "僅使用字母、數字、空格、逗號、句號、撇號和連字符。",
181
+ "isRequired": {
182
+ "dateFormat": "日期格式為必填項",
183
+ "firstName": "名字為必填項",
184
+ "lastName": "姓氏為必填項"
185
+ }
186
+ },
187
+ "inputs": {
188
+ "label": {
189
+ "dateFormat": "選擇首選日期格式",
190
+ "firstName": "名字",
191
+ "lastName": "姓氏",
192
+ "selectCountry": "選擇國家",
193
+ "selectTimeFormat": "選擇首選時間格式",
194
+ "selectTimeZone": "選擇時區"
195
+ },
196
+ "placeholder": {
197
+ "firstName": "名字",
198
+ "lastName": "姓氏"
199
+ }
200
+ }
201
+ },
202
+ "tooltips": {
203
+ "activateUserToEdit_one": "請激活用戶以編輯其角色。",
204
+ "activateUserToEdit_other": "請激活所選用戶以編輯其角色。",
205
+ "adminMustHaveAccess": "{{roleName}} 權限無法被任何人更改。",
206
+ "clickToViewPermissions": "點擊查看角色及其權限。",
207
+ "goBackToChangeRole": "請返回以更改角色。",
208
+ "hostAppIsRequired": "此 neeto 產品是繼續進行的必需品。",
209
+ "noPermissionToAddMember": "請詢問管理員授權您添加成員。",
210
+ "noPermissionToAddRole": "請詢問管理員授權您添加角色。",
211
+ "noPermissionToEditMembers": "請詢問管理員授權您編輯成員。",
212
+ "noPermissionToEditRoles": "請詢問管理員授權您編輯角色。",
213
+ "noPermissionToRemoveRoles": "請詢問管理員授權您刪除角色。",
214
+ "uncheckOnSelectPermissions": "如果選擇此權限,將取消選擇以下權限:{{permissions}}"
215
+ },
216
+ "validations": {
217
+ "descriptionLimitExceeded": "您已超出描述的 {{limit}} 字符限制。",
218
+ "enterRoleName": "請輸入有效的角色名稱。",
219
+ "filterInvalidEmails": "點擊此處以刪除無效電子郵件。",
220
+ "max": "該字段必須少於 {{size}} 字符",
221
+ "memberLimitExceeded": "最多允許 {{limit}} 名團隊成員。<emailTo>聯繫我們</emailTo> 以增加限制。",
222
+ "minOneEmail": "請至少輸入一個電子郵件地址。",
223
+ "nameLimitExceeded": "您已超出名稱的 {{limit}} 字符限制。",
224
+ "noWhiteSpaces": "{{what, anyCase}} 開頭或結尾不得有空格",
225
+ "removeSpaces": "請刪除空格。",
226
+ "required": "{{what, anyCase}} 是必填字段",
227
+ "roleRequired": "請選擇一個角色。",
228
+ "validEmail_one": "請確保電子郵件地址有效。",
229
+ "validEmail_other": "請確保所有電子郵件地址有效。"
230
+ }
231
+ },
232
+ "taxonomyDefaultLabels": {
233
+ "group": {
234
+ "plural": "小組",
235
+ "singular": "小組"
236
+ },
237
+ "groupMember": {
238
+ "plural": "成員",
239
+ "singular": "成員"
240
+ },
241
+ "member": {
242
+ "plural": "團隊成員",
243
+ "singular": "團隊成員"
244
+ }
245
+ },
246
+ "toastr": {
247
+ "success": {
248
+ "downloadMembers": "您的文件正在準備中,將很快發送到 <strong>{{email}}</strong>."
249
+ }
250
+ }
251
+ }
@@ -17,7 +17,7 @@ import 'ramda';
17
17
  import 'react-i18next';
18
18
  import './index-ChnZuzES.js';
19
19
  import './useTeamsApi-B3QBs2O9.js';
20
- export { M as default } from './index-DJpeKjXZ.js';
20
+ export { M as default } from './index-CIJAgXY8.js';
21
21
  import './RolesRadioGroup-uBXbN2fZ.js';
22
22
  import 'react/jsx-runtime';
23
23
  import '@babel/runtime/helpers/objectWithoutProperties';
@@ -6,7 +6,7 @@ import { taxonomies, globalProps } from '@bigbinary/neeto-commons-frontend/initi
6
6
  import { useQueryParams, useFuncDebounce, useDebounce, withT, withTitle, useBreakpoints } from '@bigbinary/neeto-commons-frontend/react-utils';
7
7
  import { captureAnalyticsEvent, buildUrl } from '@bigbinary/neeto-commons-frontend/utils';
8
8
  import FiltersBar from '@bigbinary/neeto-filters-frontend/Bar';
9
- import { useHiddenColumns } from '@bigbinary/neeto-molecules/Columns';
9
+ import { useTableConfigurations } from '@bigbinary/neeto-molecules/Columns';
10
10
  import Container from '@bigbinary/neeto-molecules/Container';
11
11
  import SubHeader$1 from '@bigbinary/neeto-molecules/SubHeader';
12
12
  import TableWrapper from '@bigbinary/neeto-molecules/TableWrapper';
@@ -20,9 +20,10 @@ import { useHistory } from 'react-router-dom';
20
20
  import { w as withReactQuery } from './withReactQuery-CHybbL5V.js';
21
21
  import { u as useFetchRoles } from './index-ChnZuzES.js';
22
22
  import { e as useFetchFilterOptions, f as useBulkUpdateMembers, g as useExportMembers, u as useFetchMembers, d as useUpdateMember } from './useTeamsApi-B3QBs2O9.js';
23
+ import { TABLE_KEYS, EVENTS } from './constants.js';
23
24
  import _toConsumableArray from '@babel/runtime/helpers/toConsumableArray';
24
25
  import { buildFiltersFromURL } from '@bigbinary/neeto-filters-frontend/utils';
25
- import { d as defaultNeetoFiltersColumns, D as DEFAULT_FILTER_VALUES, b as buildFilterColumns, a as DEFAULT_IS_OPEN_VALUES, c as DEFAULT_SELECTED_ROWS, h as handlePageChange, T as TEAM_MEMBERS_HIDDEN_COLUMNS, g as getFilteredRoles, e as getColumnData, f as generateNoDataContent, i as DEFAULT_RADIX, r as renderPaginationProps, M as ManageMember, j as renderUpdateAlert } from './index-DJpeKjXZ.js';
26
+ import { d as defaultNeetoFiltersColumns, D as DEFAULT_FILTER_VALUES, b as buildFilterColumns, a as DEFAULT_IS_OPEN_VALUES, c as DEFAULT_SELECTED_ROWS, h as handlePageChange, g as getFilteredRoles, e as getColumnData, f as generateNoDataContent, i as DEFAULT_RADIX, r as renderPaginationProps, M as ManageMember, j as renderUpdateAlert } from './index-CIJAgXY8.js';
26
27
  import { n } from './inject-css-DmrvuTKK.js';
27
28
  import { noop, isNotEmpty, hyphenate, findBy } from '@bigbinary/neeto-cist';
28
29
  import Button from '@bigbinary/neetoui/Button';
@@ -37,7 +38,6 @@ import Input from '@bigbinary/neetoui/Input';
37
38
  import Pane from '@bigbinary/neetoui/Pane';
38
39
  import Radio from '@bigbinary/neetoui/Radio';
39
40
  import Toastr from '@bigbinary/neetoui/Toastr';
40
- import { EVENTS } from './constants.js';
41
41
  import NeetoHeader from '@bigbinary/neeto-molecules/Header';
42
42
  import '@tanstack/react-query';
43
43
  import './queryClient-Dsu-gu4Y.js';
@@ -551,7 +551,7 @@ var Right = withT(function (_ref3) {
551
551
  columnsButtonProps: {
552
552
  columnData: columns,
553
553
  fixedColumns: FIXED_COLUMNS,
554
- localStorageKey: TEAM_MEMBERS_HIDDEN_COLUMNS,
554
+ tableKey: TABLE_KEYS.TEAM_MEMBERS_TABLE,
555
555
  noColumnMessage: t("neetoTeamMembers.columns.noColumnsFound"),
556
556
  searchProps: {
557
557
  placeholder: t("neetoTeamMembers.columns.search")
@@ -833,9 +833,10 @@ var TeamMembers = function TeamMembers(_ref) {
833
833
  });
834
834
  }, [(_config$table2 = config.table) === null || _config$table2 === void 0 ? void 0 : _config$table2.dropdownProps] // eslint-disable-line react-hooks/exhaustive-deps
835
835
  );
836
- var _useHiddenColumns = useHiddenColumns(TEAM_MEMBERS_HIDDEN_COLUMNS),
837
- hideColumn = _useHiddenColumns.hideColumn,
838
- getVisibleColumnData = _useHiddenColumns.getVisibleColumnData;
836
+ var _useTableConfiguratio = useTableConfigurations(TABLE_KEYS.TEAM_MEMBERS_TABLE, columns),
837
+ isTableConfigurationLoading = _useTableConfiguratio.isTableConfigurationLoading,
838
+ customizedColumns = _useTableConfiguratio.customizedColumns,
839
+ hideColumn = _useTableConfiguratio.hideColumn;
839
840
  var handleNeetoFilterChange = function handleNeetoFilterChange(filters) {
840
841
  setFilters(mergeLeft({
841
842
  neetoFilters: filters,
@@ -909,11 +910,11 @@ var TeamMembers = function TeamMembers(_ref) {
909
910
  children: (team === null || team === void 0 ? void 0 : team.membersCount) !== 0 ? /*#__PURE__*/jsx(Table, {
910
911
  fixedHeight: true,
911
912
  allowRowClick: false,
912
- columnData: getVisibleColumnData(columns),
913
+ columnData: customizedColumns,
913
914
  currentPageNumber: parseInt(filters.page, DEFAULT_RADIX),
914
915
  "data-cy": "ntm-members-table",
915
916
  handlePageChange: handlePageChange(setFilters, history),
916
- loading: isMembersFetching,
917
+ loading: isMembersFetching || isTableConfigurationLoading,
917
918
  paginationProps: renderPaginationProps(filters.pageSize),
918
919
  rowData: team === null || team === void 0 ? void 0 : team.members,
919
920
  selectedRowKeys: selectedRows.keys,
@@ -937,8 +938,8 @@ var TeamMembers = function TeamMembers(_ref) {
937
938
  },
938
939
  onChange: handleTableChange,
939
940
  onColumnHide: function onColumnHide(_ref2) {
940
- var dataIndex = _ref2.dataIndex;
941
- return hideColumn(dataIndex);
941
+ var key = _ref2.key;
942
+ return hideColumn(key);
942
943
  },
943
944
  onRowSelect: handleRowSelect
944
945
  }) : /*#__PURE__*/jsx("div", {