Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add README files for enterprise team management and digital asset man… #181

Merged
merged 1 commit into from
Sep 1, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
104 changes: 104 additions & 0 deletions examples/digital-asset-manager/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,104 @@
# Miro Digital Asset Manager

This app shows how to implement a digital asset manager (DAM). Make the images, logos, and other assets you need available directly in a Miro board.

# 👨🏻‍💻 App Demo
https://github.com/miroapp/app-examples/assets/10800544/5eb60feb-1378-4691-a9dd-46a70003f81c







# 📒 Table of Contents
* [Included Features](#features)
* [Tools and Technologies](#tools)
* [Prerequisites](#prerequisites)
* [Associated Developer Tutorial](#tutorial)
* [Run the app locally](#run)
* [Folder Structure](#folder)
* [License](#license)

# ⚙️ Included Features <a name="features"></a>
* [Miro Web SDK](https://developers.miro.com/docs/web-sdk-reference)
* [drop event](https://developers.miro.com/docs/ui_boardui#drop-event)
* [openPanel(options)](https://developers.miro.com/docs/ui_boardui#openpanel)
* [draggable elements](https://developers.miro.com/docs/add-drag-and-drop-to-your-app#add-draggable-elements-to-the-app-panel)
* [Search and filter](https://developers.miro.com/docs/adding-search-and-filter-to-an-sdk-app)
* [Mirotone.xyz](https://www.mirotone.xyz/)



# 🛠️ Tools and Technologies <a name="tools"></a>
* [React](https://react.dev/)
* [TypeScript](https://www.typescriptlang.org/)
* [Vite](https://vitejs.dev/)
* [React Router](https://reactrouter.com/en/main)
* [Bynder API](https://developer-docs.bynder.com/api)
* [Netlify](https://www.netlify.com/)
* [Netlify Functions](https://docs.netlify.com/functions/overview/)

# ✅ Prerequisites <a name="prerequisites"></a>
* You have a [Miro account](https://miro.com/signup/).
* You're [signed in to Miro](https://miro.com/login/).
* Your Miro account has a [Developer team](https://developers.miro.com/docs/create-a-developer-team).
* Your development environment includes [Node.js 14.13](https://nodejs.org/en/download) or a later version.
* You have a Digital Asset Manager (such as [Bynder](https://www.bynder.com/)) and a [Netlify](https://www.netlify.com/) account.
* All examples use `npm` as a package manager and `npx` as a package runner.

# 📖 Associated Developer Tutorials <a name="tutorial"></a>
> To view a more in depth developer tutorial
of this app (including code explanations) see the [digital asset manager tutorial](https://developers.miro.com/docs/integrate-a-digital-asset-manager-in-miro) and [search and filter tutorial](https://developers.miro.com/docs/adding-search-and-filter-to-an-sdk-app) on Miro's Developer documentation.

# 🏃🏽‍♂️ Run the app locally <a name="run"></a>

1. Run `npm install` to install dependencies.
2. Run `npm start` to start developing. \
Your URL should be similar to this example:
```
http://localhost:3000
```
3. Open the [app manifest editor](https://developers.miro.com/docs/manually-create-an-app#step-2-configure-your-app-in-miro) by clicking **Edit in Manifest**. \
In the app manifest editor, configure the app as follows:
- [`sdkUri`](https://developers.miro.com/docs/app-manifest#sdkuri): assign `http://localhost:3000` as a value for this property. \
It defines the entry point of the app, and it corresponds to the URL of the server that the app runs on.
- [`scopes`](https://developers.miro.com/docs/app-manifest#scopes): add the permission scopes that users need to grant the app when they install it. \
To enable the app to read from and write to the board, add the following permissions:
- `boards:read`
- `boards:write`

4. Go back to your app home page, and under the `Permissions` section, you will see a blue button that says `Install app and get OAuth token`. Click that button. Then click on `Add` as shown in the video below.

> ⚠️ We recommend to install your app on a [developer team](https://developers.miro.com/docs/create-a-developer-team) while you are developing or testing apps.⚠️

https://github.com/horeaporutiu/app-examples-template/assets/10428517/456108e8-7d9b-4067-94bb-e5511c736a23

5. Go to your developer team, and open your boards.
6. Click on the plus icon from the bottom section of your left sidebar. If you hover over it, it will say `More apps`.
7. Search for your app `Digital Asset Manager` or whatever you chose to name it. Click on your app to use it, as shown in the video below.

https://github.com/horeaporutiu/app-examples-template/assets/10428517/b23d9c4c-e785-43f9-a72e-fa5d82c7b019

# 🗂️ Folder structure <a name="folder"></a>

```
.
├── netlify/functions <-- contains netlify functions
├── src
│ └── assets
│ └── components
│ └── panel
│ └── utils
│ └── styles
├── netlify.toml
├── tscongif.json
├── viteconfig.json
└── index.html <-- The app entry point. This is the value you assign to 'sdkUri' in the app manifest file.
```

# 🫱🏻‍🫲🏽 Contributing <a name="contributing"></a>
If you want to contribute to this example, or any other Miro Open Source project, please review [Miro's contributing guide](https://github.com/miroapp/app-examples/blob/main/CONTRIBUTING.md).

# 🪪 License <a name="license"></a>
[MIT License](https://github.com/miroapp/app-examples/blob/main/LICENSE).
81 changes: 81 additions & 0 deletions examples/enterprise-team-management/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
# Miro Enterprise Team Management
Manage teams and organizations within Miro using Miro's REST API. This app uses Node.js.

ℹ️ This example requires an Enterprise plan subscription and an Enterprise Team account.

# 👨🏻‍💻 App Demo
https://github.com/miroapp/app-examples/assets/10800544/6096bd94-b0a2-46bf-a01f-ba9d6a64adc6


# 📒 Table of Contents
* [Included Features](#features)
* [Tools and Technologies](#tools)
* [Prerequisites](#prerequisites)
* [Run the app locally](#run)
* [Folder Structure](#folder)
* [License](#license)

# ⚙️ Included Features <a name="features"></a>
* [Miro REST API](https://developers.miro.com/reference/api-reference)
* [Miro Enterprise REST APIs](https://developers.miro.com/reference/enterprise-create-team)


# 🛠️ Tools and Technologies <a name="tools"></a>
* [NodeJS](https://nodejs.org/)

# ✅ Prerequisites <a name="prerequisites"></a>
* You have a [Miro account](https://miro.com/signup/).
* Your account has an [Enterprise plan](https://help.miro.com/hc/en-us/articles/360017730433-Enterprise-Plan).
* You're [signed in to Miro](https://miro.com/login/).
* Your Miro account has an [Enterprise Developer team](https://help.miro.com/hc/en-us/articles/4766759572114-Enterprise-Developer-teams).
* Your development environment includes [Node.js 14.13](https://nodejs.org/en/download) or a later version.


# 🏃🏽‍♂️ Run the app locally <a name="run"></a>

1. Open the project and create a `.env` file in the root directory
2. Inside the `.env` file, specify variable `ACCESS_TOKEN` and pass the value of the token generated in **Step 5**.
> ⚠️ You will need to install your app under an Enterprise team in order to access Miro's Enterprise APIs.⚠️
```
ACCESS_TOKEN="{YOUR_ACCESS_TOKEN}"
```
3. Run `npm install` to install dependencies.
4. Open the [app manifest editor](https://developers.miro.com/docs/manually-create-an-app#step-2-configure-your-app-in-miro) by clicking **Edit in Manifest**. \
In the app manifest editor, configure the app as follows:
- [`redirectUris`](https://developers.miro.com/docs/app-manifest#redirectUris): assign `http://localhost:3000` as a value for this property. \
It defines the redirect url that the script will use for OAuth2.0.
- [`scopes`](https://developers.miro.com/docs/app-manifest#scopes): add the permission scopes that the script will need in order to call each of the included API endpoints. \
Add the following permissions:
- `boards:read`
- `boards:write`
- `organizations:read`
- `organizations:teams:write`
- `organizations:teams:read`
- `team:read`
- `team:write`

5. Go back to your app home page, and under the `Permissions` section, you will see a blue button that says `Install app and get OAuth token`. Click that button. Then click on `Add` as shown in the video below. This will generate an access_token.

> ⚠️ We recommend to install your app on an [Enterprise Developer Team](https://help.miro.com/hc/en-us/articles/4766759572114-Enterprise-Developer-teams) while you are developing or testing apps for use with Enterprise endpoints.⚠️

https://github.com/horeaporutiu/app-examples-template/assets/10428517/456108e8-7d9b-4067-94bb-e5511c736a23

6. Paste the value of the access_token in the variable `ACCESS_TOKEN`, in the `.env` file created in **Step 2.**
7. Open the script in your code editor
8. Open your terminal and run `node index.js`
>Your script will run using the access_token provided by your Enterprise installation in Step 5 and the terminal will output the team management details fulfilled by Miro's REST APIs.


# 🗂️ Folder structure <a name="folder"></a>

```
.
├── index.js <-- NodeJS script
├── .env <-- create this when you open the script
```

# 🫱🏻‍🫲🏽 Contributing <a name="contributing"></a>
If you want to contribute to this example, or any other Miro Open Source project, please review [Miro's contributing guide](https://github.com/miroapp/app-examples/blob/main/CONTRIBUTING.md).

# 🪪 License <a name="license"></a>
[MIT License](https://github.com/miroapp/app-examples/blob/main/LICENSE).