summaryrefslogtreecommitdiffstats
path: root/public/prism/prism-stylus.min.js
diff options
context:
space:
mode:
Diffstat (limited to 'public/prism/prism-stylus.min.js')
0 files changed, 0 insertions, 0 deletions
a> 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82
import { CommentData, CreateComment, CreatedComment } from '@ts/types/comments';
import { ContactData, SendEmail } from '@ts/types/contact';
import { gql } from 'graphql-request';
import { fetchApi } from './api';

//==============================================================================
// Comment mutation
//==============================================================================

export const createComment = async (
  data: CommentData
): Promise<CreatedComment> => {
  const mutation = gql`
    mutation CreateComment(
      $author: String!
      $authorEmail: String!
      $authorUrl: String!
      $content: String!
      $parent: ID!
      $commentOn: Int!
      $mutationId: String!
    ) {
      createComment(
        input: {
          author: $author
          authorEmail: $authorEmail
          authorUrl: $authorUrl
          content: $content
          parent: $parent
          commentOn: $commentOn
          clientMutationId: $mutationId
        }
      ) {
        clientMutationId
        success
        comment {
          approved
        }
      }
    }
  `;

  const variables = { ...data };
  const response = await fetchApi<CreateComment>(mutation, variables);

  return response.createComment;
};

//==============================================================================
// Contact mutation
//==============================================================================

export const sendMail = async (data: ContactData) => {
  const mutation = gql`
    mutation SendEmail(
      $subject: String!
      $body: String!
      $replyTo: String!
      $mutationId: String!
    ) {
      sendEmail(
        input: {
          clientMutationId: $mutationId
          body: $body
          replyTo: $replyTo
          subject: $subject
        }
      ) {
        clientMutationId
        message
        sent
        origin
        replyTo
        to
      }
    }
  `;

  const variables = { ...data };
  const response = await fetchApi<SendEmail>(mutation, variables);
  return response.sendEmail;
};