{
  "workflow": {
    "id": 9846,
    "name": "Travel itinerary reminders with Google Calendar, Excel, and SMS/Email alerts",
    "views": 530,
    "recentViews": 1,
    "totalViews": 530,
    "createdAt": "2025-10-17T15:10:53.355Z",
    "description": "This automated n8n workflow checks daily travel itineraries, syncs upcoming trips to Google Calendar, and sends reminder notifications to travelers via email or SMS. Perfect for travel agencies, tour operators, and organizations managing group trips to keep travelers informed about their schedules and bookings.\n\n## What This Workflow Does\n\n* Automatically checks travel itineraries every day\n* Identifies today's trips and upcoming departures\n* Syncs trip information to Google Calendar\n* Sends personalized reminders to assigned travelers\n* Tracks reminder delivery status and logs activities\n* Handles both email and SMS notification preferences\n* Provides pre-travel checklists and booking confirmations\n* Manages multi-day trip schedules and activities\n\n## Main Components\n\n* **Daily Travel Check** - Triggers daily to check travel itineraries\n* **Read Travel Itinerary** - Retrieves today's trips and bookings from database/Excel\n* **Filter Today's Trips** - Identifies trips departing today and upcoming activities\n* **Has Trips Today?** - Checks if there are any trips scheduled\n* **Read Traveler Contacts** - Gets traveler contact information for assigned trips\n* **Sync to Google Calendar** - Creates/updates trip events in Google Calendar\n* **Create Traveler Reminders** - Generates personalized reminder messages with travel details\n* **Split Into Batches** - Processes reminders in manageable batches\n* **Email or SMS?** - Routes based on traveler communication preferences\n* **Prepare Email Reminders** - Creates detailed email reminder content with checklists\n* **Prepare SMS Reminders** - Creates SMS reminder content optimized for text\n* **Read Reminder Log** - Checks previous reminder history\n* **Update Reminder Log** - Records sent reminders with timestamps\n* **Save Reminder Log** - Saves updated log data for audit trail\n\n## Essential Prerequisites\n\n* Travel itinerary database/Excel file with trip assignments\n* Traveler contact database with email and phone numbers\n* Google Calendar API access and credentials\n* SMTP server for email notifications\n* SMS service provider (Twilio, Nexmo, etc.) for text reminders\n* Reminder log file for tracking sent notifications\n* Booking confirmation system (flight, hotel, transport)\n\n## Required Data Files\n\n### trip_itinerary.xlsx:\n* Trip ID | Trip Name | Date | Departure Time | Duration\n* Departure Location | Destination | Hotel | Flight Number\n* Assigned Travelers | Status | Booking Reference | Cost\n\n### traveler_contacts.xlsx:\n* Traveler ID | First Name | Last Name | Email | Phone\n* Preferred Contact | Assigned Trips | Passport Number | Emergency Contact\n\n### reminder_log.xlsx:\n* Log ID | Date | Traveler ID | Trip ID | Contact Method\n* Status | Sent Time | Message Preview | Confirmation\n\n## Key Features\n\n* ⏰ **Daily Automation**: Runs automatically every day at scheduled times\n* 📅 **Calendar Sync**: Syncs trips to Google Calendar for easy viewing\n* 📧 **Smart Reminders**: Sends email or SMS based on traveler preference\n* 👥 **Batch Processing**: Handles multiple travelers efficiently\n* 📊 **Activity Logging**: Tracks all reminder activities and delivery status\n* 🔄 **Duplicate Prevention**: Avoids sending multiple reminders\n* 📱 **Multi-Channel**: Supports both email and SMS notifications\n* ✈️ **Travel-Specific**: Includes flight numbers, locations, accommodation details\n* 📋 **Pre-Travel Checklist**: Provides comprehensive packing and document reminders\n* 🌍 **Multi-Destination**: Manages complex multi-stop itineraries\n\n## Quick Setup\n\n1. Import workflow JSON into n8n\n2. Configure daily trigger schedule (recommended: 6 AM and 6 PM)\n3. Set up trip itinerary and traveler contact files\n4. Connect Google Calendar API credentials\n5. Configure SMTP server for emails\n6. Set up SMS service provider (Twilio, Nexmo, or similar)\n7. Map Excel sheet columns to workflow variables\n8. Test with sample trip data\n9. Activate workflow\n\n## Parameters to Configure\n\n* `schedule_file_path`: Path to trip itinerary file\n* `contacts_file_path`: Path to traveler contacts file\n* `reminder_hours`: Hours before departure to send reminder (default: 24)\n* `google_calendar_id`: Google Calendar ID for syncing trips\n* `google_api_credentials`: Google Calendar API credentials\n* `smtp_host`: Email server settings\n* `smtp_user`: Email username\n* `smtp_password`: Email password\n* `sms_api_key`: SMS service API key\n* `sms_phone_number`: SMS sender phone number\n* `reminder_log_path`: Path to reminder log file\n\n## Sample Reminder Messages\n\n**Email Subject**: \"✈️ Travel Reminder: [Trip Name] Today at [Time]\"\n\n**Email Body**:\n```\nHello [Traveler Name],\n\nYour trip is happening today! Here are your travel details:\n\nTrip: [Trip Name]\nDeparture: [Departure Time]\nFrom: [Departure Location]\nTo: [Destination]\nFlight/Transport: [Flight Number]\nHotel: [Hotel Name]\nDuration: [X] days\n\nPre-Travel Checklist:\n☑ Passport and travel documents\n☑ Travel insurance documents\n☑ Hotel confirmations\n☑ Medications and toiletries\n☑ Weather-appropriate clothing\n☑ Phone charger and adapters\n\n⚠️ Please arrive at the departure point 2 hours early!\n\nHave a wonderful trip!\n```\n\n**SMS**: \"✈️ Travel Reminder: '[Trip Name]' departs at [Time] today from [Location]. Arrive 2 hours early! Flight: [Number]\"\n\n**Tomorrow Evening Preview (SMS)**: \"📅 Tomorrow: '[Trip Name]' departs at [Time] from [Location]. Pack tonight! ([X] days)\"\n\n## Use Cases\n\n* Daily trip departure reminders for travelers\n* Last-minute itinerary change notifications\n* Flight cancellation and delay alerts\n* Hotel check-in and checkout reminders\n* Travel document expiration warnings\n* Group tour activity scheduling\n* Adventure/hiking trip departure alerts\n* Business travel itinerary updates\n* Family vacation coordination\n* Study abroad program notifications\n* Multi-city tour route confirmations\n* Transport connection reminders\n\n## Advanced Features\n\n### Reminder Escalation\n* 24-hour reminder: Full details with checklist\n* 6-hour reminder: Quick confirmation with transport details\n* 2-hour reminder: Urgent departure notification\n\n### Conditional Logic\n* Different messages for single-day vs. multi-day trips\n* Domestic vs. international travel variations\n* Group size-based messaging\n* Weather-based travel advisories\n\n### Integration Capabilities\n* Connect to airline APIs for real-time flight status\n* Link to hotel management systems for check-in info\n* Integrate weather services for destination forecasts\n* Sync with payment systems for booking confirmations\n\n## Troubleshooting\n\n| Issue | Solution |\n|-------|----------|\n| Reminders not sending | Check email/SMS credentials and service quotas |\n| Calendar sync failing | Verify Google Calendar API permissions |\n| Duplicate reminders | Check for overlapping reminder time windows |\n| Missing traveler data | Verify contact file formatting and column mapping |\n| Batch processing slow | Reduce batch size in Split Into Batches node |\n\n## Security Considerations\n\n* Store API credentials in n8n environment variables\n* Use OAuth2 for Google Calendar authentication\n* Encrypt sensitive data in reminder logs\n* Implement role-based access to trip data\n* Audit log all reminder activities\n* Comply with GDPR/privacy regulations for traveler data\n\n## Performance Metrics\n\n* **Processing Time**: ~2-5 seconds per 50 travelers\n* **Success Rate**: &gt;99% for delivery logging\n* **Calendar Sync**: Real-time updates\n* **Batch Limit**: 10 travelers per batch (configurable)\n\n## Support & Maintenance\n\n* Review reminder logs weekly for delivery issues\n* Update traveler contacts as needed\n* Monitor email/SMS service quotas\n* Test workflow after system updates\n* Archive old reminder logs monthly",
    "workflow": {
      "id": "HdSUjNHdVNGiveKd",
      "meta": {
        "instanceId": "dd69efaf8212c74ad206700d104739d3329588a6f3f8381a46a481f34c9cc281"
      },
      "name": "Automated Journey Scheduler & SMS/Email Alerts",
      "tags": [],
      "nodes": [
        {
          "id": "2c9cace5-a7fa-4a0f-975d-c10c7f4405ad",
          "name": "Daily Travel Check",
          "type": "n8n-nodes-base.cron",
          "position": [
            -448,
            240
          ],
          "parameters": {},
          "typeVersion": 1
        },
        {
          "id": "5e304a56-4b9c-42dc-84d9-b63f336a5a99",
          "name": "Read Travel Itinerary",
          "type": "n8n-nodes-base.microsoftExcel",
          "position": [
            -224,
            240
          ],
          "parameters": {
            "filters": {}
          },
          "credentials": {
            "microsoftExcelOAuth2Api": {
              "id": "credential-id",
              "name": "microsoftExcelOAuth2Api Credential"
            }
          },
          "typeVersion": 2
        },
        {
          "id": "e41bf01b-ddc7-47cb-b0b8-027016b22fca",
          "name": "Filter Today's Trips",
          "type": "n8n-nodes-base.code",
          "position": [
            0,
            240
          ],
          "parameters": {
            "jsCode": "// Get current date and time\nconst now = new Date();\nconst today = now.toISOString().split('T')[0];\nconst currentHour = now.getHours();\n\n// Get all itinerary data\nconst itineraryData = $input.all();\n\n// Filter trips for today and upcoming reminders\nconst todayTrips = itineraryData.filter(item => {\n  const tripDate = item.json['Trip Date'];\n  const departureTime = item.json['Departure Time'];\n  const reminderHours = item.json['Reminder Hours'] || 24;\n  \n  // Check if trip is today\n  if (tripDate === today) {\n    // Parse departure time\n    const [hours, minutes] = departureTime.split(':');\n    const departureHour = parseInt(hours);\n    \n    // Check if we need to send reminder\n    const hoursUntilTrip = departureHour - currentHour;\n    \n    // Send reminder if within reminder window\n    if (hoursUntilTrip > 0 && hoursUntilTrip <= reminderHours) {\n      return true;\n    }\n  }\n  \n  return false;\n});\n\n// Also get tomorrow's trips for evening prep\nconst tomorrow = new Date(now);\ntomorrow.setDate(tomorrow.getDate() + 1);\nconst tomorrowDate = tomorrow.toISOString().split('T')[0];\n\nconst tomorrowTrips = itineraryData.filter(item => {\n  return item.json['Trip Date'] === tomorrowDate && currentHour >= 18; // After 6 PM\n});\n\n// Combine today's reminders and tomorrow's prep\nconst tripsToProcess = [...todayTrips, ...tomorrowTrips];\n\nreturn tripsToProcess.map(item => ({\n  json: {\n    ...item.json,\n    reminderType: todayTrips.includes(item) ? 'today' : 'tomorrow',\n    currentTime: now.toISOString()\n  }\n}));"
          },
          "typeVersion": 2
        },
        {
          "id": "a978bf0f-96e8-4257-abd0-a10b19dc3143",
          "name": "Has Trips Today?",
          "type": "n8n-nodes-base.if",
          "position": [
            224,
            128
          ],
          "parameters": {
            "conditions": {
              "string": [
                {
                  "value1": "={{$json['Trip Name']}}",
                  "operation": "isNotEmpty"
                }
              ]
            }
          },
          "typeVersion": 1
        },
        {
          "id": "bcd8b022-52db-4095-8f69-6c95f8b1135f",
          "name": "Read Traveler Contacts",
          "type": "n8n-nodes-base.microsoftExcel",
          "position": [
            448,
            128
          ],
          "parameters": {
            "filters": {}
          },
          "credentials": {
            "microsoftExcelOAuth2Api": {
              "id": "credential-id",
              "name": "microsoftExcelOAuth2Api Credential"
            }
          },
          "typeVersion": 2
        },
        {
          "id": "586c2dcb-e203-4817-874b-c52480abe596",
          "name": "Create Traveler Reminders",
          "type": "n8n-nodes-base.code",
          "position": [
            656,
            240
          ],
          "parameters": {
            "jsCode": "// Get trip data and traveler contacts\nconst tripData = $('Filter Today\\'s Trips').all();\nconst travelerContacts = $input.all();\n\n// Create reminder messages for each trip\nconst reminders = [];\n\ntripData.forEach(tripItem => {\n  const tripInfo = tripItem.json;\n  \n  // Find travelers assigned to this trip\n  const assignedTravelers = travelerContacts.filter(traveler => {\n    const travelerTrips = traveler.json['Assigned Trips'] || '';\n    return travelerTrips.includes(tripInfo['Trip Name']);\n  });\n  \n  // Create reminder for each assigned traveler\n  assignedTravelers.forEach(traveler => {\n    const reminderMessage = tripInfo.reminderType === 'today' \n      ? `✈️ Travel Reminder: Your \"${tripInfo['Trip Name']}\" trip departs at ${tripInfo['Departure Time']} today!\\n\\n📍 From: ${tripInfo['Departure Location'] || 'TBD'}\\n📍 To: ${tripInfo['Destination'] || 'TBD'}\\n✈️ Flight/Transport: ${tripInfo['Flight Number'] || 'TBD'}\\n🏨 Accommodation: ${tripInfo['Hotel'] || 'TBD'}\\n\\n⚠️ Please arrive at the departure point 2 hours early. Don't forget your passport and documents!`\n      : `📅 Tomorrow's Trip: \"${tripInfo['Trip Name']}\" departs at ${tripInfo['Departure Time']}\\n\\n📍 From: ${tripInfo['Departure Location'] || 'TBD'}\\n📍 To: ${tripInfo['Destination'] || 'TBD'}\\n✈️ Flight/Transport: ${tripInfo['Flight Number'] || 'TBD'}\\n🏨 Accommodation: ${tripInfo['Hotel'] || 'TBD'}\\n\\n💡 Tip: Pack tonight and prepare your documents!`;\n    \n    reminders.push({\n      json: {\n        travelerName: `${traveler.json['First Name']} ${traveler.json['Last Name']}`,\n        travelerEmail: traveler.json['Email'],\n        travelerPhone: traveler.json['Phone'],\n        tripName: tripInfo['Trip Name'],\n        departureTime: tripInfo['Departure Time'],\n        tripDate: tripInfo['Trip Date'],\n        departureLocation: tripInfo['Departure Location'],\n        destination: tripInfo['Destination'],\n        flightNumber: tripInfo['Flight Number'],\n        hotel: tripInfo['Hotel'],\n        tripDuration: tripInfo['Duration (Days)'],\n        reminderType: tripInfo.reminderType,\n        message: reminderMessage,\n        preferredContact: traveler.json['Preferred Contact'] || 'email'\n      }\n    });\n  });\n});\n\nreturn reminders;"
          },
          "typeVersion": 2
        },
        {
          "id": "7773868f-847a-4e2c-b3f8-d9c46342235b",
          "name": "Split Into Batches",
          "type": "n8n-nodes-base.splitInBatches",
          "position": [
            1088,
            240
          ],
          "parameters": {
            "options": {},
            "batchSize": 10
          },
          "typeVersion": 3
        },
        {
          "id": "4b4296c2-4710-49e0-9272-c5dc39e4e7d2",
          "name": "Email or SMS?",
          "type": "n8n-nodes-base.if",
          "position": [
            1312,
            240
          ],
          "parameters": {
            "conditions": {
              "string": [
                {
                  "value1": "={{$json.preferredContact}}",
                  "value2": "email"
                }
              ]
            }
          },
          "typeVersion": 1
        },
        {
          "id": "0c27ad59-6f7b-49ea-93a9-93529773438f",
          "name": "Prepare Email Reminders",
          "type": "n8n-nodes-base.code",
          "position": [
            1536,
            128
          ],
          "parameters": {
            "jsCode": "// Prepare email data for trip reminders\nconst reminderData = $input.all();\n\nconst emailsToSend = reminderData.map(item => {\n  const data = item.json;\n  \n  const subject = data.reminderType === 'today' \n    ? `✈️ Travel Reminder: ${data.tripName} Today`\n    : `📅 Tomorrow's Trip: ${data.tripName}`;\n  \n  const htmlBody = `\n    <!DOCTYPE html>\n    <html>\n    <head>\n        <style>\n            body { font-family: Arial, sans-serif; color: #333; margin: 0; padding: 20px; }\n            .container { max-width: 600px; margin: 0 auto; }\n            .header { background: linear-gradient(135deg, #1e90ff 0%, #4169e1 100%); color: white; padding: 20px; border-radius: 8px 8px 0 0; text-align: center; }\n            .content { background: #f9f9f9; padding: 25px; border-radius: 0 0 8px 8px; }\n            .trip-info { background: white; padding: 20px; border-radius: 8px; margin: 15px 0; border-left: 4px solid #1e90ff; }\n            .info-row { margin: 10px 0; }\n            .info-label { font-weight: bold; color: #1e90ff; }\n            .footer { text-align: center; margin-top: 20px; color: #666; font-size: 12px; }\n            .emoji { font-size: 18px; }\n            .checklist { background: #fffbea; padding: 15px; border-radius: 8px; margin: 15px 0; border-left: 4px solid #ffa500; }\n        </style>\n    </head>\n    <body>\n        <div class=\"container\">\n            <div class=\"header\">\n                <h1><span class=\"emoji\">✈️</span> Travel ${data.reminderType === 'today' ? 'Reminder' : 'Preview'}</h1>\n            </div>\n            <div class=\"content\">\n                <p>Hello ${data.travelerName},</p>\n                <p>${data.reminderType === 'today' ? 'Your trip is happening today!' : 'Get ready for tomorrow\\'s adventure!'}</p>\n                \n                <div class=\"trip-info\">\n                    <div class=\"info-row\"><span class=\"info-label\">✈️ Trip:</span> ${data.tripName}</div>\n                    <div class=\"info-row\"><span class=\"info-label\">🕐 Departure:</span> ${data.departureTime}</div>\n                    <div class=\"info-row\"><span class=\"info-label\">📅 Date:</span> ${data.tripDate}</div>\n                    <div class=\"info-row\"><span class=\"info-label\">📍 From:</span> ${data.departureLocation || 'TBD'}</div>\n                    <div class=\"info-row\"><span class=\"info-label\">📍 To:</span> ${data.destination || 'TBD'}</div>\n                    <div class=\"info-row\"><span class=\"info-label\">🛫 Flight/Transport:</span> ${data.flightNumber || 'TBD'}</div>\n                    <div class=\"info-row\"><span class=\"info-label\">🏨 Hotel:</span> ${data.hotel || 'TBD'}</div>\n                    <div class=\"info-row\"><span class=\"info-label\">📆 Duration:</span> ${data.tripDuration || 'N/A'} days</div>\n                </div>\n                \n                <div class=\"checklist\">\n                    <strong>📋 Pre-Travel Checklist:</strong>\n                    <ul>\n                        <li>Passport and travel documents</li>\n                        <li>Travel insurance documents</li>\n                        <li>Hotel confirmations and bookings</li>\n                        <li>Medications and toiletries</li>\n                        <li>Weather-appropriate clothing</li>\n                        <li>Phone charger and adapters</li>\n                    </ul>\n                </div>\n                \n                ${data.reminderType === 'today' \n                  ? '<p><strong>⚠️ Please arrive at the departure point 2 hours early!</strong></p>'\n                  : '<p><strong>💡 Tip: Pack and prepare your documents tonight for a stress-free departure tomorrow!</strong></p>'\n                }\n                \n                <p>Have a wonderful trip!</p>\n            </div>\n            <div class=\"footer\">\n                <p>This is an automated reminder from your travel management system.</p>\n            </div>\n        </div>\n    </body>\n    </html>\n  `;\n  \n  return {\n    json: {\n      to: data.travelerEmail,\n      subject: subject,\n      body: data.message,\n      html: htmlBody,\n      travelerName: data.travelerName,\n      tripName: data.tripName\n    }\n  };\n});\n\nreturn emailsToSend;"
          },
          "typeVersion": 2
        },
        {
          "id": "71d0ce98-bcb5-4b70-9be8-a3bc7264c8a7",
          "name": "Prepare SMS Reminders",
          "type": "n8n-nodes-base.code",
          "position": [
            1536,
            336
          ],
          "parameters": {
            "jsCode": "// Prepare SMS data for travel reminders\nconst reminderData = $input.all();\n\nconst smsToSend = reminderData.map(item => {\n  const data = item.json;\n  \n  const smsMessage = data.reminderType === 'today'\n    ? `✈️ Travel Reminder: \"${data.tripName}\" departs at ${data.departureTime} today from ${data.departureLocation || 'TBD'}. Arrive 2 hours early! Flight: ${data.flightNumber || 'N/A'}`\n    : `📅 Tomorrow: \"${data.tripName}\" departs at ${data.departureTime} from ${data.departureLocation || 'TBD'}. Pack tonight! (${data.tripDuration || '?'} days)`;\n  \n  return {\n    json: {\n      to: data.travelerPhone,\n      message: smsMessage,\n      travelerName: data.travelerName,\n      tripName: data.tripName\n    }\n  };\n});\n\nreturn smsToSend;"
          },
          "typeVersion": 2
        },
        {
          "id": "bd8a65eb-1712-42ce-82de-f9b6525a2a00",
          "name": "Sync to Google Calendar",
          "type": "n8n-nodes-base.googleCalendar",
          "position": [
            448,
            336
          ],
          "parameters": {
            "end": "={{$json['Trip Date']}}T{{(parseInt($json['Departure Time'].split(':')[0]) + 12).toString().padStart(2, '0')}}:{{$json['Departure Time'].split(':')[1].padStart(2, '0')}}:00",
            "start": "={{$json['Trip Date']}}T{{$json['Departure Time'].split(':')[0].padStart(2, '0')}}:{{$json['Departure Time'].split(':')[1].padStart(2, '0')}}:00",
            "calendar": {
              "__rl": true,
              "mode": "id",
              "value": "user@example.com"
            },
            "additionalFields": {}
          },
          "credentials": {
            "googleCalendarOAuth2Api": {
              "id": "credential-id",
              "name": "googleCalendarOAuth2Api Credential"
            }
          },
          "typeVersion": 1
        },
        {
          "id": "7cd24c85-ebc9-488a-ba09-0d038aed0600",
          "name": "Read Reminder Log",
          "type": "n8n-nodes-base.microsoftExcel",
          "position": [
            1744,
            240
          ],
          "parameters": {
            "filters": {}
          },
          "credentials": {
            "microsoftExcelOAuth2Api": {
              "id": "credential-id",
              "name": "microsoftExcelOAuth2Api Credential"
            }
          },
          "typeVersion": 2
        },
        {
          "id": "fec45952-9b13-4611-89da-5dda16dc9895",
          "name": "Update Reminder Log",
          "type": "n8n-nodes-base.code",
          "position": [
            1968,
            240
          ],
          "parameters": {
            "jsCode": "// Get existing log data\nconst existingLogs = $input.all();\n\n// Get sent reminders data\nconst sentEmails = $('Prepare Email Reminders').all() || [];\nconst sentSMS = $('Prepare SMS Reminders').all() || [];\n\n// Create log entries for sent reminders\nconst newLogEntries = [];\n\n// Log email reminders\nsentEmails.forEach(email => {\n  newLogEntries.push({\n    'Log ID': 'LOG-' + Date.now() + '-' + Math.random().toString(36).substr(2, 9),\n    'Timestamp': new Date().toISOString(),\n    'Traveler Name': email.json.travelerName,\n    'Trip Name': email.json.tripName,\n    'Contact Method': 'Email',\n    'Contact Info': email.json.to,\n    'Status': 'Sent',\n    'Reminder Type': 'Travel Reminder',\n    'Message Preview': email.json.subject\n  });\n});\n\n// Log SMS reminders\nsentSMS.forEach(sms => {\n  newLogEntries.push({\n    'Log ID': 'LOG-' + Date.now() + '-' + Math.random().toString(36).substr(2, 9),\n    'Timestamp': new Date().toISOString(),\n    'Traveler Name': sms.json.travelerName,\n    'Trip Name': sms.json.tripName,\n    'Contact Method': 'SMS',\n    'Contact Info': sms.json.to,\n    'Status': 'Sent',\n    'Reminder Type': 'Travel Reminder',\n    'Message Preview': sms.json.message.substring(0, 50) + '...'\n  });\n});\n\n// Combine existing logs with new entries\nconst allLogs = [...existingLogs, ...newLogEntries];\n\nreturn allLogs.map(item => ({ json: item }));"
          },
          "typeVersion": 2
        },
        {
          "id": "3b8caca5-4c45-484b-860f-17ef4ea2566b",
          "name": "Save Reminder Log",
          "type": "n8n-nodes-base.microsoftExcel",
          "position": [
            2192,
            240
          ],
          "parameters": {
            "options": {},
            "resource": "worksheet",
            "workbook": {
              "__rl": true,
              "mode": "id",
              "value": "3456yuhh"
            },
            "operation": "append",
            "worksheet": {
              "__rl": true,
              "mode": "id",
              "value": "=23456yuytrewerfgn"
            }
          },
          "credentials": {
            "microsoftExcelOAuth2Api": {
              "id": "credential-id",
              "name": "microsoftExcelOAuth2Api Credential"
            }
          },
          "typeVersion": 2
        },
        {
          "id": "aed8c63f-1c9d-43a3-b514-8b971303a377",
          "name": "Wait For Data",
          "type": "n8n-nodes-base.wait",
          "position": [
            864,
            240
          ],
          "webhookId": "fbd474eb-c62b-4953-bf0f-a745253bfcb0",
          "parameters": {
            "amount": 15
          },
          "typeVersion": 1.1
        },
        {
          "id": "c32a8171-99f7-4a2f-9b13-c70de6b93e02",
          "name": "Sticky Note",
          "type": "n8n-nodes-base.stickyNote",
          "position": [
            288,
            -256
          ],
          "parameters": {
            "color": 3,
            "width": 624,
            "height": 272,
            "content": "## What This Workflow Does\n\n* Automatically checks travel itineraries every day\n* Identifies today's trips and upcoming departures\n* Syncs trip information to Google Calendar\n* Sends personalized reminders to assigned travelers\n* Tracks reminder delivery status and logs activities\n* Handles both email and SMS notification preferences\n* Provides pre-travel checklists and booking confirmations\n* Manages multi-day trip schedules and activities"
          },
          "typeVersion": 1
        },
        {
          "id": "8bb24600-34ec-4f10-a221-4d900ad777b4",
          "name": "Sticky Note1",
          "type": "n8n-nodes-base.stickyNote",
          "position": [
            336,
            -576
          ],
          "parameters": {
            "width": 560,
            "height": 240,
            "content": "## Essential Prerequisites\n\n* Travel itinerary database/Excel file with trip assignments\n* Traveler contact database with email and phone numbers\n* Google Calendar API access and credentials\n* SMTP server for email notifications\n* SMS service provider (Twilio, Nexmo, etc.) for text reminders\n* Reminder log file for tracking sent notifications\n* Booking confirmation system (flight, hotel, transport)"
          },
          "typeVersion": 1
        },
        {
          "id": "24480f08-45ae-418e-a086-aaea9b8648a3",
          "name": "Sticky Note2",
          "type": "n8n-nodes-base.stickyNote",
          "position": [
            960,
            -672
          ],
          "parameters": {
            "color": 4,
            "width": 512,
            "height": 816,
            "content": "## Required Data Files\n\n### trip_itinerary.xlsx:\n* Trip ID | Trip Name | Date | Departure Time | Duration\n* Departure Location | Destination | Hotel | Flight Number\n* Assigned Travelers | Status | Booking Reference | Cost\n\n### traveler_contacts.xlsx:\n* Traveler ID | First Name | Last Name | Email | Phone\n* Preferred Contact | Assigned Trips | Passport Number | Emergency Contact\n\n### reminder_log.xlsx:\n* Log ID | Date | Traveler ID | Trip ID | Contact Method\n* Status | Sent Time | Message Preview | Confirmation\n\n## Key Features\n\n* ⏰ **Daily Automation**: Runs automatically every day at scheduled times\n* 📅 **Calendar Sync**: Syncs trips to Google Calendar for easy viewing\n* 📧 **Smart Reminders**: Sends email or SMS based on traveler preference\n* 👥 **Batch Processing**: Handles multiple travelers efficiently\n* 📊 **Activity Logging**: Tracks all reminder activities and delivery status\n* 🔄 **Duplicate Prevention**: Avoids sending multiple reminders\n* 📱 **Multi-Channel**: Supports both email and SMS notifications\n* ✈️ **Travel-Specific**: Includes flight numbers, locations, accommodation details\n* 📋 **Pre-Travel Checklist**: Provides comprehensive packing and document reminders\n* 🌍 **Multi-Destination**: Manages complex multi-stop itineraries\n"
          },
          "typeVersion": 1
        },
        {
          "id": "f3b7fd2c-3fd6-4fc1-aff2-94241fb42a28",
          "name": "Sticky Note3",
          "type": "n8n-nodes-base.stickyNote",
          "position": [
            -464,
            -528
          ],
          "parameters": {
            "color": 5,
            "width": 640,
            "height": 416,
            "content": "## Main Components\n\n* **Daily Travel Check** - Triggers daily to check travel itineraries\n* **Read Travel Itinerary** - Retrieves today's trips and bookings from database/Excel\n* **Filter Today's Trips** - Identifies trips departing today and upcoming activities\n* **Has Trips Today?** - Checks if there are any trips scheduled\n* **Read Traveler Contacts** - Gets traveler contact information for assigned trips\n* **Sync to Google Calendar** - Creates/updates trip events in Google Calendar\n* **Create Traveler Reminders** - Generates personalized reminder messages with travel details\n* **Split Into Batches** - Processes reminders in manageable batches\n* **Email or SMS?** - Routes based on traveler communication preferences\n* **Prepare Email Reminders** - Creates detailed email reminder content with checklists\n* **Prepare SMS Reminders** - Creates SMS reminder content optimized for text\n* **Read Reminder Log** - Checks previous reminder history\n* **Update Reminder Log** - Records sent reminders with timestamps\n* **Save Reminder Log** - Saves updated log data for audit trail"
          },
          "typeVersion": 1
        }
      ],
      "active": false,
      "pinData": {},
      "settings": {
        "executionOrder": "v1"
      },
      "versionId": "c42adac1-72fc-44c6-bcc9-b314a49fa442",
      "connections": {
        "Email or SMS?": {
          "main": [
            [
              {
                "node": "Prepare Email Reminders",
                "type": "main",
                "index": 0
              }
            ],
            [
              {
                "node": "Prepare SMS Reminders",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Wait For Data": {
          "main": [
            [
              {
                "node": "Split Into Batches",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Has Trips Today?": {
          "main": [
            [
              {
                "node": "Read Traveler Contacts",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Read Reminder Log": {
          "main": [
            [
              {
                "node": "Update Reminder Log",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Daily Travel Check": {
          "main": [
            [
              {
                "node": "Read Travel Itinerary",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Split Into Batches": {
          "main": [
            [
              {
                "node": "Email or SMS?",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Update Reminder Log": {
          "main": [
            [
              {
                "node": "Save Reminder Log",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Filter Today's Trips": {
          "main": [
            [
              {
                "node": "Has Trips Today?",
                "type": "main",
                "index": 0
              },
              {
                "node": "Sync to Google Calendar",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Prepare SMS Reminders": {
          "main": [
            [
              {
                "node": "Read Reminder Log",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Read Travel Itinerary": {
          "main": [
            [
              {
                "node": "Filter Today's Trips",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Read Traveler Contacts": {
          "main": [
            [
              {
                "node": "Create Traveler Reminders",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Prepare Email Reminders": {
          "main": [
            [
              {
                "node": "Read Reminder Log",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Sync to Google Calendar": {
          "main": [
            [
              {
                "node": "Create Traveler Reminders",
                "type": "main",
                "index": 0
              }
            ]
          ]
        },
        "Create Traveler Reminders": {
          "main": [
            [
              {
                "node": "Wait For Data",
                "type": "main",
                "index": 0
              }
            ]
          ]
        }
      }
    },
    "lastUpdatedBy": 1,
    "workflowInfo": {
      "nodeCount": 19,
      "nodeTypes": {
        "n8n-nodes-base.if": {
          "count": 2
        },
        "n8n-nodes-base.code": {
          "count": 5
        },
        "n8n-nodes-base.cron": {
          "count": 1
        },
        "n8n-nodes-base.wait": {
          "count": 1
        },
        "n8n-nodes-base.stickyNote": {
          "count": 4
        },
        "n8n-nodes-base.googleCalendar": {
          "count": 1
        },
        "n8n-nodes-base.microsoftExcel": {
          "count": 4
        },
        "n8n-nodes-base.splitInBatches": {
          "count": 1
        }
      }
    },
    "status": "published",
    "user": {
      "name": "Oneclick AI Squad",
      "username": "oneclick-ai",
      "bio": "The AI Squad Initiative is a pioneering effort to build, automate and scale AI-powered workflows using n8n.io. Our mission is to help individuals and businesses integrate AI agents seamlessly into their daily operations  from automating tasks and enhancing productivity to creating innovative, intelligent solutions. We design modular, reusable AI workflow templates that empower creators, developers and teams to supercharge their automation with minimal effort and maximum impact.",
      "verified": true,
      "links": [
        "https://www.oneclickitsolution.com/"
      ],
      "avatar": "https://gravatar.com/avatar/848fca91367142f65f9e5c55d64e5c9952b160d7b060d103b52aa343c6bc7b3d?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": 20,
        "icon": "fa:map-signs",
        "name": "n8n-nodes-base.if",
        "codex": {
          "data": {
            "alias": [
              "Router",
              "Filter",
              "Condition",
              "Logic",
              "Boolean",
              "Branch"
            ],
            "details": "The IF node can be used to implement binary conditional logic in your workflow. You can set up one-to-many conditions to evaluate each item of data being inputted into the node. That data will either evaluate to TRUE or FALSE and route out of the node accordingly.\n\nThis node has multiple types of conditions: Bool, String, Number, and Date & Time.",
            "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/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/create-a-toxic-language-detector-for-telegram/",
                  "icon": "🤬",
                  "label": "Create a toxic language detector for Telegram in 4 step"
                },
                {
                  "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/automation-for-maintainers-of-open-source-projects/",
                  "icon": "🏷️",
                  "label": "How to automatically manage contributions to open-source projects"
                },
                {
                  "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/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/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-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/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.if/"
                }
              ]
            },
            "categories": [
              "Core Nodes"
            ],
            "nodeVersion": "1.0",
            "codexVersion": "1.0",
            "subcategories": {
              "Core Nodes": [
                "Flow"
              ]
            }
          }
        },
        "group": "[\"transform\"]",
        "defaults": {
          "name": "If",
          "color": "#408000"
        },
        "iconData": {
          "icon": "map-signs",
          "type": "icon"
        },
        "displayName": "If",
        "typeVersion": 2,
        "nodeCategories": [
          {
            "id": 9,
            "name": "Core Nodes"
          }
        ]
      },
      {
        "id": 39,
        "icon": "fa:sync",
        "name": "n8n-nodes-base.splitInBatches",
        "codex": {
          "data": {
            "alias": [
              "Loop",
              "Concatenate",
              "Batch",
              "Split",
              "Split In Batches"
            ],
            "resources": {
              "generic": [
                {
                  "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/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"
                }
              ],
              "primaryDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/core-nodes/n8n-nodes-base.splitinbatches/"
                }
              ]
            },
            "categories": [
              "Core Nodes"
            ],
            "nodeVersion": "1.0",
            "codexVersion": "1.0",
            "subcategories": {
              "Core Nodes": [
                "Flow"
              ]
            }
          }
        },
        "group": "[\"organization\"]",
        "defaults": {
          "name": "Loop Over Items",
          "color": "#007755"
        },
        "iconData": {
          "icon": "sync",
          "type": "icon"
        },
        "displayName": "Loop Over Items (Split in Batches)",
        "typeVersion": 3,
        "nodeCategories": [
          {
            "id": 9,
            "name": "Core Nodes"
          }
        ]
      },
      {
        "id": 317,
        "icon": "file:googleCalendar.svg",
        "name": "n8n-nodes-base.googleCalendar",
        "codex": {
          "data": {
            "resources": {
              "generic": [
                {
                  "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/supercharging-your-conference-registration-process-with-n8n/",
                  "icon": "🎫",
                  "label": "Supercharging your conference registration process with 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/5-workflow-automations-for-mattermost-that-we-love-at-n8n/",
                  "icon": "🤖",
                  "label": "5 workflow automation for Mattermost that we love at 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"
                }
              ],
              "primaryDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/app-nodes/n8n-nodes-base.googlecalendar/"
                }
              ],
              "credentialDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/credentials/google/oauth-single-service/"
                }
              ]
            },
            "categories": [
              "Productivity"
            ],
            "nodeVersion": "1.0",
            "codexVersion": "1.0"
          }
        },
        "group": "[\"input\"]",
        "defaults": {
          "name": "Google Calendar"
        },
        "iconData": {
          "type": "file",
          "fileBuffer": "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiBmaWxsPSIjZmZmIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIHN0cm9rZT0iIzAwMCIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIiB2aWV3Qm94PSIwIDAgODEgODIiPjx1c2UgeGxpbms6aHJlZj0iI2EiIHg9Ii41IiB5PSIuNSIvPjxzeW1ib2wgaWQ9ImEiIG92ZXJmbG93PSJ2aXNpYmxlIj48ZyBmaWxsLXJ1bGU9Im5vbnplcm8iIHN0cm9rZT0ibm9uZSI+PHBhdGggZD0iTTYxLjA1MiAxOC45NDdIMTguOTQ3djQyLjEwNWg0Mi4xMDV6Ii8+PHBhdGggZmlsbD0iI2VhNDMzNSIgZD0iTTYxLjA1MyA4MCA4MCA2MS4wNTNINjEuMDUzeiIvPjxwYXRoIGZpbGw9IiNmYmJjMDQiIGQ9Ik04MCAxOC45NDdINjEuMDUzdjQyLjEwNUg4MHoiLz48cGF0aCBmaWxsPSIjMzRhODUzIiBkPSJNNjEuMDUyIDYxLjA1M0gxOC45NDdWODBoNDIuMTA1eiIvPjxwYXRoIGZpbGw9IiMxODgwMzgiIGQ9Ik0wIDYxLjA1M3YxMi42MzJBNi4zMTQgNi4zMTQgMCAwIDAgNi4zMTYgODBoMTIuNjMyVjYxLjA1M3oiLz48cGF0aCBmaWxsPSIjMTk2N2QyIiBkPSJNODAgMTguOTQ3VjYuMzE2QTYuMzE0IDYuMzE0IDAgMCAwIDczLjY4NSAwSDYxLjA1M3YxOC45NDd6Ii8+PHBhdGggZmlsbD0iIzQyODVmNCIgZD0iTTYxLjA1MyAwSDYuMzE2QTYuMzE0IDYuMzE0IDAgMCAwIDAgNi4zMTZ2NTQuNzM3aDE4Ljk0N1YxOC45NDdoNDIuMTA1VjB6TTI3LjU4NCA1MS42MTFjLTEuNTc0LTEuMDYzLTIuNjYzLTIuNjE2LTMuMjU4LTQuNjY4bDMuNjUzLTEuNTA1cS40OTggMS44OTQgMS43MzcgMi45MzdjMS4yMzkgMS4wNDMgMS44MjEgMS4wMzcgMi45ODkgMS4wMzdxMS43OTIgMCAzLjA3OS0xLjA4OWMxLjI4Ny0xLjA4OSAxLjI5LTEuNjUzIDEuMjktMi43NzRhMy40NCAzLjQ0IDAgMCAwLTEuMzU4LTIuODExYy0uOTA1LS43MjctMi4wNDItMS4wODktMy40LTEuMDg5aC0yLjExMXYtMy42MTZIMzIuMXExLjc1MiAwIDIuOTUzLS45NDdjMS4yMDEtLjk0NyAxLjItMS40OTUgMS4yLTIuNTk1cTAtMS40NjctMS4wNzQtMi4zNDJjLTEuMDc0LS44NzUtMS42MjEtLjg3OS0yLjcyMS0uODc5cS0xLjYxLS4wMDItMi41NTguODU4Yy0uOTQ4Ljg2LTEuMTA2IDEuMzAxLTEuMzc5IDIuMTExbC0zLjYxNi0xLjUwNWMuNDc5LTEuMzU4IDEuMzU4LTIuNTU4IDIuNjQ3LTMuNTk1czIuOTM3LTEuNTU4IDQuOTM3LTEuNTU4cTIuMjItLjAwMiAzLjk4OS44NThjMS43NjkuODYgMi4xMDUgMS4zNjggMi43NzQgMi4zNzlzMSAyLjE1MyAxIDMuNDE2cTAgMS45MzItLjkzMiAzLjI3NGMtLjkzMiAxLjM0Mi0xLjM4NCAxLjU3OS0yLjI4OSAyLjA1OHYuMjE2YTYuOTUgNi45NSAwIDAgMSAyLjkzNyAyLjI4OXExLjE0NiAxLjUzOCAxLjE0NyAzLjY4NGMuMDAxIDIuMTQ2LS4zNjMgMi43MTEtMS4wODkgMy44MzJzLTEuNzMyIDIuMDA1LTMuMDA1IDIuNjQ3Yy0xLjI3OS42NDItMi43MTYuOTY4LTQuMzExLjk2OC0xLjg0Ny4wMDUtMy41NTMtLjUyNi01LjEyNi0xLjU4OXptMjIuNDM3LTE4LjEyNi00LjAxIDIuOS0yLjAwNS0zLjA0MiA3LjE5NS01LjE4OWgyLjc1OHYyNC40NzloLTMuOTM3VjMzLjQ4NHoiLz48L2c+PC9zeW1ib2w+PC9zdmc+"
        },
        "displayName": "Google Calendar",
        "typeVersion": 1,
        "nodeCategories": [
          {
            "id": 4,
            "name": "Productivity"
          }
        ]
      },
      {
        "id": 322,
        "icon": "file:excel.svg",
        "name": "n8n-nodes-base.microsoftExcel",
        "codex": {
          "data": {
            "alias": [
              "_Excel",
              "Excel",
              "Sheet",
              "CSV",
              "Spreadsheet"
            ],
            "resources": {
              "primaryDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/app-nodes/n8n-nodes-base.microsoftexcel/"
                }
              ],
              "credentialDocumentation": [
                {
                  "url": "https://docs.n8n.io/integrations/builtin/credentials/microsoft/"
                }
              ]
            },
            "categories": [
              "Data & Storage",
              "Productivity"
            ],
            "nodeVersion": "1.0",
            "codexVersion": "1.0"
          }
        },
        "group": "[\"input\"]",
        "defaults": {
          "name": "Microsoft Excel 365"
        },
        "iconData": {
          "type": "file",
          "fileBuffer": "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI2MCIgaGVpZ2h0PSI2MCI+PGcgZmlsbD0iIzAyNzIzQiIgZmlsbC1ydWxlPSJldmVub2RkIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiPjxwYXRoIGQ9Ik00My4xIDIwLjIyN2g5LjUxMnY0LjY5MmgtOS41MTN6bTAtNy4wMzRoOS41MTJ2NC42OWgtOS41MTN6bTAgMTQuMjI3aDkuNTEydjQuNjkxaC05LjUxM3ptMCA3LjAzNmg5LjUxMnY0LjY5MWgtOS41MTN6Ii8+PHBhdGggZD0iTTQzLjEgNDEuNjQ5aDkuNTEydjQuNjloLTkuNTEzek01OC4wNyA2Ljc4SDM1LjE0NlYuMzdMLjM3IDYuNDY3djQ3LjIybDM0Ljc3NiA1Ljk0MnYtNy4xODZINTguMDdjLjkzNSAwIDEuNTU5LS43ODEgMS41NTktMS41NTVWOC4zNDRjMC0uNzgxLS42MjQtMS41NTUtMS41Ni0xLjU1NVY2Ljc4ek0yMC4wMTggNDAuNTU0bC0zLjI3NC04LjU5M2gtLjE0OGMwIC4xNDktMy4yNzUgOC4xMy0zLjI3NSA4LjEzbC00LjM2Ni0uMzEyTDE0LjEgMjkuNjE2IDkuNDIyIDE5LjQ1M2w0LjM2Ny0uMzEyIDIuOTYzIDcuOTc0aC4xNDhjMC0uMTQ4IDMuMjc0LTguMjg3IDMuMjc0LTguMjg3bDQuNTIyLS4zMTItNS40NTcgMTEuMTAxIDUuNjE0IDExLjEwMi00LjgzNC0uMTQ5ek01Ny42IDUwLjcxN0gzNS4xNDZ2LTQuMzdoNS40NTh2LTQuNjkxaC01LjQ1OHYtMi4zNTJoNS40NTh2LTQuNjloLTUuNDU4di0yLjM0N2g1LjQ1OHYtNC42OWgtNS40NThWMjUuMjNoNS40NTh2LTQuNjloLTUuNDU4di0yLjM0NWg1LjQ1OHYtNC42OTJoLTUuNDU4di00LjY5aDIyLjQ1NnY0MS45MDNoLS4wMDF6Ii8+PHBhdGggZD0iTTQyLjcyOSAxOS44NTdoOS41MTJ2NC42OTFINDIuNzN6bTAtNy4wMzVoOS41MTJ2NC42OTFINDIuNzN6bTAgMTQuMjI4aDkuNTEydjQuNjlINDIuNzN6bTAgNy4wMzZoOS41MTJ2NC42OTFINDIuNzN6Ii8+PHBhdGggZD0iTTQyLjcyOSA0MS4yNzloOS41MTJ2NC42OUg0Mi43M3pNNTcuNjk5IDYuNDFIMzQuNzc2VjBMMCA2LjA5OHY0Ny4yMmwzNC43NzYgNS45NDF2LTcuMTg1aDIyLjkyM2MuOTM2IDAgMS41Ni0uNzgxIDEuNTYtMS41NTVWNy45NzRjMC0uNzgxLS42MjQtMS41NTUtMS41Ni0xLjU1NXpNMTkuNjQ3IDQwLjE4NGwtMy4yNzQtOC41OTNoLS4xNDhjMCAuMTQ4LTMuMjc0IDguMTMtMy4yNzQgOC4xM2wtNC4zNjctLjMxMiA1LjE0Ni0xMC4xNjMtNC42NzgtMTAuMTYzIDQuMzY3LS4zMTMgMi45NjIgNy45NzRoLjE0OWMwLS4xNDggMy4yNzQtOC4yODYgMy4yNzQtOC4yODZsNC41MjItLjMxMy01LjQ1OCAxMS4xMDIgNS42MTUgMTEuMTAxLTQuODM0LS4xNDh6TTU3LjIzIDUwLjM0N0gzNC43NzZ2LTQuMzdoNS40NTd2LTQuNjkyaC01LjQ1N3YtMi4zNTJoNS40NTd2LTQuNjloLTUuNDU3di0yLjM0N2g1LjQ1N3YtNC42OWgtNS40NTdWMjQuODZoNS40NTd2LTQuNjloLTUuNDU3di0yLjM0Nmg1LjQ1N3YtNC42OTJoLTUuNDU3di00LjY5aDIyLjQ1NnY0MS45MDR6Ii8+PC9nPjwvc3ZnPg=="
        },
        "displayName": "Microsoft Excel 365",
        "typeVersion": 2,
        "nodeCategories": [
          {
            "id": 3,
            "name": "Data & Storage"
          },
          {
            "id": 4,
            "name": "Productivity"
          }
        ]
      },
      {
        "id": 514,
        "icon": "fa:pause-circle",
        "name": "n8n-nodes-base.wait",
        "codex": {
          "data": {
            "alias": [
              "pause",
              "sleep",
              "delay",
              "timeout"
            ],
            "resources": {
              "generic": [
                {
                  "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/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.wait/"
                }
              ]
            },
            "categories": [
              "Core Nodes"
            ],
            "nodeVersion": "1.0",
            "codexVersion": "1.0",
            "subcategories": {
              "Core Nodes": [
                "Helpers",
                "Flow"
              ]
            }
          }
        },
        "group": "[\"organization\"]",
        "defaults": {
          "name": "Wait",
          "color": "#804050"
        },
        "iconData": {
          "icon": "pause-circle",
          "type": "icon"
        },
        "displayName": "Wait",
        "typeVersion": 1,
        "nodeCategories": [
          {
            "id": 9,
            "name": "Core Nodes"
          }
        ]
      },
      {
        "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": 40,
        "name": "Support Chatbot"
      },
      {
        "id": 47,
        "name": "AI Chatbot"
      }
    ],
    "image": []
  }
}