Convert Figma logo to code with AI

graffle-js logograffle

Simple GraphQL Client for JavaScript. Minimal. Extensible. Type Safe. Runs everywhere.

5,895
311
5,895
25

Top Related Projects

71,459

Generation of diagrams like flowcharts or sequence diagrams from text in a similar manner as markdown

10,438

Generate diagrams from textual description

2,898

Creates diagrams from textual descriptions!

16,701

D2 is a modern diagram scripting language that turns text to diagrams.

Virtual whiteboard for sketching hand-drawn like diagrams

41,012

draw.io is a JavaScript, client-side editor for general diagramming.

Quick Overview

Graffle is a TypeScript library for building GraphQL servers. It provides a type-safe and declarative approach to defining GraphQL schemas and resolvers, with a focus on developer experience and code maintainability.

Pros

  • Strong type safety with TypeScript integration
  • Declarative schema definition using a code-first approach
  • Automatic generation of GraphQL SDL from TypeScript types
  • Built-in support for common GraphQL features like pagination and filtering

Cons

  • Limited documentation and examples available
  • Relatively new project with a smaller community compared to established GraphQL libraries
  • May have a steeper learning curve for developers new to GraphQL or TypeScript

Code Examples

  1. Defining a simple GraphQL schema:
import { createSchema, t } from 'graffle'

const schema = createSchema({
  types: {
    User: t.object({
      id: t.id(),
      name: t.string(),
      email: t.string(),
    }),
  },
  query: {
    user: t.field({
      type: 'User',
      args: {
        id: t.id(),
      },
      resolve: (_, { id }, ctx) => ctx.db.findUser(id),
    }),
  },
})
  1. Adding a mutation:
const schema = createSchema({
  // ... other schema definitions
  mutation: {
    createUser: t.field({
      type: 'User',
      args: {
        name: t.string(),
        email: t.string(),
      },
      resolve: (_, { name, email }, ctx) => ctx.db.createUser({ name, email }),
    }),
  },
})
  1. Using pagination:
const schema = createSchema({
  // ... other schema definitions
  query: {
    users: t.connection({
      type: 'User',
      resolve: (_, args, ctx) => ctx.db.findUsers(args),
    }),
  },
})

Getting Started

To start using Graffle, follow these steps:

  1. Install the library:

    npm install graffle
    
  2. Create a new TypeScript file and import Graffle:

    import { createSchema, t } from 'graffle'
    
  3. Define your schema and resolvers:

    const schema = createSchema({
      types: {
        // Define your types here
      },
      query: {
        // Define your queries here
      },
      mutation: {
        // Define your mutations here
      },
    })
    
  4. Create a GraphQL server using your preferred framework (e.g., Express) and use the generated schema.

Competitor Comparisons

71,459

Generation of diagrams like flowcharts or sequence diagrams from text in a similar manner as markdown

Pros of Mermaid

  • More mature and widely adopted project with a larger community
  • Supports a broader range of diagram types (flowcharts, sequence diagrams, Gantt charts, etc.)
  • Extensive documentation and examples available

Cons of Mermaid

  • Steeper learning curve due to more complex syntax
  • Larger file size and potentially slower rendering for complex diagrams

Code Comparison

Mermaid example:

graph TD
    A[Start] --> B{Is it?}
    B -->|Yes| C[OK]
    B -->|No| D[End]

Graffle example:

const g = graffle`
  (Start) -> [Is it?]
  [Is it?] -> (OK) {label: Yes}
  [Is it?] -> (End) {label: No}
`

Summary

Mermaid is a more established and feature-rich diagramming tool, offering support for various diagram types and extensive documentation. However, it may have a steeper learning curve and potentially slower rendering for complex diagrams. Graffle, on the other hand, appears to have a simpler syntax and potentially faster rendering, but with fewer diagram types and a smaller community. The choice between the two depends on the specific needs of the project and the user's preference for syntax complexity versus simplicity.

10,438

Generate diagrams from textual description

Pros of PlantUML

  • Widely adopted and supported in various tools and platforms
  • Extensive documentation and large community for support
  • Supports a wide range of diagram types beyond just UML

Cons of PlantUML

  • Syntax can be verbose and less intuitive for beginners
  • Limited customization options for diagram styling
  • Slower rendering performance for complex diagrams

Code Comparison

PlantUML:

@startuml
Alice -> Bob: Hello
Bob --> Alice: Hi there
@enduml

Graffle:

graph(`
  Alice -> Bob: Hello
  Bob -> Alice: Hi there
`)

Summary

PlantUML is a mature and widely-used tool for creating various types of diagrams, including UML. It offers extensive documentation and community support. However, its syntax can be verbose, and customization options are limited.

