skills/claude-skills-open/skills/crm/log-activity/SKILL.md
Log activity to activities.csv
npx skillsauth add aaaaqwq/agi-super-team log-activityInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Logging outreach activities (calls, messages, emails)
| What | Path |
|------|------|
| Activities | $CRM_PATH/activities.csv |
| People | $CRM_PATH/contacts/people.csv |
activity_id,linkedin_url,date,channel,activity_type,message_preview,result,response_quality,next_followup_date,audience_segment,hook_type,notes
import pandas as pd
from datetime import date, timedelta
import uuid
activities = pd.read_csv('$CRM_PATH/activities.csv')
new_activity = {
'activity_id': f'act-{uuid.uuid4().hex[:8]}',
'linkedin_url': 'https://linkedin.com/in/example', # or email
'date': str(date.today()),
'channel': 'telegram', # linkedin/email/twitter/telegram/whatsapp
'activity_type': 'dm', # dm/connect_request/followup/email/call/research
'message_preview': 'Hi! This is Ivan from WeLabelData...', # first 100 characters
'result': 'sent', # sent/replied/no_response/accepted/rejected
'response_quality': '', # positive/neutral/negative/meeting
'next_followup_date': str(date.today() + timedelta(days=7)),
'audience_segment': 'training_course',
'hook_type': 'course_invitation',
'notes': ''
}
activities = pd.concat([activities, pd.DataFrame([new_activity])], ignore_index=True)
activities.to_csv('$CRM_PATH/activities.csv', index=False)
people = pd.read_csv('$CRM_PATH/contacts/people.csv')
mask = people['linkedin_url'] == 'https://linkedin.com/in/example'
people.loc[mask, 'status'] = 'contacted'
people.loc[mask, 'last_contact_date'] = str(date.today())
people.loc[mask, 'next_followup_date'] = str(date.today() + timedelta(days=7))
people.loc[mask, 'last_updated'] = str(date.today())
people.to_csv('$CRM_PATH/contacts/people.csv', index=False)
linkedin -- LinkedIn DMemail -- Emailtelegram -- Telegramwhatsapp -- WhatsApptwitter -- Twitter/Xdm -- Direct messageconnect_request -- Connection requestfollowup -- Follow-up contactemail -- Email messagecall -- Phone callresearch -- Research (not outreach)sent -- Sent, waiting for responsereplied -- Received a responseno_response -- No response (after N days)accepted -- Accepted request/invitationrejected -- Declinedpositive -- Interestedneutral -- Neither yes nor nonegative -- Not interestedmeeting -- Meeting scheduledFor mass outreach -- log multiple at once:
sent_to = ['[email protected]', '[email protected]', '[email protected]']
for email in sent_to:
new_activity = {
'activity_id': f'act-{uuid.uuid4().hex[:8]}',
'linkedin_url': email, # using email as ID
'date': str(date.today()),
'channel': 'telegram',
'activity_type': 'dm',
'result': 'sent',
# ...
}
activities = pd.concat([activities, pd.DataFrame([new_activity])], ignore_index=True)
telegram-send -- before loggingupdate-lead -- update person statusdevelopment
Technology-agnostic prompt generator that creates customizable AI prompts for scanning codebases and identifying high-quality code exemplars. Supports multiple programming languages (.NET, Java, JavaScript, TypeScript, React, Angular, Python) with configurable analysis depth, categorization methods, and documentation formats to establish coding standards and maintain consistency across development teams.
tools
Expert-level browser automation, debugging, and performance analysis using Chrome DevTools MCP. Use for interacting with web pages, capturing screenshots, analyzing network traffic, and profiling performance.
data-ai
Prompt for creating detailed feature implementation plans, following Epoch monorepo structure.
tools
Interactive prompt refinement workflow: interrogates scope, deliverables, constraints; copies final markdown to clipboard; never writes code. Requires the Joyride extension.