@lokalise/harmony 1.28.0 → 1.28.1

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 (108) hide show
  1. package/dist/harmony.cjs +4 -1
  2. package/dist/harmony.cjs.map +1 -1
  3. package/dist/harmony.mjs +5 -2
  4. package/dist/harmony100.cjs +4 -59
  5. package/dist/harmony100.cjs.map +1 -1
  6. package/dist/harmony100.mjs +5 -60
  7. package/dist/harmony100.mjs.map +1 -1
  8. package/dist/harmony101.cjs +39 -6
  9. package/dist/harmony101.cjs.map +1 -1
  10. package/dist/harmony101.mjs +39 -6
  11. package/dist/harmony101.mjs.map +1 -1
  12. package/dist/harmony102.cjs +60 -18
  13. package/dist/harmony102.cjs.map +1 -1
  14. package/dist/harmony102.mjs +60 -18
  15. package/dist/harmony102.mjs.map +1 -1
  16. package/dist/harmony103.cjs +6 -13
  17. package/dist/harmony103.cjs.map +1 -1
  18. package/dist/harmony103.mjs +6 -13
  19. package/dist/harmony103.mjs.map +1 -1
  20. package/dist/harmony104.cjs +7 -17
  21. package/dist/harmony104.cjs.map +1 -1
  22. package/dist/harmony104.mjs +6 -16
  23. package/dist/harmony104.mjs.map +1 -1
  24. package/dist/harmony105.cjs +99 -6
  25. package/dist/harmony105.cjs.map +1 -1
  26. package/dist/harmony105.mjs +81 -5
  27. package/dist/harmony105.mjs.map +1 -1
  28. package/dist/harmony106.cjs +63 -6
  29. package/dist/harmony106.cjs.map +1 -1
  30. package/dist/harmony106.mjs +62 -5
  31. package/dist/harmony106.mjs.map +1 -1
  32. package/dist/harmony107.cjs +89 -6
  33. package/dist/harmony107.cjs.map +1 -1
  34. package/dist/harmony107.mjs +88 -5
  35. package/dist/harmony107.mjs.map +1 -1
  36. package/dist/harmony108.cjs +19 -63
  37. package/dist/harmony108.cjs.map +1 -1
  38. package/dist/harmony108.mjs +18 -62
  39. package/dist/harmony108.mjs.map +1 -1
  40. package/dist/harmony109.cjs +6 -89
  41. package/dist/harmony109.cjs.map +1 -1
  42. package/dist/harmony109.mjs +5 -88
  43. package/dist/harmony109.mjs.map +1 -1
  44. package/dist/harmony110.cjs +5 -18
  45. package/dist/harmony110.cjs.map +1 -1
  46. package/dist/harmony110.mjs +5 -18
  47. package/dist/harmony110.mjs.map +1 -1
  48. package/dist/harmony117.cjs +1 -1
  49. package/dist/harmony117.mjs +1 -1
  50. package/dist/harmony127.cjs +1 -1
  51. package/dist/harmony127.mjs +1 -1
  52. package/dist/harmony15.cjs +1 -1
  53. package/dist/harmony15.mjs +1 -1
  54. package/dist/harmony22.cjs +1 -1
  55. package/dist/harmony22.mjs +1 -1
  56. package/dist/harmony23.cjs +1 -1
  57. package/dist/harmony23.mjs +1 -1
  58. package/dist/harmony30.cjs +1 -1
  59. package/dist/harmony30.mjs +1 -1
  60. package/dist/harmony60.cjs +63 -29
  61. package/dist/harmony60.cjs.map +1 -1
  62. package/dist/harmony60.mjs +63 -29
  63. package/dist/harmony60.mjs.map +1 -1
  64. package/dist/harmony65.cjs +1 -1
  65. package/dist/harmony65.mjs +1 -1
  66. package/dist/harmony75.cjs +6 -6
  67. package/dist/harmony75.mjs +6 -6
  68. package/dist/harmony83.cjs +1 -1
  69. package/dist/harmony83.mjs +1 -1
  70. package/dist/harmony84.cjs +3 -2
  71. package/dist/harmony84.cjs.map +1 -1
  72. package/dist/harmony84.mjs +3 -2
  73. package/dist/harmony84.mjs.map +1 -1
  74. package/dist/harmony89.cjs +1 -1
  75. package/dist/harmony89.mjs +1 -1
  76. package/dist/harmony93.cjs +18 -99
  77. package/dist/harmony93.cjs.map +1 -1
  78. package/dist/harmony93.mjs +18 -82
  79. package/dist/harmony93.mjs.map +1 -1
  80. package/dist/harmony94.cjs +14 -21
  81. package/dist/harmony94.cjs.map +1 -1
  82. package/dist/harmony94.mjs +13 -20
  83. package/dist/harmony94.mjs.map +1 -1
  84. package/dist/harmony95.cjs +16 -5
  85. package/dist/harmony95.cjs.map +1 -1
  86. package/dist/harmony95.mjs +16 -5
  87. package/dist/harmony95.mjs.map +1 -1
  88. package/dist/harmony96.cjs +21 -132
  89. package/dist/harmony96.cjs.map +1 -1
  90. package/dist/harmony96.mjs +20 -131
  91. package/dist/harmony96.mjs.map +1 -1
  92. package/dist/harmony97.cjs +6 -12
  93. package/dist/harmony97.cjs.map +1 -1
  94. package/dist/harmony97.mjs +5 -11
  95. package/dist/harmony97.mjs.map +1 -1
  96. package/dist/harmony98.cjs +132 -5
  97. package/dist/harmony98.cjs.map +1 -1
  98. package/dist/harmony98.mjs +132 -5
  99. package/dist/harmony98.mjs.map +1 -1
  100. package/dist/harmony99.cjs +12 -40
  101. package/dist/harmony99.cjs.map +1 -1
  102. package/dist/harmony99.mjs +11 -39
  103. package/dist/harmony99.mjs.map +1 -1
  104. package/dist/types/src/features/publicApi/hooks/useListTeamsQuery.d.ts +7 -9
  105. package/dist/types/src/features/publicApi/hooks/useRetrieveTeamQuery.d.ts +24 -11
  106. package/dist/types/src/features/publicApi/team.d.ts +187 -108
  107. package/dist/types/src/features/publicApi/types/teamTypes.d.ts +272 -115
  108. package/package.json +1 -1
@@ -3,7 +3,7 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("react/jsx-runtime");
4
4
  const louis = require("@lokalise/louis");
5
5
  const React = require("react");
