{
  "workflow": {
    "id": 9464,
    "name": "Sync KPI metrics from ClickUp and Google Sheets to Slack and Gmail",
    "views": 275,
    "recentViews": 0,
    "totalViews": 275,
    "createdAt": "2025-10-10T11:20:38.796Z",
    "description": "## Description\nAutomate daily KPI tracking and reporting by integrating ClickUp tasks and Google Sheets lead data into a unified dashboard. This workflow computes performance metrics, analyzes sentiment, and delivers visualized reports to Slack and Gmail for instant team insights. 📊💬📧\n\n## What This Template Does\n- Triggers automatically every day using a cron scheduler. ⏰\n- Fetches project task data from ClickUp, including status, priority, and assignee metrics.\n- Retrieves lead generation data and responses from Google Sheets.\n- Merges both data sources to create a unified performance dataset.\n- Computes detailed KPI metrics (task completion, overdue %, sentiment analysis, response trends).\n- Formats data for reporting and visualization.\n- Posts a concise KPI summary snapshot to a designated Slack channel.\n- Sends a professionally formatted HTML report via Gmail.\n- Notifies your Slack channel instantly in case of any workflow errors.\n\n## Key Benefits\n✅ Eliminates manual KPI tracking and reporting.\n ✅ Combines ClickUp and Google Sheets data into one view.\n ✅ Provides real-time insights for decision-making.\n ✅ Automates daily updates for consistent visibility.\n ✅ Delivers both quick Slack summaries and detailed email reports.\n ✅ Built-in error alerting ensures uninterrupted automation.\n\n## Features\n- Scheduled daily cron trigger for automated execution.\n- OAuth2-secured integrations with ClickUp, Google Sheets, Slack, and Gmail.\n- Parallel data fetching for faster performance.\n- Smart KPI calculations with sentiment and trend analysis.\n- Custom HTML email template with visual charts and highlights.\n- Slack snapshot notifications for instant updates.\n- Error-handling mechanism with Slack alerts.\n\n## Requirements\n- ClickUp account with OAuth2 credentials.\n- Google Sheets access with OAuth2 credentials.\n- Slack API credentials with chat:write permission.\n- Gmail OAuth2 credentials for report delivery.\n\n## Target Audience\n- Project managers tracking performance KPIs.\n- Operations teams needing daily performance visibility.\n- Marketing and sales teams monitoring task and lead metrics.\n- Automation and analytics engineers building executive dashboards.\n\n## Step-by-Step Setup Instructions\n- Connect your ClickUp, Google Sheets, Slack, and Gmail accounts. 🔑\n- Replace placeholder IDs (Sheet ID, Channel ID, Email) with your actual values.\n- Adjust the cron trigger time as per your timezone.\n- Test with sample data to confirm correct KPI calculations.\n- Enable workflow to start daily automated execution. 🚀\n",
    "workflow": {
      "id": "H39e9rSjzJIcbpt4",
      "meta": {
        "instanceId": "8443f10082278c46aa5cf3acf8ff0f70061a2c58bce76efac814b16290845177",
        "templateCredsSetupCompleted": true
      },
      "name": "Sync KPI Metrics from ClickUp and Google Sheets to Slack and Gmail",
      "tags": [],
      "nodes": [
        {
          "id": "7cad3d2c-f079-481d-bfe3-cdc1f7c68e2f",
          "name": "Workflow Overview",
          "type": "n8n-nodes-base.stickyNote",
          "position": [
            -3360,
            -896
          ],
          "parameters": {
            "color": 4,
            "width": 360,
            "height": 672,
            "content": "## 📊 Sync KPI Metrics from ClickUp and Google Sheets to Slack and Gmail\n\n### Workflow Overview\nThis workflow automatically generates and distributes a comprehensive KPI dashboard report combining:\n- **ClickUp Tasks**: Fetch task metrics\n- **Google Sheets Leads**: Retrieve lead generation data and responses\n- **Analytics Engine**: Process and compute KPI trends\n- **Multi-Channel Distribution**: Send reports via Slack and Gmail\n\n### Key Features\n✅ Automated daily execution via cron schedule\n✅ Real-time task and lead analytics\n✅ Slack dashboard snapshots\n✅ Error handling and alerting\n\n### Setup Requirements\n1. ClickUp OAuth2 credentials\n2. Google Sheets OAuth2 credentials\n3. Slack API credentials\n4. Gmail OAuth2 credentials\n\n### Execution Flow\n1. Trigger daily at scheduled time\n2. Fetch data from ClickUp and Google Sheets in parallel\n3. Merge datasets\n4. Compute KPI metrics and trends\n5. Format and send reports to Slack and Email\n6. Handle errors with Slack notifications\n"
          },
          "typeVersion": 1
        },
        {
          "id": "aa0e932d-ad35-435e-9305-d806dcc81a28",
          "name": "Cron Trigger Note",
          "type": "n8n-nodes-base.stickyNote",
          "position": [
            -2896,
            -896
          ],
          "parameters": {
            "height": 200,
            "content": "## ⏰ Daily Trigger\n\nSchedules workflow execution\nat a specific time each day.\n\nConfigure your preferred time\nand timezone in node settings."
          },
          "typeVersion": 1
        },
        {
          "id": "67817fbe-5283-4be8-b0f6-22e452afefc2",
          "name": "ClickUp Tasks Note",
          "type": "n8n-nodes-base.stickyNote",
          "position": [
            -2560,
            -1072
          ],
          "parameters": {
            "height": 280,
            "content": "## 🔗 Fetch ClickUp Tasks\n\nRetrieves task data:\n- Status & priority\n- Assignees\n- Time tracking\n- Due dates\n\nUses OAuth2 authentication"
          },
          "typeVersion": 1
        },
        {
          "id": "b38f8201-079c-4bd9-8b2a-41a1f7b5b8ea",
          "name": "Google Sheets Note",
          "type": "n8n-nodes-base.stickyNote",
          "position": [
            -2608,
            -384
          ],
          "parameters": {
            "height": 248,
            "content": "## 📑 Fetch Lead Data\n\nRetrieves lead information\nfrom Google Sheets:\n- Contact details\n- Reply content\n- Source tracking\n- Status updates"
          },
          "typeVersion": 1
        },
        {
          "id": "6f599e7f-063d-45cb-9e92-17f7c7c86f33",
          "name": "Merge Data Note",
          "type": "n8n-nodes-base.stickyNote",
          "position": [
            -2224,
            -896
          ],
          "parameters": {
            "height": 192,
            "content": "## 🔀 Merge Data\n\nCombines ClickUp tasks and\nGoogle Sheets leads into\na single dataset for analysis."
          },
          "typeVersion": 1
        },
        {
          "id": "4f4b18ab-89c0-4ab6-8d0b-35583341f914",
          "name": "KPI Computation Note",
          "type": "n8n-nodes-base.stickyNote",
          "position": [
            -2064,
            -480
          ],
          "parameters": {
            "width": 260,
            "height": 304,
            "content": "## 🧮 KPI Analytics\n\n**Calculates metrics:**\n- Task completion rates\n- Overdue tasks\n- Lead sentiment analysis\n- Source performance\n- Trend indicators\n\nCustomize the JavaScript\ncode to add your own KPIs."
          },
          "typeVersion": 1
        },
        {
          "id": "07cbcf4f-3de8-40cb-9b96-3fdeb452474d",
          "name": "Data Formatter Note",
          "type": "n8n-nodes-base.stickyNote",
          "position": [
            -1856,
            -880
          ],
          "parameters": {
            "height": 180,
            "content": "## 📤 Format Data\n\nStructures KPI metrics for\nSlack and Gmail outputs.\n\nExtracts key values and\nprepares template variables."
          },
          "typeVersion": 1
        },
        {
          "id": "738d9580-b855-43fd-8be1-986759fae45e",
          "name": "Slack Dashboard Note",
          "type": "n8n-nodes-base.stickyNote",
          "position": [
            -1408,
            -928
          ],
          "parameters": {
            "height": 180,
            "content": "## 💬 Slack Summary\n\nPosts quick KPI snapshot\nto your Slack channel.\n\nUpdate channel ID in\nnode configuration."
          },
          "typeVersion": 1
        },
        {
          "id": "9780b484-e977-44d3-b123-43f74d412cb3",
          "name": "Gmail Report Note",
          "type": "n8n-nodes-base.stickyNote",
          "position": [
            -1392,
            -496
          ],
          "parameters": {
            "height": 248,
            "content": "## 📧 Email Report\n\nSends detailed HTML report\nwith comprehensive KPI analysis,\ncharts, and insights.\n\nUpdate recipient email address\nin node settings."
          },
          "typeVersion": 1
        },
        {
          "id": "cfc0967b-c5cc-49a6-9480-01615b9b449d",
          "name": "Error Handling Note",
          "type": "n8n-nodes-base.stickyNote",
          "position": [
            -3024,
            96
          ],
          "parameters": {
            "height": 180,
            "content": "## ⚠️ Error Alerts\n\nCaptures workflow failures\nand sends alerts to Slack.\n\nConfigure alerts channel\nfor team notifications."
          },
          "typeVersion": 1
        },
        {
          "id": "a9ce4348-b49b-47b8-a723-72328fc7c928",
          "name": "Error Trigger Handler",
          "type": "n8n-nodes-base.errorTrigger",
          "position": [
            -2720,
            96
          ],
          "parameters": {},
          "typeVersion": 1
        },
        {
          "id": "172f269d-41ce-4d11-8d2d-3442315a8d2d",
          "name": "Slack - Send Error Alert",
          "type": "n8n-nodes-base.slack",
          "position": [
            -2496,
            96
          ],
          "webhookId": "1abab466-eb85-4d88-a60d-c9028cff110b",
          "parameters": {
            "text": "=⌠*KPI Dashboard Workflow Failed*\n\n*Error Details:*\n{{ $json.error?.message || 'Unknown error occurred' }}\n\n*Failed Node:* {{ $json.node?.name || 'Unknown node' }}\n*Execution ID:* {{ $execution.id }}\n*Timestamp:* {{ $now.format('YYYY-MM-DD HH:mm:ss') }}\n\n*Action Required:*\n1. Check execution logs in n8n\n2. Verify data source connections\n3. Review node configurations\n4. Restart workflow if needed\n\n_Automated alert from KPI Dashboard System_",
            "select": "channel",
            "channelId": {
              "__rl": true,
              "mode": "list",
              "value": "YOUR_ALERTS_CHANNEL_ID",
              "cachedResultName": "workflow-alerts"
            },
            "otherOptions": {}
          },
          "credentials": {
            "slackApi": {
              "id": "credential-id",
              "name": "slackApi Credential"
            }
          },
          "typeVersion": 2
        },
        {
          "id": "d7e79592-f836-4053-b917-c741784a61dd",
          "name": "Daily Cron Trigger",
          "type": "n8n-nodes-base.cron",
          "position": [
            -2672,
            -672
          ],
          "parameters": {},
          "typeVersion": 1
        },
        {
          "id": "9cad37f4-6719-439d-9652-5eeec89ad983",
          "name": "ClickUp - Fetch Tasks",
          "type": "n8n-nodes-base.clickUp",
          "position": [
            -2448,
            -768
          ],
          "parameters": {
            "list": "901611392518",
            "team": "9016683627",
            "limit": 5,
            "space": "90162844741",
            "folder": "90164394824",
            "filters": {
              "subtasks": false
            },
            "operation": "getAll",
            "returnAll": false,
            "authentication": "oAuth2"
          },
          "credentials": {
            "clickUpOAuth2Api": {
              "id": "credential-id",
              "name": "clickUpOAuth2Api Credential"
            }
          },
          "typeVersion": 1
        },
        {
          "id": "d5bb389e-dc40-45ad-bd5e-7c59d9a536c9",
          "name": "Google Sheets - Fetch Lead Data",
          "type": "n8n-nodes-base.googleSheets",
          "position": [
            -2448,
            -576
          ],
          "parameters": {
            "options": {},
            "sheetName": {
              "__rl": true,
              "mode": "list",
              "value": 1856159589,
              "cachedResultUrl": "https://docs.google.com/spreadsheets/d/17rcNd_ZpUQLm0uWEVbD-NY6GyFUkrD4BglvawlyBygM/edit#gid=1856159589",
              "cachedResultName": "KPI Data"
            },
            "documentId": {
              "__rl": true,
              "mode": "list",
              "value": "17rcNd_ZpUQLm0uWEVbD-NY6GyFUkrD4BglvawlyBygM",
              "cachedResultUrl": "https://docs.google.com/spreadsheets/d/17rcNd_ZpUQLm0uWEVbD-NY6GyFUkrD4BglvawlyBygM/edit?usp=drivesdk",
              "cachedResultName": "sample_leads_50"
            }
          },
          "credentials": {
            "googleSheetsOAuth2Api": {
              "id": "credential-id",
              "name": "googleSheetsOAuth2Api Credential"
            }
          },
          "typeVersion": 3
        },
        {
          "id": "75c5f34a-d851-4eae-bff7-7289d608a03c",
          "name": "Merge - Consolidate Datasets",
          "type": "n8n-nodes-base.merge",
          "position": [
            -2224,
            -672
          ],
          "parameters": {},
          "typeVersion": 1
        },
        {
          "id": "fa353353-2fd0-424a-a09a-639831c2dabc",
          "name": "Code - Compute KPI Trends",
          "type": "n8n-nodes-base.code",
          "position": [
            -2000,
            -672
          ],
          "parameters": {
            "jsCode": "// n8n Code Node - Compute KPI Trends\n// This code analyzes ClickUp tasks and lead data to generate KPIs\n\nconst items = $input.all();\nconst data = items.map(item => item.json);\n\n// Separate tasks and leads\nconst tasks = data.filter(item => item.id && item.id.startsWith('86d0'));\nconst leads = data.filter(item => item.leadId);\n\n// Initialize KPI object\nconst kpis = {\n  timestamp: new Date().toISOString(),\n  tasks: {},\n  leads: {},\n  overall: {}\n};\n\n// ===== TASK KPIs =====\nif (tasks.length > 0) {\n  // Status distribution\n  const statusCount = {};\n  const priorityCount = {};\n  const assigneeCount = {};\n  let totalTimeSpent = 0;\n  let tasksWithTime = 0;\n  let overdueTasks = 0;\n  const today = Date.now();\n\n  tasks.forEach(task => {\n    // Status counting\n    const status = task.status?.status || 'unknown';\n    statusCount[status] = (statusCount[status] || 0) + 1;\n\n    // Priority counting\n    const priority = task.priority?.priority || 'none';\n    priorityCount[priority] = (priorityCount[priority] || 0) + 1;\n\n    // Assignee counting\n    task.assignees?.forEach(assignee => {\n      assigneeCount[assignee.username] = (assigneeCount[assignee.username] || 0) + 1;\n    });\n\n    // Time tracking\n    if (task.time_spent) {\n      totalTimeSpent += task.time_spent;\n      tasksWithTime++;\n    }\n\n    // Overdue calculation\n    if (task.due_date && parseInt(task.due_date) < today && !task.date_done) {\n      overdueTasks++;\n    }\n  });\n\n  kpis.tasks = {\n    total: tasks.length,\n    byStatus: statusCount,\n    byPriority: priorityCount,\n    byAssignee: assigneeCount,\n    overdue: overdueTasks,\n    overduePercentage: ((overdueTasks / tasks.length) * 100).toFixed(2),\n    avgTimeSpent: tasksWithTime > 0 ? Math.round(totalTimeSpent / tasksWithTime) : 0,\n    avgTimeSpentHours: tasksWithTime > 0 ? (totalTimeSpent / tasksWithTime / 3600000).toFixed(2) : 0,\n    completion: {\n      done: statusCount['done'] || 0,\n      inProgress: statusCount['in progress'] || 0,\n      finalReview: statusCount['final review'] || 0,\n      backlogs: statusCount['backlogs'] || 0\n    }\n  };\n}\n\n// ===== LEAD KPIs =====\nif (leads.length > 0) {\n  const sourceCount = {};\n  const statusCount = {};\n  const responsesByDate = {};\n  let positiveResponses = 0;\n  let negativeResponses = 0;\n  let neutralResponses = 0;\n\n  // Keywords for sentiment analysis\n  const positiveKeywords = ['interested', 'love', 'promising', 'sounds interesting', 'count me in', 'yes', 'great'];\n  const negativeKeywords = ['not interested', 'not sure', 'concerns', 'difficult', 'already have'];\n\n  leads.forEach(lead => {\n    // Source counting\n    const source = lead.source || 'unknown';\n    sourceCount[source] = (sourceCount[source] || 0) + 1;\n\n    // Status counting\n    const status = lead.status || 'unknown';\n    statusCount[status] = (statusCount[status] || 0) + 1;\n\n    // Date grouping\n    const date = lead.replyDate || 'unknown';\n    responsesByDate[date] = (responsesByDate[date] || 0) + 1;\n\n    // Simple sentiment analysis\n    if (lead.reply) {\n      const replyLower = lead.reply.toLowerCase();\n      const hasPositive = positiveKeywords.some(kw => replyLower.includes(kw));\n      const hasNegative = negativeKeywords.some(kw => replyLower.includes(kw));\n\n      if (hasPositive && !hasNegative) {\n        positiveResponses++;\n      } else if (hasNegative && !hasPositive) {\n        negativeResponses++;\n      } else {\n        neutralResponses++;\n      }\n    }\n  });\n\n  kpis.leads = {\n    total: leads.length,\n    bySource: sourceCount,\n    byStatus: statusCount,\n    byDate: responsesByDate,\n    sentiment: {\n      positive: positiveResponses,\n      negative: negativeResponses,\n      neutral: neutralResponses,\n      positiveRate: ((positiveResponses / leads.length) * 100).toFixed(2),\n      negativeRate: ((negativeResponses / leads.length) * 100).toFixed(2)\n    },\n    topSources: Object.entries(sourceCount)\n      .sort((a, b) => b[1] - a[1])\n      .slice(0, 3)\n      .map(([source, count]) => ({ source, count }))\n  };\n}\n\n// ===== OVERALL KPIs =====\nkpis.overall = {\n  totalItems: data.length,\n  tasksCount: tasks.length,\n  leadsCount: leads.length,\n  dataQuality: {\n    tasksWithDueDate: tasks.filter(t => t.due_date).length,\n    tasksWithAssignees: tasks.filter(t => t.assignees?.length > 0).length,\n    leadsWithCompany: leads.filter(l => l.company).length,\n    leadsWithPhone: leads.filter(l => l.phone).length\n  }\n};\n\n// ===== TREND INDICATORS =====\nkpis.trends = {\n  taskTrend: tasks.length > 0 ? 'stable' : 'no data',\n  leadTrend: leads.length > 5 ? 'active' : 'low activity',\n  urgentTasks: tasks.filter(t => t.priority?.priority === 'urgent').length,\n  newReplies: leads.filter(l => l.status === 'New Reply').length\n};\n\n// Return as single item with comprehensive KPI data\nreturn [{ json: kpis }];"
          },
          "typeVersion": 1
        },
        {
          "id": "414f7e49-df31-4690-950c-d7f451fc6014",
          "name": "Set - Format Output Data",
          "type": "n8n-nodes-base.set",
          "position": [
            -1776,
            -672
          ],
          "parameters": {
            "options": {},
            "assignments": {
              "assignments": [
                {
                  "id": "dbb44ee9-0676-45ac-8c9e-e1ab1b801a6e",
                  "name": "tasks",
                  "type": "object",
                  "value": "={{ $json.tasks }}"
                },
                {
                  "id": "63779c8a-c71e-4267-9ec0-22098ecabd28",
                  "name": "tasks.overdue",
                  "type": "number",
                  "value": "={{ $json.tasks.overdue }}"
                },
                {
                  "id": "5d3f4a88-1526-4cb3-bc24-963efd1e50bf",
                  "name": "tasks.overduePercentage",
                  "type": "string",
                  "value": "={{ $json.tasks.overduePercentage }}"
                },
                {
                  "id": "709e0406-4d96-49ab-b0d1-40e35bc876f1",
                  "name": "tasks.avgTimeSpent",
                  "type": "number",
                  "value": "={{ $json.tasks.avgTimeSpent }}"
                },
                {
                  "id": "6aebe018-4dd6-4ca9-826a-8290c7b3c355",
                  "name": "tasks.avgTimeSpentHours",
                  "type": "string",
                  "value": "={{ $json.tasks.avgTimeSpentHours }}"
                },
                {
                  "id": "c5912159-c328-4403-8e50-8ae94511d307",
                  "name": "tasks.completion",
                  "type": "object",
                  "value": "={{ $json.tasks.completion }}"
                },
                {
                  "id": "0141ac77-5e6d-46f1-a8fe-8e781f33a632",
                  "name": "leads",
                  "type": "object",
                  "value": "={{ $json.leads }}"
                },
                {
                  "id": "54567372-ce0a-4aa1-b163-aed6f0b1d8db",
                  "name": "leads.topSources",
                  "type": "array",
                  "value": "={{ $json.leads.topSources }}"
                },
                {
                  "id": "6ea32021-40ad-454e-ad96-f905f8cf9967",
                  "name": "overall",
                  "type": "object",
                  "value": "={{ $json.overall }}"
                },
                {
                  "id": "f77c2c65-3b7e-43f1-9bbe-71b7e60468ea",
                  "name": "trends",
                  "type": "object",
                  "value": "={{ $json.trends }}"
                }
              ]
            }
          },
          "typeVersion": 3.4
        },
        {
          "id": "5449a5fb-aa27-4280-8e2f-dc1333b4611f",
          "name": "Slack - Post Dashboard Snapshot",
          "type": "n8n-nodes-base.slack",
          "position": [
            -1552,
            -768
          ],
          "webhookId": "d987216d-dd09-4518-aacd-01fbda90908f",
          "parameters": {
            "text": "=📊 *Daily KPI Dashboard Updated*\n\n*Task Metrics:*  \n• Total Task: {{ $json.tasks.total }}  \n• Overdue:  {{ $json.tasks.overdue }} ({{ $json.tasks.overduePercentage }}%)\n• Average Time Spent: {{ $json.tasks.avgTimeSpentHours }} hours\n\n*Lead Generation:*\n• Total: {{ $json.leads.total }} leads  \n• Positive Sentiment: {{ $json.leads.sentiment.positiveRate }}%\n• New Replies: {{ $json.trends.newReplies }}\n\n*Top Sources:*\n{{ Object.entries($json.leads.bySource).map(([source, count]) => `• ${source}: ${count}`).join('\\n') }}\n\n*Overall Status:*\n• Total Items: {{ $json.overall.totalItems }} \n• Tasks: {{ $json.overall.tasksCount }} | Leads: {{ $json.overall.leadsCount }}\n• Urgent Tasks: {{ $json.trends.urgentTasks }}\n\n_Report generated at {{ $now.format('HH:mm') }}_",
            "select": "channel",
            "channelId": {
              "__rl": true,
              "mode": "list",
              "value": "C09GNB90TED",
              "cachedResultName": "general-information"
            },
            "otherOptions": {}
          },
          "credentials": {
            "slackApi": {
              "id": "credential-id",
              "name": "slackApi Credential"
            }
          },
          "typeVersion": 2
        },
        {
          "id": "3853cf8a-ca5c-44e0-93d1-b31f6c222b10",
          "name": "Gmail - Send KPI Report",
          "type": "n8n-nodes-base.gmail",
          "position": [
            -1552,
            -576
          ],
          "webhookId": "ac83548d-967a-4ebc-b011-25668788c29c",
          "parameters": {
            "sendTo": "={{ $env.REPORT_EMAIL || 'your-email@example.com' }}",
            "message": "=<!DOCTYPE html> <html lang=\"en\"> <head>     <meta charset=\"UTF-8\">     <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">     <title>Daily KPI Report</title>     <style>         body {             font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;             line-height: 1.6;             color: #333;             max-width: 800px;             margin: 0 auto;             padding: 20px;             background-color: #f4f4f4;         }         .container {             background-color: #ffffff;             border-radius: 10px;             box-shadow: 0 2px 10px rgba(0,0,0,0.1);             overflow: hidden;         }         .header {             background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);             color: white;             padding: 30px;             text-align: center;         }         .header h1 {             margin: 0;             font-size: 28px;             font-weight: 600;         }         .header p {             margin: 10px 0 0 0;             opacity: 0.9;             font-size: 14px;         }         .section {             padding: 25px 30px;             border-bottom: 1px solid #e0e0e0;         }         .section:last-child {             border-bottom: none;         }         .section-title {             font-size: 20px;             font-weight: 600;             margin-bottom: 15px;             color: #2c3e50;             display: flex;             align-items: center;         }         .section-title .icon {             margin-right: 10px;             font-size: 24px;         }         .stats-grid {             display: grid;             grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));             gap: 15px;             margin-top: 15px;         }         .stat-card {             background-color: #f8f9fa;             border-left: 4px solid #667eea;             padding: 15px;             border-radius: 5px;         }         .stat-card.urgent {             border-left-color: #dc3545;             background-color: #fff5f5;         }         .stat-card.success {             border-left-color: #28a745;             background-color: #f0fff4;         }         .stat-card.warning {             border-left-color: #ffc107;             background-color: #fffbf0;         }         .stat-label {             font-size: 13px;             color: #6c757d;             font-weight: 500;             text-transform: uppercase;             letter-spacing: 0.5px;         }         .stat-value {             font-size: 28px;             font-weight: 700;             margin: 5px 0;             color: #2c3e50;         }         .stat-detail {             font-size: 12px;             color: #6c757d;         }         .progress-bar {             background-color: #e9ecef;             border-radius: 10px;             height: 10px;             margin-top: 8px;             overflow: hidden;         }         .progress-fill {             height: 100%;             background: linear-gradient(90deg, #667eea 0%, #764ba2 100%);             border-radius: 10px;             transition: width 0.3s ease;         }         .progress-fill.danger {             background: linear-gradient(90deg, #dc3545 0%, #c82333 100%);         }         .progress-fill.success {             background: linear-gradient(90deg, #28a745 0%, #218838 100%);         }         .sentiment-container {             display: flex;             gap: 15px;             margin-top: 15px;         }         .sentiment-item {             flex: 1;             text-align: center;             padding: 15px;             border-radius: 8px;             background-color: #f8f9fa;         }         .sentiment-item.positive {             background-color: #d4edda;             border: 2px solid #28a745;         }         .sentiment-item.negative {             background-color: #f8d7da;             border: 2px solid #dc3545;         }         .sentiment-item.neutral {             background-color: #fff3cd;             border: 2px solid #ffc107;         }         .sentiment-emoji {             font-size: 36px;             margin-bottom: 5px;         }         .sentiment-count {             font-size: 24px;             font-weight: 700;             color: #2c3e50;         }         .sentiment-label {             font-size: 12px;             color: #6c757d;             font-weight: 600;             text-transform: uppercase;         }         .trend-badge {             display: inline-block;             padding: 5px 12px;             border-radius: 20px;             font-size: 12px;             font-weight: 600;             margin-top: 5px;         }         .trend-badge.stable {             background-color: #cce5ff;             color: #004085;         }         .trend-badge.active {             background-color: #d4edda;             color: #155724;         }         .footer {             background-color: #f8f9fa;             padding: 20px 30px;             text-align: center;             color: #6c757d;             font-size: 12px;         }         .assignee-list {             display: flex;             flex-wrap: wrap;             gap: 10px;             margin-top: 10px;         }         .assignee-badge {             background-color: #e9ecef;             padding: 6px 12px;             border-radius: 20px;             font-size: 12px;             font-weight: 500;         }         .source-list {             display: grid;             grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));             gap: 10px;             margin-top: 10px;         }         .source-item {             background-color: #f8f9fa;             padding: 8px 12px;             border-radius: 5px;             font-size: 12px;             border-left: 3px solid #667eea;         }     </style> </head> <body>     <div class=\"container\">         <div class=\"header\">             <h1>📊 Daily KPI Dashboard Report</h1>             <p>Generated on {{ $now.format('MMMM DD, YYYY') }} at {{ $now.format('HH:mm:ss') }}</p>         </div>          <div class=\"section\">             <div class=\"section-title\">                 <span class=\"icon\">✅</span>                 <span>Tasks Overview</span>             </div>                          <div class=\"stats-grid\">                 <div class=\"stat-card\">                     <div class=\"stat-label\">Total Tasks</div>                     <div class=\"stat-value\">{{ $json.tasks.total }}</div>                 </div>                                  <div class=\"stat-card urgent\">                     <div class=\"stat-label\">Overdue Tasks</div>                     <div class=\"stat-value\">{{ $json.tasks.overdue }}</div>                     <div class=\"stat-detail\">{{ $json.tasks.overduePercentage }}% of total</div>                     <div class=\"progress-bar\">                         <div class=\"progress-fill danger\" style=\"width: {{ $json.tasks.overduePercentage }}%\"></div>                     </div>                 </div>                                  <div class=\"stat-card warning\">                     <div class=\"stat-label\">Urgent Priority</div>                     <div class=\"stat-value\">{{ $json.trends.urgentTasks }}</div>                     <div class=\"stat-detail\">Requires immediate attention</div>                 </div>                                  <div class=\"stat-card\">                     <div class=\"stat-label\">Avg Time Spent</div>                     <div class=\"stat-value\">{{ $json.tasks.avgTimeSpentHours }}</div>                     <div class=\"stat-detail\">hours per task</div>                 </div>             </div>              <div style=\"margin-top: 25px;\">                 <strong style=\"font-size: 14px; color: #6c757d;\">TASK STATUS BREAKDOWN</strong>                 <div class=\"stats-grid\" style=\"margin-top: 10px;\">                     <div class=\"stat-card\">                         <div class=\"stat-label\">In Progress</div>                         <div class=\"stat-value\" style=\"font-size: 22px; color: #5f55ee;\">{{ $json.tasks.completion.inProgress }}</div>                     </div>                     <div class=\"stat-card\">                         <div class=\"stat-label\">Final Review</div>                         <div class=\"stat-value\" style=\"font-size: 22px; color: #f8ae00;\">{{ $json.tasks.completion.finalReview }}</div>                     </div>                     <div class=\"stat-card\">                         <div class=\"stat-label\">Backlogs</div>                         <div class=\"stat-value\" style=\"font-size: 22px; color: #87909e;\">{{ $json.tasks.completion.backlogs }}</div>                     </div>                     <div class=\"stat-card success\">                         <div class=\"stat-label\">Completed</div>                         <div class=\"stat-value\" style=\"font-size: 22px; color: #28a745;\">{{ $json.tasks.completion.done }}</div>                     </div>                 </div>             </div>              <div style=\"margin-top: 25px;\">                 <strong style=\"font-size: 14px; color: #6c757d;\">TASK DISTRIBUTION BY ASSIGNEE</strong>                 <div class=\"assignee-list\">                     {{ Object.entries($json.tasks.byAssignee).map(([name, count]) => `<div class=\"assignee-badge\">${name}: <strong>${count}</strong> task(s)</div>`).join('') }}                 </div>             </div>         </div>          <div class=\"section\">             <div class=\"section-title\">                 <span class=\"icon\">👥</span>                 <span>Leads Overview</span>             </div>                          <div class=\"stats-grid\">                 <div class=\"stat-card\">                     <div class=\"stat-label\">Total Leads</div>                     <div class=\"stat-value\">{{ $json.leads.total }}</div>                 </div>                                  <div class=\"stat-card success\">                     <div class=\"stat-label\">New Replies</div>                     <div class=\"stat-value\">{{ $json.trends.newReplies }}</div>                     <div class=\"stat-detail\">Awaiting response</div>                 </div>             </div>              <div style=\"margin-top: 25px;\">                 <strong style=\"font-size: 14px; color: #6c757d;\">SENTIMENT ANALYSIS</strong>                 <div class=\"sentiment-container\">                     <div class=\"sentiment-item positive\">                         <div class=\"sentiment-emoji\">😊</div>                         <div class=\"sentiment-count\">{{ $json.leads.sentiment.positive }}</div>                         <div class=\"sentiment-label\">Positive</div>                         <div style=\"font-size: 14px; font-weight: 600; margin-top: 5px; color: #28a745;\">{{ $json.leads.sentiment.positiveRate }}%</div>                     </div>                     <div class=\"sentiment-item neutral\">                         <div class=\"sentiment-emoji\">😐</div>                         <div class=\"sentiment-count\">{{ $json.leads.sentiment.neutral }}</div>                         <div class=\"sentiment-label\">Neutral</div>                         <div style=\"font-size: 14px; font-weight: 600; margin-top: 5px; color: #856404;\">{{ (($json.leads.sentiment.neutral / $json.leads.total) * 100).toFixed(2) }}%</div>                     </div>                     <div class=\"sentiment-item negative\">                         <div class=\"sentiment-emoji\">😟</div>                         <div class=\"sentiment-count\">{{ $json.leads.sentiment.negative }}</div>                         <div class=\"sentiment-label\">Negative</div>                         <div style=\"font-size: 14px; font-weight: 600; margin-top: 5px; color: #dc3545;\">{{ $json.leads.sentiment.negativeRate }}%</div>                     </div>                 </div>             </div>              <div style=\"margin-top: 25px;\">                 <strong style=\"font-size: 14px; color: #6c757d;\">TOP LEAD SOURCES</strong>                 <div class=\"source-list\">                     {{ Object.entries($json.leads.bySource).map(([source, count]) => `<div class=\"source-item\"><strong>${source}</strong><br>${count} lead(s)</div>`).join('') }}                 </div>             </div>              <div style=\"margin-top: 25px;\">                 <strong style=\"font-size: 14px; color: #6c757d;\">REPLIES BY DATE</strong>                 <div style=\"margin-top: 10px;\">                     {{ Object.entries($json.leads.byDate).map(([date, count]) => `                         <div style=\"display: flex; justify-content: space-between; padding: 8px 12px; background-color: #f8f9fa; margin-bottom: 5px; border-radius: 5px;\">                             <span style=\"font-weight: 500;\">${date}</span>                             <span style=\"font-weight: 700; color: #667eea;\">${count} replies</span>                         </div>                     `).join('') }}                 </div>             </div>         </div>          <div class=\"section\">             <div class=\"section-title\">                 <span class=\"icon\">📈</span>                 <span>Trends & Insights</span>             </div>                          <div style=\"display: grid; grid-template-columns: 1fr 1fr; gap: 20px;\">                 <div>                     <div style=\"font-size: 14px; color: #6c757d; margin-bottom: 8px;\">TASK TREND</div>                     <div style=\"font-size: 20px; font-weight: 600; color: #2c3e50;\">                         {{ $json.trends.taskTrend }}                         <span class=\"trend-badge stable\">{{ $json.trends.taskTrend }}</span>                     </div>                 </div>                 <div>                     <div style=\"font-size: 14px; color: #6c757d; margin-bottom: 8px;\">LEAD TREND</div>                     <div style=\"font-size: 20px; font-weight: 600; color: #2c3e50;\">                         {{ $json.trends.leadTrend }}                         <span class=\"trend-badge active\">{{ $json.trends.leadTrend }}</span>                     </div>                 </div>             </div>              <div style=\"margin-top: 20px; padding: 15px; background-color: #e7f3ff; border-left: 4px solid #0066cc; border-radius: 5px;\">                 <strong style=\"color: #004085;\">💡 Key Insights:</strong>                 <ul style=\"margin: 10px 0 0 0; padding-left: 20px; color: #004085;\">                     <li>You have <strong>{{ $json.tasks.overdue }}</strong> overdue tasks that need immediate attention</li>                     <li><strong>{{ $json.leads.sentiment.positiveRate }}%</strong> of leads show positive interest</li>                     <li>Average task completion time: <strong>{{ $json.tasks.avgTimeSpentHours }} hours</strong></li>                     <li><strong>{{ $json.trends.newReplies }}</strong> new lead replies to follow up on</li>                 </ul>             </div>         </div>          <div class=\"footer\">             <p style=\"margin: 0;\">This report was automatically generated by your KPI Dashboard System</p>             <p style=\"margin: 5px 0 0 0;\">For questions or support, please contact your system administrator</p>         </div>     </div> </body> </html>",
            "options": {},
            "subject": "=Daily KPI Dashboard - {{ $now.format('MMMM DD, YYYY') }}"
          },
          "credentials": {
            "gmailOAuth2": {
              "id": "credential-id",
              "name": "gmailOAuth2 Credential"
            }
          },
          "typeVersion": 2
        }
      ],
      "active": false,
      "pinData": {},
      "settings": {
        "executionOrder": "v1"
      },
      "versionId": "3d7eb7d9-714c-4f9a-b953-4b3cbe9a1cf4",
      "connections": {
        "Daily Cron Trigger": {
          "main": [
            [
              {
                "node": "Google Sheets - Fetch Lead Data",
                "type": "main",
                "index": 0
              },
              {
                "node": "ClickUp - Fetch Tasks",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "ClickUp - Fetch Tasks": {
          "main": [
            [
              {
                "node": "Merge - Consolidate Datasets",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Error Trigger Handler": {
          "main": [
            [
              {
                "node": "Slack - Send Error Alert",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Set - Format Output Data": {
          "main": [
            [
              {
                "node": "Slack - Post Dashboard Snapshot",
                "type": "main",
                "index": 0
              },
              {
                "node": "Gmail - Send KPI Report",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Code - Compute KPI Trends": {
          "main": [
            [
              {
                "node": "Set - Format Output Data",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Merge - Consolidate Datasets": {
          "main": [
            [
              {
                "node": "Code - Compute KPI Trends",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Google Sheets - Fetch Lead Data": {
          "main": [
            [
              {
                "node": "Merge - Consolidate Datasets",
                "type": "main",
                "index": 1
              }
            ]
          ]
        }
      }
    },
    "lastUpdatedBy": 1,
    "workflowInfo": {
      "nodeCount": 20,
      "nodeTypes": {
        "n8n-nodes-base.set": {
          "count": 1
        },
        "n8n-nodes-base.code": {
          "count": 1
        },
        "n8n-nodes-base.cron": {
          "count": 1
        },
        "n8n-nodes-base.gmail": {
          "count": 1
        },
        "n8n-nodes-base.merge": {
          "count": 1
        },
        "n8n-nodes-base.slack": {
          "count": 2
        },
        "n8n-nodes-base.clickUp": {
          "count": 1
        },
        "n8n-nodes-base.stickyNote": {
          "count": 10
        },
        "n8n-nodes-base.errorTrigger": {
          "count": 1
        },
        "n8n-nodes-base.googleSheets": {
          "count": 1
        }
      }
    },
    "status": "published",
    "user": {
      "name": "Rahul Joshi",
      "username": "rahul08",
      "bio": "Rahul Joshi is a seasoned technology leader specializing in the n8n automation tool and AI-driven workflow automation. With deep expertise in building open-source workflow automation and self-hosted automation platforms, he helps organizations eliminate manual processes through intelligent n8n ai agent automation solutions.\n\n",
      "verified": true,
      "links": [
        "https://www.linkedin.com/in/callrahul/"
      ],
      "avatar": "https://gravatar.com/avatar/b6cf57822463143589b36ada06fbf6cb1509223a740fae3160b28f1ce41ccc12?r=pg&d=retro&size=200"
    },
    "nodes": [
      {
        "id": 7,
        "icon": "fa:clock",
        "name": "n8n-nodes-base.cron",
        "codex": {
          "data": {
            "alias": [
              "Time",
              "Scheduler",
              "Polling",
              "Cron",
              "Interval"
            ],
            "details": "The Cron node uses Cron under the hood - a time-based job scheduler in Unix-like computer operating systems. Use this node when you want to trigger workflows periodically, especially in more complex scenarios like \"every Tuesday at 9 am\" or \"Weekdays\".",
            "resources": {
              "generic": [
                {
                  "url": "https://n8n.io/blog/2021-goals-level-up-your-vocabulary-with-vonage-and-n8n/",
                  "icon": "🎯",
                  "label": "2021 Goals: Level Up Your Vocabulary With Vonage and n8n"
                },
                {
                  "url": "https://n8n.io/blog/love-at-first-sight-ricardos-n8n-journey/",
                  "icon": "❤️",
                  "label": "Love at first sight: Ricardo’s n8n journey"
                },
                {
                  "url": "https://n8n.io/blog/2021-the-year-to-automate-the-new-you-with-n8n/",
                  "icon": "☀️",
                  "label": "2021: The Year to Automate the New You with n8n"
                },
                {
                  "url": "https://n8n.io/blog/why-business-process-automation-with-n8n-can-change-your-daily-life/",
                  "icon": "🧬",
                  "label": "Why business process automation with n8n can change your daily life"
                },
                {
                  "url": "https://n8n.io/blog/why-i-chose-n8n-over-zapier-in-2020/",
                  "icon": "😍",
                  "label": "Why I chose n8n over Zapier in 2020"
                },
                {
                  "url": "https://n8n.io/blog/how-to-host-virtual-coffee-breaks-with-n8n/",
                  "icon": "☕️",
                  "label": "How to host virtual coffee breaks with n8n"
                },
                {
                  "url": "https://n8n.io/blog/automatically-pulling-and-visualizing-data-with-n8n/",
                  "icon": "📈",
                  "label": "Automatically pulling and visualizing data with n8n"
                },
                {
                  "url": "https://n8n.io/blog/how-to-sync-data-between-two-systems/",
                  "icon": "🏬",
                  "label": "How to synchronize data between two systems (one-way vs. two-way sync"
                },
                {
                  "url": "https://n8n.io/blog/database-monitoring-and-alerting-with-n8n/",
                  "icon": "📡",
                  "label": "Database Monitoring and Alerting with n8n"
                },
                {
                  "url": "https://n8n.io/blog/automate-your-data-processing-pipeline-in-9-steps-with-n8n/",
                  "icon": "⚙️",
                  "label": "Automate your data processing pipeline in 9 steps"
                },
                {
                  "url": "https://n8n.io/blog/5-tasks-you-can-automate-with-notion-api/",
                  "icon": "⚡️",
                  "label": "5 tasks you can automate with the new Notion API "
                },
                {
                  "url": "https://n8n.io/blog/world-poetry-day-workflow/",
                  "icon": "📜",
                  "label": "Celebrating World Poetry Day with a daily poem in Telegram"
                },
                {
                  "url": "https://n8n.io/blog/automate-google-apps-for-productivity/",
                  "icon": "💡",
                  "label": "15 Google apps you can combine and automate to increase productivity"
                },
                {
                  "url": "https://n8n.io/blog/automate-designs-with-bannerbear-and-n8n/",
                  "icon": "🎨",
                  "label": "Automate Designs with Bannerbear and n8n"
                },
                {
                  "url": "https://n8n.io/blog/tracking-time-spent-in-meetings-with-google-calendar-twilio-and-n8n/",
                  "icon": "🗓",
                  "label": "Tracking Time Spent in Meetings With Google Calendar, Twilio, and n8n"
                },
                {
                  "url": "https://n8n.io/blog/creating-error-workflows-in-n8n/",
                  "icon": "🌪",
                  "label": "Creating Error Workflows in n8n"
                },
                {
                  "url": "https://n8n.io/blog/using-automation-to-boost-productivity-in-the-workplace/",
                  "icon": "💪",
                  "label": "Using Automation to Boost Productivity in the Workplace"
                },
                {
                  "url": "https://n8n.io/blog/why-this-product-manager-loves-workflow-automation-with-n8n/",
                  "icon": "🧠",
                  "label": "Why this Product Manager loves workflow automation with n8n"
                },
                {
                  "url": "https://n8n.io/blog/sending-automated-congratulations-with-google-sheets-twilio-and-n8n/",
                  "icon": "🙌",
                  "label": "Sending Automated Congratulations with Google Sheets, Twilio, and n8n "
                },
                {
                  "url": "https://n8n.io/blog/a-low-code-bitcoin-ticker-built-with-questdb-and-n8n-io/",
                  "icon": "📈",
                  "label": "A low-code bitcoin ticker built with QuestDB and n8n.io"
                },
                {
                  "url": "https://n8n.io/blog/benefits-of-automation-and-n8n-an-interview-with-hubspots-hugh-durkin/",
                  "icon": "🎖",
                  "label": "Benefits of automation and n8n: An interview with HubSpot's Hugh Durkin"
                },
                {
                  "url": "https://n8n.io/blog/creating-scheduled-text-affirmations-with-n8n/",
                  "icon": "🤟",
                  "label": "Creating scheduled text affirmations with n8n"
                },
                {
                  "url": "https://n8n.io/blog/how-goomer-automated-their-operations-with-over-200-n8n-workflows/",
                  "icon": "🛵",
                  "label": "How Goomer automated their operations with over 200 n8n workflows"
                }
              ],
              "primaryDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/core-nodes/n8n-nodes-base.scheduletrigger/"
                }
              ]
            },
            "categories": [
              "Core Nodes"
            ],
            "nodeVersion": "1.0",
            "codexVersion": "1.0",
            "subcategories": {
              "Core Nodes": [
                "Flow"
              ]
            }
          }
        },
        "group": "[\"trigger\",\"schedule\"]",
        "defaults": {
          "name": "Cron",
          "color": "#29a568"
        },
        "iconData": {
          "icon": "clock",
          "type": "icon"
        },
        "displayName": "Cron",
        "typeVersion": 1,
        "nodeCategories": [
          {
            "id": 9,
            "name": "Core Nodes"
          }
        ]
      },
      {
        "id": 12,
        "icon": "fa:bug",
        "name": "n8n-nodes-base.errorTrigger",
        "codex": {
          "data": {
            "details": "In n8n, when a workflow execution fails, it can start another workflow. This second workflow can be any arbitrary workflow on your n8n instance. Use the Error Trigger node as your Trigger in the Error workflow.",
            "resources": {
              "generic": [
                {
                  "url": "https://n8n.io/blog/creating-error-workflows-in-n8n/",
                  "icon": "🌪",
                  "label": "Creating Error Workflows in n8n"
                }
              ],
              "primaryDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/core-nodes/n8n-nodes-base.errortrigger/"
                }
              ]
            },
            "categories": [
              "Development",
              "Core Nodes"
            ],
            "nodeVersion": "1.0",
            "codexVersion": "1.0",
            "subcategories": {
              "Core Nodes": [
                "Other Trigger Nodes"
              ]
            }
          }
        },
        "group": "[\"trigger\"]",
        "defaults": {
          "name": "Error Trigger",
          "color": "#0000FF"
        },
        "iconData": {
          "icon": "bug",
          "type": "icon"
        },
        "displayName": "Error Trigger",
        "typeVersion": 1,
        "nodeCategories": [
          {
            "id": 5,
            "name": "Development"
          },
          {
            "id": 9,
            "name": "Core Nodes"
          }
        ]
      },
      {
        "id": 18,
        "icon": "file:googleSheets.svg",
        "name": "n8n-nodes-base.googleSheets",
        "codex": {
          "data": {
            "alias": [
              "CSV",
              "Sheet",
              "Spreadsheet",
              "GS"
            ],
            "resources": {
              "generic": [
                {
                  "url": "https://n8n.io/blog/love-at-first-sight-ricardos-n8n-journey/",
                  "icon": "❤️",
                  "label": "Love at first sight: Ricardo’s n8n journey"
                },
                {
                  "url": "https://n8n.io/blog/why-business-process-automation-with-n8n-can-change-your-daily-life/",
                  "icon": "🧬",
                  "label": "Why business process automation with n8n can change your daily life"
                },
                {
                  "url": "https://n8n.io/blog/automatically-adding-expense-receipts-to-google-sheets-with-telegram-mindee-twilio-and-n8n/",
                  "icon": "🧾",
                  "label": "Automatically Adding Expense Receipts to Google Sheets with Telegram, Mindee, Twilio, and n8n"
                },
                {
                  "url": "https://n8n.io/blog/supercharging-your-conference-registration-process-with-n8n/",
                  "icon": "🎫",
                  "label": "Supercharging your conference registration process with n8n"
                },
                {
                  "url": "https://n8n.io/blog/creating-triggers-for-n8n-workflows-using-polling/",
                  "icon": "⏲",
                  "label": "Creating triggers for n8n workflows using polling"
                },
                {
                  "url": "https://n8n.io/blog/no-code-ecommerce-workflow-automations/",
                  "icon": "store",
                  "label": "6 e-commerce workflows to power up your Shopify s"
                },
                {
                  "url": "https://n8n.io/blog/migrating-community-metrics-to-orbit-using-n8n/",
                  "icon": "📈",
                  "label": "Migrating Community Metrics to Orbit using n8n"
                },
                {
                  "url": "https://n8n.io/blog/automate-google-apps-for-productivity/",
                  "icon": "💡",
                  "label": "15 Google apps you can combine and automate to increase productivity"
                },
                {
                  "url": "https://n8n.io/blog/your-business-doesnt-need-you-to-operate/",
                  "icon": " 🖥️",
                  "label": "Hey founders! Your business doesn't need you to operate"
                },
                {
                  "url": "https://n8n.io/blog/how-honest-burgers-use-automation-to-save-100k-per-year/",
                  "icon": "🍔",
                  "label": "How Honest Burgers Use Automation to Save $100k per year"
                },
                {
                  "url": "https://n8n.io/blog/how-a-digital-strategist-uses-n8n-for-online-marketing/",
                  "icon": "💻",
                  "label": "How a digital strategist uses n8n for online marketing"
                },
                {
                  "url": "https://n8n.io/blog/why-this-product-manager-loves-workflow-automation-with-n8n/",
                  "icon": "🧠",
                  "label": "Why this Product Manager loves workflow automation with n8n"
                },
                {
                  "url": "https://n8n.io/blog/sending-automated-congratulations-with-google-sheets-twilio-and-n8n/",
                  "icon": "🙌",
                  "label": "Sending Automated Congratulations with Google Sheets, Twilio, and n8n "
                },
                {
                  "url": "https://n8n.io/blog/how-a-membership-development-manager-automates-his-work-and-investments/",
                  "icon": "📈",
                  "label": "How a Membership Development Manager automates his work and investments"
                },
                {
                  "url": "https://n8n.io/blog/aws-workflow-automation/",
                  "label": "7 no-code workflow automations for Amazon Web Services"
                }
              ],
              "primaryDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/app-nodes/n8n-nodes-base.googlesheets/"
                }
              ],
              "credentialDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/credentials/google/oauth-single-service/"
                }
              ]
            },
            "categories": [
              "Data & Storage",
              "Productivity"
            ],
            "nodeVersion": "1.0",
            "codexVersion": "1.0"
          }
        },
        "group": "[\"input\",\"output\"]",
        "defaults": {
          "name": "Google Sheets"
        },
        "iconData": {
          "type": "file",
          "fileBuffer": "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI2MCIgaGVpZ2h0PSI2MCI+PGcgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiPjxwYXRoIGZpbGw9IiMyOEI0NDYiIGQ9Ik0zNS42OSAxIDUyIDE3LjIyNXYzOS4wODdhMy42NyAzLjY3IDAgMCAxLTEuMDg0IDIuNjFBMy43IDMuNyAwIDAgMSA0OC4yOTMgNjBIMTIuNzA3YTMuNyAzLjcgMCAwIDEtMi42MjMtMS4wNzhBMy42NyAzLjY3IDAgMCAxIDkgNTYuMzEyVjQuNjg4YTMuNjcgMy42NyAwIDAgMSAxLjA4NC0yLjYxQTMuNyAzLjcgMCAwIDEgMTIuNzA3IDF6Ii8+PHBhdGggZmlsbD0iIzZBQ0U3QyIgZD0iTTM1LjY5IDEgNTIgMTcuMjI1SDM5LjM5N2MtMi4wNTQgMC0zLjcwNy0xLjgyOS0zLjcwNy0zLjg3MnoiLz48cGF0aCBmaWxsPSIjMjE5QjM4IiBkPSJNMzkuMjExIDE3LjIyNSA1MiAyMi40OHYtNS4yNTV6Ii8+PHBhdGggZmlsbD0iI0ZGRiIgZD0iTTIwLjEyIDMxLjk3NWMwLS44MTcuNjYyLTEuNDc1IDEuNDgzLTEuNDc1aDE3Ljc5NGMuODIxIDAgMS40ODIuNjU4IDEuNDgyIDEuNDc1djE1LjQ4N2MwIC44MTgtLjY2MSAxLjQ3NS0xLjQ4MiAxLjQ3NUgyMS42MDNhMS40NzYgMS40NzYgMCAwIDEtMS40ODItMS40NzRWMzEuOTc0em0yLjIyNSAxLjQ3NWg2LjY3MnYyLjIxMmgtNi42NzJ6bTAgNS4xNjJoNi42NzJ2Mi4yMTNoLTYuNjcyem0wIDUuMTYzaDYuNjcydjIuMjEyaC02LjY3MnptOS42MzgtMTAuMzI1aDYuNjcydjIuMjEyaC02LjY3MnptMCA1LjE2Mmg2LjY3MnYyLjIxM2gtNi42NzJ6bTAgNS4xNjNoNi42NzJ2Mi4yMTJoLTYuNjcyeiIvPjxwYXRoIGZpbGw9IiMyOEI0NDYiIGQ9Ik0zNC42OSAwIDUxIDE2LjIyNXYzOS4wODdhMy42NyAzLjY3IDAgMCAxLTEuMDg0IDIuNjFBMy43IDMuNyAwIDAgMSA0Ny4yOTMgNTlIMTEuNzA3YTMuNyAzLjcgMCAwIDEtMi42MjMtMS4wNzhBMy42NyAzLjY3IDAgMCAxIDggNTUuMzEyVjMuNjg4YTMuNjcgMy42NyAwIDAgMSAxLjA4NC0yLjYxQTMuNyAzLjcgMCAwIDEgMTEuNzA3IDB6Ii8+PHBhdGggZmlsbD0iIzZBQ0U3QyIgZD0iTTM0LjY5IDAgNTEgMTYuMjI1SDM4LjM5N2MtMi4wNTQgMC0zLjcwNy0xLjgyOS0zLjcwNy0zLjg3MnoiLz48cGF0aCBmaWxsPSIjMjE5QjM4IiBkPSJNMzguMjExIDE2LjIyNSA1MSAyMS40OHYtNS4yNTV6Ii8+PHBhdGggZmlsbD0iI0ZGRiIgZD0iTTE5LjEyIDMwLjk3NWMwLS44MTcuNjYyLTEuNDc1IDEuNDgzLTEuNDc1aDE3Ljc5NGMuODIxIDAgMS40ODIuNjU4IDEuNDgyIDEuNDc1djE1LjQ4N2MwIC44MTgtLjY2MSAxLjQ3NS0xLjQ4MiAxLjQ3NUgyMC42MDNhMS40NzYgMS40NzYgMCAwIDEtMS40ODItMS40NzRWMzAuOTc0em0yLjIyNSAxLjQ3NWg2LjY3MnYyLjIxMmgtNi42NzJ6bTAgNS4xNjJoNi42NzJ2Mi4yMTNoLTYuNjcyem0wIDUuMTYzaDYuNjcydjIuMjEyaC02LjY3MnptOS42MzgtMTAuMzI1aDYuNjcydjIuMjEyaC02LjY3MnptMCA1LjE2Mmg2LjY3MnYyLjIxM2gtNi42NzJ6bTAgNS4xNjNoNi42NzJ2Mi4yMTJoLTYuNjcyeiIvPjwvZz48L3N2Zz4="
        },
        "displayName": "Google Sheets",
        "typeVersion": 5,
        "nodeCategories": [
          {
            "id": 3,
            "name": "Data & Storage"
          },
          {
            "id": 4,
            "name": "Productivity"
          }
        ]
      },
      {
        "id": 24,
        "icon": "file:merge.svg",
        "name": "n8n-nodes-base.merge",
        "codex": {
          "data": {
            "alias": [
              "Join",
              "Concatenate",
              "Wait"
            ],
            "resources": {
              "generic": [
                {
                  "url": "https://n8n.io/blog/how-to-sync-data-between-two-systems/",
                  "icon": "🏬",
                  "label": "How to synchronize data between two systems (one-way vs. two-way sync"
                },
                {
                  "url": "https://n8n.io/blog/supercharging-your-conference-registration-process-with-n8n/",
                  "icon": "🎫",
                  "label": "Supercharging your conference registration process with n8n"
                },
                {
                  "url": "https://n8n.io/blog/migrating-community-metrics-to-orbit-using-n8n/",
                  "icon": "📈",
                  "label": "Migrating Community Metrics to Orbit using n8n"
                },
                {
                  "url": "https://n8n.io/blog/build-your-own-virtual-assistant-with-n8n-a-step-by-step-guide/",
                  "icon": "👦",
                  "label": "Build your own virtual assistant with n8n: A step by step guide"
                },
                {
                  "url": "https://n8n.io/blog/sending-automated-congratulations-with-google-sheets-twilio-and-n8n/",
                  "icon": "🙌",
                  "label": "Sending Automated Congratulations with Google Sheets, Twilio, and n8n "
                },
                {
                  "url": "https://n8n.io/blog/aws-workflow-automation/",
                  "label": "7 no-code workflow automations for Amazon Web Services"
                }
              ],
              "primaryDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/core-nodes/n8n-nodes-base.merge/"
                }
              ]
            },
            "categories": [
              "Core Nodes"
            ],
            "nodeVersion": "1.0",
            "codexVersion": "1.0",
            "subcategories": {
              "Core Nodes": [
                "Flow",
                "Data Transformation"
              ]
            }
          }
        },
        "group": "[\"transform\"]",
        "defaults": {
          "name": "Merge"
        },
        "iconData": {
          "type": "file",
          "fileBuffer": "data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTEyIiBoZWlnaHQ9IjUxMiIgdmlld0JveD0iMCAwIDUxMiA1MTIiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMF8xMTc3XzUxOCkiPgo8cGF0aCBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGNsaXAtcnVsZT0iZXZlbm9kZCIgZD0iTTAgNDhDMCAyMS40OTAzIDIxLjQ5MDMgMCA0OCAwSDExMkMxMzguNTEgMCAxNjAgMjEuNDkwMyAxNjAgNDhWNTZIMTk2LjI1MkMyNDAuNDM1IDU2IDI3Ni4yNTIgOTEuODE3MiAyNzYuMjUyIDEzNlYxOTJDMjc2LjI1MiAyMTQuMDkxIDI5NC4xNjEgMjMyIDMxNi4yNTIgMjMySDM1MlYyMjRDMzUyIDE5Ny40OSAzNzMuNDkgMTc2IDQwMCAxNzZINDY0QzQ5MC41MSAxNzYgNTEyIDE5Ny40OSA1MTIgMjI0VjI4OEM1MTIgMzE0LjUxIDQ5MC41MSAzMzYgNDY0IDMzNkg0MDBDMzczLjQ5IDMzNiAzNTIgMzE0LjUxIDM1MiAyODhWMjgwSDMxNi4yNTJDMjk0LjE2MSAyODAgMjc2LjI1MiAyOTcuOTA5IDI3Ni4yNTIgMzIwVjM3NkMyNzYuMjUyIDQyMC4xODMgMjQwLjQzNSA0NTYgMTk2LjI1MiA0NTZIMTYwVjQ2NEMxNjAgNDkwLjUxIDEzOC41MSA1MTIgMTEyIDUxMkg0OEMyMS40OTAzIDUxMiAwIDQ5MC41MSAwIDQ2NFY0MDBDMCAzNzMuNDkgMjEuNDkwMyAzNTIgNDggMzUySDExMkMxMzguNTEgMzUyIDE2MCAzNzMuNDkgMTYwIDQwMFY0MDhIMTk2LjI1MkMyMTMuOTI1IDQwOCAyMjguMjUyIDM5My42NzMgMjI4LjI1MiAzNzZWMzIwQzIyOC4yNTIgMjk0Ljc4NCAyMzguODU5IDI3Mi4wNDQgMjU1Ljg1MyAyNTZDMjM4Ljg1OSAyMzkuOTU2IDIyOC4yNTIgMjE3LjIxNiAyMjguMjUyIDE5MlYxMzZDMjI4LjI1MiAxMTguMzI3IDIxMy45MjUgMTA0IDE5Ni4yNTIgMTA0SDE2MFYxMTJDMTYwIDEzOC41MSAxMzguNTEgMTYwIDExMiAxNjBINDhDMjEuNDkwMyAxNjAgMCAxMzguNTEgMCAxMTJWNDhaTTEwNCA0OEMxMDguNDE4IDQ4IDExMiA1MS41ODE3IDExMiA1NlYxMDRDMTEyIDEwOC40MTggMTA4LjQxOCAxMTIgMTA0IDExMkg1NkM1MS41ODE3IDExMiA0OCAxMDguNDE4IDQ4IDEwNFY1NkM0OCA1MS41ODE3IDUxLjU4MTcgNDggNTYgNDhIMTA0Wk00NTYgMjI0QzQ2MC40MTggMjI0IDQ2NCAyMjcuNTgyIDQ2NCAyMzJWMjgwQzQ2NCAyODQuNDE4IDQ2MC40MTggMjg4IDQ1NiAyODhINDA4QzQwMy41ODIgMjg4IDQwMCAyODQuNDE4IDQwMCAyODBWMjMyQzQwMCAyMjcuNTgyIDQwMy41ODIgMjI0IDQwOCAyMjRINDU2Wk0xMTIgNDA4QzExMiA0MDMuNTgyIDEwOC40MTggNDAwIDEwNCA0MDBINTZDNTEuNTgxNyA0MDAgNDggNDAzLjU4MiA0OCA0MDhWNDU2QzQ4IDQ2MC40MTggNTEuNTgxNyA0NjQgNTYgNDY0SDEwNEMxMDguNDE4IDQ2NCAxMTIgNDYwLjQxOCAxMTIgNDU2VjQwOFoiIGZpbGw9IiM1NEI4QzkiLz4KPC9nPgo8ZGVmcz4KPGNsaXBQYXRoIGlkPSJjbGlwMF8xMTc3XzUxOCI+CjxyZWN0IHdpZHRoPSI1MTIiIGhlaWdodD0iNTEyIiBmaWxsPSJ3aGl0ZSIvPgo8L2NsaXBQYXRoPgo8L2RlZnM+Cjwvc3ZnPgo="
        },
        "displayName": "Merge",
        "typeVersion": 3,
        "nodeCategories": [
          {
            "id": 9,
            "name": "Core Nodes"
          }
        ]
      },
      {
        "id": 38,
        "icon": "fa:pen",
        "name": "n8n-nodes-base.set",
        "codex": {
          "data": {
            "alias": [
              "Set",
              "JS",
              "JSON",
              "Filter",
              "Transform",
              "Map"
            ],
            "resources": {
              "generic": [
                {
                  "url": "https://n8n.io/blog/learn-to-automate-your-factorys-incident-reporting-a-step-by-step-guide/",
                  "icon": "🏭",
                  "label": "Learn to Automate Your Factory's Incident Reporting: A Step by Step Guide"
                },
                {
                  "url": "https://n8n.io/blog/2021-the-year-to-automate-the-new-you-with-n8n/",
                  "icon": "☀️",
                  "label": "2021: The Year to Automate the New You with n8n"
                },
                {
                  "url": "https://n8n.io/blog/automatically-pulling-and-visualizing-data-with-n8n/",
                  "icon": "📈",
                  "label": "Automatically pulling and visualizing data with n8n"
                },
                {
                  "url": "https://n8n.io/blog/database-monitoring-and-alerting-with-n8n/",
                  "icon": "📡",
                  "label": "Database Monitoring and Alerting with n8n"
                },
                {
                  "url": "https://n8n.io/blog/automatically-adding-expense-receipts-to-google-sheets-with-telegram-mindee-twilio-and-n8n/",
                  "icon": "🧾",
                  "label": "Automatically Adding Expense Receipts to Google Sheets with Telegram, Mindee, Twilio, and n8n"
                },
                {
                  "url": "https://n8n.io/blog/no-code-ecommerce-workflow-automations/",
                  "icon": "store",
                  "label": "6 e-commerce workflows to power up your Shopify s"
                },
                {
                  "url": "https://n8n.io/blog/how-to-build-a-low-code-self-hosted-url-shortener/",
                  "icon": "🔗",
                  "label": "How to build a low-code, self-hosted URL shortener in 3 steps"
                },
                {
                  "url": "https://n8n.io/blog/automate-your-data-processing-pipeline-in-9-steps-with-n8n/",
                  "icon": "⚙️",
                  "label": "Automate your data processing pipeline in 9 steps"
                },
                {
                  "url": "https://n8n.io/blog/how-to-get-started-with-crm-automation-and-no-code-workflow-ideas/",
                  "icon": "👥",
                  "label": "How to get started with CRM automation (with 3 no-code workflow ideas"
                },
                {
                  "url": "https://n8n.io/blog/5-tasks-you-can-automate-with-notion-api/",
                  "icon": "⚡️",
                  "label": "5 tasks you can automate with the new Notion API "
                },
                {
                  "url": "https://n8n.io/blog/automate-google-apps-for-productivity/",
                  "icon": "💡",
                  "label": "15 Google apps you can combine and automate to increase productivity"
                },
                {
                  "url": "https://n8n.io/blog/how-uproc-scraped-a-multi-page-website-with-a-low-code-workflow/",
                  "icon": " 🕸️",
                  "label": "How uProc scraped a multi-page website with a low-code workflow"
                },
                {
                  "url": "https://n8n.io/blog/building-an-expense-tracking-app-in-10-minutes/",
                  "icon": "📱",
                  "label": "Building an expense tracking app in 10 minutes"
                },
                {
                  "url": "https://n8n.io/blog/the-ultimate-guide-to-automate-your-video-collaboration-with-whereby-mattermost-and-n8n/",
                  "icon": "📹",
                  "label": "The ultimate guide to automate your video collaboration with Whereby, Mattermost, and n8n"
                },
                {
                  "url": "https://n8n.io/blog/5-workflow-automations-for-mattermost-that-we-love-at-n8n/",
                  "icon": "🤖",
                  "label": "5 workflow automations for Mattermost that we love at n8n"
                },
                {
                  "url": "https://n8n.io/blog/learn-to-build-powerful-api-endpoints-using-webhooks/",
                  "icon": "🧰",
                  "label": "Learn to Build Powerful API Endpoints Using Webhooks"
                },
                {
                  "url": "https://n8n.io/blog/how-a-membership-development-manager-automates-his-work-and-investments/",
                  "icon": "📈",
                  "label": "How a Membership Development Manager automates his work and investments"
                },
                {
                  "url": "https://n8n.io/blog/a-low-code-bitcoin-ticker-built-with-questdb-and-n8n-io/",
                  "icon": "📈",
                  "label": "A low-code bitcoin ticker built with QuestDB and n8n.io"
                },
                {
                  "url": "https://n8n.io/blog/how-to-set-up-a-ci-cd-pipeline-with-no-code/",
                  "icon": "🎡",
                  "label": "How to set up a no-code CI/CD pipeline with GitHub and TravisCI"
                },
                {
                  "url": "https://n8n.io/blog/benefits-of-automation-and-n8n-an-interview-with-hubspots-hugh-durkin/",
                  "icon": "🎖",
                  "label": "Benefits of automation and n8n: An interview with HubSpot's Hugh Durkin"
                },
                {
                  "url": "https://n8n.io/blog/how-goomer-automated-their-operations-with-over-200-n8n-workflows/",
                  "icon": "🛵",
                  "label": "How Goomer automated their operations with over 200 n8n workflows"
                },
                {
                  "url": "https://n8n.io/blog/aws-workflow-automation/",
                  "label": "7 no-code workflow automations for Amazon Web Services"
                }
              ],
              "primaryDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/core-nodes/n8n-nodes-base.set/"
                }
              ]
            },
            "categories": [
              "Core Nodes"
            ],
            "nodeVersion": "1.0",
            "codexVersion": "1.0",
            "subcategories": {
              "Core Nodes": [
                "Data Transformation"
              ]
            }
          }
        },
        "group": "[\"input\"]",
        "defaults": {
          "name": "Edit Fields"
        },
        "iconData": {
          "icon": "pen",
          "type": "icon"
        },
        "displayName": "Edit Fields (Set)",
        "typeVersion": 3,
        "nodeCategories": [
          {
            "id": 9,
            "name": "Core Nodes"
          }
        ]
      },
      {
        "id": 40,
        "icon": "file:slack.svg",
        "name": "n8n-nodes-base.slack",
        "codex": {
          "data": {
            "alias": [
              "human",
              "form",
              "wait",
              "hitl",
              "approval"
            ],
            "resources": {
              "generic": [
                {
                  "url": "https://n8n.io/blog/no-code-ecommerce-workflow-automations/",
                  "icon": "store",
                  "label": "6 e-commerce workflows to power up your Shopify s"
                },
                {
                  "url": "https://n8n.io/blog/automate-your-data-processing-pipeline-in-9-steps-with-n8n/",
                  "icon": "⚙️",
                  "label": "Automate your data processing pipeline in 9 steps"
                },
                {
                  "url": "https://n8n.io/blog/how-to-get-started-with-crm-automation-and-no-code-workflow-ideas/",
                  "icon": "👥",
                  "label": "How to get started with CRM automation (with 3 no-code workflow ideas"
                },
                {
                  "url": "https://n8n.io/blog/5-tasks-you-can-automate-with-notion-api/",
                  "icon": "⚡️",
                  "label": "5 tasks you can automate with the new Notion API "
                },
                {
                  "url": "https://n8n.io/blog/build-your-own-virtual-assistant-with-n8n-a-step-by-step-guide/",
                  "icon": "👦",
                  "label": "Build your own virtual assistant with n8n: A step by step guide"
                },
                {
                  "url": "https://n8n.io/blog/how-to-automatically-give-kudos-to-contributors-with-github-slack-and-n8n/",
                  "icon": "👏",
                  "label": "How to automatically give kudos to contributors with GitHub, Slack, and n8n"
                },
                {
                  "url": "https://n8n.io/blog/automations-for-activists/",
                  "icon": "✨",
                  "label": "How Common Knowledge use workflow automation for activism"
                }
              ],
              "primaryDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/app-nodes/n8n-nodes-base.slack/"
                }
              ],
              "credentialDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/credentials/slack/"
                }
              ]
            },
            "categories": [
              "Communication",
              "HITL"
            ],
            "nodeVersion": "1.0",
            "codexVersion": "1.0",
            "subcategories": {
              "HITL": [
                "Human in the Loop"
              ]
            }
          }
        },
        "group": "[\"output\"]",
        "defaults": {
          "name": "Slack"
        },
        "iconData": {
          "type": "file",
          "fileBuffer": "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiBmaWxsPSIjZmZmIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIHN0cm9rZT0iIzAwMCIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIiB2aWV3Qm94PSIwIDAgMTUwLjg1MiAxNTAuODUyIj48dXNlIHhsaW5rOmhyZWY9IiNhIiB4PSIuOTI2IiB5PSIuOTI2Ii8+PHN5bWJvbCBpZD0iYSIgb3ZlcmZsb3c9InZpc2libGUiPjxnIHN0cm9rZS13aWR0aD0iMS44NTIiPjxwYXRoIGZpbGw9IiNlMDFlNWEiIHN0cm9rZT0iI2UwMWU1YSIgZD0iTTQwLjc0MSA5My41NWMwLTguNzM1IDYuNjA3LTE1Ljc3MiAxNC44MTUtMTUuNzcyczE0LjgxNSA3LjAzNyAxNC44MTUgMTUuNzcydjM4LjgyNGMwIDguNzM3LTYuNjA3IDE1Ljc3NC0xNC44MTUgMTUuNzc0cy0xNC44MTUtNy4wMzctMTQuODE1LTE1Ljc3MnoiLz48cGF0aCBmaWxsPSIjZWNiMjJkIiBzdHJva2U9IiNlY2IyMmQiIGQ9Ik05My41NSAxMDcuNDA4Yy04LjczNSAwLTE1Ljc3Mi02LjYwNy0xNS43NzItMTQuODE1czcuMDM3LTE0LjgxNSAxNS43NzItMTQuODE1aDM4LjgyNmM4LjczNSAwIDE1Ljc3MiA2LjYwNyAxNS43NzIgMTQuODE1cy03LjAzNyAxNC44MTUtMTUuNzcyIDE0LjgxNXoiLz48cGF0aCBmaWxsPSIjMmZiNjdjIiBzdHJva2U9IiMyZmI2N2MiIGQ9Ik03Ny43NzggMTUuNzcyQzc3Ljc3OCA3LjAzNyA4NC4zODUgMCA5Mi41OTMgMHMxNC44MTUgNy4wMzcgMTQuODE1IDE1Ljc3MnYzOC44MjZjMCA4LjczNS02LjYwNyAxNS43NzItMTQuODE1IDE1Ljc3MnMtMTQuODE1LTcuMDM3LTE0LjgxNS0xNS43NzJ6Ii8+PHBhdGggZmlsbD0iIzM2YzVmMSIgc3Ryb2tlPSIjMzZjNWYxIiBkPSJNMTUuNzcyIDcwLjM3MUM3LjAzNyA3MC4zNzEgMCA2My43NjMgMCA1NS41NTZzNy4wMzctMTQuODE1IDE1Ljc3Mi0xNC44MTVoMzguODI2YzguNzM1IDAgMTUuNzcyIDYuNjA3IDE1Ljc3MiAxNC44MTVzLTcuMDM3IDE0LjgxNS0xNS43NzIgMTQuODE1eiIvPjxnIHN0cm9rZS1saW5lam9pbj0ibWl0ZXIiPjxwYXRoIGZpbGw9IiNlY2IyMmQiIHN0cm9rZT0iI2VjYjIyZCIgZD0iTTc3Ljc3OCAxMzMuMzMzYzAgOC4yMDggNi42MDcgMTQuODE1IDE0LjgxNSAxNC44MTVzMTQuODE1LTYuNjA3IDE0LjgxNS0xNC44MTUtNi42MDctMTQuODE1LTE0LjgxNS0xNC44MTVINzcuNzc4eiIvPjxwYXRoIGZpbGw9IiMyZmI2N2MiIHN0cm9rZT0iIzJmYjY3YyIgZD0iTTEzMy4zMzQgNzAuMzcxaC0xNC44MTVWNTUuNTU2YzAtOC4yMDcgNi42MDctMTQuODE1IDE0LjgxNS0xNC44MTVzMTQuODE1IDYuNjA3IDE0LjgxNSAxNC44MTUtNi42MDcgMTQuODE1LTE0LjgxNSAxNC44MTV6Ii8+PHBhdGggZmlsbD0iI2UwMWU1YSIgc3Ryb2tlPSIjZTAxZTVhIiBkPSJNMTQuODE1IDc3Ljc3OEgyOS42M3YxNC44MTVjMCA4LjIwNy02LjYwNyAxNC44MTUtMTQuODE1IDE0LjgxNVMwIDEwMC44IDAgOTIuNTkzczYuNjA3LTE0LjgxNSAxNC44MTUtMTQuODE1eiIvPjxwYXRoIGZpbGw9IiMzNmM1ZjEiIHN0cm9rZT0iIzM2YzVmMSIgZD0iTTcwLjM3MSAxNC44MTVWMjkuNjNINTUuNTU2Yy04LjIwNyAwLTE0LjgxNS02LjYwNy0xNC44MTUtMTQuODE1UzQ3LjM0OCAwIDU1LjU1NiAwczE0LjgxNSA2LjYwNyAxNC44MTUgMTQuODE1eiIvPjwvZz48L2c+PC9zeW1ib2w+PC9zdmc+"
        },
        "displayName": "Slack",
        "typeVersion": 2,
        "nodeCategories": [
          {
            "id": 6,
            "name": "Communication"
          },
          {
            "id": 28,
            "name": "HITL"
          }
        ]
      },
      {
        "id": 129,
        "icon": "file:clickup.svg",
        "name": "n8n-nodes-base.clickUp",
        "codex": {
          "data": {
            "resources": {
              "generic": [
                {
                  "url": "https://n8n.io/blog/2021-the-year-to-automate-the-new-you-with-n8n/",
                  "icon": "☀️",
                  "label": "2021: The Year to Automate the New You with n8n"
                }
              ],
              "primaryDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/app-nodes/n8n-nodes-base.clickup/"
                }
              ],
              "credentialDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/credentials/clickup/"
                }
              ]
            },
            "categories": [
              "Productivity",
              "Communication"
            ],
            "nodeVersion": "1.0",
            "codexVersion": "1.0"
          }
        },
        "group": "[\"output\"]",
        "defaults": {
          "name": "ClickUp"
        },
        "iconData": {
          "type": "file",
          "fileBuffer": "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9Ii0xMCAwIDE1NSAxNTUiPjxkZWZzPjxsaW5lYXJHcmFkaWVudCBpZD0iYSIgeDE9IjAlIiB5MT0iNjguMDElIiB5Mj0iNjguMDElIj48c3RvcCBvZmZzZXQ9IjAlIiBzdG9wLWNvbG9yPSIjODkzMEZEIi8+PHN0b3Agb2Zmc2V0PSIxMDAlIiBzdG9wLWNvbG9yPSIjNDlDQ0Y5Ii8+PC9saW5lYXJHcmFkaWVudD48bGluZWFyR3JhZGllbnQgaWQ9ImIiIHgxPSIwJSIgeTE9IjY4LjAxJSIgeTI9IjY4LjAxJSI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI0ZGMDJGMCIvPjxzdG9wIG9mZnNldD0iMTAwJSIgc3RvcC1jb2xvcj0iI0ZGQzgwMCIvPjwvbGluZWFyR3JhZGllbnQ+PC9kZWZzPjxnIGZpbGw9Im5vbmUiPjxwYXRoIGZpbGw9InVybCgjYSkiIGQ9Im0uNCAxMTkuMTIgMjMuODEtMTguMjRDMzYuODYgMTE3LjM5IDUwLjMgMTI1IDY1LjI2IDEyNWMxNC44OCAwIDI3Ljk0LTcuNTIgNDAuMDItMjMuOWwyNC4xNSAxNy44QzExMiAxNDIuNTIgOTAuMzQgMTU1IDY1LjI2IDE1NWMtMjUgMC00Ni44Ny0xMi40LTY0Ljg2LTM1Ljg4Ii8+PHBhdGggZmlsbD0idXJsKCNiKSIgZD0iTTY1LjE4IDM5Ljg0IDIyLjggNzYuMzYgMy4yMSA1My42NCA2NS4yNy4xNmw2MS41NyA1My41Mi0xOS42OCAyMi42NHoiLz48L2c+PC9zdmc+"
        },
        "displayName": "ClickUp",
        "typeVersion": 1,
        "nodeCategories": [
          {
            "id": 4,
            "name": "Productivity"
          },
          {
            "id": 6,
            "name": "Communication"
          }
        ]
      },
      {
        "id": 356,
        "icon": "file:gmail.svg",
        "name": "n8n-nodes-base.gmail",
        "codex": {
          "data": {
            "alias": [
              "email",
              "human",
              "form",
              "wait",
              "hitl",
              "approval"
            ],
            "resources": {
              "generic": [
                {
                  "url": "https://n8n.io/blog/why-business-process-automation-with-n8n-can-change-your-daily-life/",
                  "icon": "🧬",
                  "label": "Why business process automation with n8n can change your daily life"
                },
                {
                  "url": "https://n8n.io/blog/supercharging-your-conference-registration-process-with-n8n/",
                  "icon": "🎫",
                  "label": "Supercharging your conference registration process with n8n"
                },
                {
                  "url": "https://n8n.io/blog/no-code-ecommerce-workflow-automations/",
                  "icon": "store",
                  "label": "6 e-commerce workflows to power up your Shopify s"
                },
                {
                  "url": "https://n8n.io/blog/how-to-get-started-with-crm-automation-and-no-code-workflow-ideas/",
                  "icon": "👥",
                  "label": "How to get started with CRM automation (with 3 no-code workflow ideas"
                },
                {
                  "url": "https://n8n.io/blog/automate-google-apps-for-productivity/",
                  "icon": "💡",
                  "label": "15 Google apps you can combine and automate to increase productivity"
                },
                {
                  "url": "https://n8n.io/blog/your-business-doesnt-need-you-to-operate/",
                  "icon": " 🖥️",
                  "label": "Hey founders! Your business doesn't need you to operate"
                },
                {
                  "url": "https://n8n.io/blog/using-automation-to-boost-productivity-in-the-workplace/",
                  "icon": "💪",
                  "label": "Using Automation to Boost Productivity in the Workplace"
                }
              ],
              "primaryDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/app-nodes/n8n-nodes-base.gmail/"
                }
              ],
              "credentialDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/credentials/google/oauth-single-service/"
                }
              ]
            },
            "categories": [
              "Communication",
              "HITL"
            ],
            "nodeVersion": "1.0",
            "codexVersion": "1.0",
            "subcategories": {
              "HITL": [
                "Human in the Loop"
              ]
            }
          }
        },
        "group": "[\"transform\"]",
        "defaults": {
          "name": "Gmail"
        },
        "iconData": {
          "type": "file",
          "fileBuffer": "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNTYiIGhlaWdodD0iMTkzIiBwcmVzZXJ2ZUFzcGVjdFJhdGlvPSJ4TWlkWU1pZCI+PHBhdGggZmlsbD0iIzQyODVGNCIgZD0iTTU4LjE4MiAxOTIuMDVWOTMuMTRMMjcuNTA3IDY1LjA3NyAwIDQ5LjUwNHYxMjUuMDkxYzAgOS42NTggNy44MjUgMTcuNDU1IDE3LjQ1NSAxNy40NTV6Ii8+PHBhdGggZmlsbD0iIzM0QTg1MyIgZD0iTTE5Ny44MTggMTkyLjA1aDQwLjcyN2M5LjY1OSAwIDE3LjQ1NS03LjgyNiAxNy40NTUtMTcuNDU1VjQ5LjUwNWwtMzEuMTU2IDE3LjgzNy0yNy4wMjYgMjUuNzk4eiIvPjxwYXRoIGZpbGw9IiNFQTQzMzUiIGQ9Im01OC4xODIgOTMuMTQtNC4xNzQtMzguNjQ3IDQuMTc0LTM2Ljk4OUwxMjggNjkuODY4bDY5LjgxOC01Mi4zNjQgNC42NyAzNC45OTItNC42NyA0MC42NDRMMTI4IDE0NS41MDR6Ii8+PHBhdGggZmlsbD0iI0ZCQkMwNCIgZD0iTTE5Ny44MTggMTcuNTA0VjkzLjE0TDI1NiA0OS41MDRWMjYuMjMxYzAtMjEuNTg1LTI0LjY0LTMzLjg5LTQxLjg5LTIwLjk0NXoiLz48cGF0aCBmaWxsPSIjQzUyMjFGIiBkPSJtMCA0OS41MDQgMjYuNzU5IDIwLjA3TDU4LjE4MiA5My4xNFYxNy41MDRMNDEuODkgNS4yODZDMjQuNjEtNy42NiAwIDQuNjQ2IDAgMjYuMjN6Ii8+PC9zdmc+"
        },
        "displayName": "Gmail",
        "typeVersion": 2,
        "nodeCategories": [
          {
            "id": 6,
            "name": "Communication"
          },
          {
            "id": 28,
            "name": "HITL"
          }
        ]
      },
      {
        "id": 565,
        "icon": "fa:sticky-note",
        "name": "n8n-nodes-base.stickyNote",
        "codex": {
          "data": {
            "alias": [
              "Comments",
              "Notes",
              "Sticky"
            ],
            "categories": [
              "Core Nodes"
            ],
            "nodeVersion": "1.0",
            "codexVersion": "1.0",
            "subcategories": {
              "Core Nodes": [
                "Helpers"
              ]
            }
          }
        },
        "group": "[\"input\"]",
        "defaults": {
          "name": "Sticky Note",
          "color": "#FFD233"
        },
        "iconData": {
          "icon": "sticky-note",
          "type": "icon"
        },
        "displayName": "Sticky Note",
        "typeVersion": 1,
        "nodeCategories": [
          {
            "id": 9,
            "name": "Core Nodes"
          }
        ]
      },
      {
        "id": 834,
        "icon": "file:code.svg",
        "name": "n8n-nodes-base.code",
        "codex": {
          "data": {
            "alias": [
              "cpde",
              "Javascript",
              "JS",
              "Python",
              "Script",
              "Custom Code",
              "Function"
            ],
            "details": "The Code node allows you to execute JavaScript in your workflow.",
            "resources": {
              "primaryDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/core-nodes/n8n-nodes-base.code/"
                }
              ]
            },
            "categories": [
              "Development",
              "Core Nodes"
            ],
            "nodeVersion": "1.0",
            "codexVersion": "1.0",
            "subcategories": {
              "Core Nodes": [
                "Helpers",
                "Data Transformation"
              ]
            }
          }
        },
        "group": "[\"transform\"]",
        "defaults": {
          "name": "Code"
        },
        "iconData": {
          "type": "file",
          "fileBuffer": "data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTEyIiBoZWlnaHQ9IjUxMiIgdmlld0JveD0iMCAwIDUxMiA1MTIiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMF8xMTcxXzQ0MSkiPgo8cGF0aCBkPSJNMTcwLjI4MyA0OEgxOTYuNUMyMDMuMTI3IDQ4IDIwOC41IDQyLjYyNzQgMjA4LjUgMzZWMTJDMjA4LjUgNS4zNzI1OCAyMDMuMTI3IDAgMTk2LjUgMEgxNzAuMjgzQzEyNi4xIDAgOTAuMjgzIDM1LjgxNzIgOTAuMjgzIDgwVjE3NkM5MC4yODMgMjA2LjkyOCA2NS4yMTA5IDIzMiAzNC4yODMgMjMySDIzQzE2LjM3MjYgMjMyIDExIDIzNy4zNzIgMTEgMjQ0VjI2OEMxMSAyNzQuNjI3IDE2LjM3MjQgMjgwIDIyLjk5OTYgMjgwTDM0LjI4MyAyODBDNjUuMjEwOSAyODAgOTAuMjgzIDMwNS4wNzIgOTAuMjgzIDMzNlY0NDBDOTAuMjgzIDQ3OS43NjQgMTIyLjUxOCA1MTIgMTYyLjI4MyA1MTJIMTk2LjVDMjAzLjEyNyA1MTIgMjA4LjUgNTA2LjYyNyAyMDguNSA1MDBWNDc2QzIwOC41IDQ2OS4zNzMgMjAzLjEyNyA0NjQgMTk2LjUgNDY0SDE2Mi4yODNDMTQ5LjAyOCA0NjQgMTM4LjI4MyA0NTMuMjU1IDEzOC4yODMgNDQwVjMzNkMxMzguMjgzIDMwOS4wMjIgMTI4LjAxMSAyODQuNDQzIDExMS4xNjQgMjY1Ljk2MUMxMDYuMTA5IDI2MC40MTYgMTA2LjEwOSAyNTEuNTg0IDExMS4xNjQgMjQ2LjAzOUMxMjguMDExIDIyNy41NTcgMTM4LjI4MyAyMDIuOTc4IDEzOC4yODMgMTc2VjgwQzEzOC4yODMgNjIuMzI2OSAxNTIuNjEgNDggMTcwLjI4MyA0OFoiIGZpbGw9IiNGRjk5MjIiLz4KPHBhdGggZD0iTTMwNSAzNkMzMDUgNDIuNjI3NCAzMTAuMzczIDQ4IDMxNyA0OEgzNDIuOTc5QzM2MC42NTIgNDggMzc0Ljk3OCA2Mi4zMjY5IDM3NC45NzggODBWMTc2QzM3NC45NzggMjAyLjk3OCAzODUuMjUxIDIyNy41NTcgNDAyLjA5OCAyNDYuMDM5QzQwNy4xNTMgMjUxLjU4NCA0MDcuMTUzIDI2MC40MTYgNDAyLjA5OCAyNjUuOTYxQzM4NS4yNTEgMjg0LjQ0MyAzNzQuOTc4IDMwOS4wMjIgMzc0Ljk3OCAzMzZWNDMyQzM3NC45NzggNDQ5LjY3MyAzNjAuNjUyIDQ2NCAzNDIuOTc5IDQ2NEgzMTdDMzEwLjM3MyA0NjQgMzA1IDQ2OS4zNzMgMzA1IDQ3NlY1MDBDMzA1IDUwNi42MjcgMzEwLjM3MyA1MTIgMzE3IDUxMkgzNDIuOTc5QzM4Ny4xNjEgNTEyIDQyMi45NzggNDc2LjE4MyA0MjIuOTc4IDQzMlYzMzZDNDIyLjk3OCAzMDUuMDcyIDQ0OC4wNTEgMjgwIDQ3OC45NzkgMjgwSDQ5MEM0OTYuNjI3IDI4MCA1MDIgMjc0LjYyOCA1MDIgMjY4VjI0NEM1MDIgMjM3LjM3MyA0OTYuNjI4IDIzMiA0OTAgMjMyTDQ3OC45NzkgMjMyQzQ0OC4wNTEgMjMyIDQyMi45NzggMjA2LjkyOCA0MjIuOTc4IDE3NlY4MEM0MjIuOTc4IDM1LjgxNzIgMzg3LjE2MSAwIDM0Mi45NzkgMEgzMTdDMzEwLjM3MyAwIDMwNSA1LjM3MjU4IDMwNSAxMlYzNloiIGZpbGw9IiNGRjk5MjIiLz4KPC9nPgo8ZGVmcz4KPGNsaXBQYXRoIGlkPSJjbGlwMF8xMTcxXzQ0MSI+CjxyZWN0IHdpZHRoPSI1MTIiIGhlaWdodD0iNTEyIiBmaWxsPSJ3aGl0ZSIvPgo8L2NsaXBQYXRoPgo8L2RlZnM+Cjwvc3ZnPgo="
        },
        "displayName": "Code",
        "typeVersion": 2,
        "nodeCategories": [
          {
            "id": 5,
            "name": "Development"
          },
          {
            "id": 9,
            "name": "Core Nodes"
          }
        ]
      }
    ],
    "categories": [
      {
        "id": 32,
        "name": "Market Research"
      }
    ],
    "image": []
  }
}