-
Notifications
You must be signed in to change notification settings - Fork 114
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #276 from newrelic/dianabb_howto
Adding new page: add-query-mutate-data-NerdStorage.mdx
- Loading branch information
Showing
6 changed files
with
263 additions
and
0 deletions.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
263 changes: 263 additions & 0 deletions
263
src/markdown-pages/build-apps/add-query-mutate-data-NerdStorage.mdx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,263 @@ | ||
--- | ||
path: '/build-apps/add-query-mutate-data-nerdstorage' | ||
duration: '45 min' | ||
title: 'Add, query, and mutate data using NerdStorage' | ||
template: 'GuideTemplate' | ||
description: 'NerdStorage is a document database accessible within New Relic One. It allows you to modify, save, and retrieve documents from one session to the next.' | ||
--- | ||
|
||
<Intro> | ||
|
||
NerdStorage is a document database accessible within New Relic One. It allows you to modify, save, and retrieve documents from one session to the next. | ||
|
||
Using NerdStorage, you can create individual documents of up to 64kb in size, create different collections of documents, and store data by Entity, Account, or User level. | ||
|
||
This guide explains how to add data and documents to NerdStorage. For a introduction to what NerdStorage is and how it works, see [Intro to NerdStorage on New Relic One](https://developer.newrelic.com/build-tools/new-relic-one-applications/nerdstorage). | ||
|
||
</Intro> | ||
|
||
## Before you begin | ||
|
||
This guide requires that you have the following: | ||
|
||
* A github account | ||
* New Relic account | ||
* An [API Key](https://one.newrelic.com/launcher/developer-center.launcher?pane=eyJuZXJkbGV0SWQiOiJkZXZlbG9wZXItY2VudGVyLmRldmVsb3Blci1jZW50ZXIifQ==) for building applications | ||
* The [New Relic One CLI](https://one.newrelic.com/launcher/developer-center.launcher?pane=eyJuZXJkbGV0SWQiOiJkZXZlbG9wZXItY2VudGVyLmRldmVsb3Blci1jZW50ZXIifQ==) | ||
|
||
## Get started | ||
|
||
First, you need to get the NerdStorage app running successfully inside New Relic One. | ||
|
||
<Steps> | ||
|
||
<Step> | ||
|
||
Clone the example applications from the [GitHub repo](https://github.com/newrelic/nr1-how-to/tree/master/use-nerdstorage). | ||
|
||
</Step> | ||
|
||
<Step> | ||
|
||
Next, use the New Relic One CLI to update the application UUID and run the application locally. | ||
|
||
In the terminal, switch to the `/nr1-howto/use-nerdstorage` directory: | ||
|
||
``` | ||
cd /nr1-howto/use-nerdstorage | ||
``` | ||
Then update the UUID and serve the application: | ||
|
||
``` | ||
nr1 nerdpack:uuid -gf | ||
nr1 nerdpack:serve | ||
``` | ||
</Step> | ||
|
||
</Steps> | ||
|
||
Once the app is successfully served, your terminal will return the URL to view your running application on New Relic One: [https://one.newrelic.com/?nerdpacks=local](https://one.newrelic.com/?nerdpacks=local). | ||
|
||
Load the URL. Under **Your applications** you will see the **Use Nerdstorage** app listed. Click to launch the app. | ||
|
||
![Your applications view updated](../../images/build-an-app/NerdStorage-applications-view.png) | ||
|
||
## Add data to NerdStorage | ||
|
||
Once the app is up and running on New Relic One, you can prepare the app and start adding data. | ||
|
||
On the **How To Use NerdStorage** app screen, there's a **Saved to NerdStorage** pane with a field for adding data. However, if you type something you'll get an error message. This is because you need to be set up to store data at the `User` level. You can do this with the help of the [UserStorageMutation component](https://developer.newrelic.com/client-side-sdk/index.html#data-fetching/UserStorageMutation). | ||
|
||
![add data view 1](../../images/build-an-app/add-data-NerdStorage.png) | ||
|
||
<Steps> | ||
|
||
<Step> | ||
|
||
Open the application’s `./nerdlets/use-nerdstorage-nerdlet/index.js` file in the text editor of your choice and find the code for the `TextField` and `Button` used to enter data. The `Button onClick` prop makes a call to a helper method called `_addToNerdStorage`, and you need to update it to add `UserStorageMutation` | ||
|
||
The `UserStorage` NerdStorage components require a `collection` and `documentId`. In the constructor method in the application’s `index.js` file, you can see the variables being provided. In the `.js` file, it will look something like this: | ||
|
||
``` | ||
constructor(props) { | ||
super(props) | ||
this.collectionId = 'mycollection'; | ||
this.documentId = 'learning-nerdstorage'; | ||
this.state = { | ||
isOpen: true, | ||
storage: [], | ||
text: '', | ||
}; | ||
this._addToNerdStorage = this._addToNerdStorage.bind(this); | ||
this._removeFromNerdStorage = this._removeFromNerdStorage.bind(this); | ||
this._deleteDocument = this._deleteDocument.bind(this); | ||
} | ||
``` | ||
</Step> | ||
|
||
<Step> | ||
|
||
Import the UserStorageMutation by adding it to your import statement at the top of the index.js file: | ||
|
||
``` | ||
import {UserStorageMutation } from 'nr1'; | ||
``` | ||
|
||
Then update the helper with the code below: | ||
|
||
``` | ||
_addToNerdStorage(){ | ||
const { text, storage } = this.state; | ||
storage.push(text); | ||
this.setState({storage}, () => { | ||
UserStorageMutation.mutate({ | ||
actionType: UserStorageMutation.ACTION_TYPE.WRITE_DOCUMENT, | ||
collection: this.collectionId, | ||
documentId: this.documentId, | ||
document: { storage }, | ||
}) | ||
.then((res) => { | ||
this.setState({text: ''}); | ||
Toast.showToast({ title: "NerdStorage Update.", type: Toast.TYPE.NORMAL }); | ||
}) | ||
.catch((err) => console.log(err)); | ||
}); | ||
} | ||
``` | ||
</Step> | ||
|
||
<Step> | ||
|
||
Return to your running **How To Use NerdStorage** app screen on New Relic One and reload the page. | ||
|
||
Add some text in the text entry field and click the check button. This will update NerdStorage and trigger a `Toast` notification inside the app. You should then see the text you typed displayed as a table row below the text entry field. | ||
|
||
![add data view 2](../../images/build-an-app/add-data-NerdStorage-2.png) | ||
|
||
|
||
</Step> | ||
|
||
</Steps> | ||
|
||
## Query data from NerdStorage | ||
|
||
Once you get data storage working as described in the section above and you also need to get the app properly reading data from NerdStorage, or the app will reload with an empty state every time you navigate away from the app page and back. To to this, you need to add the `UserStorageQuery` component and update the `1componentDidMount` method. | ||
|
||
<Steps> | ||
|
||
<Step> | ||
|
||
Import the UserStorageQuery by adding it to the import statement in the application’s `./nerdlets/use-nerdstorage-nerdlet/index.js` file. | ||
|
||
``` | ||
import {UserStorageMutation, UserStorageQuery } from 'nr1'; | ||
``` | ||
</Step> | ||
|
||
<Step> | ||
|
||
Then add the following `componentDidMount` method to your application: | ||
|
||
``` | ||
componentDidMount(){ | ||
UserStorageQuery.query({ | ||
collection: this.collectionId, | ||
documentId: this.documentId, | ||
}) | ||
.then(({ data }) => { | ||
if(data !== null) { | ||
this.setState({storage: data.storage}); | ||
} | ||
}) | ||
.catch(err => console.log(err)); | ||
} | ||
``` | ||
</Step> | ||
|
||
</Steps> | ||
|
||
Back inside the NerdStorage app, test your changes by adding a few more rows using the text entry field, then exit and relaunch the application. The application should load and show all the data you entered before you navigated away. | ||
|
||
## Mutate data in NerdStorage | ||
|
||
Each NerdStorage entry displayed in the table inside the app has a trash button that can be used to update a specific entry. The trash button works by making a call to the `_removeFromNerdStorage` helper method. | ||
|
||
To get this process working, you need to update the code in `_removeFromNerdStorage`: | ||
|
||
``` | ||
_removeFromNerdStorage(index, data){ | ||
const { storage } = this.state; | ||
storage.pop(data); | ||
this.setState({storage}, () => { | ||
UserStorageMutation.mutate({ | ||
actionType: UserStorageMutation.ACTION_TYPE.WRITE_DOCUMENT, | ||
collection: this.collectionId, | ||
documentId: this.documentId, | ||
document: { storage }, | ||
}) | ||
.then((res) => { | ||
Toast.showToast({ title: "NerdStorage Update.", type: Toast.TYPE.NORMAL }); | ||
}) | ||
.catch((err) => console.log(err)); | ||
}); | ||
} | ||
``` | ||
|
||
Once this is done, clicking the trash button will remove the item it's associated with, and the app will update to show the change. | ||
|
||
![mutate data](../../images/build-an-app/mutate-data-NerdStorage.png) | ||
|
||
## Delete collection from NerdStorage | ||
|
||
While the trash button is a good method for removing specific entries one at a time, you may also want the ability to delete a whole NerdStorage document at once. You can do this by adding the **Delete Document** button to your app. | ||
|
||
<Steps> | ||
|
||
<Step> | ||
|
||
Add a new `GridItem` to the application immediately before the closing `Grid` tag. In the new `GridItem` add the following code to display your new button: | ||
|
||
``` | ||
<Button | ||
onClick={() => this._deleteDocument()} | ||
type={Button.TYPE.DESTRUCTIVE} | ||
sizeType={Button.SIZE_TYPE.SMALL} | ||
iconType={Button.ICON_TYPE.INTERFACE__OPERATIONS__TRASH} | ||
> | ||
Delete Document | ||
</Button> | ||
``` | ||
</Step> | ||
|
||
<Step> | ||
|
||
As the new **Delete Document** button will be calling the `_deleteDocument` helper method, you'll need to update that using the code below: | ||
|
||
``` | ||
_deleteDocument(){ | ||
this.setState({storage: []}); | ||
UserStorageMutation.mutate({ | ||
actionType: UserStorageMutation.ACTION_TYPE.DELETE_DOCUMENT, | ||
collection: this.collectionId, | ||
documentId: this.documentId, | ||
}); | ||
Toast.showToast({ title: "NerdStorage Update.", type: Toast.TYPE.CRITICAL }); | ||
} | ||
``` | ||
</Step> | ||
|
||
</Steps> | ||
|
||
Back inside the application, you should now see both the individual trash buttons and the newly added **Delete Document** button. | ||
|
||
![delete collection button view](../../images/build-an-app/delete-collection-NerdStorage.png) | ||
|
||
|
||
## Next steps | ||
|
||
Now that you’ve successfully implemented NerdStorage into a New Relic One application, you can store and mutate data connected to your `User`. For more information on the various NerdStorage components, please visit the New Relic developer website [API documentation](/components/user-storage-mutation). | ||
|
||
## Related info | ||
|
||
- [New Relic SDK documentation](/reference/intro-to-sdk) |