This app shows how to implement asset searching and filtering by name and tags.
- Included Features
- Tools and Technologies
- Prerequisites
- Associated Developer Tutorial
- Run the app locally
- Folder Structure
- Contributing
- License
- You have a Miro account.
- You're signed in to Miro.
- Your Miro account has a Developer team.
- Your development environment includes Node.js 14.13 or a later version.
- All examples use
npm
as a package manager andnpx
as a package runner.
To view a more in depth developer tutorial of this app (including code explanations) see the Asset Search and Filter tutorial on Miro's Developer documentation.
-
Run
npm install
to install dependencies. -
Run
npm start
to start developing.
Your URL should be similar to this example:http://localhost:3000
-
Open the app manifest editor by clicking Edit in Manifest.
In the app manifest editor, configure the app as follows:appName: Miro Asset Search sdkUri: "http://localhost:3000" scopes: - boards:read - boards:write
You can read more about Miro's app manifest on the developer documentation.
-
Go back to your app home page, and under the
Permissions
section, you will see a blue button that saysInstall app and get OAuth token
. Click that button. Then click onAdd
as shown in the video below. In the video we install a different app, but the process is the same regardless of the app.
⚠️ We recommend to install your app on a developer team while you are developing or testing apps.⚠️
install-app.mov
- Go to your developer team, and open your boards.
- Click on the plus icon from the bottom section of your left sidebar. If you hover over it, it will say
More apps
. - Search for your app
Asset Search
or whatever you chose to name it. Click on your app to use it, as shown in the video below.
search-for-app.mov
.
├── src
│ └── components
│ └── Input.tsx <-- Styled input used to search through assets.
│ └── styles
│ └── style.css <-- CSS styles for the app.
│ └── App.tsx <-- The main app. Contains structure for the sidebar when launched. This file also contains logic for fetching images from [The Noun Project](https://thenounproject.com/).
│ main.tsx <-- Initializes app, and contains logic for dropping image onto the board.
├── app.html <-- The app itself. This is loaded on the board inside the 'appContainer'.
└── index.html <-- The app entry point. This is the value you assign to 'sdkUri' in the app manifest file.
If you want to contribute to this example, or any other Miro Open Source project, please review Miro's contributing guide.