bofeiw / FiretableActions

starter repo for managing Firetable actions (cloud functions)

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Firetable Actions

This package provides a firebase cloud functions project with a callable cloud function wrapper that handles role permission and the required fields validation for Firetable action columns.

Installation

yarn add firetable-actions

Usage

This library can be used as an alternative to directly using functions.https.onCall function to deploy a callable cloud functions for use in Firetable action fields. It can be installed and used in an existing firebase cloud functions project

// import and intialize firebase admin SDK
import * as admin from "firebase-admin";
admin.initializeApp();

import callableAction from "firetable-actions";
export ExampleCallableAction = callableAction(async ({row, callableData, context}) =>{
  const {ref, column, schemaDocPath, action} = callableData;
  console.log({
    row, // docSnapshot of the called column
    context, // callable context contains data such as the time and the user running the action
    ref, // contains document id and other references related to the row
    column, // contains key of the action column
    schemaDocPath, // table schema Doc Path
    action, // latest action state
  });

  // switch statement can be used to perform different processes based on the state of the action cell
  switch (action) {
    case "run":
    case "undo":
    case "redo":
    default:
      break;
  }

  return {
    success: true, // return if the operation was success
    message: "hello world", // message shown in snackbar on the firetable ui after the completion of action
    cellStatus: "greeted", // optional cell label, to indicate the latest state of the cell/row
    newState: "redo", // "redo" | "undo" | "disabled" are options set the behavior of action button next time it runs
  };
});

Demo

To experiment with this package you can clone this repo then modify the example here.

git clone https://github.com/shamsmosowi/FiretableActions
cd FiretableActions/functions
yarn install
firebase deploy --only functions --project [projectId]

About

starter repo for managing Firetable actions (cloud functions)


Languages

Language:TypeScript 73.4%Language:JavaScript 26.6%