@lokalise/harmony 1.39.4 → 1.40.0

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 (207) hide show
  1. package/dist/harmony100.cjs +9 -12
  2. package/dist/harmony100.cjs.map +1 -1
  3. package/dist/harmony100.mjs +8 -11
  4. package/dist/harmony100.mjs.map +1 -1
  5. package/dist/harmony101.cjs +57 -12
  6. package/dist/harmony101.cjs.map +1 -1
  7. package/dist/harmony101.mjs +56 -11
  8. package/dist/harmony101.mjs.map +1 -1
  9. package/dist/harmony102.cjs +42 -6
  10. package/dist/harmony102.cjs.map +1 -1
  11. package/dist/harmony102.mjs +41 -5
  12. package/dist/harmony102.mjs.map +1 -1
  13. package/dist/harmony103.cjs +6 -10
  14. package/dist/harmony103.cjs.map +1 -1
  15. package/dist/harmony103.mjs +5 -9
  16. package/dist/harmony103.mjs.map +1 -1
  17. package/dist/harmony104.cjs +6 -6
  18. package/dist/harmony104.mjs +6 -6
  19. package/dist/harmony105.cjs +24 -57
  20. package/dist/harmony105.cjs.map +1 -1
  21. package/dist/harmony105.mjs +23 -56
  22. package/dist/harmony105.mjs.map +1 -1
  23. package/dist/harmony106.cjs +6 -42
  24. package/dist/harmony106.cjs.map +1 -1
  25. package/dist/harmony106.mjs +5 -41
  26. package/dist/harmony106.mjs.map +1 -1
  27. package/dist/harmony107.cjs +21 -5
  28. package/dist/harmony107.cjs.map +1 -1
  29. package/dist/harmony107.mjs +21 -5
  30. package/dist/harmony107.mjs.map +1 -1
  31. package/dist/harmony108.cjs +7 -4
  32. package/dist/harmony108.cjs.map +1 -1
  33. package/dist/harmony108.mjs +7 -4
  34. package/dist/harmony108.mjs.map +1 -1
  35. package/dist/harmony109.cjs +12 -25
  36. package/dist/harmony109.cjs.map +1 -1
  37. package/dist/harmony109.mjs +11 -24
  38. package/dist/harmony109.mjs.map +1 -1
  39. package/dist/harmony110.cjs +20 -5
  40. package/dist/harmony110.cjs.map +1 -1
  41. package/dist/harmony110.mjs +20 -5
  42. package/dist/harmony110.mjs.map +1 -1
  43. package/dist/harmony111.cjs +164 -19
  44. package/dist/harmony111.cjs.map +1 -1
  45. package/dist/harmony111.mjs +164 -19
  46. package/dist/harmony111.mjs.map +1 -1
  47. package/dist/harmony112.cjs +44 -12
  48. package/dist/harmony112.cjs.map +1 -1
  49. package/dist/harmony112.mjs +43 -11
  50. package/dist/harmony112.mjs.map +1 -1
  51. package/dist/harmony113.cjs +2 -2
  52. package/dist/harmony113.mjs +2 -2
  53. package/dist/harmony114.cjs +13 -86
  54. package/dist/harmony114.cjs.map +1 -1
  55. package/dist/harmony114.mjs +13 -86
  56. package/dist/harmony114.mjs.map +1 -1
  57. package/dist/harmony115.cjs +18 -30
  58. package/dist/harmony115.cjs.map +1 -1
  59. package/dist/harmony115.mjs +18 -30
  60. package/dist/harmony115.mjs.map +1 -1
  61. package/dist/harmony116.cjs +21 -14
  62. package/dist/harmony116.cjs.map +1 -1
  63. package/dist/harmony116.mjs +20 -13
  64. package/dist/harmony116.mjs.map +1 -1
  65. package/dist/harmony117.cjs +6 -18
  66. package/dist/harmony117.cjs.map +1 -1
  67. package/dist/harmony117.mjs +6 -18
  68. package/dist/harmony117.mjs.map +1 -1
  69. package/dist/harmony118.cjs +132 -21
  70. package/dist/harmony118.cjs.map +1 -1
  71. package/dist/harmony118.mjs +131 -20
  72. package/dist/harmony118.mjs.map +1 -1
  73. package/dist/harmony119.cjs +12 -6
  74. package/dist/harmony119.cjs.map +1 -1
  75. package/dist/harmony119.mjs +11 -5
  76. package/dist/harmony119.mjs.map +1 -1
  77. package/dist/harmony120.cjs +5 -132
  78. package/dist/harmony120.cjs.map +1 -1
  79. package/dist/harmony120.mjs +5 -132
  80. package/dist/harmony120.mjs.map +1 -1
  81. package/dist/harmony121.cjs +40 -12
  82. package/dist/harmony121.cjs.map +1 -1
  83. package/dist/harmony121.mjs +39 -11
  84. package/dist/harmony121.mjs.map +1 -1
  85. package/dist/harmony122.cjs +59 -4
  86. package/dist/harmony122.cjs.map +1 -1
  87. package/dist/harmony122.mjs +60 -5
  88. package/dist/harmony122.mjs.map +1 -1
  89. package/dist/harmony123.cjs +6 -39
  90. package/dist/harmony123.cjs.map +1 -1
  91. package/dist/harmony123.mjs +6 -39
  92. package/dist/harmony123.mjs.map +1 -1
  93. package/dist/harmony124.cjs +6 -60
  94. package/dist/harmony124.cjs.map +1 -1
  95. package/dist/harmony124.mjs +5 -59
  96. package/dist/harmony124.mjs.map +1 -1
  97. package/dist/harmony125.cjs +6 -8
  98. package/dist/harmony125.cjs.map +1 -1
  99. package/dist/harmony125.mjs +5 -7
  100. package/dist/harmony125.mjs.map +1 -1
  101. package/dist/harmony126.cjs +4 -4
  102. package/dist/harmony126.mjs +4 -4
  103. package/dist/harmony127.cjs +88 -6
  104. package/dist/harmony127.cjs.map +1 -1
  105. package/dist/harmony127.mjs +87 -5
  106. package/dist/harmony127.mjs.map +1 -1
  107. package/dist/harmony128.cjs +31 -7
  108. package/dist/harmony128.cjs.map +1 -1
  109. package/dist/harmony128.mjs +30 -6
  110. package/dist/harmony128.mjs.map +1 -1
  111. package/dist/harmony129.cjs +96 -10
  112. package/dist/harmony129.cjs.map +1 -1
  113. package/dist/harmony129.mjs +96 -10
  114. package/dist/harmony129.mjs.map +1 -1
  115. package/dist/harmony130.cjs +11 -94
  116. package/dist/harmony130.cjs.map +1 -1
  117. package/dist/harmony130.mjs +11 -94
  118. package/dist/harmony130.mjs.map +1 -1
  119. package/dist/harmony131.cjs +13 -12
  120. package/dist/harmony131.cjs.map +1 -1
  121. package/dist/harmony131.mjs +13 -12
  122. package/dist/harmony131.mjs.map +1 -1
  123. package/dist/harmony132.cjs +35 -13
  124. package/dist/harmony132.cjs.map +1 -1
  125. package/dist/harmony132.mjs +35 -13
  126. package/dist/harmony132.mjs.map +1 -1
  127. package/dist/harmony133.cjs +24 -32
  128. package/dist/harmony133.cjs.map +1 -1
  129. package/dist/harmony133.mjs +24 -32
  130. package/dist/harmony133.mjs.map +1 -1
  131. package/dist/harmony134.cjs +62 -28
  132. package/dist/harmony134.cjs.map +1 -1
  133. package/dist/harmony134.mjs +61 -27
  134. package/dist/harmony134.mjs.map +1 -1
  135. package/dist/harmony135.cjs +87 -61
  136. package/dist/harmony135.cjs.map +1 -1
  137. package/dist/harmony135.mjs +87 -61
  138. package/dist/harmony135.mjs.map +1 -1
  139. package/dist/harmony136.cjs +18 -88
  140. package/dist/harmony136.cjs.map +1 -1
  141. package/dist/harmony136.mjs +17 -87
  142. package/dist/harmony136.mjs.map +1 -1
  143. package/dist/harmony137.cjs +10 -18
  144. package/dist/harmony137.cjs.map +1 -1
  145. package/dist/harmony137.mjs +9 -17
  146. package/dist/harmony137.mjs.map +1 -1
  147. package/dist/harmony14.cjs +1 -1
  148. package/dist/harmony14.mjs +1 -1
  149. package/dist/harmony142.cjs +1 -1
  150. package/dist/harmony142.mjs +1 -1
  151. package/dist/harmony153.cjs +1 -1
  152. package/dist/harmony153.mjs +1 -1
  153. package/dist/harmony17.cjs +1 -1
  154. package/dist/harmony17.mjs +1 -1
  155. package/dist/harmony25.cjs +1 -1
  156. package/dist/harmony25.mjs +1 -1
  157. package/dist/harmony26.cjs +1 -1
  158. package/dist/harmony26.mjs +1 -1
  159. package/dist/harmony67.cjs +2 -1
  160. package/dist/harmony67.cjs.map +1 -1
  161. package/dist/harmony67.mjs +2 -1
  162. package/dist/harmony67.mjs.map +1 -1
  163. package/dist/harmony77.cjs +1 -1
  164. package/dist/harmony77.mjs +1 -1
  165. package/dist/harmony78.cjs +1 -1
  166. package/dist/harmony78.mjs +1 -1
  167. package/dist/harmony79.cjs +1 -1
  168. package/dist/harmony79.mjs +1 -1
  169. package/dist/harmony80.cjs +2 -2
  170. package/dist/harmony80.mjs +2 -2
  171. package/dist/harmony81.cjs +2 -2
  172. package/dist/harmony81.mjs +2 -2
  173. package/dist/harmony82.cjs +2 -2
  174. package/dist/harmony82.mjs +2 -2
  175. package/dist/harmony83.cjs +2 -2
  176. package/dist/harmony83.mjs +2 -2
  177. package/dist/harmony84.cjs +3 -3
  178. package/dist/harmony84.mjs +3 -3
  179. package/dist/harmony85.cjs +6 -6
  180. package/dist/harmony85.mjs +6 -6
  181. package/dist/harmony88.cjs +2 -2
  182. package/dist/harmony88.mjs +2 -2
  183. package/dist/harmony90.cjs +2 -2
  184. package/dist/harmony90.mjs +2 -2
  185. package/dist/harmony92.cjs +2 -2
  186. package/dist/harmony92.mjs +2 -2
  187. package/dist/harmony96.cjs +10 -9
  188. package/dist/harmony96.cjs.map +1 -1
  189. package/dist/harmony96.mjs +12 -11
  190. package/dist/harmony96.mjs.map +1 -1
  191. package/dist/harmony97.cjs +11 -20
  192. package/dist/harmony97.cjs.map +1 -1
  193. package/dist/harmony97.mjs +11 -20
  194. package/dist/harmony97.mjs.map +1 -1
  195. package/dist/harmony98.cjs +6 -166
  196. package/dist/harmony98.cjs.map +1 -1
  197. package/dist/harmony98.mjs +5 -165
  198. package/dist/harmony98.mjs.map +1 -1
  199. package/dist/harmony99.cjs +9 -44
  200. package/dist/harmony99.cjs.map +1 -1
  201. package/dist/harmony99.mjs +8 -43
  202. package/dist/harmony99.mjs.map +1 -1
  203. package/dist/types/src/features/publicApi/hooks/useCreateScoreMutation.d.ts +1 -0
  204. package/dist/types/src/features/publicApi/hooks/useGetScoreQuery.d.ts +1 -0
  205. package/dist/types/src/features/publicApi/score.d.ts +10 -0
  206. package/dist/types/src/features/publicApi/types/scoreTypes.d.ts +13 -0
  207. package/package.json +1 -1
