Skip to content

Commit

Permalink
Merge branch 'master' into feat/interview_registration_start_date
Browse files Browse the repository at this point in the history
  • Loading branch information
valerydluski authored Dec 22, 2024
2 parents b3562db + 6bf5a96 commit a0c73b7
Show file tree
Hide file tree
Showing 23 changed files with 488 additions and 70 deletions.
202 changes: 202 additions & 0 deletions client/src/api/api.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1042,6 +1042,25 @@ export interface CourseMentorsStatsDto {
*/
'epamMentorsCount': number;
}
/**
*
* @export
* @interface CourseRecord
*/
export interface CourseRecord {
/**
*
* @type {string}
* @memberof CourseRecord
*/
'courseName': string;
/**
*
* @type {number}
* @memberof CourseRecord
*/
'id': number;
}
/**
*
* @export
Expand Down Expand Up @@ -7404,6 +7423,85 @@ export interface UserNotificationsDto {
*/
'connections': object;
}
/**
*
* @export
* @interface UserSearchDto
*/
export interface UserSearchDto {
/**
*
* @type {number}
* @memberof UserSearchDto
*/
'id': number;
/**
*
* @type {string}
* @memberof UserSearchDto
*/
'githubId': string;
/**
*
* @type {string}
* @memberof UserSearchDto
*/
'name': string;
/**
*
* @type {string}
* @memberof UserSearchDto
*/
'cityName': string | null;
/**
*
* @type {string}
* @memberof UserSearchDto
*/
'countryName': string | null;
/**
*
* @type {string}
* @memberof UserSearchDto
*/
'contactsEmail': string | null;
/**
*
* @type {string}
* @memberof UserSearchDto
*/
'contactsEpamEmail': string | null;
/**
*
* @type {string}
* @memberof UserSearchDto
*/
'primaryEmail': string | null;
/**
*
* @type {string}
* @memberof UserSearchDto
*/
'contactsDiscord': string | null;
/**
*
* @type {string}
* @memberof UserSearchDto
*/
'contactsTelegram': string | null;
/**
*
* @type {Array<CourseRecord>}
* @memberof UserSearchDto
*/
'mentors': Array<CourseRecord> | null;
/**
*
* @type {Array<CourseRecord>}
* @memberof UserSearchDto
*/
'students': Array<CourseRecord> | null;
}
/**
*
* @export
Expand Down Expand Up @@ -19705,6 +19803,110 @@ export class UserGroupApi extends BaseAPI {
}


/**
* UsersApi - axios parameter creator
* @export
*/
export const UsersApiAxiosParamCreator = function (configuration?: Configuration) {
return {
/**
*
* @param {string} query
* @param {*} [options] Override http request option.
* @throws {RequiredError}
*/
searchUsers: async (query: string, options: AxiosRequestConfig = {}): Promise<RequestArgs> => {
// verify required parameter 'query' is not null or undefined
assertParamExists('searchUsers', 'query', query)
const localVarPath = `/users/search`;
// use dummy base URL string because the URL constructor only accepts absolute URLs.
const localVarUrlObj = new URL(localVarPath, DUMMY_BASE_URL);
let baseOptions;
if (configuration) {
baseOptions = configuration.baseOptions;
}

const localVarRequestOptions = { method: 'GET', ...baseOptions, ...options};
const localVarHeaderParameter = {} as any;
const localVarQueryParameter = {} as any;

if (query !== undefined) {
localVarQueryParameter['query'] = query;
}



setSearchParams(localVarUrlObj, localVarQueryParameter);
let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {};
localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers};

return {
url: toPathString(localVarUrlObj),
options: localVarRequestOptions,
};
},
}
};

