@lokalise/harmony 1.27.3-exp-fixTeamsTypes.8 → 1.27.3
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.
- package/README.md +8 -7
- package/dist/harmony.cjs +1 -4
- package/dist/harmony.cjs.map +1 -1
- package/dist/harmony.css +3 -2
- package/dist/harmony.mjs +2 -5
- package/dist/harmony104.cjs +1 -1
- package/dist/harmony104.mjs +1 -1
- package/dist/harmony105.cjs +1 -1
- package/dist/harmony105.mjs +1 -1
- package/dist/harmony113.cjs +4 -4
- package/dist/harmony113.mjs +4 -4
- package/dist/harmony118.cjs +1 -1
- package/dist/harmony118.mjs +1 -1
- package/dist/harmony122.cjs +6 -7
- package/dist/harmony122.cjs.map +1 -1
- package/dist/harmony122.mjs +6 -7
- package/dist/harmony122.mjs.map +1 -1
- package/dist/harmony123.cjs +6 -56
- package/dist/harmony123.cjs.map +1 -1
- package/dist/harmony123.mjs +6 -56
- package/dist/harmony123.mjs.map +1 -1
- package/dist/harmony124.cjs +54 -57
- package/dist/harmony124.cjs.map +1 -1
- package/dist/harmony124.mjs +55 -58
- package/dist/harmony124.mjs.map +1 -1
- package/dist/harmony125.cjs +60 -18
- package/dist/harmony125.cjs.map +1 -1
- package/dist/harmony125.mjs +59 -17
- package/dist/harmony125.mjs.map +1 -1
- package/dist/harmony126.cjs +19 -7
- package/dist/harmony126.cjs.map +1 -1
- package/dist/harmony126.mjs +18 -6
- package/dist/harmony126.mjs.map +1 -1
- package/dist/harmony15.cjs +1 -1
- package/dist/harmony15.mjs +1 -1
- package/dist/harmony22.cjs +1 -1
- package/dist/harmony22.mjs +1 -1
- package/dist/harmony23.cjs +1 -1
- package/dist/harmony23.mjs +1 -1
- package/dist/harmony30.cjs +1 -1
- package/dist/harmony30.mjs +1 -1
- package/dist/harmony4.cjs.map +1 -1
- package/dist/harmony4.mjs.map +1 -1
- package/dist/harmony59.cjs +29 -63
- package/dist/harmony59.cjs.map +1 -1
- package/dist/harmony59.mjs +29 -63
- package/dist/harmony59.mjs.map +1 -1
- package/dist/harmony71.cjs.map +1 -1
- package/dist/harmony71.mjs.map +1 -1
- package/dist/harmony83.cjs +2 -2
- package/dist/harmony83.mjs +2 -2
- package/dist/harmony93.cjs +18 -16
- package/dist/harmony93.cjs.map +1 -1
- package/dist/harmony93.mjs +18 -16
- package/dist/harmony93.mjs.map +1 -1
- package/dist/harmony94.cjs +14 -18
- package/dist/harmony94.cjs.map +1 -1
- package/dist/harmony94.mjs +14 -18
- package/dist/harmony94.mjs.map +1 -1
- package/dist/harmony95.cjs +16 -14
- package/dist/harmony95.cjs.map +1 -1
- package/dist/harmony95.mjs +16 -14
- package/dist/harmony95.mjs.map +1 -1
- package/dist/types/src/components/Sidebar/Sidebar.d.ts +1 -1
- package/dist/types/src/features/publicApi/hooks/useListTeamsQuery.d.ts +9 -7
- package/dist/types/src/features/publicApi/hooks/useRetrieveTeamQuery.d.ts +11 -24
- package/dist/types/src/features/publicApi/team.d.ts +108 -187
- package/dist/types/src/features/publicApi/types/teamTypes.d.ts +115 -272
- package/package.json +1 -1
package/dist/harmony59.cjs
CHANGED
@@ -4,84 +4,50 @@ const paginationTypes = require("./harmony52.cjs");
|
|
4
4
|
const sharedTypes = require("./harmony57.cjs");
|
5
5
|
const zod = require("zod");
|
6
6
|
const TEAM_API_BASE_HEADERS_SCHEMA = sharedTypes.BASE_API_ENDPOINT_HEADER_SCHEMA;
|
7
|
-
const
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
zod.z.
|
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 }))
|
13
14
|
]);
|
14
|
-
const
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
const
|
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
|
+
});
|
25
34
|
const LIST_TEAMS_QUERY_SCHEMA = paginationTypes.PAGINATION_QUERY_PARAMS_SCHEMA;
|
26
35
|
const LIST_TEAMS_RESPONSE_SCHEMA = zod.z.object({
|
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
|
-
)
|
36
|
+
teams: zod.z.array(BASE_TEAM_SCHEMA.and(TEAM_QUOTA_SCHEMA))
|
42
37
|
});
|
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;
|
54
38
|
const RETRIEVE_TEAM_PATH_PARAMS_SCHEMA = zod.z.object({
|
55
39
|
teamId: zod.z.union([zod.z.string().uuid(), zod.z.number()])
|
56
40
|
});
|
57
41
|
const RETRIEVE_TEAM_RESPONSE_SCHEMA = zod.z.object({
|
58
|
-
team:
|
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
|
-
})
|
42
|
+
team: BASE_TEAM_SCHEMA.and(TEAM_QUOTA_SCHEMA).and(TEAM_META_SCHEMA)
|
74
43
|
});
|
75
44
|
exports.LIST_TEAMS_QUERY_SCHEMA = LIST_TEAMS_QUERY_SCHEMA;
|
76
45
|
exports.LIST_TEAMS_RESPONSE_SCHEMA = LIST_TEAMS_RESPONSE_SCHEMA;
|
77
46
|
exports.RETRIEVE_TEAM_PATH_PARAMS_SCHEMA = RETRIEVE_TEAM_PATH_PARAMS_SCHEMA;
|
78
47
|
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;
|
83
48
|
exports.TEAM_API_BASE_HEADERS_SCHEMA = TEAM_API_BASE_HEADERS_SCHEMA;
|
84
49
|
exports.TEAM_QUOTA_ALLOWED_SCHEMA = TEAM_QUOTA_ALLOWED_SCHEMA;
|
50
|
+
exports.TEAM_QUOTA_METRICS = TEAM_QUOTA_METRICS;
|
85
51
|
exports.TEAM_QUOTA_METRICS_SCHEMA = TEAM_QUOTA_METRICS_SCHEMA;
|
86
52
|
exports.TEAM_QUOTA_USAGE_SCHEMA = TEAM_QUOTA_USAGE_SCHEMA;
|
87
53
|
//# sourceMappingURL=harmony59.cjs.map
|
package/dist/harmony59.cjs.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"harmony59.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\
|
1
|
+
{"version":3,"file":"harmony59.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;;;;;;;;;;"}
|
package/dist/harmony59.mjs
CHANGED
@@ -2,85 +2,51 @@ import { PAGINATION_QUERY_PARAMS_SCHEMA } from "./harmony52.mjs";
|
|
2
2
|
import { BASE_API_ENDPOINT_HEADER_SCHEMA } from "./harmony57.mjs";
|
3
3
|
import { z } from "zod";
|
4
4
|
const TEAM_API_BASE_HEADERS_SCHEMA = BASE_API_ENDPOINT_HEADER_SCHEMA;
|
5
|
-
const
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
z.
|
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 }))
|
11
12
|
]);
|
12
|
-
const
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
const
|
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
|
+
});
|
23
32
|
const LIST_TEAMS_QUERY_SCHEMA = PAGINATION_QUERY_PARAMS_SCHEMA;
|
24
33
|
const LIST_TEAMS_RESPONSE_SCHEMA = z.object({
|
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
|
-
)
|
34
|
+
teams: z.array(BASE_TEAM_SCHEMA.and(TEAM_QUOTA_SCHEMA))
|
40
35
|
});
|
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;
|
52
36
|
const RETRIEVE_TEAM_PATH_PARAMS_SCHEMA = z.object({
|
53
37
|
teamId: z.union([z.string().uuid(), z.number()])
|
54
38
|
});
|
55
39
|
const RETRIEVE_TEAM_RESPONSE_SCHEMA = z.object({
|
56
|
-
team:
|
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
|
-
})
|
40
|
+
team: BASE_TEAM_SCHEMA.and(TEAM_QUOTA_SCHEMA).and(TEAM_META_SCHEMA)
|
72
41
|
});
|
73
42
|
export {
|
74
43
|
LIST_TEAMS_QUERY_SCHEMA,
|
75
44
|
LIST_TEAMS_RESPONSE_SCHEMA,
|
76
45
|
RETRIEVE_TEAM_PATH_PARAMS_SCHEMA,
|
77
46
|
RETRIEVE_TEAM_RESPONSE_SCHEMA,
|
78
|
-
TEAMS_QUOTA_ALLOWED_SCHEMA,
|
79
|
-
TEAMS_QUOTA_METRICS,
|
80
|
-
TEAMS_QUOTA_METRICS_SCHEMA,
|
81
|
-
TEAMS_QUOTA_USAGE_SCHEMA,
|
82
47
|
TEAM_API_BASE_HEADERS_SCHEMA,
|
83
48
|
TEAM_QUOTA_ALLOWED_SCHEMA,
|
49
|
+
TEAM_QUOTA_METRICS,
|
84
50
|
TEAM_QUOTA_METRICS_SCHEMA,
|
85
51
|
TEAM_QUOTA_USAGE_SCHEMA
|
86
52
|
};
|
package/dist/harmony59.mjs.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"harmony59.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\
|
1
|
+
{"version":3,"file":"harmony59.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;"}
|
package/dist/harmony71.cjs.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"harmony71.cjs","sources":["../src/components/Sidebar/Widgets/ProfileMenu/TeamMenuItem/TeamMenuItem.tsx"],"sourcesContent":["import { MenuItem, UserIcon } from '@lokalise/louis'\nimport { isFreePlan, isTrialPlan } from '
|
1
|
+
{"version":3,"file":"harmony71.cjs","sources":["../src/components/Sidebar/Widgets/ProfileMenu/TeamMenuItem/TeamMenuItem.tsx"],"sourcesContent":["import { MenuItem, UserIcon } from '@lokalise/louis'\nimport { isFreePlan, isTrialPlan } from '../../../../../utils/billing/plan/plan'\nimport type { SidebarTeam } from '../../../types'\nimport { useProfileMenu } from '../ProfileMenuContext'\nimport styles from './TeamMenuItem.module.css'\n\ntype TeamMenuItemProps = {\n\t/** Team to display. If not provided, uses the current team from context */\n\tteam?: SidebarTeam\n\t/** Callback for when the team item is clicked. If provided, renders as a clickable MenuItem */\n\tonClick?: (team: SidebarTeam) => void\n\t/** Whether to hide the plan label (Free/Trial). Useful when displaying multiple teams */\n\thidePlanLabel?: boolean\n}\n\n/**\n * A component that displays team information in a menu item format.\n * Renders team logo (or default user icon), team name, role, and plan label.\n *\n * The component can be used in two modes:\n * 1. As a static display of the current team (when no onClick handler is provided)\n * 2. As a clickable menu item for team switching (when onClick handler is provided)\n *\n * @example\n * ```tsx\n * // Static current team display\n * <TeamMenuItem />\n *\n * // Clickable team item for switching\n * <TeamMenuItem\n * team={someTeam}\n * onClick={(team) => handleTeamSwitch(team)}\n * hidePlanLabel\n * />\n * ```\n *\n * @note This component must be used within a ProfileMenu component\n * as it requires access to the ProfileMenu context for current team\n * and plan information.\n */\nexport const TeamMenuItem = ({ team, onClick, hidePlanLabel }: TeamMenuItemProps) => {\n\tconst { currentTeam, planId } = useProfileMenu()\n\n\tconst contextTeam = team || currentTeam\n\n\tif (!contextTeam) {\n\t\treturn null\n\t}\n\n\tconst planLabel = isFreePlan(planId) ? 'Free' : isTrialPlan(planId) ? 'Trial' : undefined\n\n\tconst WrapperNode = onClick ? MenuItem : 'div'\n\n\treturn (\n\t\t<WrapperNode\n\t\t\tclassName={styles.wrapper}\n\t\t\t{...(onClick && { onClick: () => onClick(contextTeam) })}\n\t\t>\n\t\t\t{contextTeam.logoUrl ? (\n\t\t\t\t<img className={styles.profileImage} src={contextTeam.logoUrl} alt=\"Team logo\" />\n\t\t\t) : (\n\t\t\t\t<span className={`${styles.defaultProfileImage}`}>\n\t\t\t\t\t<UserIcon size=\"25px\" />\n\t\t\t\t</span>\n\t\t\t)}\n\t\t\t<div className={styles.teamDetails}>\n\t\t\t\t<div className={styles.planWrapper}>\n\t\t\t\t\t<span title={contextTeam.name} className={styles.teamName}>\n\t\t\t\t\t\t{contextTeam.name}\n\t\t\t\t\t</span>\n\t\t\t\t\t{planLabel && !hidePlanLabel && <span className={styles.teamName}>{planLabel}</span>}\n\t\t\t\t</div>\n\t\t\t\t<span className={styles.membership}>{contextTeam.role}</span>\n\t\t\t</div>\n\t\t</WrapperNode>\n\t)\n}\n"],"names":["useProfileMenu","isFreePlan","isTrialPlan","MenuItem","jsxs","styles","jsx","UserIcon"],"mappings":";;;;;;;AAwCO,MAAM,eAAe,CAAC,EAAE,MAAM,SAAS,oBAAuC;AACpF,QAAM,EAAE,aAAa,OAAO,IAAIA,kCAAe;AAE/C,QAAM,cAAc,QAAQ;AAE5B,MAAI,CAAC,aAAa;AACV,WAAA;AAAA,EAAA;AAGF,QAAA,YAAYC,gBAAW,MAAM,IAAI,SAASC,iBAAY,MAAM,IAAI,UAAU;AAE1E,QAAA,cAAc,UAAUC,MAAAA,WAAW;AAGxC,SAAAC,2BAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACA,WAAWC,oBAAO,QAAA;AAAA,MACjB,GAAI,WAAW,EAAE,SAAS,MAAM,QAAQ,WAAW,EAAE;AAAA,MAErD,UAAA;AAAA,QAAY,YAAA,yCACX,OAAI,EAAA,WAAWA,oBAAAA,QAAO,cAAc,KAAK,YAAY,SAAS,KAAI,YAAA,CAAY,IAE9EC,+BAAA,QAAA,EAAK,WAAW,GAAGD,oBAAO,QAAA,mBAAmB,IAC7C,UAACC,2BAAAA,IAAAC,MAAAA,UAAA,EAAS,MAAK,OAAA,CAAO,EACvB,CAAA;AAAA,QAEAH,2BAAA,KAAA,OAAA,EAAI,WAAWC,oBAAAA,QAAO,aACtB,UAAA;AAAA,UAACD,2BAAA,KAAA,OAAA,EAAI,WAAWC,oBAAAA,QAAO,aACtB,UAAA;AAAA,YAACC,2BAAAA,IAAA,QAAA,EAAK,OAAO,YAAY,MAAM,WAAWD,oBAAAA,QAAO,UAC/C,sBAAY,KACd,CAAA;AAAA,YACC,aAAa,CAAC,iBAAiBC,2BAAAA,IAAC,UAAK,WAAWD,4BAAO,UAAW,UAAU,UAAA,CAAA;AAAA,UAAA,GAC9E;AAAA,yCACC,QAAK,EAAA,WAAWA,oBAAAA,QAAO,YAAa,sBAAY,KAAK,CAAA;AAAA,QAAA,EACvD,CAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EACD;AAEF;;"}
|
package/dist/harmony71.mjs.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"harmony71.mjs","sources":["../src/components/Sidebar/Widgets/ProfileMenu/TeamMenuItem/TeamMenuItem.tsx"],"sourcesContent":["import { MenuItem, UserIcon } from '@lokalise/louis'\nimport { isFreePlan, isTrialPlan } from '
|
1
|
+
{"version":3,"file":"harmony71.mjs","sources":["../src/components/Sidebar/Widgets/ProfileMenu/TeamMenuItem/TeamMenuItem.tsx"],"sourcesContent":["import { MenuItem, UserIcon } from '@lokalise/louis'\nimport { isFreePlan, isTrialPlan } from '../../../../../utils/billing/plan/plan'\nimport type { SidebarTeam } from '../../../types'\nimport { useProfileMenu } from '../ProfileMenuContext'\nimport styles from './TeamMenuItem.module.css'\n\ntype TeamMenuItemProps = {\n\t/** Team to display. If not provided, uses the current team from context */\n\tteam?: SidebarTeam\n\t/** Callback for when the team item is clicked. If provided, renders as a clickable MenuItem */\n\tonClick?: (team: SidebarTeam) => void\n\t/** Whether to hide the plan label (Free/Trial). Useful when displaying multiple teams */\n\thidePlanLabel?: boolean\n}\n\n/**\n * A component that displays team information in a menu item format.\n * Renders team logo (or default user icon), team name, role, and plan label.\n *\n * The component can be used in two modes:\n * 1. As a static display of the current team (when no onClick handler is provided)\n * 2. As a clickable menu item for team switching (when onClick handler is provided)\n *\n * @example\n * ```tsx\n * // Static current team display\n * <TeamMenuItem />\n *\n * // Clickable team item for switching\n * <TeamMenuItem\n * team={someTeam}\n * onClick={(team) => handleTeamSwitch(team)}\n * hidePlanLabel\n * />\n * ```\n *\n * @note This component must be used within a ProfileMenu component\n * as it requires access to the ProfileMenu context for current team\n * and plan information.\n */\nexport const TeamMenuItem = ({ team, onClick, hidePlanLabel }: TeamMenuItemProps) => {\n\tconst { currentTeam, planId } = useProfileMenu()\n\n\tconst contextTeam = team || currentTeam\n\n\tif (!contextTeam) {\n\t\treturn null\n\t}\n\n\tconst planLabel = isFreePlan(planId) ? 'Free' : isTrialPlan(planId) ? 'Trial' : undefined\n\n\tconst WrapperNode = onClick ? MenuItem : 'div'\n\n\treturn (\n\t\t<WrapperNode\n\t\t\tclassName={styles.wrapper}\n\t\t\t{...(onClick && { onClick: () => onClick(contextTeam) })}\n\t\t>\n\t\t\t{contextTeam.logoUrl ? (\n\t\t\t\t<img className={styles.profileImage} src={contextTeam.logoUrl} alt=\"Team logo\" />\n\t\t\t) : (\n\t\t\t\t<span className={`${styles.defaultProfileImage}`}>\n\t\t\t\t\t<UserIcon size=\"25px\" />\n\t\t\t\t</span>\n\t\t\t)}\n\t\t\t<div className={styles.teamDetails}>\n\t\t\t\t<div className={styles.planWrapper}>\n\t\t\t\t\t<span title={contextTeam.name} className={styles.teamName}>\n\t\t\t\t\t\t{contextTeam.name}\n\t\t\t\t\t</span>\n\t\t\t\t\t{planLabel && !hidePlanLabel && <span className={styles.teamName}>{planLabel}</span>}\n\t\t\t\t</div>\n\t\t\t\t<span className={styles.membership}>{contextTeam.role}</span>\n\t\t\t</div>\n\t\t</WrapperNode>\n\t)\n}\n"],"names":[],"mappings":";;;;;AAwCO,MAAM,eAAe,CAAC,EAAE,MAAM,SAAS,oBAAuC;AACpF,QAAM,EAAE,aAAa,OAAO,IAAI,eAAe;AAE/C,QAAM,cAAc,QAAQ;AAE5B,MAAI,CAAC,aAAa;AACV,WAAA;AAAA,EAAA;AAGF,QAAA,YAAY,WAAW,MAAM,IAAI,SAAS,YAAY,MAAM,IAAI,UAAU;AAE1E,QAAA,cAAc,UAAU,WAAW;AAGxC,SAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACA,WAAW,OAAO;AAAA,MACjB,GAAI,WAAW,EAAE,SAAS,MAAM,QAAQ,WAAW,EAAE;AAAA,MAErD,UAAA;AAAA,QAAY,YAAA,8BACX,OAAI,EAAA,WAAW,OAAO,cAAc,KAAK,YAAY,SAAS,KAAI,YAAA,CAAY,IAE9E,oBAAA,QAAA,EAAK,WAAW,GAAG,OAAO,mBAAmB,IAC7C,UAAC,oBAAA,UAAA,EAAS,MAAK,OAAA,CAAO,EACvB,CAAA;AAAA,QAEA,qBAAA,OAAA,EAAI,WAAW,OAAO,aACtB,UAAA;AAAA,UAAC,qBAAA,OAAA,EAAI,WAAW,OAAO,aACtB,UAAA;AAAA,YAAC,oBAAA,QAAA,EAAK,OAAO,YAAY,MAAM,WAAW,OAAO,UAC/C,sBAAY,KACd,CAAA;AAAA,YACC,aAAa,CAAC,iBAAiB,oBAAC,UAAK,WAAW,OAAO,UAAW,UAAU,UAAA,CAAA;AAAA,UAAA,GAC9E;AAAA,8BACC,QAAK,EAAA,WAAW,OAAO,YAAa,sBAAY,KAAK,CAAA;AAAA,QAAA,EACvD,CAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EACD;AAEF;"}
|
package/dist/harmony83.cjs
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
|
3
|
-
const dropdownButton = "
|
4
|
-
const dropdownButtonActive = "
|
3
|
+
const dropdownButton = "_dropdownButton_1naek_1";
|
4
|
+
const dropdownButtonActive = "_dropdownButtonActive_1naek_19";
|
5
5
|
const styles = {
|
6
6
|
dropdownButton,
|
7
7
|
dropdownButtonActive
|
package/dist/harmony83.mjs
CHANGED
@@ -1,5 +1,5 @@
|
|
1
|
-
const dropdownButton = "
|
2
|
-
const dropdownButtonActive = "
|
1
|
+
const dropdownButton = "_dropdownButton_1naek_1";
|
2
|
+
const dropdownButtonActive = "_dropdownButtonActive_1naek_19";
|
3
3
|
const styles = {
|
4
4
|
dropdownButton,
|
5
5
|
dropdownButtonActive
|
package/dist/harmony93.cjs
CHANGED
@@ -1,19 +1,21 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
3
|
+
const zod = require("zod");
|
4
|
+
const teamRoleTypes = require("./harmony58.cjs");
|
5
|
+
const JWT_TOKEN_PAYLOAD_SCHEMA = zod.z.object({
|
6
|
+
userId: zod.z.number(),
|
7
|
+
userUuid: zod.z.string().uuid(),
|
8
|
+
teamId: zod.z.number(),
|
9
|
+
teamUuid: zod.z.string().uuid(),
|
10
|
+
userTeamRole: teamRoleTypes.TEAM_ROLE_SCHEMA,
|
11
|
+
userEmail: zod.z.string().email(),
|
12
|
+
userName: zod.z.string(),
|
13
|
+
userCurrentTeamId: zod.z.number(),
|
14
|
+
planId: zod.z.number(),
|
15
|
+
planName: zod.z.string(),
|
16
|
+
isProviderAlpha: zod.z.boolean(),
|
17
|
+
isFullyAuthenticated: zod.z.boolean(),
|
18
|
+
exp: zod.z.number()
|
19
|
+
});
|
20
|
+
exports.JWT_TOKEN_PAYLOAD_SCHEMA = JWT_TOKEN_PAYLOAD_SCHEMA;
|
19
21
|
//# sourceMappingURL=harmony93.cjs.map
|
package/dist/harmony93.cjs.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"harmony93.cjs","sources":["../
|
1
|
+
{"version":3,"file":"harmony93.cjs","sources":["../src/features/auth/core/types/jwtTokenPayload.ts"],"sourcesContent":["import { z } from 'zod'\nimport { TEAM_ROLE_SCHEMA } from '../../../publicApi/types/teamRoleTypes'\n\nexport const JWT_TOKEN_PAYLOAD_SCHEMA = z.object({\n\tuserId: z.number(),\n\tuserUuid: z.string().uuid(),\n\tteamId: z.number(),\n\tteamUuid: z.string().uuid(),\n\tuserTeamRole: TEAM_ROLE_SCHEMA,\n\tuserEmail: z.string().email(),\n\tuserName: z.string(),\n\tuserCurrentTeamId: z.number(),\n\tplanId: z.number(),\n\tplanName: z.string(),\n\tisProviderAlpha: z.boolean(),\n\tisFullyAuthenticated: z.boolean(),\n\texp: z.number(),\n})\nexport type JwtTokenPayload = z.infer<typeof JWT_TOKEN_PAYLOAD_SCHEMA>\n"],"names":["z","TEAM_ROLE_SCHEMA"],"mappings":";;;;AAGa,MAAA,2BAA2BA,MAAE,OAAO;AAAA,EAChD,QAAQA,MAAE,OAAO;AAAA,EACjB,UAAUA,IAAA,EAAE,OAAO,EAAE,KAAK;AAAA,EAC1B,QAAQA,MAAE,OAAO;AAAA,EACjB,UAAUA,IAAA,EAAE,OAAO,EAAE,KAAK;AAAA,EAC1B,cAAcC,cAAA;AAAA,EACd,WAAWD,IAAA,EAAE,OAAO,EAAE,MAAM;AAAA,EAC5B,UAAUA,MAAE,OAAO;AAAA,EACnB,mBAAmBA,MAAE,OAAO;AAAA,EAC5B,QAAQA,MAAE,OAAO;AAAA,EACjB,UAAUA,MAAE,OAAO;AAAA,EACnB,iBAAiBA,MAAE,QAAQ;AAAA,EAC3B,sBAAsBA,MAAE,QAAQ;AAAA,EAChC,KAAKA,MAAE,OAAO;AACf,CAAC;;"}
|
package/dist/harmony93.mjs
CHANGED
@@ -1,19 +1,21 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
1
|
+
import { z } from "zod";
|
2
|
+
import { TEAM_ROLE_SCHEMA } from "./harmony58.mjs";
|
3
|
+
const JWT_TOKEN_PAYLOAD_SCHEMA = z.object({
|
4
|
+
userId: z.number(),
|
5
|
+
userUuid: z.string().uuid(),
|
6
|
+
teamId: z.number(),
|
7
|
+
teamUuid: z.string().uuid(),
|
8
|
+
userTeamRole: TEAM_ROLE_SCHEMA,
|
9
|
+
userEmail: z.string().email(),
|
10
|
+
userName: z.string(),
|
11
|
+
userCurrentTeamId: z.number(),
|
12
|
+
planId: z.number(),
|
13
|
+
planName: z.string(),
|
14
|
+
isProviderAlpha: z.boolean(),
|
15
|
+
isFullyAuthenticated: z.boolean(),
|
16
|
+
exp: z.number()
|
17
|
+
});
|
16
18
|
export {
|
17
|
-
|
19
|
+
JWT_TOKEN_PAYLOAD_SCHEMA
|
18
20
|
};
|
19
21
|
//# sourceMappingURL=harmony93.mjs.map
|
package/dist/harmony93.mjs.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"harmony93.mjs","sources":["../
|
1
|
+
{"version":3,"file":"harmony93.mjs","sources":["../src/features/auth/core/types/jwtTokenPayload.ts"],"sourcesContent":["import { z } from 'zod'\nimport { TEAM_ROLE_SCHEMA } from '../../../publicApi/types/teamRoleTypes'\n\nexport const JWT_TOKEN_PAYLOAD_SCHEMA = z.object({\n\tuserId: z.number(),\n\tuserUuid: z.string().uuid(),\n\tteamId: z.number(),\n\tteamUuid: z.string().uuid(),\n\tuserTeamRole: TEAM_ROLE_SCHEMA,\n\tuserEmail: z.string().email(),\n\tuserName: z.string(),\n\tuserCurrentTeamId: z.number(),\n\tplanId: z.number(),\n\tplanName: z.string(),\n\tisProviderAlpha: z.boolean(),\n\tisFullyAuthenticated: z.boolean(),\n\texp: z.number(),\n})\nexport type JwtTokenPayload = z.infer<typeof JWT_TOKEN_PAYLOAD_SCHEMA>\n"],"names":[],"mappings":";;AAGa,MAAA,2BAA2B,EAAE,OAAO;AAAA,EAChD,QAAQ,EAAE,OAAO;AAAA,EACjB,UAAU,EAAE,OAAO,EAAE,KAAK;AAAA,EAC1B,QAAQ,EAAE,OAAO;AAAA,EACjB,UAAU,EAAE,OAAO,EAAE,KAAK;AAAA,EAC1B,cAAc;AAAA,EACd,WAAW,EAAE,OAAO,EAAE,MAAM;AAAA,EAC5B,UAAU,EAAE,OAAO;AAAA,EACnB,mBAAmB,EAAE,OAAO;AAAA,EAC5B,QAAQ,EAAE,OAAO;AAAA,EACjB,UAAU,EAAE,OAAO;AAAA,EACnB,iBAAiB,EAAE,QAAQ;AAAA,EAC3B,sBAAsB,EAAE,QAAQ;AAAA,EAChC,KAAK,EAAE,OAAO;AACf,CAAC;"}
|
package/dist/harmony94.cjs
CHANGED
@@ -1,21 +1,17 @@
|
|
1
1
|
"use strict";
|
2
|
+
var __defProp = Object.defineProperty;
|
3
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
4
|
+
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
2
5
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
3
|
-
const
|
4
|
-
const
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
planId: zod.z.number(),
|
15
|
-
planName: zod.z.string(),
|
16
|
-
isProviderAlpha: zod.z.boolean(),
|
17
|
-
isFullyAuthenticated: zod.z.boolean(),
|
18
|
-
exp: zod.z.number()
|
19
|
-
});
|
20
|
-
exports.JWT_TOKEN_PAYLOAD_SCHEMA = JWT_TOKEN_PAYLOAD_SCHEMA;
|
6
|
+
const jwtTokenPayload = require("./harmony15.cjs");
|
7
|
+
const _NewJwtIssuedEvent = class _NewJwtIssuedEvent extends CustomEvent {
|
8
|
+
constructor(token) {
|
9
|
+
super(_NewJwtIssuedEvent.eventName, {
|
10
|
+
detail: { token, payload: jwtTokenPayload.parseJwtTokenPayload(token.accessToken) }
|
11
|
+
});
|
12
|
+
}
|
13
|
+
};
|
14
|
+
__publicField(_NewJwtIssuedEvent, "eventName", "new-jwt-issued");
|
15
|
+
let NewJwtIssuedEvent = _NewJwtIssuedEvent;
|
16
|
+
exports.NewJwtIssuedEvent = NewJwtIssuedEvent;
|
21
17
|
//# sourceMappingURL=harmony94.cjs.map
|
package/dist/harmony94.cjs.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"harmony94.cjs","sources":["../src/features/auth/
|
1
|
+
{"version":3,"file":"harmony94.cjs","sources":["../src/features/auth/frontend/events/NewJwtIssuedEvent.ts"],"sourcesContent":["import type { JwtTokenPayload } from '@features/auth/core/types/jwtTokenPayload'\nimport { parseJwtTokenPayload } from '@features/auth/core/utils/jwtTokenPayload'\nimport type { JwtToken } from '@features/publicApi/types/userTokenTypes'\n\ntype NewJwtIssuedEventDetail = {\n\ttoken: JwtToken\n\tpayload: JwtTokenPayload | undefined\n}\n\n/**\n * This event is emitted when a new JWT token is issued or refreshed.\n */\nexport class NewJwtIssuedEvent extends CustomEvent<NewJwtIssuedEventDetail> {\n\tstatic readonly eventName = 'new-jwt-issued' as const\n\n\tconstructor(token: JwtToken) {\n\t\tsuper(NewJwtIssuedEvent.eventName, {\n\t\t\tdetail: { token, payload: parseJwtTokenPayload(token.accessToken) },\n\t\t})\n\t}\n}\n\nexport const isNewJwtIssuedEvent = (event: Event): event is NewJwtIssuedEvent =>\n\tevent.type === NewJwtIssuedEvent.eventName\n\ndeclare global {\n\tinterface WindowEventMap {\n\t\t[NewJwtIssuedEvent.eventName]: NewJwtIssuedEvent\n\t}\n}\n"],"names":["parseJwtTokenPayload"],"mappings":";;;;;;AAYO,MAAM,qBAAN,MAAM,2BAA0B,YAAqC;AAAA,EAG3E,YAAY,OAAiB;AAC5B,UAAM,mBAAkB,WAAW;AAAA,MAClC,QAAQ,EAAE,OAAO,SAASA,gBAAAA,qBAAqB,MAAM,WAAW,EAAE;AAAA,IAAA,CAClE;AAAA,EAAA;AAEH;AAPC,cADY,oBACI,aAAY;AADtB,IAAM,oBAAN;;"}
|
package/dist/harmony94.mjs
CHANGED
@@ -1,21 +1,17 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
isProviderAlpha: z.boolean(),
|
15
|
-
isFullyAuthenticated: z.boolean(),
|
16
|
-
exp: z.number()
|
17
|
-
});
|
1
|
+
var __defProp = Object.defineProperty;
|
2
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
3
|
+
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
4
|
+
import { parseJwtTokenPayload } from "./harmony15.mjs";
|
5
|
+
const _NewJwtIssuedEvent = class _NewJwtIssuedEvent extends CustomEvent {
|
6
|
+
constructor(token) {
|
7
|
+
super(_NewJwtIssuedEvent.eventName, {
|
8
|
+
detail: { token, payload: parseJwtTokenPayload(token.accessToken) }
|
9
|
+
});
|
10
|
+
}
|
11
|
+
};
|
12
|
+
__publicField(_NewJwtIssuedEvent, "eventName", "new-jwt-issued");
|
13
|
+
let NewJwtIssuedEvent = _NewJwtIssuedEvent;
|
18
14
|
export {
|
19
|
-
|
15
|
+
NewJwtIssuedEvent
|
20
16
|
};
|
21
17
|
//# sourceMappingURL=harmony94.mjs.map
|
package/dist/harmony94.mjs.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"harmony94.mjs","sources":["../src/features/auth/
|
1
|
+
{"version":3,"file":"harmony94.mjs","sources":["../src/features/auth/frontend/events/NewJwtIssuedEvent.ts"],"sourcesContent":["import type { JwtTokenPayload } from '@features/auth/core/types/jwtTokenPayload'\nimport { parseJwtTokenPayload } from '@features/auth/core/utils/jwtTokenPayload'\nimport type { JwtToken } from '@features/publicApi/types/userTokenTypes'\n\ntype NewJwtIssuedEventDetail = {\n\ttoken: JwtToken\n\tpayload: JwtTokenPayload | undefined\n}\n\n/**\n * This event is emitted when a new JWT token is issued or refreshed.\n */\nexport class NewJwtIssuedEvent extends CustomEvent<NewJwtIssuedEventDetail> {\n\tstatic readonly eventName = 'new-jwt-issued' as const\n\n\tconstructor(token: JwtToken) {\n\t\tsuper(NewJwtIssuedEvent.eventName, {\n\t\t\tdetail: { token, payload: parseJwtTokenPayload(token.accessToken) },\n\t\t})\n\t}\n}\n\nexport const isNewJwtIssuedEvent = (event: Event): event is NewJwtIssuedEvent =>\n\tevent.type === NewJwtIssuedEvent.eventName\n\ndeclare global {\n\tinterface WindowEventMap {\n\t\t[NewJwtIssuedEvent.eventName]: NewJwtIssuedEvent\n\t}\n}\n"],"names":[],"mappings":";;;;AAYO,MAAM,qBAAN,MAAM,2BAA0B,YAAqC;AAAA,EAG3E,YAAY,OAAiB;AAC5B,UAAM,mBAAkB,WAAW;AAAA,MAClC,QAAQ,EAAE,OAAO,SAAS,qBAAqB,MAAM,WAAW,EAAE;AAAA,IAAA,CAClE;AAAA,EAAA;AAEH;AAPC,cADY,oBACI,aAAY;AADtB,IAAM,oBAAN;"}
|
package/dist/harmony95.cjs
CHANGED
@@ -1,17 +1,19 @@
|
|
1
1
|
"use strict";
|
2
|
-
var __defProp = Object.defineProperty;
|
3
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
4
|
-
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
5
2
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
3
|
+
function buildGetRoute(params) {
|
4
|
+
return {
|
5
|
+
isEmptyResponseExpected: params.isEmptyResponseExpected ?? false,
|
6
|
+
isNonJSONResponseExpected: params.isNonJSONResponseExpected ?? false,
|
7
|
+
method: "get",
|
8
|
+
pathResolver: params.pathResolver,
|
9
|
+
requestHeaderSchema: params.requestHeaderSchema,
|
10
|
+
requestPathParamsSchema: params.requestPathParamsSchema,
|
11
|
+
requestQuerySchema: params.requestQuerySchema,
|
12
|
+
successResponseBodySchema: params.successResponseBodySchema,
|
13
|
+
description: params.description,
|
14
|
+
responseSchemasByStatusCode: params.responseSchemasByStatusCode,
|
15
|
+
metadata: params.metadata
|
16
|
+
};
|
17
|
+
}
|
18
|
+
exports.buildGetRoute = buildGetRoute;
|
17
19
|
//# sourceMappingURL=harmony95.cjs.map
|