@@ -1,169 +1,9 @@
1
- import { useMemo } from "react";
2
- import { useNavigationClient } from "./harmony94.mjs";
3
- import { getProjectNavigationVisibilityMap } from "./harmony114.mjs";
4
- const useExpertNavigation = (enabled, project, contributor) => {
5
- const adminRights = (contributor == null ? void 0 : contributor.admin_rights) || [];
6
- const marketingSupportProjectSelectedAppSlug = "selected-app-slug";
7
- const navigationClient = useNavigationClient();
8
- const expertUrl = navigationClient.getExpertUrl();
9
- return useMemo(() => {
10
- if (!project || !enabled) {
11
- return [];
12
- }
13
- const navigationVisibility = getProjectNavigationVisibilityMap(
14
- project,
15
- adminRights,
16
- () => true
17
- );
18
- const appsNavigationItem = {
19
- key: "apps",
20
- label: "Apps",
21
- isActive: (input) => input === "apps",
22
- link: `${expertUrl}/apps/${project.project_id}/`,
23
- ...navigationVisibility.apps
24
- };
25
- const appsNavigationItemArrInMainMenu = [];
26
- const appsNavigationItemArrInMoreMenu = [];
27
- if (project.project_type === "content_integration") {
28
- appsNavigationItemArrInMoreMenu.push(appsNavigationItem);
29
- } else {
30
- appsNavigationItemArrInMainMenu.push(appsNavigationItem);
31
- }
32
- return [
33
- {
34
- key: "edit",
35
- label: "Editor",
36
- link: `${expertUrl}/project/${project.project_id}/`,
37
- isActive: (input) => input === "edit",
38
- ...navigationVisibility.editor
39
- },
40
- {
41
- key: "files",
42
- label: "Files",
43
- link: `${expertUrl}/files/${project.project_id}/`,
44
- isActive: (input) => input === "files",
45
- ...navigationVisibility.files
46
- },
47
- ...project.project_type === "content_integration" ? [
48
- {
49
- key: "contentManagement",
50
- label: "Content management",
51
- isActive: (input) => input === "apps",
52
- link: `${expertUrl}/apps/${project.project_id}/${marketingSupportProjectSelectedAppSlug}`,
53
- ...navigationVisibility.contentManagement
54
- }
55
- ] : [
56
- {
57
- key: "upload",
58
- label: "Upload",
59
- link: `${expertUrl}/upload/${project.project_id}/`,
60
- isActive: (input) => input === "upload",
61
- ...navigationVisibility.upload
62
- },
63
- {
64
- key: "download",
65
- label: "Download",
66
- link: `${expertUrl}/download/${project.project_id}/`,
67
- isActive: (input) => input === "download",
68
- ...navigationVisibility.download
69
- }
70
- ],
71
- {
72
- key: "tasks",
73
- label: "Tasks",
74
- link: `${expertUrl}/tasks/${project.project_id}/`,
75
- isActive: (input) => input === "tasks",
76
- // TODO: Add task count
77
- // badge: taskCount,
78
- ...navigationVisibility.tasks
79
- },
80
- {
81
- key: "workflows",
82
- label: "Workflows",
83
- link: `${expertUrl}/workflows/${project.project_id}/`,
84
- isActive: (input) => input === "workflows",
85
- novel: "New",
86
- onClick: () => {
87
- window.location.assign(`${expertUrl}/workflows/${project.project_id}/`);
88
- },
89
- ...navigationVisibility.workflows
90
- },
91
- {
92
- key: "contributors",
93
- label: "Contributors",
94
- link: `${expertUrl}/contributors/${project.project_id}/`,
95
- isActive: (input) => input === "contributors",
96
- ...navigationVisibility.contributors
97
- },
98
- {
99
- key: "screenshots",
100
- label: "Screenshots",
101
- link: `${expertUrl}/screenshots/${project.project_id}/`,
102
- isActive: (input) => input === "screenshots",
103
- ...navigationVisibility.screenshots
104
- },
105
- {
106
- key: "glossary",
107
- label: "Glossary",
108
- link: `${expertUrl}/glossary/${project.project_id}/`,
109
- isActive: (input) => input === "glossary",
110
- ...navigationVisibility.glossary
111
- },
112
- ...appsNavigationItemArrInMainMenu,
113
- {
114
- key: "more",
115
- label: "More...",
116
- isActive: (input) => ["settings", "statistics", "duplicates", "live edit"].includes(input),
117
- ...navigationVisibility.more,
118
- dropdown: [
119
- [
120
- {
121
- link: `${expertUrl}/settings/${project.project_id}/`,
122
- label: "Settings",
123
- ...navigationVisibility.settings
124
- },
125
- {
126
- link: `${expertUrl}/settings/${project.project_id}/#branches`,
127
- label: "Branches",
128
- ...navigationVisibility.branches
129
- },
130
- {
131
- link: `${expertUrl}/settings/${project.project_id}/#ota-bundles`,
132
- label: "OTA Bundles",
133
- ...navigationVisibility.otaBundles
134
- },
135
- {
136
- link: `${expertUrl}/settings/${project.project_id}/#project-automations`,
137
- label: "Automations",
138
- ...navigationVisibility.automations
139
- },
140
- {
141
- link: `${expertUrl}/dupes/${project.project_id}/`,
142
- label: "Duplicate finder",
143
- ...navigationVisibility.duplicateFinder
144
- }
145
- ],
146
- [
147
- ...appsNavigationItemArrInMoreMenu,
148
- {
149
- // TODO: This could be problematic tab, because it is not a link and we can't just redirect. We need to find a workaround for that.
150
- label: "Activity",
151
- onClick: () => {
152
- },
153
- ...navigationVisibility.activity
154
- },
155
- {
156
- link: `${expertUrl}/statistics/${project.project_id}/`,
157
- label: "Statistics",
158
- ...navigationVisibility.statistics
159
- }
160
- ]
161
- ]
162
- }
163
- ];
164
- }, [project, adminRights, enabled, expertUrl]);
1
+ const logoLink = "_logoLink_1baxb_1";
2
+ const styles = {
3
+ logoLink
165
4
  };
166
5
  export {
167
- useExpertNavigation
6
+ styles as default,
7
+ logoLink
168
8
  };
169
9
  //# sourceMappingURL=harmony98.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony98.mjs","sources":["../src/features/navigation/hooks/useExpertNavigation.ts"],"sourcesContent":["import type { Contributor, Project } from '@features/node'\nimport { useMemo } from 'react'\nimport { useNavigationClient } from '../providers/NavigationClientProvider'\nimport type { NavigationTabsItem } from '../types/navigation'\nimport { getProjectNavigationVisibilityMap } from '../utils/toolbarVisibility'\n\n// TODO: Validate features types\nexport const getIsFeatureEnabled = (features: Record<string, boolean>, name: string) => {\n\tconst featureState = features[name]\n\n\treturn (\n\t\tfeatureState !== null &&\n\t\tfeatureState !== undefined &&\n\t\t[true, 'on', 'true'].includes(featureState)\n\t)\n}\n\n/**\n * Hook to generate legacy navigation items using the existing structure\n * but with context API instead of Redux\n */\nexport const useExpertNavigation = (\n\tenabled: boolean,\n\tproject?: Project,\n\tcontributor?: Contributor,\n) => {\n\t// Use contributor data if provided, otherwise use defaults\n\tconst adminRights = contributor?.admin_rights || []\n\t// TODO: Implement selected app slug, small investigation is needed\n\tconst marketingSupportProjectSelectedAppSlug = 'selected-app-slug'\n\tconst navigationClient = useNavigationClient()\n\tconst expertUrl = navigationClient.getExpertUrl()\n\n\treturn useMemo(() => {\n\t\t// Get data from contexts instead of Redux, or use provided data\n\t\tif (!project || !enabled) {\n\t\t\treturn []\n\t\t}\n\t\t/* TODO: We're missing badges API. We need to get it from the backend or find alternative way to get task count\n\t\t * Fetch tasks and calculate count is not a good idea, because it can have pagination, therefore we can\n\t\t * ask for an additional prop in tasks response: task_count based on branch_id + project_id + task_status\n\t\t */\n\t\t// const taskCount = getTaskCount(project, branch, badges.tasks)\n\n\t\t// TODO: Implement feature flags functionality, most likely separate package\n\t\t// const isFeatureEnabled = (feature: string) => getIsFeatureEnabled(features, feature)\n\n\t\tconst navigationVisibility = getProjectNavigationVisibilityMap(\n\t\t\tproject,\n\t\t\tadminRights,\n\t\t\t() => true /*isFeatureEnabled*/,\n\t\t)\n\n\t\tconst appsNavigationItem: NavigationTabsItem = {\n\t\t\tkey: 'apps',\n\t\t\tlabel: 'Apps',\n\t\t\tisActive: (input: string) => input === 'apps',\n\t\t\tlink: `${expertUrl}/apps/${project.project_id}/`,\n\t\t\t...navigationVisibility.apps,\n\t\t}\n\n\t\tconst appsNavigationItemArrInMainMenu: NavigationTabsItem[] = []\n\t\tconst appsNavigationItemArrInMoreMenu: NavigationTabsItem[] = []\n\n\t\tif (project.project_type === 'content_integration') {\n\t\t\tappsNavigationItemArrInMoreMenu.push(appsNavigationItem)\n\t\t} else {\n\t\t\tappsNavigationItemArrInMainMenu.push(appsNavigationItem)\n\t\t}\n\n\t\treturn [\n\t\t\t{\n\t\t\t\tkey: 'edit',\n\t\t\t\tlabel: 'Editor',\n\t\t\t\tlink: `${expertUrl}/project/${project.project_id}/`,\n\t\t\t\tisActive: (input: string) => input === 'edit',\n\t\t\t\t...navigationVisibility.editor,\n\t\t\t},\n\t\t\t{\n\t\t\t\tkey: 'files',\n\t\t\t\tlabel: 'Files',\n\t\t\t\tlink: `${expertUrl}/files/${project.project_id}/`,\n\t\t\t\tisActive: (input: string) => input === 'files',\n\t\t\t\t...navigationVisibility.files,\n\t\t\t},\n\t\t\t...(project.project_type === 'content_integration'\n\t\t\t\t? [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tkey: 'contentManagement',\n\t\t\t\t\t\t\tlabel: 'Content management',\n\t\t\t\t\t\t\tisActive: (input: string) => input === 'apps',\n\t\t\t\t\t\t\tlink: `${expertUrl}/apps/${project.project_id}/${marketingSupportProjectSelectedAppSlug}`,\n\t\t\t\t\t\t\t...navigationVisibility.contentManagement,\n\t\t\t\t\t\t},\n\t\t\t\t\t]\n\t\t\t\t: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tkey: 'upload',\n\t\t\t\t\t\t\tlabel: 'Upload',\n\t\t\t\t\t\t\tlink: `${expertUrl}/upload/${project.project_id}/`,\n\t\t\t\t\t\t\tisActive: (input: string) => input === 'upload',\n\t\t\t\t\t\t\t...navigationVisibility.upload,\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tkey: 'download',\n\t\t\t\t\t\t\tlabel: 'Download',\n\t\t\t\t\t\t\tlink: `${expertUrl}/download/${project.project_id}/`,\n\t\t\t\t\t\t\tisActive: (input: string) => input === 'download',\n\t\t\t\t\t\t\t...navigationVisibility.download,\n\t\t\t\t\t\t},\n\t\t\t\t\t]),\n\t\t\t{\n\t\t\t\tkey: 'tasks',\n\t\t\t\tlabel: 'Tasks',\n\t\t\t\tlink: `${expertUrl}/tasks/${project.project_id}/`,\n\t\t\t\tisActive: (input: string) => input === 'tasks',\n\t\t\t\t// TODO: Add task count\n\t\t\t\t// badge: taskCount,\n\t\t\t\t...navigationVisibility.tasks,\n\t\t\t},\n\t\t\t{\n\t\t\t\tkey: 'workflows',\n\t\t\t\tlabel: 'Workflows',\n\t\t\t\tlink: `${expertUrl}/workflows/${project.project_id}/`,\n\t\t\t\tisActive: (input: string) => input === 'workflows',\n\t\t\t\tnovel: 'New',\n\t\t\t\tonClick: () => {\n\t\t\t\t\t// TODO: Resolve analytics globally, most likely separate package\n\t\t\t\t\t// track(AnalyticsEventName.EDITOR_WORKFLOWS_TAB_CLICKED);\n\t\t\t\t\twindow.location.assign(`${expertUrl}/workflows/${project.project_id}/`)\n\t\t\t\t},\n\t\t\t\t...navigationVisibility.workflows,\n\t\t\t},\n\t\t\t{\n\t\t\t\tkey: 'contributors',\n\t\t\t\tlabel: 'Contributors',\n\t\t\t\tlink: `${expertUrl}/contributors/${project.project_id}/`,\n\t\t\t\tisActive: (input: string) => input === 'contributors',\n\t\t\t\t...navigationVisibility.contributors,\n\t\t\t},\n\t\t\t{\n\t\t\t\tkey: 'screenshots',\n\t\t\t\tlabel: 'Screenshots',\n\t\t\t\tlink: `${expertUrl}/screenshots/${project.project_id}/`,\n\t\t\t\tisActive: (input: string) => input === 'screenshots',\n\t\t\t\t...navigationVisibility.screenshots,\n\t\t\t},\n\t\t\t{\n\t\t\t\tkey: 'glossary',\n\t\t\t\tlabel: 'Glossary',\n\t\t\t\tlink: `${expertUrl}/glossary/${project.project_id}/`,\n\t\t\t\tisActive: (input: string) => input === 'glossary',\n\t\t\t\t...navigationVisibility.glossary,\n\t\t\t},\n\t\t\t...appsNavigationItemArrInMainMenu,\n\t\t\t{\n\t\t\t\tkey: 'more',\n\t\t\t\tlabel: 'More...',\n\t\t\t\tisActive: (input: string) =>\n\t\t\t\t\t['settings', 'statistics', 'duplicates', 'live edit'].includes(input),\n\t\t\t\t...navigationVisibility.more,\n\t\t\t\tdropdown: [\n\t\t\t\t\t[\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlink: `${expertUrl}/settings/${project.project_id}/`,\n\t\t\t\t\t\t\tlabel: 'Settings',\n\t\t\t\t\t\t\t...navigationVisibility.settings,\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlink: `${expertUrl}/settings/${project.project_id}/#branches`,\n\t\t\t\t\t\t\tlabel: 'Branches',\n\t\t\t\t\t\t\t...navigationVisibility.branches,\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlink: `${expertUrl}/settings/${project.project_id}/#ota-bundles`,\n\t\t\t\t\t\t\tlabel: 'OTA Bundles',\n\t\t\t\t\t\t\t...navigationVisibility.otaBundles,\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlink: `${expertUrl}/settings/${project.project_id}/#project-automations`,\n\t\t\t\t\t\t\tlabel: 'Automations',\n\t\t\t\t\t\t\t...navigationVisibility.automations,\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlink: `${expertUrl}/dupes/${project.project_id}/`,\n\t\t\t\t\t\t\tlabel: 'Duplicate finder',\n\t\t\t\t\t\t\t...navigationVisibility.duplicateFinder,\n\t\t\t\t\t\t},\n\t\t\t\t\t],\n\t\t\t\t\t[\n\t\t\t\t\t\t...appsNavigationItemArrInMoreMenu,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t// TODO: This could be problematic tab, because it is not a link and we can't just redirect. We need to find a workaround for that.\n\t\t\t\t\t\t\tlabel: 'Activity',\n\t\t\t\t\t\t\tonClick: () => {\n\t\t\t\t\t\t\t\t// const showActivityEvent = new CustomEvent(\"show-activity\", {\n\t\t\t\t\t\t\t\t// \tdetail: {\n\t\t\t\t\t\t\t\t// \t\tprojectId: project.id,\n\t\t\t\t\t\t\t\t// \t\tbranchId: branch.branchId,\n\t\t\t\t\t\t\t\t// \t\tbranchName: branch.branchName,\n\t\t\t\t\t\t\t\t// \t},\n\t\t\t\t\t\t\t\t// });\n\t\t\t\t\t\t\t\t// document.dispatchEvent(showActivityEvent);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t...navigationVisibility.activity,\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlink: `${expertUrl}/statistics/${project.project_id}/`,\n\t\t\t\t\t\t\tlabel: 'Statistics',\n\t\t\t\t\t\t\t...navigationVisibility.statistics,\n\t\t\t\t\t\t},\n\t\t\t\t\t],\n\t\t\t\t],\n\t\t\t},\n\t\t]\n\t}, [project, adminRights, enabled, expertUrl])\n}\n\n// TODO: Helper function for getting task count from badge data\n// const _getTaskCount = (project: any, branch: any, taskBadges: any) => {\n// \tif (!taskBadges) return 0\n\n// \t// Implementation would depend on your getTaskCountFromTasks utility\n// \t// Simplified version:\n// \tconst projectTasks = taskBadges[project.id] || {}\n// \treturn projectTasks[branch.branchId || 'master'] || 0\n// }\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"harmony98.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
@@ -1,47 +1,12 @@
1
1
  "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const React = require("react");
4
- const NavigationClientProvider = require("./harmony94.cjs");
5
- const navigationSchema = require("./harmony115.cjs");
6
- const useNextgenNavigation = (activeKey, enabled, project, contributor) => {
7
- const navigationClient = NavigationClientProvider.useNavigationClient();
8
- const nextgenUrl = navigationClient.getNextgenUrl();
9
- const navigate = React.useCallback(
10
- (path) => {
11
- window.location.href = `${nextgenUrl}${path}`;
12
- },
13
- [nextgenUrl]
14
- );
15
- return React.useMemo(() => {
16
- if (!enabled) {
17
- return [];
18
- }
19
- const projectId = (project == null ? void 0 : project.project_id) || "";
20
- const context = {
21
- flags: {},
22
- // TODO: getFeatureFlags(features),
23
- pathname: window.location.pathname,
24
- permissions: []
25
- };
26
- return navigationSchema.navigationItems.filter((item) => item.shouldShow ? item.shouldShow(context) : true).map((item) => {
27
- const disabled = typeof item.disabled === "function" ? item.disabled(context) : !!item.disabled;
28
- const badge = typeof item.badge === "function" ? item.badge(context) : item.badge;
29
- const isActive = (input) => item.isActive ? item.isActive(input) : item.key === activeKey || input === item.key;
30
- return {
31
- key: item.key,
32
- label: item.labelKey,
33
- // You can apply translations here if needed
34
- icon: item.icon,
35
- visible: true,
36
- badge,
37
- disabled,
38
- dropdown: item.dropdown,
39
- isActive,
40
- link: `${nextgenUrl}${item.path({ projectId })}`,
41
- onClick: () => navigate(item.path({ projectId }))
42
- };
43
- });
44
- }, [project, activeKey, enabled, navigate, contributor, nextgenUrl]);
2
+ Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
3
+ const link = "_link_18vhx_1";
4
+ const active = "_active_18vhx_18";
5
+ const styles = {
6
+ link,
7
+ active
45
8
  };
46
- exports.useNextgenNavigation = useNextgenNavigation;
9
+ exports.active = active;
10
+ exports.default = styles;
11
+ exports.link = link;
47
12
  //# sourceMappingURL=harmony99.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony99.cjs","sources":["../src/features/navigation/hooks/useNextgenNavigation.ts"],"sourcesContent":["import type { Contributor, Project } from '@features/node'\nimport { useCallback, useMemo } from 'react'\nimport { useNavigationClient } from '../providers/NavigationClientProvider'\n// TODO: react-router-dom as peer dependencies works only inside next-gen apps. It shouldn't be like that.\n// Because of that we can't use THE WHOLE package in legacy apps, therefore it should be implemented in legacy apps as well(almost impossible),\n// so this dependency should be installed as direct dependency. or we should think about other options\n// import { useNavigate } from \"react-router-dom\";\nimport { navigationItems } from '../schemas/navigationSchema'\n\n// TODO: Unify navigation items for next-gen and legacy apps\n/**\n * Hook to generate navigation items for new applications\n */\nexport const useNextgenNavigation = (\n\tactiveKey: string,\n\tenabled: boolean,\n\tproject?: Project,\n\tcontributor?: Contributor,\n) => {\n\tconst navigationClient = useNavigationClient()\n\tconst nextgenUrl = navigationClient.getNextgenUrl()\n\n\tconst navigate = useCallback(\n\t\t(path: string) => {\n\t\t\t// TODO: Define navigate logic here\n\t\t\twindow.location.href = `${nextgenUrl}${path}`\n\t\t},\n\t\t[nextgenUrl],\n\t)\n\n\treturn useMemo(() => {\n\t\tif (!enabled) {\n\t\t\treturn []\n\t\t}\n\n\t\tconst projectId = project?.project_id || ''\n\n\t\t// Context for filtering and transforming navigation items\n\t\tconst context = {\n\t\t\tflags: {}, // TODO: getFeatureFlags(features),\n\t\t\tpathname: window.location.pathname,\n\t\t\tpermissions: contributor?.admin_rights || [],\n\t\t}\n\n\t\t// Filter and map items\n\t\treturn (\n\t\t\tnavigationItems\n\t\t\t\t// Filter based on conditions\n\t\t\t\t.filter((item) => (item.shouldShow ? item.shouldShow(context) : true))\n\t\t\t\t// Map to NavigationTabsItem shape\n\t\t\t\t.map((item) => {\n\t\t\t\t\tconst disabled =\n\t\t\t\t\t\ttypeof item.disabled === 'function' ? item.disabled(context) : !!item.disabled\n\n\t\t\t\t\tconst badge = typeof item.badge === 'function' ? item.badge(context) : item.badge\n\n\t\t\t\t\t// Create isActive function\n\t\t\t\t\tconst isActive = (input: string) =>\n\t\t\t\t\t\titem.isActive ? item.isActive(input) : item.key === activeKey || input === item.key\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\tkey: item.key,\n\t\t\t\t\t\tlabel: item.labelKey, // You can apply translations here if needed\n\t\t\t\t\t\ticon: item.icon,\n\t\t\t\t\t\tvisible: true,\n\t\t\t\t\t\tbadge,\n\t\t\t\t\t\tdisabled,\n\t\t\t\t\t\tdropdown: item.dropdown,\n\t\t\t\t\t\tisActive,\n\t\t\t\t\t\tlink: `${nextgenUrl}${item.path({ projectId })}`,\n\t\t\t\t\t\tonClick: () => navigate(item.path({ projectId })),\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t)\n\t}, [project, activeKey, enabled, navigate, contributor, nextgenUrl])\n}\n\n// TODO: Helper to convert features to flags format\n// const getFeatureFlags = (features) => {\n// \tif (!features) return {}\n//\n// \t// Convert features to the format expected by navigation schema\n// \treturn Object.keys(features).reduce((flags, key) => {\n// \t\tflags[key] = features[key] ? 'on' : 'off'\n// \t\treturn flags\n// \t}, {})\n// }\n"],"names":["useNavigationClient","useCallback","useMemo","navigationItems"],"mappings":";;;;;AAaO,MAAM,uBAAuB,CACnC,WACA,SACA,SACA,gBACI;AACJ,QAAM,mBAAmBA,yBAAAA,oBAAoB;AACvC,QAAA,aAAa,iBAAiB,cAAc;AAElD,QAAM,WAAWC,MAAA;AAAA,IAChB,CAAC,SAAiB;AAEjB,aAAO,SAAS,OAAO,GAAG,UAAU,GAAG,IAAI;AAAA,IAC5C;AAAA,IACA,CAAC,UAAU;AAAA,EACZ;AAEA,SAAOC,cAAQ,MAAM;AACpB,QAAI,CAAC,SAAS;AACb,aAAO,CAAC;AAAA,IAAA;AAGH,UAAA,aAAY,mCAAS,eAAc;AAGzC,UAAM,UAAU;AAAA,MACf,OAAO,CAAC;AAAA;AAAA,MACR,UAAU,OAAO,SAAS;AAAA,MAC1B,aAA0C,CAAA;AAAA,IAC3C;AAGA,WACCC,iBAEE,gBAAA,OAAO,CAAC,SAAU,KAAK,aAAa,KAAK,WAAW,OAAO,IAAI,IAAK,EAEpE,IAAI,CAAC,SAAS;AACR,YAAA,WACL,OAAO,KAAK,aAAa,aAAa,KAAK,SAAS,OAAO,IAAI,CAAC,CAAC,KAAK;AAEjE,YAAA,QAAQ,OAAO,KAAK,UAAU,aAAa,KAAK,MAAM,OAAO,IAAI,KAAK;AAG5E,YAAM,WAAW,CAAC,UACjB,KAAK,WAAW,KAAK,SAAS,KAAK,IAAI,KAAK,QAAQ,aAAa,UAAU,KAAK;AAE1E,aAAA;AAAA,QACN,KAAK,KAAK;AAAA,QACV,OAAO,KAAK;AAAA;AAAA,QACZ,MAAM,KAAK;AAAA,QACX,SAAS;AAAA,QACT;AAAA,QACA;AAAA,QACA,UAAU,KAAK;AAAA,QACf;AAAA,QACA,MAAM,GAAG,UAAU,GAAG,KAAK,KAAK,EAAE,UAAW,CAAA,CAAC;AAAA,QAC9C,SAAS,MAAM,SAAS,KAAK,KAAK,EAAE,UAAA,CAAW,CAAC;AAAA,MACjD;AAAA,IAAA,CACA;AAAA,EAAA,GAED,CAAC,SAAS,WAAW,SAAS,UAAU,aAAa,UAAU,CAAC;AACpE;;"}
1
+ {"version":3,"file":"harmony99.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;"}
@@ -1,47 +1,12 @@
1
- import { useCallback, useMemo } from "react";
2
- import { useNavigationClient } from "./harmony94.mjs";
3
- import { navigationItems } from "./harmony115.mjs";
4
- const useNextgenNavigation = (activeKey, enabled, project, contributor) => {
5
- const navigationClient = useNavigationClient();
6
- const nextgenUrl = navigationClient.getNextgenUrl();
7
- const navigate = useCallback(
8
- (path) => {
9
- window.location.href = `${nextgenUrl}${path}`;
10
- },
11
- [nextgenUrl]
12
- );
13
- return useMemo(() => {
14
- if (!enabled) {
15
- return [];
16
- }
17
- const projectId = (project == null ? void 0 : project.project_id) || "";
18
- const context = {
19
- flags: {},
20
- // TODO: getFeatureFlags(features),
21
- pathname: window.location.pathname,
22
- permissions: []
23
- };
24
- return navigationItems.filter((item) => item.shouldShow ? item.shouldShow(context) : true).map((item) => {
25
- const disabled = typeof item.disabled === "function" ? item.disabled(context) : !!item.disabled;
26
- const badge = typeof item.badge === "function" ? item.badge(context) : item.badge;
27
- const isActive = (input) => item.isActive ? item.isActive(input) : item.key === activeKey || input === item.key;
28
- return {
29
- key: item.key,
30
- label: item.labelKey,
31
- // You can apply translations here if needed
32
- icon: item.icon,
33
- visible: true,
34
- badge,
35
- disabled,
36
- dropdown: item.dropdown,
37
- isActive,
38
- link: `${nextgenUrl}${item.path({ projectId })}`,
39
- onClick: () => navigate(item.path({ projectId }))
40
- };
41
- });
42
- }, [project, activeKey, enabled, navigate, contributor, nextgenUrl]);
1
+ const link = "_link_18vhx_1";
2
+ const active = "_active_18vhx_18";
3
+ const styles = {
4
+ link,
5
+ active
43
6
  };
44
7
  export {
45
- useNextgenNavigation
8
+ active,
9
+ styles as default,
10
+ link
46
11
  };
47
12
  //# sourceMappingURL=harmony99.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony99.mjs","sources":["../src/features/navigation/hooks/useNextgenNavigation.ts"],"sourcesContent":["import type { Contributor, Project } from '@features/node'\nimport { useCallback, useMemo } from 'react'\nimport { useNavigationClient } from '../providers/NavigationClientProvider'\n// TODO: react-router-dom as peer dependencies works only inside next-gen apps. It shouldn't be like that.\n// Because of that we can't use THE WHOLE package in legacy apps, therefore it should be implemented in legacy apps as well(almost impossible),\n// so this dependency should be installed as direct dependency. or we should think about other options\n// import { useNavigate } from \"react-router-dom\";\nimport { navigationItems } from '../schemas/navigationSchema'\n\n// TODO: Unify navigation items for next-gen and legacy apps\n/**\n * Hook to generate navigation items for new applications\n */\nexport const useNextgenNavigation = (\n\tactiveKey: string,\n\tenabled: boolean,\n\tproject?: Project,\n\tcontributor?: Contributor,\n) => {\n\tconst navigationClient = useNavigationClient()\n\tconst nextgenUrl = navigationClient.getNextgenUrl()\n\n\tconst navigate = useCallback(\n\t\t(path: string) => {\n\t\t\t// TODO: Define navigate logic here\n\t\t\twindow.location.href = `${nextgenUrl}${path}`\n\t\t},\n\t\t[nextgenUrl],\n\t)\n\n\treturn useMemo(() => {\n\t\tif (!enabled) {\n\t\t\treturn []\n\t\t}\n\n\t\tconst projectId = project?.project_id || ''\n\n\t\t// Context for filtering and transforming navigation items\n\t\tconst context = {\n\t\t\tflags: {}, // TODO: getFeatureFlags(features),\n\t\t\tpathname: window.location.pathname,\n\t\t\tpermissions: contributor?.admin_rights || [],\n\t\t}\n\n\t\t// Filter and map items\n\t\treturn (\n\t\t\tnavigationItems\n\t\t\t\t// Filter based on conditions\n\t\t\t\t.filter((item) => (item.shouldShow ? item.shouldShow(context) : true))\n\t\t\t\t// Map to NavigationTabsItem shape\n\t\t\t\t.map((item) => {\n\t\t\t\t\tconst disabled =\n\t\t\t\t\t\ttypeof item.disabled === 'function' ? item.disabled(context) : !!item.disabled\n\n\t\t\t\t\tconst badge = typeof item.badge === 'function' ? item.badge(context) : item.badge\n\n\t\t\t\t\t// Create isActive function\n\t\t\t\t\tconst isActive = (input: string) =>\n\t\t\t\t\t\titem.isActive ? item.isActive(input) : item.key === activeKey || input === item.key\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\tkey: item.key,\n\t\t\t\t\t\tlabel: item.labelKey, // You can apply translations here if needed\n\t\t\t\t\t\ticon: item.icon,\n\t\t\t\t\t\tvisible: true,\n\t\t\t\t\t\tbadge,\n\t\t\t\t\t\tdisabled,\n\t\t\t\t\t\tdropdown: item.dropdown,\n\t\t\t\t\t\tisActive,\n\t\t\t\t\t\tlink: `${nextgenUrl}${item.path({ projectId })}`,\n\t\t\t\t\t\tonClick: () => navigate(item.path({ projectId })),\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t)\n\t}, [project, activeKey, enabled, navigate, contributor, nextgenUrl])\n}\n\n// TODO: Helper to convert features to flags format\n// const getFeatureFlags = (features) => {\n// \tif (!features) return {}\n//\n// \t// Convert features to the format expected by navigation schema\n// \treturn Object.keys(features).reduce((flags, key) => {\n// \t\tflags[key] = features[key] ? 'on' : 'off'\n// \t\treturn flags\n// \t}, {})\n// }\n"],"names":[],"mappings":";;;AAaO,MAAM,uBAAuB,CACnC,WACA,SACA,SACA,gBACI;AACJ,QAAM,mBAAmB,oBAAoB;AACvC,QAAA,aAAa,iBAAiB,cAAc;AAElD,QAAM,WAAW;AAAA,IAChB,CAAC,SAAiB;AAEjB,aAAO,SAAS,OAAO,GAAG,UAAU,GAAG,IAAI;AAAA,IAC5C;AAAA,IACA,CAAC,UAAU;AAAA,EACZ;AAEA,SAAO,QAAQ,MAAM;AACpB,QAAI,CAAC,SAAS;AACb,aAAO,CAAC;AAAA,IAAA;AAGH,UAAA,aAAY,mCAAS,eAAc;AAGzC,UAAM,UAAU;AAAA,MACf,OAAO,CAAC;AAAA;AAAA,MACR,UAAU,OAAO,SAAS;AAAA,MAC1B,aAA0C,CAAA;AAAA,IAC3C;AAGA,WACC,gBAEE,OAAO,CAAC,SAAU,KAAK,aAAa,KAAK,WAAW,OAAO,IAAI,IAAK,EAEpE,IAAI,CAAC,SAAS;AACR,YAAA,WACL,OAAO,KAAK,aAAa,aAAa,KAAK,SAAS,OAAO,IAAI,CAAC,CAAC,KAAK;AAEjE,YAAA,QAAQ,OAAO,KAAK,UAAU,aAAa,KAAK,MAAM,OAAO,IAAI,KAAK;AAG5E,YAAM,WAAW,CAAC,UACjB,KAAK,WAAW,KAAK,SAAS,KAAK,IAAI,KAAK,QAAQ,aAAa,UAAU,KAAK;AAE1E,aAAA;AAAA,QACN,KAAK,KAAK;AAAA,QACV,OAAO,KAAK;AAAA;AAAA,QACZ,MAAM,KAAK;AAAA,QACX,SAAS;AAAA,QACT;AAAA,QACA;AAAA,QACA,UAAU,KAAK;AAAA,QACf;AAAA,QACA,MAAM,GAAG,UAAU,GAAG,KAAK,KAAK,EAAE,UAAW,CAAA,CAAC;AAAA,QAC9C,SAAS,MAAM,SAAS,KAAK,KAAK,EAAE,UAAA,CAAW,CAAC;AAAA,MACjD;AAAA,IAAA,CACA;AAAA,EAAA,GAED,CAAC,SAAS,WAAW,SAAS,UAAU,aAAa,UAAU,CAAC;AACpE;"}
1
+ {"version":3,"file":"harmony99.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -15,6 +15,7 @@ export declare function useCreateScoreMutation<T>(wretchClient: Wretch<T>, heade
15
15
  category: string;
16
16
  comment: string;
17
17
  severity: "critical" | "major" | "minor" | "neutral";
18
+ penalty: number;
18
19
  }[];
19
20
  score: number;
20
21
  hasMajorIssue: boolean;
@@ -15,6 +15,7 @@ export declare function useGetScoreQuery<T>(wretchClient: Wretch<T>, headers: He
15
15
  category: string;
16
16
  comment: string;
17
17
  severity: "critical" | "major" | "minor" | "neutral";
18
+ penalty: number;
18
19
  }[];
19
20
  score: number;
20
21
  hasMajorIssue: boolean;
@@ -10,20 +10,24 @@ export declare const getScore: import('@lokalise/api-contracts').GetRouteDefinit
10
10
  category: import('zod').ZodString;
11
11
  comment: import('zod').ZodString;
12
12
  severity: import('zod').ZodEnum<["critical", "major", "minor", "neutral"]>;
13
+ penalty: import('zod').ZodNumber;
13
14
  }, "strip", import('zod').ZodTypeAny, {
14
15
  category: string;
15
16
  comment: string;
16
17
  severity: "critical" | "major" | "minor" | "neutral";
18
+ penalty: number;
17
19
  }, {
18
20
  category: string;
19
21
  comment: string;
20
22
  severity: "critical" | "major" | "minor" | "neutral";
23
+ penalty: number;
21
24
  }>, "many">;
22
25
  }, "strip", import('zod').ZodTypeAny, {
23
26
  issues: {
24
27
  category: string;
25
28
  comment: string;
26
29
  severity: "critical" | "major" | "minor" | "neutral";
30
+ penalty: number;
27
31
  }[];
28
32
  score: number;
29
33
  hasMajorIssue: boolean;
@@ -33,6 +37,7 @@ export declare const getScore: import('@lokalise/api-contracts').GetRouteDefinit
33
37
  category: string;
34
38
  comment: string;
35
39
  severity: "critical" | "major" | "minor" | "neutral";
40
+ penalty: number;
36
41
  }[];
37
42
  score: number;
38
43
  hasMajorIssue: boolean;
@@ -196,20 +201,24 @@ export declare const createScore: import('@lokalise/api-contracts').PayloadRoute
196
201
  category: import('zod').ZodString;
197
202
  comment: import('zod').ZodString;
198
203
  severity: import('zod').ZodEnum<["critical", "major", "minor", "neutral"]>;
204
+ penalty: import('zod').ZodNumber;
199
205
  }, "strip", import('zod').ZodTypeAny, {
200
206
  category: string;
201
207
  comment: string;
202
208
  severity: "critical" | "major" | "minor" | "neutral";
209
+ penalty: number;
203
210
  }, {
204
211
  category: string;
205
212
  comment: string;
206
213
  severity: "critical" | "major" | "minor" | "neutral";
214
+ penalty: number;
207
215
  }>, "many">;
