calendar-automation

Automate Google Calendar and Outlook scheduling, time blocking, meeting prep, and daily digests with Slack and Sheets integration. Supports five core workflows: daily calendar digests to Slack, one-hour-before meeting prep automation, smart weekly time blocking, Calendly booking synchronization, and calendar analytics reporting Includes pre-built templates for maker and manager schedules, with configurable time blocking rules (minimum gaps, max meetings per day, focus block allocation) Integrates with Slack notifications, Google Sheets logging, CRM systems (HubSpot), and attendee research tools (LinkedIn, email search) Generates meeting prep documents with attendee profiles, context from past interactions, and AI-suggested agendas and talking points Provides weekly analytics covering time distribution, meeting quality metrics, productivity scoring, and fragmentation analysis

INSTALLATION
npx skills add https://github.com/claude-office-skills/skills --skill calendar-automation
Run in your project or agent environment. Adjust flags if your CLI version differs.

SKILL.md

Calendar Automation

Automate Google Calendar and Outlook workflows for meeting management, time blocking, daily digests, and cross-platform synchronization. Based on n8n workflow templates.

Overview

This skill covers:

  • Meeting scheduling automation
  • Time blocking strategies
  • Daily calendar digests to Slack
  • Meeting prep reminders
  • Calendar analytics

Core Workflows

1. Daily Calendar Digest to Slack

workflow: "Morning Calendar Briefing"

schedule: "6:00 AM daily"

steps:

  1. get_today_events:

      calendar: primary

      time_min: today_start

      time_max: today_end

  2. categorize_events:

      categories:

        meetings: has_attendees == true

        focus_time: title contains "Focus" OR "Deep Work"

        one_on_ones: title contains "1:1" OR "1-on-1"

        interviews: title contains "Interview"

  3. calculate_stats:

      total_meetings: count(meetings)

      total_hours: sum(duration)

      free_time: 8 - total_hours

      back_to_back: count(gap < 15min)

  4. format_message:

      template: |

        β˜€οΈ *Good morning! Here's your day:*

        πŸ“… *{date}*

        *Schedule Overview:*

        β€’ {total_meetings} meetings ({total_hours}h)

        β€’ {free_time}h of free time

        β€’ {back_to_back} back-to-back slots ⚠️

        *Today's Events:*

        {event_list}

        πŸ’‘ *Tip:* {daily_tip}

  5. send_to_slack:

      channel: "#daily-schedule" or DM

  6. log_to_sheets:

      spreadsheet: "Calendar Analytics"

      data: [date, meetings, hours, categories]

Event List Format:

β€’ 9:00 AM - Team Standup (15m) πŸ“ž Zoom

β€’ 10:00 AM - 1:1 with Sarah (30m) πŸ‘₯

β€’ 11:00 AM - Focus Time (2h) 🧠

β€’ 2:00 PM - Client Call (1h) 🀝 Google Meet

β€’ 4:00 PM - Interview - PM Role (45m) 🎯

2. Meeting Prep Automation

workflow: "Meeting Preparation"

trigger:

  type: calendar_event

  time: 1_hour_before_meeting

  filter: has_attendees AND duration >= 30min

steps:

  1. get_meeting_details:

      extract: [title, attendees, description, meeting_link]

  2. research_attendees:

      for_each: attendee

      actions:

        - linkedin_lookup: get_title_company

        - crm_lookup: get_past_interactions

        - email_search: recent_threads

  3. generate_prep_doc:

      template: |

        # Meeting Prep: {title}

        **Time:** {start_time}

        **Duration:** {duration}

        **Link:** {meeting_link}

        ## Attendees

        {attendee_profiles}

        ## Context

        - Last interaction: {last_meeting_date}

        - Open items: {open_tasks}

        - Recent emails: {email_summary}

        ## Suggested Agenda

        {ai_suggested_agenda}

        ## Talking Points

        {ai_talking_points}

  4. send_reminder:

      slack_dm:

        message: |

          ⏰ Meeting in 1 hour: *{title}*

          πŸ“‹ [Prep Doc]({prep_doc_link})

          πŸ”— [Join Meeting]({meeting_link})

          Quick context: {one_line_summary}