/**
* UsersApi - functional programming interface
* @export
*/
export const UsersApiFp = function(configuration?: Configuration) {
const localVarAxiosParamCreator = UsersApiAxiosParamCreator(configuration)
return {
/**
*
* @param {string} query
* @param {*} [options] Override http request option.
* @throws {RequiredError}
*/
async searchUsers(query: string, options?: AxiosRequestConfig): Promise<(axios?: AxiosInstance, basePath?: string) => AxiosPromise<Array<UserSearchDto>>> {
const localVarAxiosArgs = await localVarAxiosParamCreator.searchUsers(query, options);
return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration);
},
}
};

/**
* UsersApi - factory interface
* @export
*/
export const UsersApiFactory = function (configuration?: Configuration, basePath?: string, axios?: AxiosInstance) {
const localVarFp = UsersApiFp(configuration)
return {
/**
*
* @param {string} query
* @param {*} [options] Override http request option.
* @throws {RequiredError}
*/
searchUsers(query: string, options?: any): AxiosPromise<Array<UserSearchDto>> {
return localVarFp.searchUsers(query, options).then((request) => request(axios, basePath));
},
};
};

/**
* UsersApi - object-oriented interface
* @export
* @class UsersApi
* @extends {BaseAPI}
*/
export class UsersApi extends BaseAPI {
/**
*
* @param {string} query
* @param {*} [options] Override http request option.
* @throws {RequiredError}
* @memberof UsersApi
*/
public searchUsers(query: string, options?: AxiosRequestConfig) {
return UsersApiFp(this.configuration).searchUsers(query, options).then((request) => request(this.axios, this.basePath));
}
}


/**
* UsersNotificationsApi - axios parameter creator
* @export
Expand Down
2 changes: 1 addition & 1 deletion client/src/components/UserSearch.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ export function UserSearch(props: UserProps) {
suffixIcon={defaultValues ? Boolean(defaultValues.length) : false}
filterOption={false}
onSearch={handleSearch}
placeholder={defaultValues?.length ?? 0 > 0 ? 'Select...' : 'Search...'}
placeholder={(defaultValues?.length ?? 0 > 0) ? 'Select...' : 'Search...'}
notFoundContent={null}
>
{data.map(person => {
Expand Down
6 changes: 4 additions & 2 deletions client/src/modules/CrossCheck/components/CriteriaForm.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,9 @@ export function CriteriaForm({ authorId, comments, reviewComments, criteria, onC
.map(d => ({
criteriaId: d.criteriaId,
percentage:
criteriaId === d.criteriaId ? percentage : value?.find(v => v.criteriaId === d.criteriaId)?.percentage ?? 0,
criteriaId === d.criteriaId
? percentage
: (value?.find(v => v.criteriaId === d.criteriaId)?.percentage ?? 0),
}));
onChange?.(newReview, reviewComments);
},
Expand All @@ -69,7 +71,7 @@ export function CriteriaForm({ authorId, comments, reviewComments, criteria, onC
authorId: authorId,
timestamp: comment?.timestamp ?? Date.now(),
criteriaId: d.criteriaId,
text: criteriaId === d.criteriaId ? text : comment?.text ?? '',
text: criteriaId === d.criteriaId ? text : (comment?.text ?? ''),
};
})
.filter(c => c.text);
Expand Down
24 changes: 14 additions & 10 deletions client/src/modules/Notifications/components/Consents.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -40,17 +40,21 @@ export function Consents({

return !hasContacts ? (
<Space direction="vertical" style={{ width: '100%' }}>
{!hasTelegram && (
<Alert
message={
<div>
Note: To enable telegram notifications please open the <a href={rsschoolBotLink}>@rsschool_bot</a> and
<Alert
message={
hasTelegram ? (
<>
Telegram notifications are sent from <a href={rsschoolBotLink}>@rsschool_bot</a>
</>
) : (
<>
Note: To enable Telegram notifications please open the <a href={rsschoolBotLink}>@rsschool_bot</a> and
click the <b>Start</b> button to set it up
</div>
}
type="info"
/>
)}
</>
)
}
type="info"
/>

{!hasDiscord && (
<Alert
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ type Props = {
updateUrl: () => void;
};

const getGithubRepoName = (url: string | null | undefined) => (url ? url.split('/').pop() ?? '' : '');
const getGithubRepoName = (url: string | null | undefined) => (url ? (url.split('/').pop() ?? '') : '');

export function RepositoryCard(props: Props) {
const { Text, Paragraph } = Typography;
Expand Down
2 changes: 1 addition & 1 deletion client/src/pages/admin/auto-test-task.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ function Page() {
const router = useRouter();
const [isLoading, setIsLoading] = useState(false);
const [selectedTask, setSelectedTask] = useState<AutoTestTask>();
const taskId = router?.query ? router.query?.taskId ?? null : null;
const taskId = router?.query ? (router.query?.taskId ?? null) : null;
const { courses } = useActiveCourseContext();

useAsync(async () => {
Expand Down
46 changes: 31 additions & 15 deletions client/src/pages/admin/users.tsx
Original file line number Diff line number Diff line change
@@ -1,24 +1,25 @@
import { useState, useMemo } from 'react';
import { useState } from 'react';
import { Button, Col, Input, List, Row, Layout, Form } from 'antd';
import { GithubAvatar } from 'components/GithubAvatar';
import { UserService, UserFull } from 'services/user';
import { AdminPageLayout } from 'components/PageLayout';
import { CourseRole } from 'services/models';
import { ActiveCourseProvider, SessionProvider, useActiveCourseContext } from 'modules/Course/contexts';
import { UsersApi, UserSearchDto } from 'api';

const { Content } = Layout;

const userApi = new UsersApi();

function Page() {
const { courses } = useActiveCourseContext();
const [users, setUsers] = useState(null as any[] | null);
const userService = useMemo(() => new UserService(), []);
const [users, setUsers] = useState(null as UserSearchDto[] | null);

const handleSearch = async (values: any) => {
if (!values.searchText) {
return;
}
const users = await userService.extendedUserSearch(values.searchText);
setUsers(users);
const users = await userApi.searchUsers(values.searchText);
setUsers(users.data);
};

return (
Expand Down Expand Up @@ -48,20 +49,22 @@ function Page() {
rowKey="id"
locale={{ emptyText: 'No results' }}
dataSource={users}
renderItem={(user: UserFull) => (
renderItem={user => (
<List.Item>
<List.Item.Meta
avatar={<GithubAvatar size={48} githubId={user.githubId} />}
title={<a href={`/profile?githubId=${user.githubId}`}>{user.githubId}</a>}
description={
<div>
<div>{user.name}</div>
<div>{`Primary email: ${user.primaryEmail || ''}`}</div>
<div>{`EPAM email: ${user.contactsEpamEmail || ''}`}</div>
<div>{`Skype: ${user.contactsSkype || ''}`}</div>
<div>{`Telegram: ${user.contactsTelegram || ''}`}</div>
<div>{`Discord: ${user.discord || ''}`}</div>
</div>
<>
<UserField value={user.name} />
<UserField label="Primary Email" value={user.primaryEmail} />
<UserField label="Contacts Email" value={user.contactsEmail} />
<UserField label="Contacts EPAM Email" value={user.contactsEpamEmail} />
<UserField label="Contacts Telegram" value={user.contactsTelegram} />
<UserField label="Contacts Discord" value={user.contactsDiscord} />
<UserField label="Mentor" value={user.mentors?.map(({ courseName }) => courseName)} />
<UserField label="Student" value={user.students?.map(({ courseName }) => courseName)} />
</>
}
/>
</List.Item>
Expand All @@ -76,6 +79,19 @@ function Page() {
);
}

function UserField({ label, value }: { label?: string; value: string | string[] | null | undefined }) {
const valueStr = Array.isArray(value) ? value.join(', ') : value;
if (!valueStr) {
return null;
}
return (
<div>
{label ? <span>{label}: </span> : null}
<span>{valueStr}</span>
</div>
);
}

export default function () {
return (
<ActiveCourseProvider>
Expand Down
Loading

0 comments on commit a0c73b7

Please sign in to comment.