208
216
  }, "strip", import('zod').ZodTypeAny, {
209
217
  issues: {
210
218
  category: string;
211
219
  comment: string;
212
220
  severity: "critical" | "major" | "minor" | "neutral";
221
+ penalty: number;
213
222
  }[];
214
223
  score: number;
215
224
  hasMajorIssue: boolean;
@@ -219,6 +228,7 @@ export declare const createScore: import('@lokalise/api-contracts').PayloadRoute
219
228
  category: string;
220
229
  comment: string;
221
230
  severity: "critical" | "major" | "minor" | "neutral";
231
+ penalty: number;
222
232
  }[];
223
233
  score: number;
224
234
  hasMajorIssue: boolean;
@@ -5,14 +5,17 @@ export declare const ISSUE_SCHEMA: z.ZodObject<{
5
5
  category: z.ZodString;
6
6
  comment: z.ZodString;
7
7
  severity: z.ZodEnum<["critical", "major", "minor", "neutral"]>;
8
+ penalty: z.ZodNumber;
8
9
  }, "strip", z.ZodTypeAny, {
9
10
  category: string;
10
11
  comment: string;
11
12
  severity: "critical" | "major" | "minor" | "neutral";
13
+ penalty: number;
12
14
  }, {
13
15
  category: string;
14
16
  comment: string;
15
17
  severity: "critical" | "major" | "minor" | "neutral";
18
+ penalty: number;
16
19
  }>;