Graffle, on the other hand, is a newer project that aims to provide a simpler and more intuitive syntax for creating diagrams. It focuses on graph-based diagrams and offers a JavaScript-based approach. While it may not have the same level of adoption or feature set as PlantUML, it provides a more streamlined experience for certain types of diagrams.

The choice between the two depends on specific requirements, such as the types of diagrams needed, integration with existing tools, and the preferred syntax style.

2,898

Creates diagrams from textual descriptions!

Pros of Kroki

  • Supports a wide range of diagram types (20+), including PlantUML, Mermaid, and GraphViz
  • Offers multiple deployment options: Docker, CLI, and web service
  • Actively maintained with regular updates and contributions

Cons of Kroki

  • Requires external dependencies for each diagram type
  • May have a steeper learning curve due to the variety of supported formats
  • Potentially higher resource usage when running as a service

Code Comparison

Kroki (Docker usage):

docker run -d -p 8000:8000 yuzutech/kroki
curl -X POST --data-raw 'digraph G {Hello->World}' http://localhost:8000/graphviz/svg

Graffle (JavaScript usage):

import { graffle } from 'graffle'

const svg = graffle`
  graph TD
    A-->B
`

Summary

Kroki offers a comprehensive solution for generating various types of diagrams, with multiple deployment options and broad format support. However, it may require more setup and resources compared to Graffle. Graffle, on the other hand, provides a simpler JavaScript-based approach but with more limited diagram types. The choice between the two depends on the specific needs of the project, such as the variety of diagrams required and the preferred integration method.

16,701

D2 is a modern diagram scripting language that turns text to diagrams.

Pros of d2

  • More active development with frequent updates and contributions
  • Broader range of diagram types and features
  • Better documentation and examples

Cons of d2

  • Steeper learning curve due to more complex syntax
  • Larger codebase, potentially harder to customize or extend

Code Comparison

d2:

shape: sequence_diagram
alice -> bob: Hello
bob -> alice: Hi

graffle:

const diagram = graffle.new()
diagram.add(graffle.box('Alice'))
diagram.add(graffle.box('Bob'))
diagram.add(graffle.arrow('Alice', 'Bob', 'Hello'))

Summary

d2 offers a more comprehensive diagramming solution with a wider range of features and diagram types. It has a more active community and better documentation. However, this comes at the cost of a steeper learning curve and a more complex codebase.

graffle, on the other hand, provides a simpler, JavaScript-based approach to creating diagrams. It may be easier to integrate into existing JavaScript projects but offers fewer features and diagram types compared to d2.

The choice between the two depends on the specific needs of the project, the desired level of complexity, and the preferred programming language or environment.

Virtual whiteboard for sketching hand-drawn like diagrams

Pros of Excalidraw

  • More feature-rich and mature project with a larger community
  • Offers a complete drawing application with a user interface
  • Supports collaborative editing and real-time collaboration

Cons of Excalidraw

  • Larger codebase and potentially more complex to contribute to
  • May have more dependencies and a steeper learning curve
  • Focused on a specific use case (whiteboard-style drawings)

Code Comparison

Excalidraw (React component usage):

import { Excalidraw } from "@excalidraw/excalidraw";

<Excalidraw
  initialData={initialData}
  onChange={(elements, state) => console.log("Elements :", elements, "State : ", state)}
/>

Graffle (Node.js usage):

const graffle = require('graffle')

const diagram = graffle.create()
diagram.addNode('A')
diagram.addNode('B')
diagram.addEdge('A', 'B')

Excalidraw is a full-featured drawing application with a web-based interface, while Graffle appears to be a simpler library for creating diagrams programmatically. Excalidraw offers a more comprehensive solution for collaborative drawing, but Graffle might be easier to integrate into existing Node.js projects for generating diagrams.

41,012

draw.io is a JavaScript, client-side editor for general diagramming.

Pros of draw.io

  • More comprehensive and feature-rich diagramming tool
  • Supports a wide range of diagram types and export formats
  • Active development with frequent updates and improvements

Cons of draw.io

  • Larger codebase and more complex architecture
  • Steeper learning curve for new users
  • Heavier resource usage due to its extensive feature set

Code Comparison

draw.io (JavaScript):

mxGraph.prototype.insertVertex = function(parent, id, value, x, y, width, height, style, relative)
{
  var vertex = this.createVertex(parent, id, value, x, y, width, height, style, relative);
  return this.addCell(vertex, parent);
};

Graffle (TypeScript):

export function createNode(
  graph: Graph,
  options: CreateNodeOptions
): Node {
  const node = new Node(options);
  graph.addNode(node);
  return node;
}

