npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@iflow-mcp/olgasafonova-tilbudstrolden-mcp

v0.4.0

Published

MCP server for Nordic grocery deal hunting (Denmark, Norway, Sweden). Search offers, score recipes against current deals, and generate optimized shopping lists.

Readme

TilbudsTrolden

CI TypeScript License: MIT MCP

The deal troll that lives under the bridge between your fridge and your wallet.

An MCP server for Nordic grocery shopping. It finds the best deals across supermarkets in Denmark, Norway, and Sweden, plans your weekly dinners around what's cheap, and builds shopping lists grouped by store. You talk to your AI assistant about dinner; the troll does the legwork.

Works with any MCP-compatible client: Claude Desktop, Claude Code, VS Code, Cursor, Windsurf, ChatGPT, and others.

Features

Deal search

Search current deals across grocery chains in Denmark, Norway, and Sweden. Compare unit prices (kr/kg) side by side. Check what's on offer at a specific store, or get a combined view from all your preferred stores at once.

Recipe library

Ships with 32 starter recipes (Danish households) spanning Danish, Italian, Asian, Mexican, and Swedish cuisines. Deals are matched to ingredients automatically. Add your own recipes in your local language, remove ones you don't like, or tweak the defaults. Norwegian and Swedish households start with a clean slate for adding recipes with local search terms.

Meal planning

Plan your week's dinners. The planner checks current deals, picks the cheapest combination of recipes, and makes sure you're not eating chicken four nights in a row. You set the rules: no pork, slow-cook only on weekends, at least 3 Asian dishes this week. It handles the rest.

Shopping lists

Get a shopping list from any set of recipes. Shared ingredients are added up across recipes (8 carrots, not "2 for this + 3 for that + 3 for the other"). Pantry items are excluded. Current deals are matched per ingredient and grouped by store.

Household config

Tell the assistant which country you're in (DK, NO, or SE), how many people you're cooking for, which stores you prefer, and any dietary restrictions. Everything else follows from that: deals from your stores rank higher, pork disappears if you said no pork, and shopping lists scale to your household. Country defaults to Denmark if not set.

Pantry tracking

Tell the assistant what you already have at home. Those items get skipped in shopping lists, so you don't come home with a third bottle of soy sauce.

Meal and spend logging

Record what you cooked and what you spent. The planner keeps track so you don't end up eating lasagne every Tuesday.

Supported stores

Denmark: Netto, Meny, Lidl, REMA 1000, Foetex, Bilka, Spar, Kvickly, 365discount

Norway: REMA 1000, KIWI, Meny, Coop Prix, Extra, Bunnpris, Obs, Spar, Joker

Sweden: ICA (Maxi/Kvantum/Supermarket/Nara), Willys, Hemkop, City Gross, Coop, Stora Coop, Tempo

All deal data is fetched via the etilbudsavis.dk (Tjek) API, which serves flyer data for all three countries. Coverage varies; Denmark has the deepest data, followed by Sweden and Norway.

Quick start

Install

git clone https://github.com/olgasafonova/tilbudstrolden-mcp.git
cd tilbudstrolden-mcp
npm install
npm run build

Connect to your MCP client

Pick your client below. All use stdio transport; no API keys or auth required.

Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):

{
  "mcpServers": {
    "tilbudstrolden": {
      "command": "node",
      "args": ["/absolute/path/to/tilbudstrolden-mcp/dist/server.js"]
    }
  }
}

Restart Claude Desktop after saving.

claude mcp add tilbudstrolden node /absolute/path/to/tilbudstrolden-mcp/dist/server.js

Add to your workspace .vscode/mcp.json:

{
  "servers": {
    "tilbudstrolden": {
      "command": "node",
      "args": ["/absolute/path/to/tilbudstrolden-mcp/dist/server.js"]
    }
  }
}

Add to ~/.cursor/mcp.json:

{
  "mcpServers": {
    "tilbudstrolden": {
      "command": "node",
      "args": ["/absolute/path/to/tilbudstrolden-mcp/dist/server.js"]
    }
  }
}

Add to ~/.codeium/windsurf/mcp_config.json:

{
  "mcpServers": {
    "tilbudstrolden": {
      "command": "node",
      "args": ["/absolute/path/to/tilbudstrolden-mcp/dist/server.js"]
    }
  }
}

In Settings > MCP Servers, click "Add Server" and enter:

  • Name: tilbudstrolden
  • Command: node
  • Arguments: /absolute/path/to/tilbudstrolden-mcp/dist/server.js

TilbudsTrolden uses stdio transport. Point your client at:

command: node
args: ["/absolute/path/to/tilbudstrolden-mcp/dist/server.js"]

Optional environment variable:

TILBUDSTROLDEN_DATA=/custom/path/to/data.json

Tools

Deals

| Tool | What it does | |------|-------------| | search_deals | Search current offers across stores by keyword (DK/NO/SE) | | get_store_offers | List this week's offers from a specific store | | deals_this_week | Show the best deals from your preferred stores, with expiring items and biggest savings | | list_stores | List available grocery chains with dealer IDs |

Household and pantry

| Tool | What it does | |------|-------------| | get_household | View current household config | | update_household | Set country (DK/NO/SE), household members, dietary restrictions, preferred stores, servings | | get_pantry | View pantry contents | | update_pantry | Add or remove pantry items (excluded from shopping lists) |

Recipes

| Tool | What it does | |------|-------------| | get_recipes | List all saved recipes | | add_recipe | Save a new recipe with ingredients, search terms (in your language), complexity, cuisine, and protein type | | remove_recipe | Delete a recipe by name |

Planning

| Tool | What it does | |------|-------------| | score_recipes | Score all recipes against current deals, ranked by deal coverage | | plan_and_shop | Score, plan a week, and generate a shopping list in one step | | generate_shopping_list | Build a shopping list from specific recipes, with deals matched per ingredient |

Tracking

| Tool | What it does | |------|-------------| | log_meal | Record what you cooked and when | | get_meal_history | View past meals | | log_spend | Record grocery spending | | get_spend_log | View spending history |

Starter recipes

TilbudsTrolden ships with 32 recipes that work out of the box. They're loaded on first use and fully editable; add your own or remove any you don't need.

Danish (13): Frikadeller, Brændende Kærlighed, Kylling i Karry, Laks i fad, Flæskesteg, Tomatsuppe, Hakkebøffer med bløde løg, Kartoffelsuppe, Fiskefilet med remoulade, Biksemad, Koteletter i fad, Bagt kylling med ovnkartofler, Pølsegryde

Italian (6): Spaghetti Bolognese, Lasagne, Spaghetti Carbonara, Tomatrisotto, Salsiccia Pasta, Marry Me Chicken

Asian (7): Wok med kylling, Nudelsuppe med kylling, Uncle Roger's Egg Fried Rice, Nasi Goreng, Chow Mein, Uncle Roger's Adobo, Maangchi's Bulgogi

Mexican (2): Chili con Carne, Tacos med kylling

Swedish (4): Kajsas Kycklingfile med senap och rosepeber, Grillet laks med tomatsmor, Sagas Krydderisauce, Fransk grillet kylling med dragonsauce

Complexity ranges from quick (15-20 min) through medium (30-45 min) to slow (1+ hour). Proteins cover chicken, beef, pork, fish, egg, and vegetarian.

Example conversations

Real examples of how you'd talk to your AI assistant with TilbudsTrolden running.

Set up your household

You: We're 3 people, no pork, and we shop at Netto, REMA 1000, and Meny.

The assistant saves your setup. From now on, deals from Netto, REMA, and Meny get priority, and pork recipes are excluded from meal plans.

Check deals

You: What's on sale at my stores this week?

You get a summary per store: expiring deals that need action, biggest savings, and highlights.

You: Find me the cheapest hakket oksekoed.

Found 6 deals for "hakket oksekød":
1. Hakket okse- eller grisekød - 99 DKK (76.15 kr/kg) @ Bilka
2. Hakket oksekød 8-12% - 36.66 DKK (91.65 kr/kg) @ Fleggaard
3. Velsmag hakket oksekød 7-10% - 45 DKK (112.50 kr/kg) @ Netto
...

Plan a full week

You: Plan next week's dinners. No pork except Tuesday, mix of Asian and other.