17
20
  export type Issue = z.infer<typeof ISSUE_SCHEMA>;
18
21
  export declare const SCORE_REQUEST_QUERY_SCHEMA: z.ZodObject<{
@@ -37,20 +40,24 @@ export declare const GET_SCORE_RESPONSE_SCHEMA: z.ZodObject<{
37
40
  category: z.ZodString;
38
41
  comment: z.ZodString;
39
42
  severity: z.ZodEnum<["critical", "major", "minor", "neutral"]>;
43
+ penalty: z.ZodNumber;
40
44
  }, "strip", z.ZodTypeAny, {
41
45
  category: string;
42
46
  comment: string;
43
47
  severity: "critical" | "major" | "minor" | "neutral";
48
+ penalty: number;
44
49
  }, {
45
50
  category: string;
46
51
  comment: string;
47
52
  severity: "critical" | "major" | "minor" | "neutral";
53
+ penalty: number;
48
54
  }>, "many">;
49
55
  }, "strip", z.ZodTypeAny, {
50
56
  issues: {
51
57
  category: string;
52
58
  comment: string;
53
59
  severity: "critical" | "major" | "minor" | "neutral";
60
+ penalty: number;
54
61
  }[];
55
62
  score: number;
56
63
  hasMajorIssue: boolean;
@@ -60,6 +67,7 @@ export declare const GET_SCORE_RESPONSE_SCHEMA: z.ZodObject<{
60
67
  category: string;
61
68
  comment: string;
62
69
  severity: "critical" | "major" | "minor" | "neutral";
70
+ penalty: number;
63
71
  }[];
64
72
  score: number;
65
73
  hasMajorIssue: boolean;
@@ -87,20 +95,24 @@ export declare const CREATE_SCORE_RESPONSE_SCHEMA: z.ZodObject<{
87
95
  category: z.ZodString;
88
96
  comment: z.ZodString;
89
97
  severity: z.ZodEnum<["critical", "major", "minor", "neutral"]>;
98
+ penalty: z.ZodNumber;
90
99
  }, "strip", z.ZodTypeAny, {
91
100
  category: string;
92
101
  comment: string;
93
102
  severity: "critical" | "major" | "minor" | "neutral";
103
+ penalty: number;
94
104
  }, {
95
105
  category: string;
96
106
  comment: string;
97
107
  severity: "critical" | "major" | "minor" | "neutral";
108
+ penalty: number;
98
109
  }>, "many">;
99
110
  }, "strip", z.ZodTypeAny, {
100
111
  issues: {
101
112
  category: string;
102
113
  comment: string;
103
114
  severity: "critical" | "major" | "minor" | "neutral";
115
+ penalty: number;
104
116
  }[];
105
117
  score: number;
106
118
  hasMajorIssue: boolean;
@@ -110,6 +122,7 @@ export declare const CREATE_SCORE_RESPONSE_SCHEMA: z.ZodObject<{
110
122
  category: string;
111
123
  comment: string;
112
124
  severity: "critical" | "major" | "minor" | "neutral";
125
+ penalty: number;
113
126
  }[];
114
127
  score: number;
115
128
  hasMajorIssue: boolean;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lokalise/harmony",
3
- "version": "1.39.4",
3
+ "version": "1.40.0",
4
4
  "author": {
5
5
  "name": "Lokalise",
6
6
  "url": "https://lokalise.com/"