@sideline/domain 0.10.0 → 0.11.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/api/EventApi.js +15 -2
- package/dist/cjs/api/EventApi.js.map +1 -1
- package/dist/cjs/api/EventRsvpApi.js +3 -1
- package/dist/cjs/api/EventRsvpApi.js.map +1 -1
- package/dist/cjs/api/EventSeriesApi.js +19 -2
- package/dist/cjs/api/EventSeriesApi.js.map +1 -1
- package/dist/cjs/api/RoleApi.js +9 -3
- package/dist/cjs/api/RoleApi.js.map +1 -1
- package/dist/cjs/api/Roster.js +9 -3
- package/dist/cjs/api/Roster.js.map +1 -1
- package/dist/cjs/api/TrainingTypeApi.js +14 -4
- package/dist/cjs/api/TrainingTypeApi.js.map +1 -1
- package/dist/cjs/models/Event.js +3 -0
- package/dist/cjs/models/Event.js.map +1 -1
- package/dist/cjs/models/EventSeries.js +3 -0
- package/dist/cjs/models/EventSeries.js.map +1 -1
- package/dist/cjs/models/TrainingType.js +2 -1
- package/dist/cjs/models/TrainingType.js.map +1 -1
- package/dist/cjs/rpc/event/EventRpcGroup.js +1 -1
- package/dist/cjs/rpc/event/EventRpcGroup.js.map +1 -1
- package/dist/cjs/rpc/event/EventRpcModels.js +3 -1
- package/dist/cjs/rpc/event/EventRpcModels.js.map +1 -1
- package/dist/dts/api/EventApi.d.ts +40 -0
- package/dist/dts/api/EventApi.d.ts.map +1 -1
- package/dist/dts/api/EventRsvpApi.d.ts +1 -1
- package/dist/dts/api/EventSeriesApi.d.ts +56 -0
- package/dist/dts/api/EventSeriesApi.d.ts.map +1 -1
- package/dist/dts/api/RoleApi.d.ts +18 -1
- package/dist/dts/api/RoleApi.d.ts.map +1 -1
- package/dist/dts/api/Roster.d.ts +18 -1
- package/dist/dts/api/Roster.d.ts.map +1 -1
- package/dist/dts/api/TrainingTypeApi.d.ts +48 -16
- package/dist/dts/api/TrainingTypeApi.d.ts.map +1 -1
- package/dist/dts/models/Event.d.ts +26 -0
- package/dist/dts/models/Event.d.ts.map +1 -1
- package/dist/dts/models/EventSeries.d.ts +26 -0
- package/dist/dts/models/EventSeries.d.ts.map +1 -1
- package/dist/dts/models/TrainingType.d.ts +24 -11
- package/dist/dts/models/TrainingType.d.ts.map +1 -1
- package/dist/dts/rpc/SyncRpcs.d.ts +1 -1
- package/dist/dts/rpc/event/EventRpcGroup.d.ts +2 -2
- package/dist/dts/rpc/event/EventRpcGroup.d.ts.map +1 -1
- package/dist/dts/rpc/event/EventRpcModels.d.ts +5 -0
- package/dist/dts/rpc/event/EventRpcModels.d.ts.map +1 -1
- package/dist/esm/api/EventApi.js +15 -2
- package/dist/esm/api/EventApi.js.map +1 -1
- package/dist/esm/api/EventRsvpApi.js +3 -1
- package/dist/esm/api/EventRsvpApi.js.map +1 -1
- package/dist/esm/api/EventSeriesApi.js +19 -2
- package/dist/esm/api/EventSeriesApi.js.map +1 -1
- package/dist/esm/api/RoleApi.js +7 -2
- package/dist/esm/api/RoleApi.js.map +1 -1
- package/dist/esm/api/Roster.js +7 -2
- package/dist/esm/api/Roster.js.map +1 -1
- package/dist/esm/api/TrainingTypeApi.js +14 -4
- package/dist/esm/api/TrainingTypeApi.js.map +1 -1
- package/dist/esm/models/Event.js +3 -0
- package/dist/esm/models/Event.js.map +1 -1
- package/dist/esm/models/EventSeries.js +3 -0
- package/dist/esm/models/EventSeries.js.map +1 -1
- package/dist/esm/models/TrainingType.js +2 -1
- package/dist/esm/models/TrainingType.js.map +1 -1
- package/dist/esm/rpc/event/EventRpcGroup.js +2 -2
- package/dist/esm/rpc/event/EventRpcGroup.js.map +1 -1
- package/dist/esm/rpc/event/EventRpcModels.js +1 -0
- package/dist/esm/rpc/event/EventRpcModels.js.map +1 -1
- package/package.json +2 -2
- package/src/api/EventApi.ts +9 -0
- package/src/api/EventRsvpApi.ts +1 -1
- package/src/api/EventSeriesApi.ts +13 -0
- package/src/api/RoleApi.ts +7 -1
- package/src/api/Roster.ts +7 -1
- package/src/api/TrainingTypeApi.ts +10 -4
- package/src/models/Event.ts +3 -0
- package/src/models/EventSeries.ts +3 -0
- package/src/models/TrainingType.ts +2 -1
- package/src/rpc/event/EventRpcGroup.ts +7 -1
- package/src/rpc/event/EventRpcModels.ts +5 -0
package/src/api/Roster.ts
CHANGED
|
@@ -55,6 +55,11 @@ export class RosterInfo extends Schema.Class<RosterInfo>('RosterInfo')({
|
|
|
55
55
|
createdAt: Schema.String,
|
|
56
56
|
}) {}
|
|
57
57
|
|
|
58
|
+
export class RosterListResponse extends Schema.Class<RosterListResponse>('RosterListResponse')({
|
|
59
|
+
canManage: Schema.Boolean,
|
|
60
|
+
rosters: Schema.Array(RosterInfo),
|
|
61
|
+
}) {}
|
|
62
|
+
|
|
58
63
|
export class RosterDetail extends Schema.Class<RosterDetail>('RosterDetail')({
|
|
59
64
|
rosterId: RosterId,
|
|
60
65
|
teamId: TeamId,
|
|
@@ -62,6 +67,7 @@ export class RosterDetail extends Schema.Class<RosterDetail>('RosterDetail')({
|
|
|
62
67
|
active: Schema.Boolean,
|
|
63
68
|
createdAt: Schema.String,
|
|
64
69
|
members: Schema.Array(RosterPlayer),
|
|
70
|
+
canManage: Schema.Boolean,
|
|
65
71
|
}) {}
|
|
66
72
|
|
|
67
73
|
export class CreateRosterRequest extends Schema.Class<CreateRosterRequest>('CreateRosterRequest')({
|
|
@@ -114,7 +120,7 @@ export class RosterApiGroup extends HttpApiGroup.make('roster')
|
|
|
114
120
|
)
|
|
115
121
|
.add(
|
|
116
122
|
HttpApiEndpoint.get('listRosters', '/teams/:teamId/rosters')
|
|
117
|
-
.addSuccess(
|
|
123
|
+
.addSuccess(RosterListResponse)
|
|
118
124
|
.addError(Forbidden, { status: 403 })
|
|
119
125
|
.setPath(Schema.Struct({ teamId: TeamId }))
|
|
120
126
|
.middleware(AuthMiddleware),
|
|
@@ -10,15 +10,18 @@ export class TrainingTypeInfo extends Schema.Class<TrainingTypeInfo>('TrainingTy
|
|
|
10
10
|
trainingTypeId: TrainingTypeId,
|
|
11
11
|
teamId: TeamId,
|
|
12
12
|
name: Schema.String,
|
|
13
|
-
|
|
13
|
+
ownerGroupName: Schema.OptionFromNullOr(Schema.String),
|
|
14
|
+
memberGroupName: Schema.OptionFromNullOr(Schema.String),
|
|
14
15
|
}) {}
|
|
15
16
|
|
|
16
17
|
export class TrainingTypeDetail extends Schema.Class<TrainingTypeDetail>('TrainingTypeDetail')({
|
|
17
18
|
trainingTypeId: TrainingTypeId,
|
|
18
19
|
teamId: TeamId,
|
|
19
20
|
name: Schema.String,
|
|
20
|
-
|
|
21
|
-
|
|
21
|
+
ownerGroupId: Schema.OptionFromNullOr(GroupId),
|
|
22
|
+
ownerGroupName: Schema.OptionFromNullOr(Schema.String),
|
|
23
|
+
memberGroupId: Schema.OptionFromNullOr(GroupId),
|
|
24
|
+
memberGroupName: Schema.OptionFromNullOr(Schema.String),
|
|
22
25
|
discordChannelId: Schema.OptionFromNullOr(Snowflake),
|
|
23
26
|
canAdmin: Schema.Boolean,
|
|
24
27
|
}) {}
|
|
@@ -34,7 +37,8 @@ export class CreateTrainingTypeRequest extends Schema.Class<CreateTrainingTypeRe
|
|
|
34
37
|
'CreateTrainingTypeRequest',
|
|
35
38
|
)({
|
|
36
39
|
name: Schema.NonEmptyString,
|
|
37
|
-
|
|
40
|
+
ownerGroupId: Schema.OptionFromNullOr(GroupId),
|
|
41
|
+
memberGroupId: Schema.OptionFromNullOr(GroupId),
|
|
38
42
|
discordChannelId: Schema.OptionFromNullOr(Snowflake),
|
|
39
43
|
}) {}
|
|
40
44
|
|
|
@@ -42,6 +46,8 @@ export class UpdateTrainingTypeRequest extends Schema.Class<UpdateTrainingTypeRe
|
|
|
42
46
|
'UpdateTrainingTypeRequest',
|
|
43
47
|
)({
|
|
44
48
|
name: Schema.NonEmptyString,
|
|
49
|
+
ownerGroupId: Schema.optionalWith(Schema.OptionFromNullOr(GroupId), { as: 'Option' }),
|
|
50
|
+
memberGroupId: Schema.optionalWith(Schema.OptionFromNullOr(GroupId), { as: 'Option' }),
|
|
45
51
|
discordChannelId: Schema.optionalWith(Schema.OptionFromNullOr(Snowflake), { as: 'Option' }),
|
|
46
52
|
}) {}
|
|
47
53
|
|
package/src/models/Event.ts
CHANGED
|
@@ -2,6 +2,7 @@ import { Model } from '@effect/sql';
|
|
|
2
2
|
import * as Schemas from '@sideline/effect-lib/Schemas';
|
|
3
3
|
import { Schema } from 'effect';
|
|
4
4
|
import { EventSeriesId } from '~/models/EventSeries.js';
|
|
5
|
+
import { GroupId } from '~/models/GroupModel.js';
|
|
5
6
|
import { TeamId } from '~/models/Team.js';
|
|
6
7
|
import { TeamMemberId } from '~/models/TeamMember.js';
|
|
7
8
|
import { TrainingTypeId } from '~/models/TrainingType.js';
|
|
@@ -32,6 +33,8 @@ export class Event extends Model.Class<Event>('Event')({
|
|
|
32
33
|
start_at: Schemas.DateTimeFromDate,
|
|
33
34
|
end_at: Schema.OptionFromNullOr(Schemas.DateTimeFromDate),
|
|
34
35
|
location: Schema.OptionFromNullOr(Schema.String),
|
|
36
|
+
owner_group_id: Schema.OptionFromNullOr(GroupId),
|
|
37
|
+
member_group_id: Schema.OptionFromNullOr(GroupId),
|
|
35
38
|
series_id: Schema.OptionFromNullOr(EventSeriesId),
|
|
36
39
|
series_modified: Schema.Boolean,
|
|
37
40
|
status: Model.FieldExcept('update')(EventStatus),
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Model } from '@effect/sql';
|
|
2
2
|
import { Schema } from 'effect';
|
|
3
|
+
import { GroupId } from '~/models/GroupModel.js';
|
|
3
4
|
import { TeamId } from '~/models/Team.js';
|
|
4
5
|
import { TeamMemberId } from '~/models/TeamMember.js';
|
|
5
6
|
import { TrainingTypeId } from '~/models/TrainingType.js';
|
|
@@ -32,6 +33,8 @@ export class EventSeries extends Model.Class<EventSeries>('EventSeries')({
|
|
|
32
33
|
days_of_week: DaysOfWeek,
|
|
33
34
|
start_date: Schema.DateFromSelf,
|
|
34
35
|
end_date: Schema.OptionFromNullOr(Schema.DateFromSelf),
|
|
36
|
+
owner_group_id: Schema.OptionFromNullOr(GroupId),
|
|
37
|
+
member_group_id: Schema.OptionFromNullOr(GroupId),
|
|
35
38
|
status: Model.FieldExcept('update')(EventSeriesStatus),
|
|
36
39
|
created_by: TeamMemberId,
|
|
37
40
|
created_at: Model.DateTimeInsertFromDate,
|
|
@@ -10,6 +10,7 @@ export class TrainingType extends Model.Class<TrainingType>('TrainingType')({
|
|
|
10
10
|
id: Model.Generated(TrainingTypeId),
|
|
11
11
|
team_id: TeamId,
|
|
12
12
|
name: Schema.String,
|
|
13
|
-
|
|
13
|
+
owner_group_id: Schema.OptionFromNullOr(GroupId),
|
|
14
|
+
member_group_id: Schema.OptionFromNullOr(GroupId),
|
|
14
15
|
created_at: Model.DateTimeInsertFromDate,
|
|
15
16
|
}) {}
|
|
@@ -17,6 +17,7 @@ import {
|
|
|
17
17
|
RsvpDeadlinePassed,
|
|
18
18
|
RsvpEventNotFound,
|
|
19
19
|
RsvpMemberNotFound,
|
|
20
|
+
RsvpNotGroupMember,
|
|
20
21
|
RsvpReminderSummary,
|
|
21
22
|
} from './EventRpcModels.js';
|
|
22
23
|
|
|
@@ -51,7 +52,12 @@ export const EventRpcGroup = RpcGroup.make(
|
|
|
51
52
|
message: Schema.OptionFromNullOr(Schema.String),
|
|
52
53
|
},
|
|
53
54
|
success: RsvpCountsResult,
|
|
54
|
-
error: Schema.Union(
|
|
55
|
+
error: Schema.Union(
|
|
56
|
+
RsvpMemberNotFound,
|
|
57
|
+
RsvpDeadlinePassed,
|
|
58
|
+
RsvpEventNotFound,
|
|
59
|
+
RsvpNotGroupMember,
|
|
60
|
+
),
|
|
55
61
|
}),
|
|
56
62
|
Rpc.make('GetRsvpCounts', {
|
|
57
63
|
payload: { event_id: Event.EventId },
|
|
@@ -51,6 +51,11 @@ export class RsvpEventNotFound extends Schema.TaggedError<RsvpEventNotFound>()(
|
|
|
51
51
|
{},
|
|
52
52
|
) {}
|
|
53
53
|
|
|
54
|
+
export class RsvpNotGroupMember extends Schema.TaggedError<RsvpNotGroupMember>()(
|
|
55
|
+
'RsvpNotGroupMember',
|
|
56
|
+
{},
|
|
57
|
+
) {}
|
|
58
|
+
|
|
54
59
|
export class CreateEventNotMember extends Schema.TaggedError<CreateEventNotMember>()(
|
|
55
60
|
'CreateEventNotMember',
|
|
56
61
|
{},
|