Tips for updating the value of a dynamically fetched field in a Firestore document using Cloud Functions

I have a simple question: How can I update a field in a firestore document when the field name is only known dynamically through a variable?

const myCounterName = "exampleName";
const docRef = admin.firestore().collection("metadata").doc("myDoc");
docRef.set({myCounterName : admin.firestore.FieldValue.increment(1)}, {merge: true});

The challenge lies in the fact that Firestore interprets the field I want to change as "myCounterName" rather than "exampleName".

Answer №1

To achieve this, you can utilize the square brackets notation in the following manner:

const nameOfCounter = "counterExample";

const data = {};
data[nameOfCounter] = admin.firestore.FieldValue.increment(1);

const documentReference = admin.firestore().collection("statistics").doc("myDataDoc");
documentReference.set(data, {merge: true});

Similar questions

If you have not found the answer to your question or you are interested in this topic, then look at other similar questions below or use the search

Executing a typescript class from a bash script: tips and tricks

Is it possible to invoke a TypeScript class and function from a bash script file? I have been unable to locate any relevant documentation on this topic. Below is the code snippet: TypeScript code: export class TestClass { constructor( public name ...

What is the best way to forward specific props from a parent to its children?

Currently, I am working on a React + Typescript architecture called "forward." The purpose of this architecture is to pass all props received down to its children components. However, I have encountered an issue where I want to restrict the type of props ...

What methods does TypeScript use to verify primitive types during runtime?

Is it true that Typescript removes any type or interface at compile time? If so, how is it possible to determine an object's primitive type using the typeof keyword? Are custom interfaces handled differently than primitive types? const a = "strin ...

Guide on transitioning an Angular 4 project created in Visual Studio 2015 to Angular 6 with Visual Studio Code

Currently, I am collaborating on an Angular 4 project that utilizes a web API in Visual Studio 2015 update 3. This project serves as an ERP solution. My goal is to enhance the project by updating it to Angular 6, with Visual Studio Code as the primary too ...

When handling a document click event in Typescript, an error may occur where it cannot read

Just starting out with Typescript and diving into Angular, I am currently in the process of converting my project to the Angular system. However, I've hit a roadblock. I need to figure out how to close the dropdown content when the user clicks anywher ...

Moving the starting directory of a NodeJS application on Azure

My NodeJS app on Azure was initially written in Javascript with the app.js file located in the root directory. This file was automatically detected during deployment via Git. Recently, I converted the app to Typescript and now have a build directory, with ...

Leverage ENUM in Sequelize with Typescript

I'm currently working on developing an API with a USER class that can authenticate itself in multiple ways. Initially, I had success with setting up one user with one credential. However, when attempting to expand the functionality to allow for multi ...

Angular 6 Error: Failed to parse template. Unable to establish a connection with 'routerLink' as it is not recognized as a valid property of 'a'

During app testing with npm test An error is encountered : Failed: Template parse errors: Can't bind to 'routerLink' since it isn't a known property of 'a'. (" <nav> <ul> <li><a class=" ...

An issue has occurred: TransformError SyntaxError: Unexpected keyword 'const' was encountered

While practicing programming with React-Native, I encountered a problem that I couldn't figure out how to solve. I attempted to use solutions from various forums, but none of them worked. import { StyleSheet, Text, View, Image } from 'react-nativ ...

Getting information from the firebase database

I'm currently working on a web application that utilizes Firebase database. I'm encountering difficulties when trying to access the elements that are labeled as encircled. Can anyone offer any guidance or suggestions? Here is the code snippet I& ...

Tips for integrating JavaScript libraries into TypeScript build process in Visual Studio

Is it possible to configure the "TypeScript Build" feature in Visual Studio 2017 to include both Javascript libraries and TypeScript files in the generated bundle.js output? ...

Leveraging the ngFor local variable within nested elements

Is there a way to properly display a property of the local variable theme, such as theme.name? Below is an example of how my *ngFor is structured: <ul> <li *ngFor="#theme of themes"> <span>theme.name</span> </li> ...

Once I introduce ngModel into mat-checkbox, the functionality of 'checked' stops working

When I add an ngModel to my mat-checkbox, the checked = "checked" functionality stops working as expected. The following code will work: <mat-checkbox name="BlackBeard" ngModel checked = "checked"> Zehahaha? </mat-checkbox> However, the foll ...

Asynchronously alter each element within the array observable and then send back the updated observable

In my Angular project, I am developing a service with ngrx that is responsible for retrieving a list of messages from the store. Once it fetches the list, the service then needs to obtain additional asynchronous data for each message and create a new objec ...

Having trouble getting Typescript code to function properly when using commonjs style require statements

I am completely new to Typescript, Node.js, and Express. Following the instructions outlined in this tutorial (https://www.digitalocean.com/community/tutorials/setting-up-a-node-project-with-typescript), I set up my project exactly as described there. The ...

Theme customization in Material UI includes the addition of a custom color. However, this custom color is missing from the control values in Story

Currently in my project, I am utilizing a stack that includes React 18, TypeScript, MUI 5, and Storybook 6.5. I have been attempting to incorporate custom colors into my MUI Theme and have them reflect in Storybook's dropdown options for the color p ...

Unable to link to 'Attribute A' because it is not recognized as a valid property of 'Subcomponent'

Within my project, I have a generic class with several components that inherit from it. BaseRdnInput.ts: @Injectable() export abstract class BaseRdnInput implements ControlValueAccessor, Validator { @Input() rdnModel?: any | Array<any ...

Exploring type delegation in TypeScript

Here is a scenario where I am using the builder pattern in my code: export class ValidationBuilderBase implements IValidationBuilder { public isRequired(): IValidationBuilder { const validationResult = Validators.required(this.baseControl); ...

Having trouble changing the title with Switch/Case in Angular?

I am facing an issue where the title is not displayed as expected based on the environment value in appConfig.json. appConfig.json "env": "stage", app.component.ts env: string; constructor( private configService: ConfigService ) ...

There was an issue: Control with the name 'name' could not be located

Whenever I submit the form and try to go back, an error pops up saying "ERROR Error: Cannot find control with the name: 'name'". I'm not sure what I might be missing. Do I need to include additional checks? Below is my HTML file: <div ...