6
- const TasksContext = require("./harmony98.cjs");
6
+ const TasksContext = require("./harmony100.cjs");
7
7
  const TaskLanguageCompleted = ({ task, language }) => {
8
8
  const [loading, setLoading] = React.useState(false);
9
9
  const [isMarkAsDonePromptShown, setIsMarkAsDonePromptShown] = React.useState(false);
@@ -1,7 +1,7 @@
1
1
  import { jsxs, Fragment, jsx } from "react/jsx-runtime";
2
2
  import { ConfirmModal, Alert, Link } from "@lokalise/louis";
3
3
  import { useState } from "react";
4
- import { useTasks } from "./harmony98.mjs";
4
+ import { useTasks } from "./harmony100.mjs";
5
5
  const TaskLanguageCompleted = ({ task, language }) => {
6
6
  const [loading, setLoading] = useState(false);
7
7
  const [isMarkAsDonePromptShown, setIsMarkAsDonePromptShown] = useState(false);
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const jwtTokenPayload = require("./harmony102.cjs");
3
+ const jwtTokenPayload = require("./harmony93.cjs");
4
4
  function parseJwtTokenPayload(token) {
5
5
  try {
6
6
  const payload = token.split(".")[1];
@@ -1,4 +1,4 @@
1
- import { JWT_TOKEN_PAYLOAD_SCHEMA } from "./harmony102.mjs";
1
+ import { JWT_TOKEN_PAYLOAD_SCHEMA } from "./harmony93.mjs";
2
2
  function parseJwtTokenPayload(token) {
3
3
  try {
4
4
  const payload = token.split(".")[1];
@@ -2,7 +2,7 @@
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const useGetUserTokenQuery = require("./harmony41.cjs");
4
4
  const React = require("react");
5
- const NewJwtIssuedEvent = require("./harmony103.cjs");
5
+ const NewJwtIssuedEvent = require("./harmony94.cjs");
6
6
  const cookieTokenUtils = require("./harmony16.cjs");
7
7
  function useGetPromotedClassicSessionJwtQuery(wretchClient, headers, teamId) {
8
8
  const csrf = cookieTokenUtils.getCsrfTokenFromCookie();
@@ -1,6 +1,6 @@
1
1
  import { useGetUserTokenQuery, getUserTokenKey } from "./harmony41.mjs";
2
2
  import { useRef, useEffect } from "react";
3
- import { NewJwtIssuedEvent } from "./harmony103.mjs";
3
+ import { NewJwtIssuedEvent } from "./harmony94.mjs";
4
4
  import { getCsrfTokenFromCookie } from "./harmony16.mjs";
5
5
  function useGetPromotedClassicSessionJwtQuery(wretchClient, headers, teamId) {
6
6
  const csrf = getCsrfTokenFromCookie();
@@ -2,7 +2,7 @@
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const React = require("react");
4
4
  const jwtTokenPayload = require("./harmony15.cjs");
5
- const NewJwtIssuedEvent = require("./harmony103.cjs");
5
+ const NewJwtIssuedEvent = require("./harmony94.cjs");
6
6
  const cookieTokenUtils = require("./harmony16.cjs");
7
7
  function useAuthenticatedSessionPayload() {
8
8
  const [payload, setPayload] = React.useState();
@@ -1,6 +1,6 @@
1
1
  import { useState, useEffect } from "react";
2
2
  import { parseJwtTokenPayload } from "./harmony15.mjs";
3
- import { NewJwtIssuedEvent } from "./harmony103.mjs";
3
+ import { NewJwtIssuedEvent } from "./harmony94.mjs";
4
4
  import { getJwtTokenFromCookie } from "./harmony16.mjs";
5
5
  function useAuthenticatedSessionPayload() {
6
6
  const [payload, setPayload] = useState();
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const apiContracts = require("./harmony104.cjs");
3
+ const apiContracts = require("./harmony95.cjs");
4
4
  const scoreTypes = require("./harmony57.cjs");
5
5
  const sharedTypes = require("./harmony58.cjs");
6
6
  const getScore = apiContracts.buildGetRoute({
@@ -1,4 +1,4 @@
1
- import { buildGetRoute } from "./harmony104.mjs";
1
+ import { buildGetRoute } from "./harmony95.mjs";
2
2
  import { GET_SCORE_RESPONSE_SCHEMA, GET_SCORE_REQUEST_QUERY_SCHEMA } from "./harmony57.mjs";
3
3
  import { BASE_API_ENDPOINT_HEADER_SCHEMA } from "./harmony58.mjs";
4
4
  const getScore = buildGetRoute({
@@ -4,50 +4,84 @@ const paginationTypes = require("./harmony53.cjs");
4
4
  const sharedTypes = require("./harmony58.cjs");
5
5
  const zod = require("zod");
6
6
  const TEAM_API_BASE_HEADERS_SCHEMA = sharedTypes.BASE_API_ENDPOINT_HEADER_SCHEMA;
7
- const TEAM_QUOTA_METRICS = ["keys", "projects", "mau", "trafficBytes", "ai_words"];
8
- const TEAM_QUOTA_METRICS_SCHEMA = zod.z.enum(TEAM_QUOTA_METRICS);
9
- const TEAM_QUOTA_USAGE_SCHEMA = zod.z.record(TEAM_QUOTA_METRICS_SCHEMA, zod.z.number());
10
- const TEAM_QUOTA_ALLOWED_SCHEMA = zod.z.record(TEAM_QUOTA_METRICS_SCHEMA, zod.z.number());
11
- const NORMALISED_TEAM_ID_SCHEMA = zod.z.union([
12
- zod.z.object({ id: zod.z.number() }),
13
- zod.z.object({ team_id: zod.z.number() }).transform(({ team_id }) => ({ id: team_id }))
7
+ const EXTENDED_DATE_TIME_SCHEMA = zod.z.union([
8
+ zod.z.string().refine((val) => /^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2} \(.*\)$/.test(val), {
9
+ message: "Invalid datetime format"
10
+ }),
11
+ zod.z.string().datetime({ offset: true }),
12
+ zod.z.string().datetime()
14
13
  ]);
15
- const BASE_TEAM_SCHEMA = NORMALISED_TEAM_ID_SCHEMA.and(
16
- zod.z.object({
17
- // TODO: This should not be optional, but the API is not consistent yet
18
- uuid: zod.z.string().uuid().optional(),
19
- name: zod.z.string(),
20
- created_at: zod.z.string().datetime(),
21
- created_at_timestamp: zod.z.number(),
22
- plan: zod.z.string()
23
- })
24
- );
25
- const TEAM_QUOTA_SCHEMA = zod.z.object({
26
- quota_usage: TEAM_QUOTA_USAGE_SCHEMA,
27
- quota_allowed: TEAM_QUOTA_ALLOWED_SCHEMA
28
- });
29
- const TEAM_META_SCHEMA = zod.z.object({
30
- is_team_suspended: zod.z.boolean(),
31
- is_end_of_trial_active: zod.z.boolean(),
32
- trial_days_left: zod.z.number()
33
- });
14
+ const TEAMS_QUOTA_METRICS = [
15
+ "users",
16
+ "keys",
17
+ "projects",
18
+ "mau",
19
+ "trafficBytes",
20
+ "ai_words"
21
+ ];
22
+ const TEAMS_QUOTA_METRICS_SCHEMA = zod.z.enum(TEAMS_QUOTA_METRICS);
23
+ const TEAMS_QUOTA_USAGE_SCHEMA = zod.z.record(TEAMS_QUOTA_METRICS_SCHEMA, zod.z.number());
24
+ const TEAMS_QUOTA_ALLOWED_SCHEMA = zod.z.record(TEAMS_QUOTA_METRICS_SCHEMA, zod.z.number());
34
25
  const LIST_TEAMS_QUERY_SCHEMA = paginationTypes.PAGINATION_QUERY_PARAMS_SCHEMA;
35
26
  const LIST_TEAMS_RESPONSE_SCHEMA = zod.z.object({
36
- teams: zod.z.array(BASE_TEAM_SCHEMA.and(TEAM_QUOTA_SCHEMA))
27
+ teams: zod.z.array(
28
+ zod.z.object({
29
+ team_id: zod.z.number(),
30
+ // TODO: This should not be optional, but the API is not consistent yet
31
+ uuid: zod.z.string().uuid().optional(),
32
+ name: zod.z.string(),
33
+ plan: zod.z.string(),
34
+ logo_url: zod.z.string(),
35
+ role: zod.z.string(),
36
+ created_at: EXTENDED_DATE_TIME_SCHEMA,
37
+ created_at_timestamp: zod.z.number(),
38
+ quota_usage: TEAMS_QUOTA_USAGE_SCHEMA,
39
+ quota_allowed: TEAMS_QUOTA_ALLOWED_SCHEMA
40
+ })
41
+ )
37
42
  });
43
+ const TEAM_QUOTA_METRICS_SCHEMA = zod.z.object({
44
+ id: zod.z.number().nullable().optional(),
45
+ users: zod.z.number(),
46
+ keys: zod.z.number(),
47
+ projects: zod.z.number(),
48
+ mau: zod.z.number(),
49
+ trafficBytes: zod.z.number(),
50
+ aiWords: zod.z.number()
51
+ });
52
+ const TEAM_QUOTA_USAGE_SCHEMA = TEAM_QUOTA_METRICS_SCHEMA;
53
+ const TEAM_QUOTA_ALLOWED_SCHEMA = TEAM_QUOTA_METRICS_SCHEMA;
38
54
  const RETRIEVE_TEAM_PATH_PARAMS_SCHEMA = zod.z.object({
39
55
  teamId: zod.z.union([zod.z.string().uuid(), zod.z.number()])
40
56
  });
41
57
  const RETRIEVE_TEAM_RESPONSE_SCHEMA = zod.z.object({
42
- team: BASE_TEAM_SCHEMA.and(TEAM_QUOTA_SCHEMA).and(TEAM_META_SCHEMA)
58
+ team: zod.z.object({
59
+ team_id: zod.z.number(),
60
+ // TODO: This should not be optional, but the API is not consistent yet
61
+ uuid: zod.z.string().uuid().optional(),
62
+ name: zod.z.string(),
63
+ plan_name: zod.z.string(),
64
+ created_at: EXTENDED_DATE_TIME_SCHEMA,
65
+ created_at_timestamp: zod.z.number(),
66
+ logo_url: zod.z.string(),
67
+ role: zod.z.string(),
68
+ quota_usage: TEAM_QUOTA_USAGE_SCHEMA,
69
+ quota_allowed: TEAM_QUOTA_ALLOWED_SCHEMA,
70
+ is_team_suspended: zod.z.boolean(),
71
+ is_end_of_trial_active: zod.z.boolean(),
72
+ trial_days_left: zod.z.number()
73
+ })
43
74
  });
44
75
  exports.LIST_TEAMS_QUERY_SCHEMA = LIST_TEAMS_QUERY_SCHEMA;
45
76
  exports.LIST_TEAMS_RESPONSE_SCHEMA = LIST_TEAMS_RESPONSE_SCHEMA;
46
77
  exports.RETRIEVE_TEAM_PATH_PARAMS_SCHEMA = RETRIEVE_TEAM_PATH_PARAMS_SCHEMA;
47
78
  exports.RETRIEVE_TEAM_RESPONSE_SCHEMA = RETRIEVE_TEAM_RESPONSE_SCHEMA;
79
+ exports.TEAMS_QUOTA_ALLOWED_SCHEMA = TEAMS_QUOTA_ALLOWED_SCHEMA;
80
+ exports.TEAMS_QUOTA_METRICS = TEAMS_QUOTA_METRICS;
81
+ exports.TEAMS_QUOTA_METRICS_SCHEMA = TEAMS_QUOTA_METRICS_SCHEMA;
82
+ exports.TEAMS_QUOTA_USAGE_SCHEMA = TEAMS_QUOTA_USAGE_SCHEMA;
48
83
  exports.TEAM_API_BASE_HEADERS_SCHEMA = TEAM_API_BASE_HEADERS_SCHEMA;
49
84
  exports.TEAM_QUOTA_ALLOWED_SCHEMA = TEAM_QUOTA_ALLOWED_SCHEMA;
50
- exports.TEAM_QUOTA_METRICS = TEAM_QUOTA_METRICS;
51
85
  exports.TEAM_QUOTA_METRICS_SCHEMA = TEAM_QUOTA_METRICS_SCHEMA;
52
86
  exports.TEAM_QUOTA_USAGE_SCHEMA = TEAM_QUOTA_USAGE_SCHEMA;
53
87
  //# sourceMappingURL=harmony60.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony60.cjs","sources":["../src/features/publicApi/types/teamTypes.ts"],"sourcesContent":["import { PAGINATION_QUERY_PARAMS_SCHEMA } from '@features/publicApi/types/paginationTypes'\nimport { BASE_API_ENDPOINT_HEADER_SCHEMA } from '@features/publicApi/types/sharedTypes'\nimport { z } from 'zod'\n\nexport const TEAM_API_BASE_HEADERS_SCHEMA = BASE_API_ENDPOINT_HEADER_SCHEMA\n\nexport type TeamApiBaseHeaders = z.infer<typeof TEAM_API_BASE_HEADERS_SCHEMA>\n\nexport const TEAM_QUOTA_METRICS = ['keys', 'projects', 'mau', 'trafficBytes', 'ai_words'] as const\nexport const TEAM_QUOTA_METRICS_SCHEMA = z.enum(TEAM_QUOTA_METRICS)\nexport type TeamQuotaMetrics = z.infer<typeof TEAM_QUOTA_METRICS_SCHEMA>\n\nexport const TEAM_QUOTA_USAGE_SCHEMA = z.record(TEAM_QUOTA_METRICS_SCHEMA, z.number())\nexport type TeamQuotaUsage = z.infer<typeof TEAM_QUOTA_USAGE_SCHEMA>\n\nexport const TEAM_QUOTA_ALLOWED_SCHEMA = z.record(TEAM_QUOTA_METRICS_SCHEMA, z.number())\nexport type TeamQuotaAllowed = z.infer<typeof TEAM_QUOTA_ALLOWED_SCHEMA>\n\n// This is a MASSIVE HACK to make the API work with the old `team_id` field so that it's normalised to `id`\nconst NORMALISED_TEAM_ID_SCHEMA = z.union([\n\tz.object({ id: z.number() }),\n\tz.object({ team_id: z.number() }).transform(({ team_id }) => ({ id: team_id })),\n])\n\nconst BASE_TEAM_SCHEMA = NORMALISED_TEAM_ID_SCHEMA.and(\n\tz.object({\n\t\t// TODO: This should not be optional, but the API is not consistent yet\n\t\tuuid: z.string().uuid().optional(),\n\t\tname: z.string(),\n\t\tcreated_at: z.string().datetime(),\n\t\tcreated_at_timestamp: z.number(),\n\t\tplan: z.string(),\n\t}),\n)\n\nconst TEAM_QUOTA_SCHEMA = z.object({\n\tquota_usage: TEAM_QUOTA_USAGE_SCHEMA,\n\tquota_allowed: TEAM_QUOTA_ALLOWED_SCHEMA,\n})\n\nconst TEAM_META_SCHEMA = z.object({\n\tis_team_suspended: z.boolean(),\n\tis_end_of_trial_active: z.boolean(),\n\ttrial_days_left: z.number(),\n})\n\nexport const LIST_TEAMS_QUERY_SCHEMA = PAGINATION_QUERY_PARAMS_SCHEMA\nexport type ListTeamsQueryParams = z.infer<typeof LIST_TEAMS_QUERY_SCHEMA>\n\nexport const LIST_TEAMS_RESPONSE_SCHEMA = z.object({\n\tteams: z.array(BASE_TEAM_SCHEMA.and(TEAM_QUOTA_SCHEMA)),\n})\n\nexport type ListTeamsResponse = z.infer<typeof LIST_TEAMS_RESPONSE_SCHEMA>\n\nexport const RETRIEVE_TEAM_PATH_PARAMS_SCHEMA = z.object({\n\tteamId: z.union([z.string().uuid(), z.number()]),\n})\n\nexport type RetrieveTeamPathParams = z.infer<typeof RETRIEVE_TEAM_PATH_PARAMS_SCHEMA>\n\nexport const RETRIEVE_TEAM_RESPONSE_SCHEMA = z.object({\n\tteam: BASE_TEAM_SCHEMA.and(TEAM_QUOTA_SCHEMA).and(TEAM_META_SCHEMA),\n})\n\nexport type RetrieveTeamResponse = z.infer<typeof RETRIEVE_TEAM_RESPONSE_SCHEMA>\n"],"names":["BASE_API_ENDPOINT_HEADER_SCHEMA","z","PAGINATION_QUERY_PARAMS_SCHEMA"],"mappings":";;;;;AAIO,MAAM,+BAA+BA,YAAAA;AAIrC,MAAM,qBAAqB,CAAC,QAAQ,YAAY,OAAO,gBAAgB,UAAU;AAC3E,MAAA,4BAA4BC,IAAAA,EAAE,KAAK,kBAAkB;AAG3D,MAAM,0BAA0BA,IAAAA,EAAE,OAAO,2BAA2BA,IAAAA,EAAE,OAAQ,CAAA;AAG9E,MAAM,4BAA4BA,IAAAA,EAAE,OAAO,2BAA2BA,IAAAA,EAAE,OAAQ,CAAA;AAIvF,MAAM,4BAA4BA,MAAE,MAAM;AAAA,EACzCA,MAAE,OAAO,EAAE,IAAIA,IAAAA,EAAE,UAAU;AAAA,EAC3BA,IAAAA,EAAE,OAAO,EAAE,SAASA,IAAA,EAAE,SAAU,CAAA,EAAE,UAAU,CAAC,EAAE,QAAA,OAAe,EAAE,IAAI,UAAU;AAC/E,CAAC;AAED,MAAM,mBAAmB,0BAA0B;AAAA,EAClDA,IAAAA,EAAE,OAAO;AAAA;AAAA,IAER,MAAMA,IAAAA,EAAE,OAAS,EAAA,KAAA,EAAO,SAAS;AAAA,IACjC,MAAMA,MAAE,OAAO;AAAA,IACf,YAAYA,IAAA,EAAE,OAAO,EAAE,SAAS;AAAA,IAChC,sBAAsBA,MAAE,OAAO;AAAA,IAC/B,MAAMA,MAAE,OAAO;AAAA,EACf,CAAA;AACF;AAEA,MAAM,oBAAoBA,MAAE,OAAO;AAAA,EAClC,aAAa;AAAA,EACb,eAAe;AAChB,CAAC;AAED,MAAM,mBAAmBA,MAAE,OAAO;AAAA,EACjC,mBAAmBA,MAAE,QAAQ;AAAA,EAC7B,wBAAwBA,MAAE,QAAQ;AAAA,EAClC,iBAAiBA,MAAE,OAAO;AAC3B,CAAC;AAEM,MAAM,0BAA0BC,gBAAAA;AAG1B,MAAA,6BAA6BD,MAAE,OAAO;AAAA,EAClD,OAAOA,IAAAA,EAAE,MAAM,iBAAiB,IAAI,iBAAiB,CAAC;AACvD,CAAC;AAIY,MAAA,mCAAmCA,MAAE,OAAO;AAAA,EACxD,QAAQA,IAAAA,EAAE,MAAM,CAACA,IAAE,EAAA,OAAS,EAAA,KAAQ,GAAAA,MAAE,QAAQ,CAAC;AAChD,CAAC;AAIY,MAAA,gCAAgCA,MAAE,OAAO;AAAA,EACrD,MAAM,iBAAiB,IAAI,iBAAiB,EAAE,IAAI,gBAAgB;AACnE,CAAC;;;;;;;;;;"}
1
+ {"version":3,"file":"harmony60.cjs","sources":["../src/features/publicApi/types/teamTypes.ts"],"sourcesContent":["import { PAGINATION_QUERY_PARAMS_SCHEMA } from '@features/publicApi/types/paginationTypes'\nimport { BASE_API_ENDPOINT_HEADER_SCHEMA } from '@features/publicApi/types/sharedTypes'\nimport { z } from 'zod'\n\n// Shared schema\nexport const TEAM_API_BASE_HEADERS_SCHEMA = BASE_API_ENDPOINT_HEADER_SCHEMA\n\nexport type TeamApiBaseHeaders = z.infer<typeof TEAM_API_BASE_HEADERS_SCHEMA>\n\n/**\n * TODO - created_at is using custom format like 2024-10-03 09:45:52 (Etc/UTC)\n * instead of ISO 8601 which is expected by ZOD and we need a custom datetime schema\n */\nconst EXTENDED_DATE_TIME_SCHEMA = z.union([\n\tz.string().refine((val) => /^\\d{4}-\\d{2}-\\d{2} \\d{2}:\\d{2}:\\d{2} \\(.*\\)$/.test(val), {\n\t\tmessage: 'Invalid datetime format',\n\t}),\n\tz.string().datetime({ offset: true }),\n\tz.string().datetime(),\n])\n\n// There are too many differences between teams list and retrieving team\n// It is better to keep schemas separately\n\n// List teams\nexport const TEAMS_QUOTA_METRICS = [\n\t'users',\n\t'keys',\n\t'projects',\n\t'mau',\n\t'trafficBytes',\n\t'ai_words',\n] as const\n\nexport const TEAMS_QUOTA_METRICS_SCHEMA = z.enum(TEAMS_QUOTA_METRICS)\nexport type TeamsQuotaMetrics = z.infer<typeof TEAMS_QUOTA_METRICS_SCHEMA>\n\nexport const TEAMS_QUOTA_USAGE_SCHEMA = z.record(TEAMS_QUOTA_METRICS_SCHEMA, z.number())\nexport type TeamsQuotaUsage = z.infer<typeof TEAMS_QUOTA_USAGE_SCHEMA>\n\nexport const TEAMS_QUOTA_ALLOWED_SCHEMA = z.record(TEAMS_QUOTA_METRICS_SCHEMA, z.number())\nexport type TeamsQuotaAllowed = z.infer<typeof TEAMS_QUOTA_ALLOWED_SCHEMA>\n\nexport const LIST_TEAMS_QUERY_SCHEMA = PAGINATION_QUERY_PARAMS_SCHEMA\nexport type ListTeamsQueryParams = z.infer<typeof LIST_TEAMS_QUERY_SCHEMA>\n\nexport const LIST_TEAMS_RESPONSE_SCHEMA = z.object({\n\tteams: z.array(\n\t\tz.object({\n\t\t\tteam_id: z.number(),\n\t\t\t// TODO: This should not be optional, but the API is not consistent yet\n\t\t\tuuid: z.string().uuid().optional(),\n\t\t\tname: z.string(),\n\t\t\tplan: z.string(),\n\t\t\tlogo_url: z.string(),\n\t\t\trole: z.string(),\n\t\t\tcreated_at: EXTENDED_DATE_TIME_SCHEMA,\n\t\t\tcreated_at_timestamp: z.number(),\n\t\t\tquota_usage: TEAMS_QUOTA_USAGE_SCHEMA,\n\t\t\tquota_allowed: TEAMS_QUOTA_ALLOWED_SCHEMA,\n\t\t}),\n\t),\n})\n\nexport type ListTeamsResponse = z.infer<typeof LIST_TEAMS_RESPONSE_SCHEMA>\n\n// Retrieve team\nexport const TEAM_QUOTA_METRICS_SCHEMA = z.object({\n\tid: z.number().nullable().optional(),\n\tusers: z.number(),\n\tkeys: z.number(),\n\tprojects: z.number(),\n\tmau: z.number(),\n\ttrafficBytes: z.number(),\n\taiWords: z.number(),\n})\n\nexport type TeamQuotaMetrics = z.infer<typeof TEAM_QUOTA_METRICS_SCHEMA>\n\nexport const TEAM_QUOTA_USAGE_SCHEMA = TEAM_QUOTA_METRICS_SCHEMA\nexport type TeamQuotaUsage = z.infer<typeof TEAM_QUOTA_USAGE_SCHEMA>\n\nexport const TEAM_QUOTA_ALLOWED_SCHEMA = TEAM_QUOTA_METRICS_SCHEMA\nexport type TeamQuotaAllowed = z.infer<typeof TEAM_QUOTA_ALLOWED_SCHEMA>\n\nexport const RETRIEVE_TEAM_PATH_PARAMS_SCHEMA = z.object({\n\tteamId: z.union([z.string().uuid(), z.number()]),\n})\n\nexport type RetrieveTeamPathParams = z.infer<typeof RETRIEVE_TEAM_PATH_PARAMS_SCHEMA>\n\nexport const RETRIEVE_TEAM_RESPONSE_SCHEMA = z.object({\n\tteam: z.object({\n\t\tteam_id: z.number(),\n\t\t// TODO: This should not be optional, but the API is not consistent yet\n\t\tuuid: z.string().uuid().optional(),\n\t\tname: z.string(),\n\t\tplan_name: z.string(),\n\t\tcreated_at: EXTENDED_DATE_TIME_SCHEMA,\n\t\tcreated_at_timestamp: z.number(),\n\t\tlogo_url: z.string(),\n\t\trole: z.string(),\n\t\tquota_usage: TEAM_QUOTA_USAGE_SCHEMA,\n\t\tquota_allowed: TEAM_QUOTA_ALLOWED_SCHEMA,\n\t\tis_team_suspended: z.boolean(),\n\t\tis_end_of_trial_active: z.boolean(),\n\t\ttrial_days_left: z.number(),\n\t}),\n})\n\nexport type RetrieveTeamResponse = z.infer<typeof RETRIEVE_TEAM_RESPONSE_SCHEMA>\n"],"names":["BASE_API_ENDPOINT_HEADER_SCHEMA","z","PAGINATION_QUERY_PARAMS_SCHEMA"],"mappings":";;;;;AAKO,MAAM,+BAA+BA,YAAAA;AAQ5C,MAAM,4BAA4BC,MAAE,MAAM;AAAA,EACzCA,MAAE,OAAS,EAAA,OAAO,CAAC,QAAQ,+CAA+C,KAAK,GAAG,GAAG;AAAA,IACpF,SAAS;AAAA,EAAA,CACT;AAAA,EACDA,MAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,MAAM;AAAA,EACpCA,IAAA,EAAE,OAAO,EAAE,SAAS;AACrB,CAAC;AAMM,MAAM,sBAAsB;AAAA,EAClC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACD;AAEa,MAAA,6BAA6BA,IAAAA,EAAE,KAAK,mBAAmB;AAG7D,MAAM,2BAA2BA,IAAAA,EAAE,OAAO,4BAA4BA,IAAAA,EAAE,OAAQ,CAAA;AAGhF,MAAM,6BAA6BA,IAAAA,EAAE,OAAO,4BAA4BA,IAAAA,EAAE,OAAQ,CAAA;AAGlF,MAAM,0BAA0BC,gBAAAA;AAG1B,MAAA,6BAA6BD,MAAE,OAAO;AAAA,EAClD,OAAOA,IAAE,EAAA;AAAA,IACRA,IAAAA,EAAE,OAAO;AAAA,MACR,SAASA,MAAE,OAAO;AAAA;AAAA,MAElB,MAAMA,IAAAA,EAAE,OAAS,EAAA,KAAA,EAAO,SAAS;AAAA,MACjC,MAAMA,MAAE,OAAO;AAAA,MACf,MAAMA,MAAE,OAAO;AAAA,MACf,UAAUA,MAAE,OAAO;AAAA,MACnB,MAAMA,MAAE,OAAO;AAAA,MACf,YAAY;AAAA,MACZ,sBAAsBA,MAAE,OAAO;AAAA,MAC/B,aAAa;AAAA,MACb,eAAe;AAAA,IACf,CAAA;AAAA,EAAA;AAEH,CAAC;AAKY,MAAA,4BAA4BA,MAAE,OAAO;AAAA,EACjD,IAAIA,IAAAA,EAAE,OAAS,EAAA,SAAA,EAAW,SAAS;AAAA,EACnC,OAAOA,MAAE,OAAO;AAAA,EAChB,MAAMA,MAAE,OAAO;AAAA,EACf,UAAUA,MAAE,OAAO;AAAA,EACnB,KAAKA,MAAE,OAAO;AAAA,EACd,cAAcA,MAAE,OAAO;AAAA,EACvB,SAASA,MAAE,OAAO;AACnB,CAAC;AAIM,MAAM,0BAA0B;AAGhC,MAAM,4BAA4B;AAG5B,MAAA,mCAAmCA,MAAE,OAAO;AAAA,EACxD,QAAQA,IAAAA,EAAE,MAAM,CAACA,IAAE,EAAA,OAAS,EAAA,KAAQ,GAAAA,MAAE,QAAQ,CAAC;AAChD,CAAC;AAIY,MAAA,gCAAgCA,MAAE,OAAO;AAAA,EACrD,MAAMA,MAAE,OAAO;AAAA,IACd,SAASA,MAAE,OAAO;AAAA;AAAA,IAElB,MAAMA,IAAAA,EAAE,OAAS,EAAA,KAAA,EAAO,SAAS;AAAA,IACjC,MAAMA,MAAE,OAAO;AAAA,IACf,WAAWA,MAAE,OAAO;AAAA,IACpB,YAAY;AAAA,IACZ,sBAAsBA,MAAE,OAAO;AAAA,IAC/B,UAAUA,MAAE,OAAO;AAAA,IACnB,MAAMA,MAAE,OAAO;AAAA,IACf,aAAa;AAAA,IACb,eAAe;AAAA,IACf,mBAAmBA,MAAE,QAAQ;AAAA,IAC7B,wBAAwBA,MAAE,QAAQ;AAAA,IAClC,iBAAiBA,MAAE,OAAO;AAAA,EAC1B,CAAA;AACF,CAAC;;;;;;;;;;;;;"}
@@ -2,51 +2,85 @@ import { PAGINATION_QUERY_PARAMS_SCHEMA } from "./harmony53.mjs";
2
2
  import { BASE_API_ENDPOINT_HEADER_SCHEMA } from "./harmony58.mjs";
3
3
  import { z } from "zod";
4
4
  const TEAM_API_BASE_HEADERS_SCHEMA = BASE_API_ENDPOINT_HEADER_SCHEMA;
5
- const TEAM_QUOTA_METRICS = ["keys", "projects", "mau", "trafficBytes", "ai_words"];
6
- const TEAM_QUOTA_METRICS_SCHEMA = z.enum(TEAM_QUOTA_METRICS);
7
- const TEAM_QUOTA_USAGE_SCHEMA = z.record(TEAM_QUOTA_METRICS_SCHEMA, z.number());
8
- const TEAM_QUOTA_ALLOWED_SCHEMA = z.record(TEAM_QUOTA_METRICS_SCHEMA, z.number());
9
- const NORMALISED_TEAM_ID_SCHEMA = z.union([
10
- z.object({ id: z.number() }),
11
- z.object({ team_id: z.number() }).transform(({ team_id }) => ({ id: team_id }))
5
+ const EXTENDED_DATE_TIME_SCHEMA = z.union([
6
+ z.string().refine((val) => /^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2} \(.*\)$/.test(val), {
7
+ message: "Invalid datetime format"
8
+ }),
9
+ z.string().datetime({ offset: true }),
10
+ z.string().datetime()
12
11
  ]);
13
- const BASE_TEAM_SCHEMA = NORMALISED_TEAM_ID_SCHEMA.and(
14
- z.object({
15
- // TODO: This should not be optional, but the API is not consistent yet
16
- uuid: z.string().uuid().optional(),
17
- name: z.string(),
18
- created_at: z.string().datetime(),
19
- created_at_timestamp: z.number(),
20
- plan: z.string()
21
- })
22
- );
23
- const TEAM_QUOTA_SCHEMA = z.object({
24
- quota_usage: TEAM_QUOTA_USAGE_SCHEMA,
25
- quota_allowed: TEAM_QUOTA_ALLOWED_SCHEMA
26
- });
27
- const TEAM_META_SCHEMA = z.object({
28
- is_team_suspended: z.boolean(),
29
- is_end_of_trial_active: z.boolean(),
30
- trial_days_left: z.number()
31
- });
12
+ const TEAMS_QUOTA_METRICS = [
13
+ "users",
14
+ "keys",
15
+ "projects",
16
+ "mau",
17
+ "trafficBytes",
18
+ "ai_words"
19
+ ];
20
+ const TEAMS_QUOTA_METRICS_SCHEMA = z.enum(TEAMS_QUOTA_METRICS);
21
+ const TEAMS_QUOTA_USAGE_SCHEMA = z.record(TEAMS_QUOTA_METRICS_SCHEMA, z.number());
22
+ const TEAMS_QUOTA_ALLOWED_SCHEMA = z.record(TEAMS_QUOTA_METRICS_SCHEMA, z.number());
32
23
  const LIST_TEAMS_QUERY_SCHEMA = PAGINATION_QUERY_PARAMS_SCHEMA;
33
24
  const LIST_TEAMS_RESPONSE_SCHEMA = z.object({
34
- teams: z.array(BASE_TEAM_SCHEMA.and(TEAM_QUOTA_SCHEMA))
25
+ teams: z.array(
26
+ z.object({
27
+ team_id: z.number(),
28
+ // TODO: This should not be optional, but the API is not consistent yet
29
+ uuid: z.string().uuid().optional(),
30
+ name: z.string(),
31
+ plan: z.string(),
32
+ logo_url: z.string(),
33
+ role: z.string(),
34
+ created_at: EXTENDED_DATE_TIME_SCHEMA,
35
+ created_at_timestamp: z.number(),
36
+ quota_usage: TEAMS_QUOTA_USAGE_SCHEMA,
37
+ quota_allowed: TEAMS_QUOTA_ALLOWED_SCHEMA
38
+ })
39
+ )
35
40
  });
41
+ const TEAM_QUOTA_METRICS_SCHEMA = z.object({
42
+ id: z.number().nullable().optional(),
43
+ users: z.number(),
44
+ keys: z.number(),
45
+ projects: z.number(),
46
+ mau: z.number(),
47
+ trafficBytes: z.number(),
48
+ aiWords: z.number()
49
+ });
50
+ const TEAM_QUOTA_USAGE_SCHEMA = TEAM_QUOTA_METRICS_SCHEMA;
51
+ const TEAM_QUOTA_ALLOWED_SCHEMA = TEAM_QUOTA_METRICS_SCHEMA;
36
52
  const RETRIEVE_TEAM_PATH_PARAMS_SCHEMA = z.object({
37
53
  teamId: z.union([z.string().uuid(), z.number()])
38
54
  });
39
55
  const RETRIEVE_TEAM_RESPONSE_SCHEMA = z.object({
40
- team: BASE_TEAM_SCHEMA.and(TEAM_QUOTA_SCHEMA).and(TEAM_META_SCHEMA)
56
+ team: z.object({
57
+ team_id: z.number(),
58
+ // TODO: This should not be optional, but the API is not consistent yet
59
+ uuid: z.string().uuid().optional(),
60
+ name: z.string(),
61
+ plan_name: z.string(),
62
+ created_at: EXTENDED_DATE_TIME_SCHEMA,
63
+ created_at_timestamp: z.number(),
64
+ logo_url: z.string(),
65
+ role: z.string(),
66
+ quota_usage: TEAM_QUOTA_USAGE_SCHEMA,
67
+ quota_allowed: TEAM_QUOTA_ALLOWED_SCHEMA,
68
+ is_team_suspended: z.boolean(),
69
+ is_end_of_trial_active: z.boolean(),
70
+ trial_days_left: z.number()
71
+ })
41
72
  });
42
73
  export {
43
74
  LIST_TEAMS_QUERY_SCHEMA,
44
75
  LIST_TEAMS_RESPONSE_SCHEMA,
45
76
  RETRIEVE_TEAM_PATH_PARAMS_SCHEMA,
46
77
  RETRIEVE_TEAM_RESPONSE_SCHEMA,
78
+ TEAMS_QUOTA_ALLOWED_SCHEMA,
79
+ TEAMS_QUOTA_METRICS,
80
+ TEAMS_QUOTA_METRICS_SCHEMA,
81
+ TEAMS_QUOTA_USAGE_SCHEMA,
47
82
  TEAM_API_BASE_HEADERS_SCHEMA,
48
83
  TEAM_QUOTA_ALLOWED_SCHEMA,
49
- TEAM_QUOTA_METRICS,
50
84
  TEAM_QUOTA_METRICS_SCHEMA,
51
85
  TEAM_QUOTA_USAGE_SCHEMA
52
86
  };
@@ -1 +1 @@
1
- {"version":3,"file":"harmony60.mjs","sources":["../src/features/publicApi/types/teamTypes.ts"],"sourcesContent":["import { PAGINATION_QUERY_PARAMS_SCHEMA } from '@features/publicApi/types/paginationTypes'\nimport { BASE_API_ENDPOINT_HEADER_SCHEMA } from '@features/publicApi/types/sharedTypes'\nimport { z } from 'zod'\n\nexport const TEAM_API_BASE_HEADERS_SCHEMA = BASE_API_ENDPOINT_HEADER_SCHEMA\n\nexport type TeamApiBaseHeaders = z.infer<typeof TEAM_API_BASE_HEADERS_SCHEMA>\n\nexport const TEAM_QUOTA_METRICS = ['keys', 'projects', 'mau', 'trafficBytes', 'ai_words'] as const\nexport const TEAM_QUOTA_METRICS_SCHEMA = z.enum(TEAM_QUOTA_METRICS)\nexport type TeamQuotaMetrics = z.infer<typeof TEAM_QUOTA_METRICS_SCHEMA>\n\nexport const TEAM_QUOTA_USAGE_SCHEMA = z.record(TEAM_QUOTA_METRICS_SCHEMA, z.number())\nexport type TeamQuotaUsage = z.infer<typeof TEAM_QUOTA_USAGE_SCHEMA>\n\nexport const TEAM_QUOTA_ALLOWED_SCHEMA = z.record(TEAM_QUOTA_METRICS_SCHEMA, z.number())\nexport type TeamQuotaAllowed = z.infer<typeof TEAM_QUOTA_ALLOWED_SCHEMA>\n\n// This is a MASSIVE HACK to make the API work with the old `team_id` field so that it's normalised to `id`\nconst NORMALISED_TEAM_ID_SCHEMA = z.union([\n\tz.object({ id: z.number() }),\n\tz.object({ team_id: z.number() }).transform(({ team_id }) => ({ id: team_id })),\n])\n\nconst BASE_TEAM_SCHEMA = NORMALISED_TEAM_ID_SCHEMA.and(\n\tz.object({\n\t\t// TODO: This should not be optional, but the API is not consistent yet\n\t\tuuid: z.string().uuid().optional(),\n\t\tname: z.string(),\n\t\tcreated_at: z.string().datetime(),\n\t\tcreated_at_timestamp: z.number(),\n\t\tplan: z.string(),\n\t}),\n)\n\nconst TEAM_QUOTA_SCHEMA = z.object({\n\tquota_usage: TEAM_QUOTA_USAGE_SCHEMA,\n\tquota_allowed: TEAM_QUOTA_ALLOWED_SCHEMA,\n})\n\nconst TEAM_META_SCHEMA = z.object({\n\tis_team_suspended: z.boolean(),\n\tis_end_of_trial_active: z.boolean(),\n\ttrial_days_left: z.number(),\n})\n\nexport const LIST_TEAMS_QUERY_SCHEMA = PAGINATION_QUERY_PARAMS_SCHEMA\nexport type ListTeamsQueryParams = z.infer<typeof LIST_TEAMS_QUERY_SCHEMA>\n\nexport const LIST_TEAMS_RESPONSE_SCHEMA = z.object({\n\tteams: z.array(BASE_TEAM_SCHEMA.and(TEAM_QUOTA_SCHEMA)),\n})\n\nexport type ListTeamsResponse = z.infer<typeof LIST_TEAMS_RESPONSE_SCHEMA>\n\nexport const RETRIEVE_TEAM_PATH_PARAMS_SCHEMA = z.object({\n\tteamId: z.union([z.string().uuid(), z.number()]),\n})\n\nexport type RetrieveTeamPathParams = z.infer<typeof RETRIEVE_TEAM_PATH_PARAMS_SCHEMA>\n\nexport const RETRIEVE_TEAM_RESPONSE_SCHEMA = z.object({\n\tteam: BASE_TEAM_SCHEMA.and(TEAM_QUOTA_SCHEMA).and(TEAM_META_SCHEMA),\n})\n\nexport type RetrieveTeamResponse = z.infer<typeof RETRIEVE_TEAM_RESPONSE_SCHEMA>\n"],"names":[],"mappings":";;;AAIO,MAAM,+BAA+B;AAIrC,MAAM,qBAAqB,CAAC,QAAQ,YAAY,OAAO,gBAAgB,UAAU;AAC3E,MAAA,4BAA4B,EAAE,KAAK,kBAAkB;AAG3D,MAAM,0BAA0B,EAAE,OAAO,2BAA2B,EAAE,OAAQ,CAAA;AAG9E,MAAM,4BAA4B,EAAE,OAAO,2BAA2B,EAAE,OAAQ,CAAA;AAIvF,MAAM,4BAA4B,EAAE,MAAM;AAAA,EACzC,EAAE,OAAO,EAAE,IAAI,EAAE,UAAU;AAAA,EAC3B,EAAE,OAAO,EAAE,SAAS,EAAE,SAAU,CAAA,EAAE,UAAU,CAAC,EAAE,QAAA,OAAe,EAAE,IAAI,UAAU;AAC/E,CAAC;AAED,MAAM,mBAAmB,0BAA0B;AAAA,EAClD,EAAE,OAAO;AAAA;AAAA,IAER,MAAM,EAAE,OAAS,EAAA,KAAA,EAAO,SAAS;AAAA,IACjC,MAAM,EAAE,OAAO;AAAA,IACf,YAAY,EAAE,OAAO,EAAE,SAAS;AAAA,IAChC,sBAAsB,EAAE,OAAO;AAAA,IAC/B,MAAM,EAAE,OAAO;AAAA,EACf,CAAA;AACF;AAEA,MAAM,oBAAoB,EAAE,OAAO;AAAA,EAClC,aAAa;AAAA,EACb,eAAe;AAChB,CAAC;AAED,MAAM,mBAAmB,EAAE,OAAO;AAAA,EACjC,mBAAmB,EAAE,QAAQ;AAAA,EAC7B,wBAAwB,EAAE,QAAQ;AAAA,EAClC,iBAAiB,EAAE,OAAO;AAC3B,CAAC;AAEM,MAAM,0BAA0B;AAG1B,MAAA,6BAA6B,EAAE,OAAO;AAAA,EAClD,OAAO,EAAE,MAAM,iBAAiB,IAAI,iBAAiB,CAAC;AACvD,CAAC;AAIY,MAAA,mCAAmC,EAAE,OAAO;AAAA,EACxD,QAAQ,EAAE,MAAM,CAAC,EAAE,OAAS,EAAA,KAAQ,GAAA,EAAE,QAAQ,CAAC;AAChD,CAAC;AAIY,MAAA,gCAAgC,EAAE,OAAO;AAAA,EACrD,MAAM,iBAAiB,IAAI,iBAAiB,EAAE,IAAI,gBAAgB;AACnE,CAAC;"}
1
+ {"version":3,"file":"harmony60.mjs","sources":["../src/features/publicApi/types/teamTypes.ts"],"sourcesContent":["import { PAGINATION_QUERY_PARAMS_SCHEMA } from '@features/publicApi/types/paginationTypes'\nimport { BASE_API_ENDPOINT_HEADER_SCHEMA } from '@features/publicApi/types/sharedTypes'\nimport { z } from 'zod'\n\n// Shared schema\nexport const TEAM_API_BASE_HEADERS_SCHEMA = BASE_API_ENDPOINT_HEADER_SCHEMA\n\nexport type TeamApiBaseHeaders = z.infer<typeof TEAM_API_BASE_HEADERS_SCHEMA>\n\n/**\n * TODO - created_at is using custom format like 2024-10-03 09:45:52 (Etc/UTC)\n * instead of ISO 8601 which is expected by ZOD and we need a custom datetime schema\n */\nconst EXTENDED_DATE_TIME_SCHEMA = z.union([\n\tz.string().refine((val) => /^\\d{4}-\\d{2}-\\d{2} \\d{2}:\\d{2}:\\d{2} \\(.*\\)$/.test(val), {\n\t\tmessage: 'Invalid datetime format',\n\t}),\n\tz.string().datetime({ offset: true }),\n\tz.string().datetime(),\n])\n\n// There are too many differences between teams list and retrieving team\n// It is better to keep schemas separately\n\n// List teams\nexport const TEAMS_QUOTA_METRICS = [\n\t'users',\n\t'keys',\n\t'projects',\n\t'mau',\n\t'trafficBytes',\n\t'ai_words',\n] as const\n\nexport const TEAMS_QUOTA_METRICS_SCHEMA = z.enum(TEAMS_QUOTA_METRICS)\nexport type TeamsQuotaMetrics = z.infer<typeof TEAMS_QUOTA_METRICS_SCHEMA>\n\nexport const TEAMS_QUOTA_USAGE_SCHEMA = z.record(TEAMS_QUOTA_METRICS_SCHEMA, z.number())\nexport type TeamsQuotaUsage = z.infer<typeof TEAMS_QUOTA_USAGE_SCHEMA>\n\nexport const TEAMS_QUOTA_ALLOWED_SCHEMA = z.record(TEAMS_QUOTA_METRICS_SCHEMA, z.number())\nexport type TeamsQuotaAllowed = z.infer<typeof TEAMS_QUOTA_ALLOWED_SCHEMA>\n\nexport const LIST_TEAMS_QUERY_SCHEMA = PAGINATION_QUERY_PARAMS_SCHEMA\nexport type ListTeamsQueryParams = z.infer<typeof LIST_TEAMS_QUERY_SCHEMA>\n\nexport const LIST_TEAMS_RESPONSE_SCHEMA = z.object({\n\tteams: z.array(\n\t\tz.object({\n\t\t\tteam_id: z.number(),\n\t\t\t// TODO: This should not be optional, but the API is not consistent yet\n\t\t\tuuid: z.string().uuid().optional(),\n\t\t\tname: z.string(),\n\t\t\tplan: z.string(),\n\t\t\tlogo_url: z.string(),\n\t\t\trole: z.string(),\n\t\t\tcreated_at: EXTENDED_DATE_TIME_SCHEMA,\n\t\t\tcreated_at_timestamp: z.number(),\n\t\t\tquota_usage: TEAMS_QUOTA_USAGE_SCHEMA,\n\t\t\tquota_allowed: TEAMS_QUOTA_ALLOWED_SCHEMA,\n\t\t}),\n\t),\n})\n\nexport type ListTeamsResponse = z.infer<typeof LIST_TEAMS_RESPONSE_SCHEMA>\n\n// Retrieve team\nexport const TEAM_QUOTA_METRICS_SCHEMA = z.object({\n\tid: z.number().nullable().optional(),\n\tusers: z.number(),\n\tkeys: z.number(),\n\tprojects: z.number(),\n\tmau: z.number(),\n\ttrafficBytes: z.number(),\n\taiWords: z.number(),\n})\n\nexport type TeamQuotaMetrics = z.infer<typeof TEAM_QUOTA_METRICS_SCHEMA>\n\nexport const TEAM_QUOTA_USAGE_SCHEMA = TEAM_QUOTA_METRICS_SCHEMA\nexport type TeamQuotaUsage = z.infer<typeof TEAM_QUOTA_USAGE_SCHEMA>\n\nexport const TEAM_QUOTA_ALLOWED_SCHEMA = TEAM_QUOTA_METRICS_SCHEMA\nexport type TeamQuotaAllowed = z.infer<typeof TEAM_QUOTA_ALLOWED_SCHEMA>\n\nexport const RETRIEVE_TEAM_PATH_PARAMS_SCHEMA = z.object({\n\tteamId: z.union([z.string().uuid(), z.number()]),\n})\n\nexport type RetrieveTeamPathParams = z.infer<typeof RETRIEVE_TEAM_PATH_PARAMS_SCHEMA>\n\nexport const RETRIEVE_TEAM_RESPONSE_SCHEMA = z.object({\n\tteam: z.object({\n\t\tteam_id: z.number(),\n\t\t// TODO: This should not be optional, but the API is not consistent yet\n\t\tuuid: z.string().uuid().optional(),\n\t\tname: z.string(),\n\t\tplan_name: z.string(),\n\t\tcreated_at: EXTENDED_DATE_TIME_SCHEMA,\n\t\tcreated_at_timestamp: z.number(),\n\t\tlogo_url: z.string(),\n\t\trole: z.string(),\n\t\tquota_usage: TEAM_QUOTA_USAGE_SCHEMA,\n\t\tquota_allowed: TEAM_QUOTA_ALLOWED_SCHEMA,\n\t\tis_team_suspended: z.boolean(),\n\t\tis_end_of_trial_active: z.boolean(),\n\t\ttrial_days_left: z.number(),\n\t}),\n})\n\nexport type RetrieveTeamResponse = z.infer<typeof RETRIEVE_TEAM_RESPONSE_SCHEMA>\n"],"names":[],"mappings":";;;AAKO,MAAM,+BAA+B;AAQ5C,MAAM,4BAA4B,EAAE,MAAM;AAAA,EACzC,EAAE,OAAS,EAAA,OAAO,CAAC,QAAQ,+CAA+C,KAAK,GAAG,GAAG;AAAA,IACpF,SAAS;AAAA,EAAA,CACT;AAAA,EACD,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,MAAM;AAAA,EACpC,EAAE,OAAO,EAAE,SAAS;AACrB,CAAC;AAMM,MAAM,sBAAsB;AAAA,EAClC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACD;AAEa,MAAA,6BAA6B,EAAE,KAAK,mBAAmB;AAG7D,MAAM,2BAA2B,EAAE,OAAO,4BAA4B,EAAE,OAAQ,CAAA;AAGhF,MAAM,6BAA6B,EAAE,OAAO,4BAA4B,EAAE,OAAQ,CAAA;AAGlF,MAAM,0BAA0B;AAG1B,MAAA,6BAA6B,EAAE,OAAO;AAAA,EAClD,OAAO,EAAE;AAAA,IACR,EAAE,OAAO;AAAA,MACR,SAAS,EAAE,OAAO;AAAA;AAAA,MAElB,MAAM,EAAE,OAAS,EAAA,KAAA,EAAO,SAAS;AAAA,MACjC,MAAM,EAAE,OAAO;AAAA,MACf,MAAM,EAAE,OAAO;AAAA,MACf,UAAU,EAAE,OAAO;AAAA,MACnB,MAAM,EAAE,OAAO;AAAA,MACf,YAAY;AAAA,MACZ,sBAAsB,EAAE,OAAO;AAAA,MAC/B,aAAa;AAAA,MACb,eAAe;AAAA,IACf,CAAA;AAAA,EAAA;AAEH,CAAC;AAKY,MAAA,4BAA4B,EAAE,OAAO;AAAA,EACjD,IAAI,EAAE,OAAS,EAAA,SAAA,EAAW,SAAS;AAAA,EACnC,OAAO,EAAE,OAAO;AAAA,EAChB,MAAM,EAAE,OAAO;AAAA,EACf,UAAU,EAAE,OAAO;AAAA,EACnB,KAAK,EAAE,OAAO;AAAA,EACd,cAAc,EAAE,OAAO;AAAA,EACvB,SAAS,EAAE,OAAO;AACnB,CAAC;AAIM,MAAM,0BAA0B;AAGhC,MAAM,4BAA4B;AAG5B,MAAA,mCAAmC,EAAE,OAAO;AAAA,EACxD,QAAQ,EAAE,MAAM,CAAC,EAAE,OAAS,EAAA,KAAQ,GAAA,EAAE,QAAQ,CAAC;AAChD,CAAC;AAIY,MAAA,gCAAgC,EAAE,OAAO;AAAA,EACrD,MAAM,EAAE,OAAO;AAAA,IACd,SAAS,EAAE,OAAO;AAAA;AAAA,IAElB,MAAM,EAAE,OAAS,EAAA,KAAA,EAAO,SAAS;AAAA,IACjC,MAAM,EAAE,OAAO;AAAA,IACf,WAAW,EAAE,OAAO;AAAA,IACpB,YAAY;AAAA,IACZ,sBAAsB,EAAE,OAAO;AAAA,IAC/B,UAAU,EAAE,OAAO;AAAA,IACnB,MAAM,EAAE,OAAO;AAAA,IACf,aAAa;AAAA,IACb,eAAe;AAAA,IACf,mBAAmB,EAAE,QAAQ;AAAA,IAC7B,wBAAwB,EAAE,QAAQ;AAAA,IAClC,iBAAiB,EAAE,OAAO;AAAA,EAC1B,CAAA;AACF,CAAC;"}
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
3
3
  const React = require("react");
4
- const utils = require("./harmony93.cjs");
4
+ const utils = require("./harmony105.cjs");
5
5
  function useResizeDetector({ skipOnMount = false, refreshMode, refreshRate = 1e3, refreshOptions, handleWidth = true, handleHeight = true, targetRef, observerOptions, onResize } = {}) {
6
6
  const skipResize = React.useRef(skipOnMount);
7
7
  const onResizeRef = utils.useCallbackRef(onResize);
@@ -1,5 +1,5 @@
1
1
  import { useRef, useState, useCallback, useEffect } from "react";
2
- import { useCallbackRef, useRefProxy, getDimensions, patchResizeCallback } from "./harmony93.mjs";
2
+ import { useCallbackRef, useRefProxy, getDimensions, patchResizeCallback } from "./harmony105.mjs";
3
3
  function useResizeDetector({ skipOnMount = false, refreshMode, refreshRate = 1e3, refreshOptions, handleWidth = true, handleHeight = true, targetRef, observerOptions, onResize } = {}) {
4
4
  const skipResize = useRef(skipOnMount);
5
5
  const onResizeRef = useCallbackRef(onResize);
@@ -1,16 +1,16 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("react/jsx-runtime");
4
- const floatingUi_core = require("./harmony96.cjs");
4
+ const floatingUi_core = require("./harmony98.cjs");
5
5
  const louis = require("@lokalise/louis");
6
6
  const useEffectOnce = require("./harmony11.cjs");
7
7
  const clsx = require("./harmony63.cjs");
8
8
  const React = require("react");
9
- const Tasks_module = require("./harmony97.cjs");
10
- const TasksContext = require("./harmony98.cjs");
11
- const TasksPopover = require("./harmony99.cjs");
12
- const TasksProvider = require("./harmony100.cjs");
13
- const taskEvents = require("./harmony101.cjs");
9
+ const Tasks_module = require("./harmony99.cjs");
10
+ const TasksContext = require("./harmony100.cjs");
11
+ const TasksPopover = require("./harmony101.cjs");
12
+ const TasksProvider = require("./harmony102.cjs");
13
+ const taskEvents = require("./harmony103.cjs");
14
14
  const Tasks = TasksProvider.withTasksContext(() => {
15
15
  const [open, setOpen] = React.useState(false);
16
16
  const { tasksCount } = TasksContext.useTasks();
@@ -1,14 +1,14 @@
1
1
  import { jsx, jsxs } from "react/jsx-runtime";
2
- import { shift } from "./harmony96.mjs";
2
+ import { shift } from "./harmony98.mjs";
3
3
  import { Tooltip, Popover, Button, JobIcon } from "@lokalise/louis";
4
4
  import { useEffectOnce } from "./harmony11.mjs";
5
5
  import { clsx } from "./harmony63.mjs";
6
6
  import { useState } from "react";
7
- import styles from "./harmony97.mjs";
8
- import { useTasks } from "./harmony98.mjs";
9
- import { TasksPopover } from "./harmony99.mjs";
10
- import { withTasksContext } from "./harmony100.mjs";
11
- import { TaskEvents } from "./harmony101.mjs";
7
+ import styles from "./harmony99.mjs";
8
+ import { useTasks } from "./harmony100.mjs";
9
+ import { TasksPopover } from "./harmony101.mjs";
10
+ import { withTasksContext } from "./harmony102.mjs";
11
+ import { TaskEvents } from "./harmony103.mjs";
12
12
  const Tasks = withTasksContext(() => {
13
13
  const [open, setOpen] = useState(false);
14
14
  const { tasksCount } = useTasks();
@@ -4,7 +4,7 @@ const jsxRuntime = require("react/jsx-runtime");
4
4
  const louis = require("@lokalise/louis");
5
5
  const clsx = require("./harmony63.cjs");
6
6
  const UpgradeIcon = require("./harmony89.cjs");
7
- const ProfileMenuContent_module = require("./harmony94.cjs");
7
+ const ProfileMenuContent_module = require("./harmony96.cjs");
8
8
  const ProfileMenuContext = require("./harmony85.cjs");
9
9
  const ProfileMenuContent = ({ children }) => {
10
10
  const {
@@ -2,7 +2,7 @@ import { jsx, jsxs } from "react/jsx-runtime";
2
2
  import { Menu, MenuList, UserIcon } from "@lokalise/louis";
3
3
  import { clsx } from "./harmony63.mjs";
4
4
  import { UpgradeIcon } from "./harmony89.mjs";
5
- import styles from "./harmony94.mjs";
5
+ import styles from "./harmony96.mjs";
6
6
  import { useProfileMenu } from "./harmony85.mjs";
7
7
  const ProfileMenuContent = ({ children }) => {
8
8
  const {
@@ -2,11 +2,12 @@
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("react/jsx-runtime");
4
4
  const plan = require("./harmony7.cjs");
5
- const types = require("./harmony95.cjs");
5
+ const types = require("./harmony97.cjs");
6
6
  const ProfileMenuContext = require("./harmony85.cjs");
7
7
  const billingRoles = [
8
8
  types.SidebarTeamRoles.biller,
9
- types.SidebarTeamRoles.owner
9
+ types.SidebarTeamRoles.owner,
10
+ types.SidebarTeamRoles.admin
10
11
  ];
11
12
  const ProfileMenuProvider = ({ children, config }) => {
12
13
  const { teams, currentTeamId, planId, isEndOfTrialActive, isFullyAuthenticated, userTeamRole } = config;
@@ -1 +1 @@
1
- {"version":3,"file":"harmony84.cjs","sources":["../src/components/Sidebar/Widgets/ProfileMenu/ProfileMenuProvider.tsx"],"sourcesContent":["import { isFreePlan, isTrialPlan } from '@utils'\nimport type { PropsWithChildren } from 'react'\nimport { type SidebarTeamRole, SidebarTeamRoles } from '../../types'\nimport { ProfileMenuContext } from './ProfileMenuContext'\nimport type { SidebarProfileMenuConfig } from './types'\n\ntype ProfileMenuProviderProps = PropsWithChildren<{\n\tconfig: SidebarProfileMenuConfig\n}>\n\nconst billingRoles: ReadonlyArray<SidebarTeamRole> = [\n\tSidebarTeamRoles.biller,\n\tSidebarTeamRoles.owner,\n]\n\nexport const ProfileMenuProvider = ({ children, config }: ProfileMenuProviderProps) => {\n\tconst { teams, currentTeamId, planId, isEndOfTrialActive, isFullyAuthenticated, userTeamRole } =\n\t\tconfig\n\n\tconst currentTeam = teams.find((t) => t.id === currentTeamId)\n\n\tconst otherTeams = teams.filter((t) => t.id !== currentTeamId)\n\n\tconst canChangeBilling = billingRoles.includes(userTeamRole)\n\n\tconst canAccessTeamSettings = billingRoles.includes(userTeamRole)\n\n\tconst isOnFreeOrTrialPlan = isFreePlan(planId) || isTrialPlan(planId)\n\n\tconst showUpgradeCta = isFullyAuthenticated && isOnFreeOrTrialPlan && canChangeBilling\n\n\tconst showBillingButton = isFullyAuthenticated && canAccessTeamSettings && canChangeBilling\n\n\tconst allowTeamCreation = isFullyAuthenticated && !isEndOfTrialActive\n\n\tconst providerValue = {\n\t\t...config,\n\t\tcurrentTeam,\n\t\totherTeams,\n\t\tcanChangeBilling,\n\t\tcanAccessTeamSettings,\n\t\tisOnFreeOrTrialPlan,\n\t\tshowUpgradeCta,\n\t\tshowBillingButton,\n\t\tallowTeamCreation,\n\t}\n\n\treturn <ProfileMenuContext.Provider value={providerValue}>{children}</ProfileMenuContext.Provider>\n}\n"],"names":["SidebarTeamRoles","isFreePlan","isTrialPlan","ProfileMenuContext"],"mappings":";;;;;;AAUA,MAAM,eAA+C;AAAA,EACpDA,MAAAA,iBAAiB;AAAA,EACjBA,uBAAiB;AAClB;AAEO,MAAM,sBAAsB,CAAC,EAAE,UAAU,aAAuC;AACtF,QAAM,EAAE,OAAO,eAAe,QAAQ,oBAAoB,sBAAsB,iBAC/E;AAED,QAAM,cAAc,MAAM,KAAK,CAAC,MAAM,EAAE,OAAO,aAAa;AAE5D,QAAM,aAAa,MAAM,OAAO,CAAC,MAAM,EAAE,OAAO,aAAa;AAEvD,QAAA,mBAAmB,aAAa,SAAS,YAAY;AAErD,QAAA,wBAAwB,aAAa,SAAS,YAAY;AAEhE,QAAM,sBAAsBC,KAAA,WAAW,MAAM,KAAKC,KAAAA,YAAY,MAAM;AAE9D,QAAA,iBAAiB,wBAAwB,uBAAuB;AAEhE,QAAA,oBAAoB,wBAAwB,yBAAyB;AAErE,QAAA,oBAAoB,wBAAwB,CAAC;AAEnD,QAAM,gBAAgB;AAAA,IACrB,GAAG;AAAA,IACH;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACD;AAEA,wCAAQC,mBAAAA,mBAAmB,UAAnB,EAA4B,OAAO,eAAgB,UAAS;AACrE;;"}
1
+ {"version":3,"file":"harmony84.cjs","sources":["../src/components/Sidebar/Widgets/ProfileMenu/ProfileMenuProvider.tsx"],"sourcesContent":["import { isFreePlan, isTrialPlan } from '@utils'\nimport type { PropsWithChildren } from 'react'\nimport { type SidebarTeamRole, SidebarTeamRoles } from '../../types'\nimport { ProfileMenuContext } from './ProfileMenuContext'\nimport type { SidebarProfileMenuConfig } from './types'\n\ntype ProfileMenuProviderProps = PropsWithChildren<{\n\tconfig: SidebarProfileMenuConfig\n}>\n\nconst billingRoles: ReadonlyArray<SidebarTeamRole> = [\n\tSidebarTeamRoles.biller,\n\tSidebarTeamRoles.owner,\n\tSidebarTeamRoles.admin,\n]\n\nexport const ProfileMenuProvider = ({ children, config }: ProfileMenuProviderProps) => {\n\tconst { teams, currentTeamId, planId, isEndOfTrialActive, isFullyAuthenticated, userTeamRole } =\n\t\tconfig\n\n\tconst currentTeam = teams.find((t) => t.id === currentTeamId)\n\n\tconst otherTeams = teams.filter((t) => t.id !== currentTeamId)\n\n\tconst canChangeBilling = billingRoles.includes(userTeamRole)\n\n\tconst canAccessTeamSettings = billingRoles.includes(userTeamRole)\n\n\tconst isOnFreeOrTrialPlan = isFreePlan(planId) || isTrialPlan(planId)\n\n\tconst showUpgradeCta = isFullyAuthenticated && isOnFreeOrTrialPlan && canChangeBilling\n\n\tconst showBillingButton = isFullyAuthenticated && canAccessTeamSettings && canChangeBilling\n\n\tconst allowTeamCreation = isFullyAuthenticated && !isEndOfTrialActive\n\n\tconst providerValue = {\n\t\t...config,\n\t\tcurrentTeam,\n\t\totherTeams,\n\t\tcanChangeBilling,\n\t\tcanAccessTeamSettings,\n\t\tisOnFreeOrTrialPlan,\n\t\tshowUpgradeCta,\n\t\tshowBillingButton,\n\t\tallowTeamCreation,\n\t}\n\n\treturn <ProfileMenuContext.Provider value={providerValue}>{children}</ProfileMenuContext.Provider>\n}\n"],"names":["SidebarTeamRoles","isFreePlan","isTrialPlan","ProfileMenuContext"],"mappings":";;;;;;AAUA,MAAM,eAA+C;AAAA,EACpDA,MAAAA,iBAAiB;AAAA,EACjBA,MAAAA,iBAAiB;AAAA,EACjBA,uBAAiB;AAClB;AAEO,MAAM,sBAAsB,CAAC,EAAE,UAAU,aAAuC;AACtF,QAAM,EAAE,OAAO,eAAe,QAAQ,oBAAoB,sBAAsB,iBAC/E;AAED,QAAM,cAAc,MAAM,KAAK,CAAC,MAAM,EAAE,OAAO,aAAa;AAE5D,QAAM,aAAa,MAAM,OAAO,CAAC,MAAM,EAAE,OAAO,aAAa;AAEvD,QAAA,mBAAmB,aAAa,SAAS,YAAY;AAErD,QAAA,wBAAwB,aAAa,SAAS,YAAY;AAEhE,QAAM,sBAAsBC,KAAA,WAAW,MAAM,KAAKC,KAAAA,YAAY,MAAM;AAE9D,QAAA,iBAAiB,wBAAwB,uBAAuB;AAEhE,QAAA,oBAAoB,wBAAwB,yBAAyB;AAErE,QAAA,oBAAoB,wBAAwB,CAAC;AAEnD,QAAM,gBAAgB;AAAA,IACrB,GAAG;AAAA,IACH;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACD;AAEA,wCAAQC,mBAAAA,mBAAmB,UAAnB,EAA4B,OAAO,eAAgB,UAAS;AACrE;;"}
@@ -1,10 +1,11 @@
1
1
  import { jsx } from "react/jsx-runtime";
2
2
  import { isFreePlan, isTrialPlan } from "./harmony7.mjs";
3
- import { SidebarTeamRoles } from "./harmony95.mjs";
3
+ import { SidebarTeamRoles } from "./harmony97.mjs";
4
4
  import { ProfileMenuContext } from "./harmony85.mjs";
5
5
  const billingRoles = [
6
6
  SidebarTeamRoles.biller,
7
- SidebarTeamRoles.owner
7
+ SidebarTeamRoles.owner,
8
+ SidebarTeamRoles.admin
8
9
  ];
9
10
  const ProfileMenuProvider = ({ children, config }) => {
10
11
  const { teams, currentTeamId, planId, isEndOfTrialActive, isFullyAuthenticated, userTeamRole } = config;
@@ -1 +1 @@
1
- {"version":3,"file":"harmony84.mjs","sources":["../src/components/Sidebar/Widgets/ProfileMenu/ProfileMenuProvider.tsx"],"sourcesContent":["import { isFreePlan, isTrialPlan } from '@utils'\nimport type { PropsWithChildren } from 'react'\nimport { type SidebarTeamRole, SidebarTeamRoles } from '../../types'\nimport { ProfileMenuContext } from './ProfileMenuContext'\nimport type { SidebarProfileMenuConfig } from './types'\n\ntype ProfileMenuProviderProps = PropsWithChildren<{\n\tconfig: SidebarProfileMenuConfig\n}>\n\nconst billingRoles: ReadonlyArray<SidebarTeamRole> = [\n\tSidebarTeamRoles.biller,\n\tSidebarTeamRoles.owner,\n]\n\nexport const ProfileMenuProvider = ({ children, config }: ProfileMenuProviderProps) => {\n\tconst { teams, currentTeamId, planId, isEndOfTrialActive, isFullyAuthenticated, userTeamRole } =\n\t\tconfig\n\n\tconst currentTeam = teams.find((t) => t.id === currentTeamId)\n\n\tconst otherTeams = teams.filter((t) => t.id !== currentTeamId)\n\n\tconst canChangeBilling = billingRoles.includes(userTeamRole)\n\n\tconst canAccessTeamSettings = billingRoles.includes(userTeamRole)\n\n\tconst isOnFreeOrTrialPlan = isFreePlan(planId) || isTrialPlan(planId)\n\n\tconst showUpgradeCta = isFullyAuthenticated && isOnFreeOrTrialPlan && canChangeBilling\n\n\tconst showBillingButton = isFullyAuthenticated && canAccessTeamSettings && canChangeBilling\n\n\tconst allowTeamCreation = isFullyAuthenticated && !isEndOfTrialActive\n\n\tconst providerValue = {\n\t\t...config,\n\t\tcurrentTeam,\n\t\totherTeams,\n\t\tcanChangeBilling,\n\t\tcanAccessTeamSettings,\n\t\tisOnFreeOrTrialPlan,\n\t\tshowUpgradeCta,\n\t\tshowBillingButton,\n\t\tallowTeamCreation,\n\t}\n\n\treturn <ProfileMenuContext.Provider value={providerValue}>{children}</ProfileMenuContext.Provider>\n}\n"],"names":[],"mappings":";;;;AAUA,MAAM,eAA+C;AAAA,EACpD,iBAAiB;AAAA,EACjB,iBAAiB;AAClB;AAEO,MAAM,sBAAsB,CAAC,EAAE,UAAU,aAAuC;AACtF,QAAM,EAAE,OAAO,eAAe,QAAQ,oBAAoB,sBAAsB,iBAC/E;AAED,QAAM,cAAc,MAAM,KAAK,CAAC,MAAM,EAAE,OAAO,aAAa;AAE5D,QAAM,aAAa,MAAM,OAAO,CAAC,MAAM,EAAE,OAAO,aAAa;AAEvD,QAAA,mBAAmB,aAAa,SAAS,YAAY;AAErD,QAAA,wBAAwB,aAAa,SAAS,YAAY;AAEhE,QAAM,sBAAsB,WAAW,MAAM,KAAK,YAAY,MAAM;AAE9D,QAAA,iBAAiB,wBAAwB,uBAAuB;AAEhE,QAAA,oBAAoB,wBAAwB,yBAAyB;AAErE,QAAA,oBAAoB,wBAAwB,CAAC;AAEnD,QAAM,gBAAgB;AAAA,IACrB,GAAG;AAAA,IACH;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACD;AAEA,6BAAQ,mBAAmB,UAAnB,EAA4B,OAAO,eAAgB,UAAS;AACrE;"}
1
+ {"version":3,"file":"harmony84.mjs","sources":["../src/components/Sidebar/Widgets/ProfileMenu/ProfileMenuProvider.tsx"],"sourcesContent":["import { isFreePlan, isTrialPlan } from '@utils'\nimport type { PropsWithChildren } from 'react'\nimport { type SidebarTeamRole, SidebarTeamRoles } from '../../types'\nimport { ProfileMenuContext } from './ProfileMenuContext'\nimport type { SidebarProfileMenuConfig } from './types'\n\ntype ProfileMenuProviderProps = PropsWithChildren<{\n\tconfig: SidebarProfileMenuConfig\n}>\n\nconst billingRoles: ReadonlyArray<SidebarTeamRole> = [\n\tSidebarTeamRoles.biller,\n\tSidebarTeamRoles.owner,\n\tSidebarTeamRoles.admin,\n]\n\nexport const ProfileMenuProvider = ({ children, config }: ProfileMenuProviderProps) => {\n\tconst { teams, currentTeamId, planId, isEndOfTrialActive, isFullyAuthenticated, userTeamRole } =\n\t\tconfig\n\n\tconst currentTeam = teams.find((t) => t.id === currentTeamId)\n\n\tconst otherTeams = teams.filter((t) => t.id !== currentTeamId)\n\n\tconst canChangeBilling = billingRoles.includes(userTeamRole)\n\n\tconst canAccessTeamSettings = billingRoles.includes(userTeamRole)\n\n\tconst isOnFreeOrTrialPlan = isFreePlan(planId) || isTrialPlan(planId)\n\n\tconst showUpgradeCta = isFullyAuthenticated && isOnFreeOrTrialPlan && canChangeBilling\n\n\tconst showBillingButton = isFullyAuthenticated && canAccessTeamSettings && canChangeBilling\n\n\tconst allowTeamCreation = isFullyAuthenticated && !isEndOfTrialActive\n\n\tconst providerValue = {\n\t\t...config,\n\t\tcurrentTeam,\n\t\totherTeams,\n\t\tcanChangeBilling,\n\t\tcanAccessTeamSettings,\n\t\tisOnFreeOrTrialPlan,\n\t\tshowUpgradeCta,\n\t\tshowBillingButton,\n\t\tallowTeamCreation,\n\t}\n\n\treturn <ProfileMenuContext.Provider value={providerValue}>{children}</ProfileMenuContext.Provider>\n}\n"],"names":[],"mappings":";;;;AAUA,MAAM,eAA+C;AAAA,EACpD,iBAAiB;AAAA,EACjB,iBAAiB;AAAA,EACjB,iBAAiB;AAClB;AAEO,MAAM,sBAAsB,CAAC,EAAE,UAAU,aAAuC;AACtF,QAAM,EAAE,OAAO,eAAe,QAAQ,oBAAoB,sBAAsB,iBAC/E;AAED,QAAM,cAAc,MAAM,KAAK,CAAC,MAAM,EAAE,OAAO,aAAa;AAE5D,QAAM,aAAa,MAAM,OAAO,CAAC,MAAM,EAAE,OAAO,aAAa;AAEvD,QAAA,mBAAmB,aAAa,SAAS,YAAY;AAErD,QAAA,wBAAwB,aAAa,SAAS,YAAY;AAEhE,QAAM,sBAAsB,WAAW,MAAM,KAAK,YAAY,MAAM;AAE9D,QAAA,iBAAiB,wBAAwB,uBAAuB;AAEhE,QAAA,oBAAoB,wBAAwB,yBAAyB;AAErE,QAAA,oBAAoB,wBAAwB,CAAC;AAEnD,QAAM,gBAAgB;AAAA,IACrB,GAAG;AAAA,IACH;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACD;AAEA,6BAAQ,mBAAmB,UAAnB,EAA4B,OAAO,eAAgB,UAAS;AACrE;"}
@@ -3,7 +3,7 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("react/jsx-runtime");
4
4
  const louis = require("@lokalise/louis");
5
5
  const clsx = require("./harmony63.cjs");
6
- const UpgradeIcon_module = require("./harmony105.cjs");
6
+ const UpgradeIcon_module = require("./harmony104.cjs");
7
7
  const UpgradeIcon = ({ className = "" }) => {
8
8
  return /* @__PURE__ */ jsxRuntime.jsx(
9
9
  "div",
@@ -1,7 +1,7 @@
1
1
  import { jsx } from "react/jsx-runtime";
2
2
  import { CaretUpIcon } from "@lokalise/louis";
3
3
  import { clsx } from "./harmony63.mjs";
4
- import styles from "./harmony105.mjs";
4
+ import styles from "./harmony104.mjs";
5
5
  const UpgradeIcon = ({ className = "" }) => {
6
6
  return /* @__PURE__ */ jsx(
7
7
  "div",