3. Smart Time Blocking

workflow: "Auto Time Blocking"

schedule: "Sunday 8pm" # Plan for next week

steps:

  1. analyze_calendar:

      range: next_7_days

      identify:

        - existing_meetings

        - recurring_meetings

        - available_slots

  2. get_priorities:

      source: [todoist, asana, notion]

      filter: due_this_week AND high_priority

  3. allocate_focus_time:

      rules:

        - morning_block: 9-11am (deep work)

        - afternoon_block: 2-4pm (collaborative)

        - minimum_gap: 15min between meetings

        - max_meetings_per_day: 5

  4. create_blocks:

      types:

        deep_work:

          duration: 2h

          frequency: daily

          preferred_time: 9-11am

          color: blue

        admin_time:

          duration: 1h

          frequency: daily

          preferred_time: 4-5pm

          color: gray

        buffer:

          duration: 15min

          after: external_meetings

          color: yellow

  5. notify:

      slack: "βœ… Weekly time blocks created. {x} hours of focus time protected."

4. Calendly β†’ Calendar + CRM

workflow: "Calendly Booking Handler"

trigger:

  type: calendly

  event: booking_created

steps:

  1. get_booking_details:

      extract: [invitee, event_type, scheduled_time, answers]

  2. enrich_contact:

      clearbit: lookup_by_email

      linkedin: get_profile

  3. create_calendar_event:

      google_calendar:

        title: "{event_type} with {invitee_name}"

        time: scheduled_time

        description: |

          **Booked via Calendly**

          Name: {invitee_name}

          Email: {invitee_email}

          Company: {company}

          **Pre-meeting questions:**

          {calendly_answers}

        attendees: [invitee_email, owner_email]

        reminders: [1_day, 1_hour, 15_min]

  4. update_crm:

      hubspot:

        create_or_update_contact:

          email: invitee_email

          properties:

            last_meeting_booked: scheduled_time

            meeting_type: event_type

        create_engagement:

          type: MEETING

          timestamp: scheduled_time

  5. send_confirmation:

      email:

        to: invitee_email

        template: meeting_confirmation

        include: [calendar_invite, prep_questions]

  6. notify_slack:

      channel: "#meetings"

      message: "πŸ“… New booking: {event_type} with {invitee_name} on {date}"

5. Calendar Analytics

analytics_workflow:

  name: "Weekly Calendar Report"

  schedule: "Friday 5pm"

  metrics:

    time_distribution:

      - meetings_total_hours

      - focus_time_hours

      - admin_time_hours

      - 1on1_time_hours

    meeting_quality:

      - avg_meeting_length

      - back_to_back_count

      - meetings_with_agenda

      - external_vs_internal

    productivity:

      - longest_focus_block

      - fragmentation_score

      - after_hours_meetings

  output:

    format: markdown

    destinations: [slack, google_sheets]

  report_template: |

    # πŸ“Š Weekly Calendar Analytics

    ## Time Distribution

    | Category | Hours | % of Week |

    |----------|-------|-----------|

    | Meetings | {meetings_hours} | {meetings_pct}% |

    | Focus Time | {focus_hours} | {focus_pct}% |

    | Admin | {admin_hours} | {admin_pct}% |

    | Available | {available_hours} | {available_pct}% |

    ## Meeting Insights

    - Total meetings: {total_meetings}

    - Average length: {avg_length} min

    - Back-to-back: {b2b_count} ({b2b_pct}%)

    - With agenda: {agenda_pct}%

    ## Productivity Score

    🎯 **{productivity_score}/100**

    - Longest focus block: {longest_focus}

    - Meeting fragmentation: {fragmentation}

    - After-hours: {after_hours_count}

    ## Recommendations

    {ai_recommendations}

