Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@amagaki/amagaki-plugin-google-sheets

Package Overview
Dependencies
Maintainers
2
Versions
15
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@amagaki/amagaki-plugin-google-sheets

[![NPM Version][npm-image]][npm-url] [![GitHub Actions][github-image]][github-url] [![TypeScript Style Guide][gts-image]][gts-url]

  • 1.0.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
2.2K
increased by955.56%
Maintainers
2
Weekly downloads
 
Created
Source

amagaki-plugin-google-sheets

NPM Version GitHub Actions TypeScript Style Guide

An Amagaki plugin for fetching content from Google Sheets. Capable of transforming Google Sheets into various formats, and supports using Google Sheets for managing translations.

Use this to allow non-developers to manage content (including website copy, data, and translations) in a Google Sheet, and consuming that content within your Amagaki project to build a website.

Usage

  1. Install the plugin.
npm install --save @amagaki/amagaki-plugin-google-sheets
  1. Acquire a service account key file. You can do this interactively, from the IAM section of the Google Cloud Console, or you can do this via the gcloud CLI (see below).
PROJECT=yourGcpProject \
  gcloud --project=$PROJECT \
    iam service-accounts create \
    amagaki \
  && gcloud --project=$PROJECT \
    iam service-accounts keys create \
    --iam-account amagaki@$PROJECT.iam.gserviceaccount.com \
    key.json
  1. Ensure the sheet is shared with the service account.

  2. Ensure key.json is added to your .gitignore.

  3. Add to amagaki.js.

const googleSheetsPlugin = require('./plugins/google-sheets');

module.exports = async function (pod) {
  const sheetsPlugin = googleSheetsPlugin.register(pod, {
    keyFile: 'key.json',
  });

  // Run Google Sheets plugin only when dev server starts.
  const serverPlugin = pod.plugins.get('ServerPlugin');
  serverPlugin.register(() => {
    // Saves a single file, "homepage" tab, `strings` transformation.
    sheetsPlugin.saveFile({
      podPath: '/content/partials/homepage.yaml',
      spreadsheetId: '1qP7IPYJ1nIA5useXKbm8nHyj96Ue_6YMEFkwgpUoL-c',
      range: 'homepage',
      transform: 'strings',
    });

    // Save a single file, "about" tab, `grid` transformation.
    sheetsPlugin.saveFile({
      podPath: '/content/partials/about.yaml',
      spreadsheetId: '1qP7IPYJ1nIA5useXKbm8nHyj96Ue_6YMEFkwgpUoL-c',
      range: 'about',
      transform: 'grid',
    });

    // Save a single file, "about" tab, `objectRows` transformation.
    sheetsPlugin.saveFile({
      podPath: '/content/partials/aboutObjectRows.yaml',
      spreadsheetId: '1qP7IPYJ1nIA5useXKbm8nHyj96Ue_6YMEFkwgpUoL-c',
      range: 'about',
      transform: 'objectRows',
    });

    // Binds a collection to specified tabs within the Google Sheet. Deletes
    // files from the collection that no longer exist in the sheet.
    // Because the `transform` value is set to `strings`, the plugin will also
    // import any translations contained within the sheets to their respective
    // locale files.
    sheetsPlugin.bindCollection({
      collectionPath: '/content/strings',
      spreadsheetId: '1qP7IPYJ1nIA5useXKbm8nHyj96Ue_6YMEFkwgpUoL-c',
      ranges: ['homepage', 'about'],
      transform: 'strings',
    });
  });
};

Transform options

strings

NOTE: The preferString and !IfLocale features of this plugin are currently unimplemented.

Use the strings format when managing website copy (and optionally translation strings) inside a Google Sheet. Non-translation data can also be added, by leaving the type field blank.

Converts a sheet formatted as a grid of strings into a mapping of keys to localized strings. The sheet must be in the following format:

| key  | type         | en        | de      | es    |
| ---- | ------------ | --------- | ------- | ----- |
| foo  | string       | Hello     | Hallo   | Hola  |
| bar  | string       | Bye       | Tschüss | Adiós |
| bar  | preferString | Goodbye   |         |       |
| baz  | | https://example.com | https://example.de | https://example.es |

The values are transformed to:

foo:
  !pod.string
    value: Hello
bar:
  !pod.string
    prefer: Goodbye
    value: Bye
baz:
  !IfLocale
    default: https://example.com
    de: https://example.de
    es: https://example.es

Furthermore, any translation strings denoted by type "string" within the sheet are automatically saved to the pod's locale files. Any rows that do not have type "string" are not imported to the locale files.

To refer to your Google Sheets data from documents, use the !pod.yaml YAML type. The content can be accessed in a template regularly. !pod.string types are automatically translated, and !IfLocale types are automatically localized.

partials:
- partial: hero
  headline: !pod.yaml /content/strings/homepage.yaml?foo
  body: !pod.yaml /content/strings/homepage.yaml?bar
  button:
    url: !pod.yaml /content/strings/homepage.yaml?baz

grid

Converts a sheet formatted as a grid of strings into a mapping of keys to headers to values. The sheet must be in the following format:

| <BLANK>  | header1 | header2 |
| -------- | ------- | ------- |
| foo      | a       | b       |
| bar      | c       | d       |

The values are transformed to:

foo:
  header1: a
  header2: b
bar:
  header1: c
  header2: d

objectRows

Converts a sheet formatted as a grid of strings into a list of objects mapping headers to values. The sheet must be in the following format:

| header1  | header2 | header3 |
| -------- | ------- | ------- |
| foo      | a       | b       |
| bar      | c       | d       |

The values are transformed to:

- header1: foo
  header2: a
  header3: b
- header1: bar
  header2: c
  header3: d

rows (default)

Does not modify response from Google Sheets. The sheet is simply serialized as a list of lists.

| header1  | header2 | header3 |
| -------- | ------- | ------- |
| foo      | a       | b       |
| bar      | c       | d       |

The values are transformed to:

- - header1
  - header2
  - header3
- - foo
  - a
  - b
- - bar
  - c
  - d

FAQs

Package last updated on 27 May 2021

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc