Updates, Tips, and Project Reports

  • Combining ActionKit Query Reports with CTEs

    As organizations operationalize their mail targeting, there’s a tendency to build up a few big monolithic queries that define key user segments based on a mix of different signals. For example, you might define a pool of “core mailable users” that includes 90-day clickers, plus 60-day openers, plus 3-year donors — and as time goes…

  • Storing ActionKit Queries in Template Files

    A couple of months ago, I posted about a technique I have used for developing complicated dashboard reports: store the code in a template file, and take advantage of the developer tools and GitHub sync that feature provides. (That writeup includes more details about the advantages this provides.) More recently, I wondered… “well, why can’t…

  • Sampling Random Rows with the ActionKit Query Builder

    For a lot of database queries, we want to see all of the matching records, or perhaps only the most recent or highest based on some measure — but in a few cases, it’s actually useful to get a random sampling of the results. There isn’t an obvious option to do this kind of sampling…

  • A Brief Introduction to ActionKit Page Translation

    Organizations that are new to ActionKit can run into questions about the various elements involved in translating their forms into multiple languages. The terminology here can be confusing, with words like “page” and “template” being used to mean different things depending on the context, so I thought it might be useful to review the major…

  • Recognizing ActionKit Users with sticky-akid.js

    The user-recognition system in ActionKit is primarily focused on tokens called AKIDs that are automatically included in the links included by the mailings sent out from the platform. (There is a separate login system based on passwords and session cookies, but it is only used in a limited number of cases, such as changing recurring…

  • Extending ActionKit With API-Powered Admin Dashboards

    ActionKit provides a rich API that allows organizations to build custom functionality on top of the platform, including rich user interactions, back-end automation, and integrations with third-party services. Unfortunately, there are lots of organizations that don’t have anyone on their staff who is fluent in Python, C++, or Perl that can build and deploy custom…

  • Using Template Files in ActionKit Mailings

    The templating capabilities of ActionKit mailings are very powerful, and numerous organizations have built sophisticated examples that incorporate various user attributes to customize the message and calls to action. The enhancements made to custom mailing fields and email wrapper templates has made it easier to build flexible models that can be customized and reused over…

  • Storing ActionKit Dashboards in Template Files

    ActionKit dashboard reports are a wonderful mechanism for extended the admin interface with new capabilities and custom logic. Most obviously, dashboard reports can run query reports and format their results in innovative ways. But dashboards can also contain custom JavaScript logic, including functions that call the ActionKit REST API to create or modify records on…

  • Building Template Strings for ActionKit’s include_tmpl

    The Django templating system that ActionKit leverages to let organizations build customized pages and mailings does provide an admirable amount of flexibility, but as those templates grow larger and more complicated we can ourselves wishing we had equivalents of some of the tools found in other programming languages, such as subroutines. Conveniently, ActionKit provides us…

  • Self-Dealing “Scam PACs” Pollute the Advocacy Ecosystem

    As the election season continues to pick up, the flood of fundraising appeals has escalated. I understand that this is an inescapable part of our modern political system, but the frenzied tone and overlapping asks from multiple campaigns can be disheartening — it’s unfortunate that this is such a central part of the landscape. And…