GitXplorerGitXplorer
o

gatsby-source-dropbox

public
7 stars
7 forks
10 issues

Commits

List of commits on branch master.
Verified
2e54b9c35c4749201af54a46ee4c1a1e2c33efc4

Merge pull request #12 from oorestisime/dependabot/npm_and_yarn/node-fetch-2.6.1

nniklas-may committed 4 years ago
Verified
27d64cb3adcd6c4adf6be39d7c49bde8f6d03acf

Update README.md

nniklas-may committed 4 years ago
Verified
ea61259e61ab4d08bcc0779f54fce78d43c04376

Bump node-fetch from 2.6.0 to 2.6.1

ddependabot[bot] committed 4 years ago
Verified
a2c8d3ca0dff26e5874bbb0de62ba6e1dae5e022

Merge pull request #9 from dvhtn/master

nniklas-may committed 5 years ago
Unverified
308900d150b7b7f6f43f54e9b98b0a416076e91a

feat: downloading new file if cached file is outdated

nniklas-may committed 5 years ago
Unverified
0c61fd35af2d7def74fbad9c7318a6a403243619

merge

nniklas-may committed 5 years ago

README

The README file for this repository.

gatsby-source-dropbox npm version

Source plugin for getting data from Dropbox account.

If you want to work with Markdown files that include images, you also need to install gatsby-remark-dropbox-images

Install

npm install --save gatsby-source-dropbox

How to use

Configure the plugin

// In your gatsby-config.js
plugins: [
  {
    resolve: `gatsby-source-dropbox`,
    options: {
      accessToken: `access-token`,
      extensions: ['.pdf', '.jpg', '.png', '.md'],
      path: '/path/to/folder',
      recursive: false,
      createFolderNodes: false,
    },
  },
]

Options

  • accessToken: the token to use for querying dropbox. In order to get an access token you will need to create an app https://www.dropbox.com/developers/apps and generate one.
  • extensions: list of extensions used to filter out results
  • path: the folder to use to retrieve data. Defaults to '' which is the root of the dropbox project.
  • recursive: use this to retrieve files from subdirectories as well
  • createFolderNodes use this if you want see your nodes structured by the folders they where in

How to query

With createFolderNodes: false

The plugin provides some basic information of the remote files such as:

  • name the filename,
  • path the file path,
  • lastModified the last modification date,

The plugin makes use of the create remote node API of gatsby to locally download all the files in order to use them with other transformer plugins such as gatsby-transformer-sharp for images or gatsby-transformer-remark for markdown files.

Example:

query {
  allDropboxNode {
    edges {
      node {
        id
        name
        lastModified
        path
        localFile {
          childMarkdownRemark {
            html
          }
        }
      }
    }
  }
}

With createFolderNodes: true

By setting this to true, you will get the following types in graphql:

allDropboxFolder
allDropboxImage
allDropboxMarkdown
allDropboxNode # everything that's not one of the above, will be of this type

You can now easily query for files within a folder. Lets say you have a simple portfolio structured like this on your dropbox:

.
+-- Project-01-Lorem-Name
|   +-- Description.md
|   +-- Gallery-Image-01.jpg
|   +-- Gallery-Image-02.jpg
+-- Project-02-Ipsum-Name
|   +--Description.md
|   +--Gallery-Image-01.jpg
|   +--Gallery-Image-02.jpg

You can now query like following in gatsby-node.js and create project pages with a corresponding template:

query MyQuery {
  allDropboxFolder(filter: {name: {regex: "/Project/"}}) {
    group(field: name) {
      nodes {
        name
        dropboxImage {
          localFile {
            childImageSharp {
              fluid {
                src
              }
            }
          }
        }
        dropboxMarkdown {
          localFile {
            childMarkdownRemark {
              html
            }
          }
        }
      }
    }
  }
}