import { uniqueId } from 'lodash'; import { VALID_DESIGN_FILE_MIMETYPE } from '../constants'; export const isValidDesignFile = ({ type }) => (type.match(VALID_DESIGN_FILE_MIMETYPE.regex) || []).length > 0; /** * Returns formatted array of discussions * * @param {Array} discussions */ export const extractDiscussions = discussions => discussions.nodes.map((discussion, index) => ({ ...discussion, index: index + 1, notes: discussion.notes.nodes, })); /** * Returns a discussion with the given id from discussions array * * @param {Array} discussions */ export const extractCurrentDiscussion = (discussions, id) => discussions.nodes.find(discussion => discussion.id === id); export const findVersionId = id => (id.match('::Version/(.+$)') || [])[1]; export const findNoteId = id => (id.match('DiffNote/(.+$)') || [])[1]; export const findIssueId = id => (id.match('Issue/(.+$)') || [])[1]; export const findDesignId = id => (id.match('Design/(.+$)') || [])[1]; export const extractDesigns = data => data.project.issue.designCollection.designs.nodes; export const extractDesign = data => (extractDesigns(data) || [])[0]; export const toDiffNoteGid = noteId => `gid://gitlab/DiffNote/${noteId}`; /** * Return the note ID from a URL hash parameter * @param {String} urlHash URL hash, including `#` prefix */ export const extractDesignNoteId = urlHash => { const [, noteId] = urlHash.match('#note_([0-9]+$)') || []; return noteId || null; }; /** * Generates optimistic response for a design upload mutation * @param {Array} files */ export const designUploadOptimisticResponse = files => { const designs = files.map(file => ({ // False positive i18n lint: https://gitlab.com/gitlab-org/frontend/eslint-plugin-i18n/issues/26 // eslint-disable-next-line @gitlab/require-i18n-strings __typename: 'Design', id: -uniqueId(), image: '', imageV432x230: '', filename: file.name, fullPath: '', notesCount: 0, event: 'NONE', currentUserTodos: { __typename: 'TodoConnection', nodes: [], }, diffRefs: { __typename: 'DiffRefs', baseSha: '', startSha: '', headSha: '', }, discussions: { __typename: 'DesignDiscussion', nodes: [], }, versions: { __typename: 'DesignVersionConnection', nodes: { __typename: 'DesignVersion', id: -uniqueId(), sha: -uniqueId(), }, }, })); return { // False positive i18n lint: https://gitlab.com/gitlab-org/frontend/eslint-plugin-i18n/issues/26 // eslint-disable-next-line @gitlab/require-i18n-strings __typename: 'Mutation', designManagementUpload: { __typename: 'DesignManagementUploadPayload', designs, skippedDesigns: [], errors: [], }, }; }; /** * Generates optimistic response for a design upload mutation * @param {Object} note * @param {Object} position */ export const updateImageDiffNoteOptimisticResponse = (note, { position }) => ({ // False positive i18n lint: https://gitlab.com/gitlab-org/frontend/eslint-plugin-i18n/issues/26 // eslint-disable-next-line @gitlab/require-i18n-strings __typename: 'Mutation', updateImageDiffNote: { __typename: 'UpdateImageDiffNotePayload', note: { ...note, position: { ...note.position, ...position, }, }, errors: [], }, }); /** * Generates optimistic response for a design upload mutation * @param {Array} designs */ export const moveDesignOptimisticResponse = designs => ({ // False positive i18n lint: https://gitlab.com/gitlab-org/frontend/eslint-plugin-i18n/issues/26 // eslint-disable-next-line @gitlab/require-i18n-strings __typename: 'Mutation', designManagementMove: { __typename: 'DesignManagementMovePayload', designCollection: { __typename: 'DesignCollection', designs: { __typename: 'DesignConnection', nodes: designs, }, }, errors: [], }, }); const normalizeAuthor = author => ({ ...author, web_url: author.webUrl, avatar_url: author.avatarUrl, }); export const extractParticipants = users => users.map(node => normalizeAuthor(node)); export const getPageLayoutElement = () => document.querySelector('.layout-page'); /** * Extract the ID of the To-Do for a given 'delete' path * Example of todoDeletePath: /delete/1234 * @param {String} todoDeletePath delete_path from REST API response */ export const extractTodoIdFromDeletePath = todoDeletePath => (todoDeletePath.match('todos/([0-9]+$)') || [])[1]; const createTodoGid = todoId => { return `gid://gitlab/Todo/${todoId}`; }; export const createPendingTodo = todoId => { return { __typename: 'Todo', // eslint-disable-line @gitlab/require-i18n-strings id: createTodoGid(todoId), }; };