How to Import Stripe Data into Notion and Build Custom Dashboards
Stripe is one of the most powerful payment processing platforms, used by businesses of all sizes to handle transactions, manage subscriptions, and track revenue. It provides detailed financial data, but often, businesses need a more customized and centralized way to track their key metrics.
Many business owners and teams already use Notion to organize their projects, documents, and databases. But what if you could bring Stripe data directly into Notion to create dynamic dashboards and real-time financial tracking?
With Note API Connector, you can automatically import Stripe invoices, subscriptions, and payments into Notion—without manual data entry.
In this tutorial we will cover:
- Track Monthly Recurring Revenue (MRR) in a customizable Notion database
- Analyze top-selling products with interactive charts
- Automate data syncing to keep everything up to date
This tutorial will guide you step by step through integrating Stripe with Notion, so you can visualize your business performance and make better financial decisions—all within the tool you already use daily.
Getting started with Note API Connector
You can get started in just a few clicks:
- Web App: Access the platform directly via the Note API Connector Web App.
- Chrome Extension: Install the Note API Connector Chrome Extension to use Note API Connector in Notion.
Once installed, simply authenticate your Notion account, grant the necessary permissions, and start creating API requests effortlessly.
👉 Follow the official setup guide for step-by-step instructions.
Generate a Stripe API Key for Secure Access
To connect Stripe with Notion, we need to retrieve financial data securely using Stripe’s API. Stripe provides API keys that allow external tools—like Note API Connector—to access your Stripe account and pull relevant data into Notion.
Open your Stripe dashboard. Scroll down and click Developers → API keys.
data:image/s3,"s3://crabby-images/9ff45/9ff4552268173b1901377a45307f17c7a468f946" alt="Stripe API Keys Stripe API Keys"
You will see a list of existing keys. Let’s create a restricted key that only has read access to the Stripe data we need.
data:image/s3,"s3://crabby-images/eebd9/eebd9557690fefaf1ccc259e47400f239a30b23c" alt="Stripe create API Keys Stripe create API Keys"
On the next screen, choose Building your own integration.
data:image/s3,"s3://crabby-images/8ee55/8ee55aed11db47436bade94c7c8489e8994cd658" alt="Stripe building integration Stripe building integration"
Choose a clear name like Note API Connector.
data:image/s3,"s3://crabby-images/e0a73/e0a730d1dfb27b6f6998953dbade84d2656fbea8" alt="Stripe create API key name Stripe create API key name"
Now, you can choose which data the integration should have access to. For this tutorial, we only need read access, so I’m selecting Invoices. Feel free to select the data you need—you can always adjust these settings later.
data:image/s3,"s3://crabby-images/ce1b0/ce1b0c2561a28b1faaf39c5ff89aec0dad88fd72" alt="Stripe restricted access Stripe restricted access"
After selecting your permissions, scroll down and click Create Key. Your new key will be generated—be sure to copy it.
data:image/s3,"s3://crabby-images/ad1d6/ad1d6bfa4154a1e7ad64c8b39c909bf6193e48c8" alt="Stripe new key Stripe new key"
With your API key ready, we can now move on to pulling Stripe data into Notion using Note API Connector.
Import Stripe Data into Notion
Now we are ready to pull data into Notion. You can take a look at Stripe API documentation. In this tutorial we will work with /invoice api.
data:image/s3,"s3://crabby-images/5e95b/5e95b3ed901a804cb4f0b725fd841d3ab56dba76" alt="Stripe API Invoices Stripe API Invoices"
Tracking Monthly Recurring Revenue (MRR) in Notion
To track MRR, we have two main approaches:
- Project future revenue by pulling active subscriptions from Stripe.
- Track actual revenue received by importing paid invoices, which is more reliable for cash flow monitoring.
For this tutorial, we'll focus on actual revenue by using the Stripe Invoices API (/v1/invoices
with status=paid
).
The Invoices API returns a maximum of 10 invoices per request by default. To retrieve more data, increase the limit
parameter to the maximum allowed value of 100. Additionally, add status=paid
to filter and import only successfully paid invoices, ensuring accurate MRR tracking.
data:image/s3,"s3://crabby-images/b7f4f/b7f4feef41c8ac5d0db170844ac0cd35e73b06b2" alt="Stripe API Limit Stripe API Limit"
Now create a new Notion database MRR Import.
data:image/s3,"s3://crabby-images/050a2/050a23fa3d32d5169d524b61c64c8210573de3bc" alt="Notion MRR Database Notion MRR Database"
Now you can create a new request in Note API Connector.
data:image/s3,"s3://crabby-images/deb25/deb251d4941ce2521f47dbe040190748dc5d1681" alt="Create new request Create new request"
First select the Notion database MRR Import.
data:image/s3,"s3://crabby-images/6ca15/6ca1571e8967b8ba6a25404428b9842f3df3d794" alt="Note API Connector select page Note API Connector select page"
Then, add the request name and paste the url https://api.stripe.com/v1/invoices?status=paid&limit=100
into the URL field.
data:image/s3,"s3://crabby-images/891c4/891c44ae18e9ca6bde665fa9615cd0feeb1c250d" alt="Note API Connector URL Note API Connector URL"
Then, paste the Bearer token into Auth field.
data:image/s3,"s3://crabby-images/02530/025308b8982a7e0f104bbfa188e3af99b84cf6c4" alt="Note API Connector Auth Note API Connector Auth"
Now you can hit Run to call api and you can see Stripe data in Response Field Mapping view. Invoice object contains a lot of fields, but we need only some of them. Let's select only id
of the invoice, amount_paid
which represents paid amount, and status_transitions.paid_at
when invoice was paid.
data:image/s3,"s3://crabby-images/428fa/428fa296db1275ad50353a90c78bd025073f12ff" alt="Notion MRR Stripe Data Notion MRR Stripe Data"
You can add customer_name
or customer_email
as existing field Name.
data:image/s3,"s3://crabby-images/7a0f0/7a0f01dcdd0094f584af9dbd956fe5ed5a9a3321" alt="Notion MRR Customer Name Notion MRR Customer Name"
Now hit Save & Import to import data into Notion database.
You can see imported data in Notion database. Field amount_paid
is in cents format and status_transitions.paid_at
is in Unix timestamp format. Let's use Notion formula to update its format. You can create new fields Amount
and Paid Date
.
data:image/s3,"s3://crabby-images/38cc1/38cc10b86ccb173d91bd9d6ca5f45c32e352b6c5" alt="Notion MRR Imported Data Notion MRR Imported Data"
Let's set Amount
property as Formula:
divide(toNumber(amount_paid.value), 100)
data:image/s3,"s3://crabby-images/7135f/7135f73f6a11b8110d976e95742e954321c87afc" alt="Notion cents to dollars formula Notion cents to dollars formula"
You can set Pay Date
as another Formula:
fromTimestamp(multiply(toNumber(status_transitions.paid_at.value), 1000))
data:image/s3,"s3://crabby-images/384f4/384f4bc27bda5c19ed5844d6e1d279eda07ea4ac" alt="Notion unix to date formula Notion unix to date formula"
Now you can see Amount in correct currency value and Pay Date in date format.
data:image/s3,"s3://crabby-images/ea30f/ea30ff14b380a2807f07e6c2b10107d08032160d" alt="Notion MRR Stripe Data Notion MRR Stripe Data"
Let's create Monthly Recurring Revenue (MRR) chart in Notion.
data:image/s3,"s3://crabby-images/66c5d/66c5dd760937974af8d72c5b7701e797c7fc98d6" alt="Notion MRR Chart Notion MRR Chart"
You can select line chart and set X axis: Pay Date -> Month
.
data:image/s3,"s3://crabby-images/06689/06689cfbaad5d21a1072e203c30f3502875ede80" alt="Notion MRR Chart X axis Notion MRR Chart X axis"
Y axis should be set as Amount -> Sum
.
data:image/s3,"s3://crabby-images/63826/63826816b96df509fa420a487e9fe1c4358b9f7a" alt="Notion MRR Chart Y axis Notion MRR Chart Y axis"
This will generate a monthly revenue graph, helping you track your business revenue.
data:image/s3,"s3://crabby-images/e3772/e377257b8f5c49b706db5e556560a5855a357457" alt="Notion MRR Final Chart Notion MRR Final Chart"
Analyze Product Sales: Identify Your Best-Selling Items
Understanding which products generate the most revenue is crucial for optimizing your sales strategy. By leveraging Stripe data in Notion, you can create a visual representation of your top-selling products, track revenue trends, and identify customer purchasing patterns.
What Stripe Data Should You Use? Depending on your business model, you’ll need different Stripe endpoints:
- Subscription-based products? → Use /v1/invoices
- One-time sales? → Use /v1/payment_intents
- Stripe Checkout purchases? → Use /v1/checkout/sessions
For this example, let's assume a subscription-based product and work with the /invoices
API.
Create a new Notion database called Top Products.
data:image/s3,"s3://crabby-images/3aedf/3aedfe3f39ed4d133df730781b00308ba8814af2" alt="Notion Top Products Dashboard Notion Top Products Dashboard"
You can use the same API request as before /v1/invoices?status=paid&limit=100
, but now we want to import it into new database Top Products.
We need to get all the individual items (products/services) that are billed in the invoice. Unlike invoice totals, product details are stored in a nested field lines
inside the Stripe API response. You can see it as [object Object]
in the Response Field Mapping view.
data:image/s3,"s3://crabby-images/132b1/132b12db4840010fd8daf24a3997fb35430204ec" alt="Stripe lines data Stripe lines data"
We need to select nested data. You can check the lines
data in API Response in Advanced Settings.
data:image/s3,"s3://crabby-images/0dd25/0dd25d5da37d7bffe9b08725ffc33ef7241b5adf" alt="Note API Connector Advanced Settings Note API Connector Advanced Settings"
In Advanced Settings, apply a JMESPath transformation to extract only the product-level data:
[].lines.data[]
Now you can see all products items for invoices data.
data:image/s3,"s3://crabby-images/37318/37318e783acc18f0e220cd686eeb0ad97dc4864f" alt="JMES filter JMES filter"
Let's select id
, amount
, and let's map description
into Name
Notion existing field. You can select quantity
and currency
.
data:image/s3,"s3://crabby-images/b5632/b5632e7ee8d9111498d9e8bf6de1d9fc1b78fc5f" alt="Top products description Top products description"
Now you can see imported data in Top Products Notion database.
data:image/s3,"s3://crabby-images/9dd9d/9dd9d81cd6baf31fef8821d668a0a18e3ed5a8b0" alt="Top products imported data Top products imported data"
We should create a new field Amount
that converts cents into dollars.
data:image/s3,"s3://crabby-images/3d1fb/3d1fbf763cf3e458e6c937fe433723fd8fe22625" alt="Top products formula Top products formula"
data:image/s3,"s3://crabby-images/f6455/f6455c32f6ba91a921525d482aa6f94ae34e6239" alt="Top products converted amount Top products converted amount"
Let's create a Donut Chart to analyze revenue distribution.
- X-Axis: Set as product
Name
. - Y-Axis: Set as sum of
Amount
.
data:image/s3,"s3://crabby-images/65793/65793e867af7fe90aef9d719910d66dd16c4c191" alt="Notion top products chart Notion top products chart"
This will generate an interactive visual of your best-performing products, helping you identify trends and optimize sales.
Automate Data Updates in Notion
Keeping your Stripe data in Notion up to date manually can be time-consuming, but with Note API Connector’s scheduling feature, you can automate the process. By setting up a recurring data sync, your invoices, payments, and product sales will automatically refresh at your preferred interval—whether hourly, daily, or weekly. This ensures that your Notion dashboards always display real-time financial insights without requiring manual imports.
Conclusion
By integrating Stripe with Notion using Note API Connector, you can transform raw transaction data into actionable insights. Whether you're tracking Monthly Recurring Revenue (MRR), identifying top-selling products, or visualizing revenue trends, this setup enables a custom financial dashboard without manual data entry.
Now that you have a dynamic Stripe dashboard in Notion, what other insights would you like to track? Drop a comment below or explore more ways to automate your workflow with Note API Connector