Summary

draw.io is a more comprehensive diagramming tool with a wider range of features, while Graffle appears to be a simpler, more focused library. draw.io's extensive capabilities come at the cost of increased complexity and resource usage, whereas Graffle likely offers a more streamlined experience for specific use cases.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

[!IMPORTANT] The next version (8) of graphql-request is being renamed to graffle. It has the same base simplicity but with many fixes, enhancements, and major new type safe features. It is not released yet but will be in the coming weeks/months and is already usable. Learn more about it here. You can see the in progress website at https://graffle.js.org.

The following README is still for graphql-request@7.x.x

graphql-request

Minimal GraphQL client supporting Node and browsers for scripts or simple apps.

GitHub Action npm version

Highlights

  • Most simple & lightweight GraphQL client
  • Promise-based API (works with async / await)
  • Pure ESM package
  • First class TypeScript support
    • Including TypedDocumentNode
  • Isomorphic (works in both Node and Browsers)

Install

npm add graffle graphql

TypeScript Setup

This package uses package.exports. Therefore if you are a TypeScript user you must:

  1. have your tsconfig.json moduleResolution set to "bundler" or "node16"/"nodenext".
  2. Have your package.json type set to "module".

Quick Start

Send a GraphQL document using a static request function:

import { gql, request } from 'graffle'

const document = gql`
  {
    company {
      ceo
    }
  }
`
await request('https://api.spacex.land/graphql/', document)

The function can be passed a configuration object for more complex cases:

await request({
  url,
  document,
  variables,
  requestHeaders,
})

A class is available for constructing your own instances:

import { gql, GraphQLClient } from 'graffle'

const document = gql`
  {
    company {
      ceo
    }
  }
`
const endpoint = 'https://api.spacex.land/graphql/'
const client = new GraphQLClient(endpoint)
await client.request(document)

Examples

Node Version Support

We only (officially) support versions of Nodejs of the following status:

  • Current
  • LTS
  • Maintenance and end of life not yet reached

So for example on Oct 24 2023 that would mean these versions: 18, 20, 21.

Any issue that exists solely for an unsupported version of Nodejs will be rejected (not worked on).

Reference

⚠️ This reference is incomplete. Check out the examples for more reference material.

Configuration

ErrorPolicy

By default GraphQLClient will throw when an error is received. However, sometimes you still want to resolve the (partial) data you received. You can define errorPolicy in the GraphQLClient constructor.

const client = new GraphQLClient(endpoint, { errorPolicy: 'all' })
None (default)

Allow no errors at all. If you receive a GraphQL error the client will throw.

Ignore

Ignore incoming errors and resolve like no errors occurred

All

Return both the errors and data, only works with rawRequest.

IgnoreOperationName

OperationName has been introduced to address issues reported here Support operation name, However, on certain occasions this information may not be needed in requests. In such cases, you might consider ignoring operationName to avoid the extraction steps currently performed by a parsing operation when the document is provided in string format.

By default the GraphQLClient tries to extract the operationName from the document. You can define excludeOperationName in the constructor of GraphQLClient to avoid the extraction process if it is not needed. This can be useful if you don't use operationName and want to optimise queries by reducing the amount of computation as much as possible, especially if we are in a context where we are using documents in string format to reduce bundle size.

// example where the operation name is not ignored
const client = new GraphQLClient(endpoint, {
  method: 'POST',
})
// example in which the operation name is ignored
const client = new GraphQLClient(endpoint, {
  method: 'POST',
  excludeOperationName: true,
})

Knowledge Base

Why was the file upload feature taken away? Will it return?

In this issue we decided to make this library more stable and maintainable. In principal the feature is still in scope of this library and will make a return when we find time to do the feature right.

Why do I have to install graphql?

graffle uses methods exposed by the graphql package to handle some internal logic. On top of that, for TypeScript users, some types are used from the graphql package to provide better typings.

Do I need to wrap my GraphQL documents inside the gql template exported by graffle?

No. It is there for convenience so that you can get the tooling support like automatic formatting and syntax highlighting. You can use gql from graphql-tag if you need it for some reason too.

What sets graffle apart from other clients like Apollo, Relay, etc.?

graffle is the most minimal and simplest to use GraphQL client. It's perfect for small scripts or simple apps.

Compared to GraphQL clients like Apollo or Relay, graffle doesn't have a built-in cache and has no integrations for frontend frameworks. The goal is to keep the package and API as minimal as possible.

Project Stats

Package Installs

NPM Usage Trend of graphql-request

Repo Beats

Alt

NPM DownloadsLast 30 Days