Time Blocking Templates

Maker Schedule (Individual Contributor)

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”

β”‚ 9:00 - 11:00  β”‚ Deep Work Block 1  β”‚

β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€

β”‚ 11:00 - 11:30 β”‚ Email/Slack        β”‚

β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€

β”‚ 11:30 - 12:30 β”‚ Meetings Window    β”‚

β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€

β”‚ 12:30 - 1:30  β”‚ Lunch              β”‚

β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€

β”‚ 1:30 - 3:30   β”‚ Deep Work Block 2  β”‚

β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€

β”‚ 3:30 - 4:00   β”‚ Buffer/Admin       β”‚

β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€

β”‚ 4:00 - 5:00   β”‚ Meetings Window    β”‚

β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€

β”‚ 5:00 - 5:30   β”‚ Daily Wrap-up      β”‚

β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Manager Schedule

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”

β”‚ 8:00 - 8:30   β”‚ Daily Planning     β”‚

β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€

β”‚ 8:30 - 9:00   β”‚ Team Standup       β”‚

β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€

β”‚ 9:00 - 12:00  β”‚ 1:1s / Meetings    β”‚

β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€

β”‚ 12:00 - 1:00  β”‚ Lunch              β”‚

β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€

β”‚ 1:00 - 2:00   β”‚ Focus Time         β”‚

β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€

β”‚ 2:00 - 5:00   β”‚ Meetings           β”‚

β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€

β”‚ 5:00 - 5:30   β”‚ Email/Wrap-up      β”‚

β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Output Example

Request: "Set up daily calendar digest for my Slack"

Output:

# Daily Calendar Digest Setup

## Workflow Configuration

name: "Morning Calendar Briefing"

schedule: "6:00 AM weekdays"

timezone: "Asia/Shanghai"

trigger:

type: cron

expression: "0 6 1-5"

actions:

1. fetch_events:

calendar: primary

date: today

2. send_slack:

channel: "@you" # or #your-channel


## Sample Output

β˜€οΈ Good morning! Here's your Thursday:

πŸ“… January 30, 2026

━━━━━━━━━━━━━━━━━━━━━━

πŸ“Š Overview:

β€’ 5 meetings (4.5h)

β€’ 3.5h free time

β€’ 1 back-to-back warning ⚠️

━━━━━━━━━━━━━━━━━━━━━━

πŸ—“οΈ Schedule:

9:00 AM β”‚ Team Standup (15m)

β”‚ πŸ“ž Google Meet

β”‚

10:00 AM β”‚ 1:1 with Sarah (30m)

β”‚ πŸ‘₯ Conference Room B

β”‚

11:00 AM β”‚ 🧠 Focus Time (2h)

β”‚

1:00 PM β”‚ Lunch

β”‚

2:00 PM β”‚ Client Call - Acme (1h)

β”‚ 🀝 Zoom (link attached)

β”‚

3:30 PM β”‚ Product Review (1h)

β”‚ πŸ“‹ Agenda attached

β”‚

5:00 PM β”‚ βœ… Day ends

━━━━━━━━━━━━━━━━━━━━━━

πŸ’‘ Tip: You have 2h of focus time - tackle your highest priority task!


## n8n Setup Instructions

- Create new workflow

- Add Schedule Trigger node (6am weekdays)

- Add Google Calendar node (Get Events)

- Add Code node (format message)

- Add Slack node (send message)

- Activate workflow

Would you like me to generate the full n8n workflow JSON?

---

Calendar Automation Skill - Part of Claude Office Skills

BrowserAct

Let your agent run on any real-world website

Bypass CAPTCHA & anti-bot for free. Start local, scale to cloud.

Explore BrowserAct Skills β†’

Stop writing automation&scrapers

Install the CLI. Run your first Skill in 30 seconds. Scale when you're ready.

Start free
free Β· no credit card