You get a 7-day plan with no consecutive protein or cuisine repeats, plus a shopping list for the whole week.

7-day meal plan (3 people)

Mon: Tomatrisotto (Italian, vegetarian)
Tue: Chow Mein (Asian, pork)
Wed: Laks i fad (Danish, fish)
Thu: Maangchi's Bulgogi (Asian, beef)
Fri: Fiskefilet med remoulade (Danish, fish)
Sat: Lasagne (Italian, beef)
Sun: Nudelsuppe med kylling (Asian, chicken)

Shopping list (58 items)
Buy at Netto: hakket oksekød 45 DKK, kyllingebrystfilet 49 DKK, ...
Buy at REMA: oksemørbrad 129.95 DKK, remoulade 10 DKK, ...
Buy at regular price: mozzarella, parmesan, kokosmælk, ...

Add your own recipe

You: Save a recipe for chicken tikka masala: 500g kyllingebryst, 200g yoghurt, tikka masala paste, hakkede tomater, piskefloede, ris. Medium, Indian, chicken.

The recipe is saved. It shows up in meal plans and deal matching from now on.

Shopping list for specific meals

You: Make a shopping list for bolognese and tacos, 4 people.

Shared ingredients (like onions used in both) are aggregated. Pantry items are excluded.

Track pantry

You: We have rice, soy sauce, and sesame oil at home.

These items get skipped in future shopping lists.

Log what you cooked

You: We made the bulgogi tonight, spent 185 kr at REMA.

No bulgogi for a while.

How deal matching works

Nordic grocery deals bundle products in creative ways ("Rejer, kold- eller varmroget laks"). TilbudsTrolden tells raw ingredients apart from processed products using language-specific food terminology for Danish, Norwegian, and Swedish. Searching for "laks" as a cooking ingredient won't match roget/rokt/rokt laks or palaeg/palegg/palagg. Your preferred stores get priority in results.

The scoring engine uses locale-specific indicators for each country: processed meat terms (roget/rokt/rokt), raw meat terms (fersk/fersk/farsk), non-food filters, and dietary exclusion patterns. All three languages have full coverage for pork, beef, lamb, fish, shellfish, dairy, gluten, beans, nuts, and egg exclusions.

The meal planner won't repeat the same protein or cuisine more than twice in a week, and you can restrict slow-cook recipes to specific days.

Data storage

All data lives in a single JSON file: ~/.tilbudstrolden.json. Override the path with the TILBUDSTROLDEN_DATA environment variable.

Everything lives there: household config, recipes, pantry, meal history, and spend log. Created automatically on first use. No database, no cloud service, no account required.

Development

npm install          # install dependencies
npm run dev          # watch mode with tsx
npm run build        # compile TypeScript
npm run lint         # run Biome linter
npm run typecheck    # strict TypeScript check
npm test             # run tests (Vitest)

Requirements

  • Node.js 18 or later
  • No API keys needed. Deal data is fetched via the etilbudsavis.dk (Tjek) public API, which serves all three Nordic markets.

Credits

Deal data fetched via the etilbudsavis.dk (Tjek) API.

Starter recipe ingredient lists adapted from valdemarsro.dk. Uncle Roger recipes from Nigel Ng's YouTube (Egg Fried Rice, Adobo). Bulgogi recipe from Maangchi. Swedish family recipes from jarfors.com by Mikael Jarfors.

More MCP Servers

Check out my other MCP servers:

| Server | Description | Stars | |--------|-------------|-------| | gleif-mcp-server | Access GLEIF LEI database. Look up company identities, verify legal entities. | GitHub stars | | mediawiki-mcp-server | Connect AI to any MediaWiki wiki. Search, read, edit wiki content. | GitHub stars | | miro-mcp-server | Control Miro whiteboards with AI. Boards, diagrams, mindmaps, and more. | GitHub stars | | nordic-registry-mcp-server | Access Nordic business registries. Look up companies across Norway, Denmark, Sweden. | GitHub stars | | productplan-mcp-server | Talk to your ProductPlan roadmaps. Query OKRs, ideas, launches. | GitHub stars | | mcp-servercard-go | Go library for SEP-2127 Server Cards. Pre-connect discovery for MCP servers. | GitHub stars |

License

MIT