npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

sheetsu-node

v0.0.7

Published

Official Sheetsu API bindings for Node.js

Downloads

69

Readme

sheetsu-node

Installation

npm install sheetsu-node --save

Usage

Generating a Client

You need to create a new sheetsu function, and populate it with your Sheetsu API URL. You can find this URL on Sheetsu Dashboard.

var sheetsu = require('sheetsu-node');

// create a config file
var config = {
  address: '020b2c0f',
};

// Create new client
var client = sheetsu(config);

for ES6

import sheetsu from 'sheetsu-node';

// create a config file
var config = {
  address: '020b2c0f',
};

// Create new client
var client = sheetsu(config);

If you have HTTP Basic Authentication turned on for your API, you should pass api_key and api_secret here, like:

// create a config file
var config = {
  address: '020b2c0f',
  api_key: 'YOUR_API_KEY',
  api_secret: 'YOUR_API_SECRET',
};

// Create new client
var client = sheetsu(config);

CRUD

Sheetsu gives you the ability to use full CRUD on your Google Spreadsheet. Remember to populate the first row of every sheet with column names. You can look at example spreadsheet.

Create

Link to docs

To add data to Google Spreadsheets, send a hash or an array of hashes.

// Adds single row
client.create({ id: 7, name: "Glenn", score: "69" }).then(function(data) {
  console.log(data);
}, function(err){
  console.log(err);
});

/// Adds bunch of rows
rows = [
  { id: 7, name: "Glenn", score: "69" },
  { id: 8, name: "Brian", score: "77" },
  { id: 9, name: "Joe", score: "45" }
]
client.create(rows).then(function(data) {
  console.log(data);
}, function(err){
  console.log(err);
});

By default, all writes are performed on the first sheet (worksheet). Pass name of a sheet as a 2nd param to add data to other worksheet.

// Adds single row to worksheet named "Sheet3"
client.create({ id: 7, name: "Glenn", score: "69" }, "Sheet3").then(function(data) {
  console.log(data);
}, function(err){
  console.log(err);
});

On success returns a hash or an array of hashes with created values.

Read

Link to docs

Read the whole sheet

client.read({ limit, offset, search, sheet }).then(function(data) {
  console.log(data);
}, function(err){
  console.log(err);
});

You can pass hash with options

  • limit - limit number of results
  • offset - start from N first record
  • search - hash with search params (more below)
  • sheet - get data from named worksheet
// Get first two rows from worksheet named "Sheet2"
client.read({ limit: 2, sheet: "Sheet2" }).then(function(data) {
  console.log(data);
}, function(err){
  console.log(err);
});

// Get 5th and 6th record from worksheet named "Sheet3"
client.read({ limit: 2, offset: 4, sheet: 'Sheet3' }).then(function(data) {
  console.log(data);
}, function(err){
  console.log(err);
});

search

Link to docs

To get rows that match search criteria, pass a hash with search params

// Get all rows where column 'id' is 'foo' and column 'value' is 'bar'
client.read({ search: { id: "foo", value: "bar" } }).then(function(data) {
  console.log(data);
}, function(err){
  console.log(err);
});

// Get all rows where column 'First name' is 'Peter' and column 'Score' is '42'
client.read({ search: { 'first name': 'Peter', 'Score': 42 } }).then(function(data) {
  console.log(data);
}, function(err){
  console.log(err);
});


// Get first two row where column 'First name' is 'Peter',
// column 'Score' is '42' from sheet named "Sheet3"
client.read({
  limit: 2,
  search: { 'first name': 'Peter', 'Score': 42 },
  sheet: 'Sheet3'
}).then(function(data) {
  console.log(data);
}, function(err){
  console.log(err);
});

On success returns an array of hashes.

Update

Link to docs

To update row(s), pass column name and its value which is used to find row(s).

client.update(columnName, value, newRow, updateWhole, sheet).then(function(data) {
  console.log(data);
}, function(err){
  console.log(err);
});
// Update all columns where 'name' is 'Peter' to have 'score' = 99 and 'last name' = 'Griffin'
client.update(
  'name', // column name
  'Peter', // value to search for
  { 'score': 99, 'last name': 'Griffin' } // hash with updates
).then(function(data) {
  console.log(data);
}, function(err){
  console.log(err);
});

By default, PATCH request is sent, which is updating only values which are in the hash passed to the method. To send PUT request, pass 4th argument being true. Read more about the difference between PUT and PATCH in our docs.

// Update all columns where 'name' is 'Peter' to have 'score' = 99 and 'last name' = 'Griffin'
// Empty all cells which matching, which are not 'score' or 'last name'
client.update(
  'name', // column name
  'Peter', // value to search for
  { 'score': 99, 'last name': 'Griffin' }, // hash with updates
  true // nullify all fields not passed in the hash above
).then(function(data) {
  console.log(data);
}, function(err){
  console.log(err);
});

To perform #update on different than the first sheet, pass sheet name as a 5th argument.

// Update all columns where 'name' is 'Peter' to have 'score' = 99 and 'last name' = 'Griffin'
// In sheet named 'Sheet3'
// Empty all cells which matching, which are not 'score' or 'last name'
client.update(
  'name', // column name
  'Peter', // value to search for
  { 'score': 99, 'last name': 'Griffin' }, // hash with updates
  true, // nullify all fields not passed in the hash above
  'Sheet3'
).then(function(data) {
  console.log(data);
}, function(err){
  console.log(err);
});

On success returns an array of hashes with updated values.

Delete

Link to docs

To delete row(s), pass column name and its value which is used to find row(s).

// Delete all rows where 'name' equals 'Peter'
client.delete(
  'name', // column name
  'Peter' // value to search for
).then(function(data) {
  console.log(data);
}, function(err){
  console.log(err);
});

You can pass sheet name as a 3rd argument. All operations are performed on the first sheet, by default.

// Delete all rows where 'foo' equals 'bar' in sheet 'Sheet3'
client.delete(
  'name', // column name
  'Peter', // value to search for
  'Sheet3'
).then(function(data) {
  console.log(data);
}, function(err){
  console.log(err);
});

If success returns :ok symbol.

Development

Run all tests:

npm test

Run a nyan version test:

npm run nyan-test

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/sheetsu/sheetsu-ruby. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.

Pull Requests

  • Add tests! Your patch won't be accepted if it doesn't have tests.

  • Create topic branches. Please, always create a branch with meaningful name. Don't ask us to pull from your master branch.

  • One pull request per feature. If you want to do more than one thing, please send multiple pull requests.

  • Send coherent history. Make sure each individual commit in your pull request is meaningful. If you had to make multiple intermediate commits while developing, please squash them before sending them to us.

Docs

Sheetsu documentation sits on GitHub. We would love your contributions! We want to make these docs accessible and easy to understand for everyone. Please send us Pull Requests or open issues on GitHub.