jdalrymple/gitbeaker

View on GitHub
packages/core/src/resources/Epics.ts

Summary

Maintainability
A
0 mins
Test Coverage
import { BaseResource } from '@gitbeaker/requester-utils';
import { RequestHelper, endpoint } from '../infrastructure';
import type {
  GitlabAPIResponse,
  MappedOmit,
  PaginationRequestOptions,
  PaginationTypes,
  ShowExpanded,
  Sudo,
} from '../infrastructure';
import type { TodoSchema } from './TodoLists';
import type { SimpleUserSchema } from './Users';
import type { GroupSchema } from './Groups';
import type { SimpleLabelSchema } from '../templates/ResourceLabels';

export interface EpicSchema extends Record<string, unknown> {
  id: number;
  iid: number;
  group_id: number;
  parent_id: number;
  parent_iid: number;
  title: string;
  description: string;
  state: string;
  confidential: string;
  web_url: string;
  references: {
    short: string;
    relative: string;
    full: string;
  };
  author: MappedOmit<SimpleUserSchema, 'created_at'>;
  start_date?: string;
  start_date_is_fixed: boolean;
  start_date_fixed?: string;
  start_date_from_inherited_source?: string;
  due_date: string;
  due_date_is_fixed: boolean;
  due_date_fixed?: string;
  due_date_from_inherited_source: string;
  created_at: string;
  updated_at: string;
  closed_at: string;
  labels: string[] | SimpleLabelSchema[];
  upvotes: number;
  downvotes: number;
  _links: {
    self: string;
    epic_issues: string;
    group: string;
  };
}

export interface EpicSchemaWithExpandedLabels extends EpicSchema {
  labels: SimpleLabelSchema[];
}

export interface EpicSchemaWithBasicLabels extends EpicSchema {
  labels: string[];
}

export interface EpicTodoSchema extends TodoSchema {
  group: Pick<GroupSchema, 'id' | 'name' | 'path' | 'kind' | 'full_path' | 'parent_id'>;
  target_type: 'Epic';
  target: EpicSchema;
}

export type AllEpicsOptions = {
  authorId?: number;
  authorUsername?: string;
  labels?: string;
  withLabelsDetails?: boolean;
  orderBy?: 'created_at' | 'updated_at' | 'title';
  sort?: string;
  search?: string;
  state?: string;
  createdAfter?: string;
  createdBefore?: string;
  updatedAfter?: string;
  updatedBefore?: string;
  includeAncestorGroups?: boolean;
  includeDescendantGroups?: boolean;
  myReactionEmoji?: string;
  not?: Record<string, string>;
};

export type CreateEpicOptions = {
  labels?: string;
  description?: string;
  color?: string;
  confidential?: boolean;
  createdAt?: string;
  startDateIsFixed?: boolean;
  startDateFixed?: string;
  dueDateIsFixed?: boolean;
  dueDateFixed?: string;
  parentId?: number | string;
};

export type EditEpicOptions = {
  addLabels?: string;
  confidential?: boolean;
  description?: string;
  dueDateFixed?: string;
  dueDateIsFixed?: boolean;
  labels?: string;
  parentId?: number | string;
  removeLabels?: string;
  startDateFixed?: string;
  startDateIsFixed?: boolean;
  stateEvent?: string;
  title?: string;
  updatedAt?: string;
  color?: string;
};
export class Epics<C extends boolean = false> extends BaseResource<C> {
  all<E extends boolean = false, P extends PaginationTypes = 'offset'>(
    groupId: string | number,
    options: AllEpicsOptions &
      PaginationRequestOptions<P> &
      Sudo &
      ShowExpanded<E> & { withLabelsDetails: true },
  ): Promise<GitlabAPIResponse<EpicSchemaWithExpandedLabels[], C, E, P>>;

  all<E extends boolean = false, P extends PaginationTypes = 'offset'>(
    groupId: string | number,
    options?: AllEpicsOptions &
      PaginationRequestOptions<P> &
      Sudo &
      ShowExpanded<E> & { withLabelsDetails?: false },
  ): Promise<GitlabAPIResponse<EpicSchemaWithBasicLabels[], C, E, P>>;

  all<E extends boolean = false, P extends PaginationTypes = 'offset'>(
    groupId: string | number,
    options?: AllEpicsOptions & PaginationRequestOptions<P> & Sudo & ShowExpanded<E>,
  ): Promise<GitlabAPIResponse<EpicSchema[], C, E, P>> {
    return RequestHelper.get<EpicSchema[]>()(this, endpoint`groups/${groupId}/epics`, options);
  }

  create<E extends boolean = false>(
    groupId: string | number,
    title: string,
    options?: CreateEpicOptions & Sudo & ShowExpanded<E>,
  ): Promise<GitlabAPIResponse<EpicSchema, C, E, void>> {
    return RequestHelper.post<EpicSchema>()(this, endpoint`groups/${groupId}/epics`, {
      title,
      ...options,
    });
  }

  createTodo<E extends boolean = false>(
    groupId: string | number,
    epicIId: number,
    options?: Sudo & ShowExpanded<E>,
  ): Promise<GitlabAPIResponse<EpicTodoSchema, C, E, void>> {
    return RequestHelper.post<EpicTodoSchema>()(
      this,
      endpoint`groups/${groupId}/epics/${epicIId}/todos`,
      options,
    );
  }

  edit<E extends boolean = false>(
    groupId: string | number,
    epicIId: number,
    options?: EditEpicOptions & Sudo & ShowExpanded<E>,
  ): Promise<GitlabAPIResponse<MappedOmit<EpicSchema, '_links'>, C, E, void>> {
    return RequestHelper.put<MappedOmit<EpicSchema, '_links'>>()(
      this,
      endpoint`groups/${groupId}/epics/${epicIId}`,
      options,
    );
  }

  remove<E extends boolean = false>(
    groupId: string | number,
    epicIId: number,
    options?: Sudo & ShowExpanded<E>,
  ): Promise<GitlabAPIResponse<void, C, E, void>> {
    return RequestHelper.del()(this, endpoint`groups/${groupId}/epics/${epicIId}`, options);
  }

  show<E extends boolean = false>(
    groupId: string | number,
    epicIId: number,
    options?: Sudo & ShowExpanded<E>,
  ): Promise<GitlabAPIResponse<EpicSchema, C, E, void>> {
    return RequestHelper.get<EpicSchema>()(
      this,
      endpoint`groups/${groupId}/epics/${epicIId}`,
      options,
    );
  }
}