12 Step Meeting List

Description

This plugin helps twelve step recovery programs list their meetings. It standardizes addresses, and displays results in a searchable list and map.

It’s also the easiest way to have your area’s meetings listed in the Meeting Guide mobile app for iOS and Android devices.

This plugin was originally designed to maintain a list of AA meetings in Santa Clara County, CA. It’s now in use in the following areas:

Alcoholics Anonymous

  1. Alexandria, LA
  2. Arkansas
  3. Aspen, CO
  4. Asheville, NC
  5. Austin, TX
  6. Baltimore, MD
  7. Batavia, IL
  8. Baton Rouge, LA
  9. Bethlehem, PA
  10. Boston, MA
  11. Bowling Green, KY
  12. Brainerd, MN
  13. Burlington, NC
  14. Cancún, Mexico
  15. Charleston, SC
  16. Charleston, WV
  17. Charlotte, NC
  18. Chico, CA
  19. Cincinnati, OH
  20. Continental Europe
  21. Colorado Springs, CO
  22. Columbus, OH
  23. Connecticut
  24. Corpus Christi, TX
  25. Dallas, TX
  26. Davenport, IA
  27. Davis, CA
  28. Dayton, OH
  29. Daytona, FL
  30. DuPage County, IL
  31. East Bay, CA
  32. East Tennessee
  33. Eastern Washington
  34. Elk Grove Village, IL
  35. Elgin, IL
  36. Fargo, ND
  37. Four Corners, NM AZ UT CO
  38. Fredericksburg, VA
  39. Fresno, CA
  40. Ft. Worth, TX
  41. Greensboro, NC
  42. Hagerstown, MD
  43. Harrisburg, IL
  44. Harrisburg, PA
  45. Hernando County, FL
  46. Houston, TX
  47. Idaho
  48. Inland Empire, CA
  49. Israel
  50. Jacksonville, FL
  51. Joliet, IL
  52. Kansas
  53. Kansas City
  54. Kentucky
  55. Lafayette, LA
  56. Lakeland, FL
  57. Lancaster, PA
  58. Langley, Canada
  59. Lawrence, KS
  60. Lebanon, PA
  61. Lee County, FL
  62. Leesburg, FL
  63. Lewis County, WA
  64. Long Beach, CA
  65. Los Angeles, CA
  66. Marblehead, MA
  67. Madison, WI
  68. Maine and New Brunswick
  69. Mansfield, OH
  70. Martin County, FL
  71. Maui, HI
  72. Memphis, TN
  73. Mercer County, PA
  74. Mesa, AZ
  75. Miami, FL
  76. Midlands, UK (Polish)
  77. Minneapolis, MN
  78. Minnesota
  79. Mississippi
  80. Modesto, CA
  81. Monterey, CA
  82. Montreal, Canada
  83. Myrtle Beach, SC
  84. Napa, CA
  85. Naples, FL District 20
  86. Naples, FL Intergroup
  87. Nassau County, NY
  88. New Hampshire
  89. New Orleans, LA
  90. New Mexico
  91. New York, NY
  92. North Central Washington
  93. North Coast, LA
  94. North County San Diego, CA
  95. North Dakota
  96. North Port, FL
  97. Northern Indiana
  98. Oahu, HI
  99. Ogden, UT
  100. Oklahoma
  101. Orlando, FL
  102. Oshawa, Canada
  103. Palm Beach County, FL
  104. Palm Springs, CA
  105. Paris, France
  106. Pensacola, FL
  107. Philadelphia, PA
  108. Placerville, CA
  109. Portland, OR
  110. Québec, Canada (All)
  111. Québec, Canada (Région 87, Southwest)
  112. Québec, Canada (Région 88, Southeast)
  113. Reading, PA
  114. Redmond, OR
  115. Regina, Canada
  116. Rhode Island
  117. Rochester, MN
  118. Rochester, NY
  119. Rockland County, NY
  120. Romania
  121. Sacramento, CA
  122. Salinas, CA
  123. San Francisco, CA
  124. San Jose, CA
  125. San Mateo, CA
  126. Santa Barbara, CA
  127. Santa Fe, NM
  128. Savannah, GA
  129. Seattle, WA
  130. Secular AA
  131. Shreveport, LA
  132. Snohomish County, WA
  133. Sonoma County, CA
  134. South Lexington, KY
  135. South Roxana, IL
  136. Southeastern Indiana
  137. Southern Colorado
  138. Southern Illinois
  139. Southern New Jersey
  140. Southwestern Missouri
  141. Spokane, WA
  142. St. Louis, MO
  143. St. Lucie, FL
  144. St. Peters, MO
  145. State College, PA
  146. Streamwood, IL
  147. Syracuse, NY
  148. Tampa, FL
  149. Tidewater Area, VA
  150. Tokyo, Japan
  151. Toronto, Canada
  152. Tri Valley, CA
  153. Topeka, KS
  154. Traverse City, MI
  155. Tulare County, CA
  156. Tulsa, OK
  157. Vacaville, CA
  158. Vancouver, Canada
  159. Ventura County, CA
  160. Vienna, Austria
  161. Virginia
  162. Virginia Peninsula
  163. Waco, TX
  164. Walnut Creek, CA
  165. Warsaw, IN
  166. Washington, DC
  167. Wenatchee, WA
  168. West Hawaii, HI
  169. West-Central Wisconsin
  170. West Pasco, FL
  171. Western Colorado
  172. Western Kentucky
  173. Western Washington
  174. Wheaton, IL
  175. Wilmington, DE
  176. Woodstock, IL

Adult Children of Alcoholics

  1. Arizona
  2. Southern California
  3. Texas

Al-Anon

  1. [Dayton, OH(https://www.al-anondaytonoh.org/meetings)
  2. Lancaster, PA
  3. Naples, FL
  4. Pennsylvania
  5. South Florida
  6. Washington

Co-Dependents Anonymous

  1. Los Angeles, CA
  2. South SF Bay Area, CA

Cocaine Anonymous

  1. England + Wales
  2. Illinois
  3. Los Angeles, CA

Debtors Anonymous

  1. Southern California

Gamblers Anonymous

  1. Australia
  2. Los Angeles, CA

Heroin Anonymous

  1. Arizona

Narcotics Anonymous

  1. Chinook, CA
  2. Lancaster, PA
  3. Maine
  4. Martha’s Vineyard, MA
  5. Marysville, CA
  6. Poland
  7. Roseville, CA
  8. Sacramento, CA
  9. Toledo, OH
  10. Vienna, Austria
  11. Western Oklahoma

Recovering Couples Anonymous

  1. Main Website

Refuge Recovery

  1. Main Website
  2. Oakland, CA

Sex Addicts Anonymous

  1. Indiana

Sexaholics Anonymous

  1. Main Website
  2. St. Louis, MO
  3. Triad, NC

Let us know if you’re using this plugin and would like to be listed here.

Notes

  • The Meeting Notes field is for any non-standardized meeting info, such as Basement, or Building C
  • Location should be a simple place-name, eg Queen of the Valley Hospital
  • Address should only be the address; no “Upstairs” or “Building C” or “Near 2nd Ave”
  • You can fill in a very basic address and then when you tab away from that field you will see it try to standardize the address for you. If you write “1000 trancas, napa” it will replace it with “1000 Trancas St, Napa, CA 94558, USA.”

Screenshots

  • Meeting list page
  • Meeting map
  • Meeting detail page
  • Edit meeting
  • Edit location

Installation

Basically you can just install it and you should be good to go. For a quick walkthrough of the process, check out this screencast video:

FAQ

Installation Instructions

Basically you can just install it and you should be good to go. For a quick walkthrough of the process, check out this screencast video:

My meeting type isn’t listed!

If it’s a broadly-applicable meeting type, please contact us so we can include it for you. We want to maintain consistency for the mobile apps, so not all proposals are included.

If you have access to your theme’s functions.php, you may add additional meeting types for your area. Simply adapt the following example to your purposes:

if (function_exists('tsml_custom_types')) {
    tsml_custom_types(array(
        'XYZ' => 'My Custom Type',
    ));
}

Please note a few things about custom types:

  1. Once you’ve added the type, you will see it under ‘More’ on the Meeting edit screen. It will show up in the dropdown once you use it on a meeting.
  2. Be careful with the codes (“XYZ” in the above example) as this gives you the ability to replace existing types.
  3. Note that custom meeting types are not imported into the Meeting Guide app.
  4. They are for searching. If you can’t imagine yourself searching for a meeting this way, then it’s probably not a type you need. Have you ever searched for a 90-minute meeting? If not, then it’s probably information that better belongs in the meeting notes.
  5. Don’t add a type for the default, eg ‘Hour Long Meeting’ or ‘Non-Smoking.’ If you do that, then you have to be careful about tagging every single meeting in order to make the data complete.
Where are my meetings listed?

It depends on your Permalinks setup. The easiest way to find the link is to go to the Dashboard > Meetings > Import & Settings page and look for it under “Where’s My Info?”

I need to correct a meeting address or change a pin’s location

We get our geocoding positions from Google (this true even if your maps are by Mapbox). Google is correct an amazing amount of the time, but not always. If you need to add a custom location, add this to your theme’s functions.php.

Note you can add multiple entries to the array below.

if (function_exists('tsml_custom_types')) {
    tsml_custom_addresses(array(
        '5 Avenue Anatole France, 75007 Paris, France' => array(
            'formatted_address' => '5 Avenue Anatole France, 75007 Paris, France',
            'city' => 'Paris',
            'latitude' => 48.858372,
            'longitude' => 2.294481,
        ),
    ));
}
How can I make the Region dropdown not be collapsible?

No problem, just add this CSS to your theme:

div#meetings .controls ul.dropdown-menu div.expand { display: none; }
div#meetings .controls ul.dropdown-menu ul.children { height: auto; }
How can I show Any Day by default?

The easiest way is to link to that view straight from your navigation. Usually that looks like /meetings/?tsml-day=any, but it can vary depending on your settings.

If you’d prefer to keep the default address, you could add this code to your theme’s functions.php instead:

$tsml_defaults['day'] = null;
How do I change the default search radius for location searches?

Add this to your theme’s functions.php. The value should be an existing value, ie 1, 5, 10, 25 or 50.

$tsml_defaults['distance'] = 25;
Can I get the meeting list to display the full address, including city, state and country?

Add this to your theme’s functions.php.

$tsml_street_only = false;
Can I change the order of the columns on the meeting list page, eg put the Region first?

Add this to your theme’s functions.php. Feel free to change the order or column names (eg ‘Region’) but keep the keys the same (eg ‘region’).

$tsml_columns = array(
    'region' => 'Region',
    'time' => 'Time',
    'distance' => 'Distance',
    'name' => 'Name',
    'location' => 'Location',
    'address' => 'Address',
    'types' => 'Types'
);
Can I change the default sort order on the meeting list page?

By default, the plugin sorts by day, then time, then location name. To set your own sort index, add this to your functions.php:

$tsml_sort_order = 'region'; //options are name, location, address, time, or region
How can I override the meeting list or detail pages?

Copy the files from the plugin’s templates directory into your theme’s root directory. If you’re using a theme from the Theme Directory, you may be better off creating a Child Theme. Now, you may override those pages. The archive-meetings.php file controls the meeting list page, single-meetings.php controls the meetings detail, and single-locations.php controls the location detail.

Please note these pages will evolve over time. If you override, you will someday experience website errors after an update. If that happens, please update your theme’s copy of the plugin pages.

When there are notes on a meeting, can I indicate that somehow in the meeting list?

Yes, with CSS. Rows that have meeting notes will have a ‘notes’ class. To add an asterisk, for example, try this:

div#tsml tr.notes a:after { content: "*"; }
Can I import a custom spreadsheet format?

If you don’t mind some PHP programming, then yes! Create a function called tsml_import_reformat, and use it to
reformat your incoming data to the standard format

if (!function_exists('tsml_import_reformat')) {
    function tsml_import_reformat($meetings) {
        //your code goes here
        return $meetings;
    }
}
How can I change some of the text on the template pages, eg the column headings?

You can make use of the gettext filter to override the plugin’s translation strings. For example, if you wanted to replace ‘Region’ with ‘City,’ you could add the following to your functions.php file.

function theme_override_tsml_strings($translated_text, $text, $domain) {
    if ($domain == '12-step-meeting-list') {
        switch ($translated_text) {
            case 'Region':
                return 'City';
        }
    }
    return $translated_text;
}
add_filter('gettext', 'theme_override_tsml_strings', 20, 3);
How can I temporarily hide a meeting without deleting it?

Save it as a draft by editing the meeting’s Status.

Are there shortcodes?

Yes, you can use [tsml_meeting_count], [tsml_location_count], [tsml_group_count], and [tsml_region_count] to display human-formatted counts of your entities. For example, “Our area currently comprises [tsml_meeting_count] meetings.” Also [tsml_next_meetings count="5"] displays a small table with the next several meetings in it. Use the count parameter to adjust how many are displayed. This will be unstyled if you’re not using bootstrap in your theme.

Additionally, you can use [tsml_types_list] and [tsml_regions_list] to output linked lists to your meeting finder.

Are there translations to other languages?

It is translated into Polish. If you would like to volunteer to help translate another language, we would be pleased to work with you.

I entered contact information into the meeting edit page but don’t see it displayed on the site.

That’s right, we don’t display that information by default for the sake of anonymity. To display it in your theme, go to Import & Settings and set the Meeting/Group Contacts dropdown to “public.”

Can I run this as my main website homepage?

Sure. Try adding this code to your theme’s functions.php:

add_action('pre_get_posts', 'tsml_front_page');

Also check out our One Page Meeting List theme.

Can I use this plugin to list telephone meetings or other meetings without a fixed location?

No, there’s not a good way to do this at this time. All meetings currently need to have a geographic location.

Some sites have used a general geographic area, such as a city name, but this isn’t a very good solution, because a map
pin will still show up for these meetings and people will try to get directions to them.

Reviews

Great Plugin

Saved me a lot of time trying to come up with a solution that probably would not have done the job nearly as well.

Nothing but positive comments from my users; that is all you can ask for.

Area 25 Kansas

It’s not quite perfect, but striving for perfection and constantly making progress. This is THE meeting plugin. It’s been a huge time saver for Area 25 Kansas and possibly a life saver. Keep up the great work!

Read all 18 reviews

Contributors & Developers

“12 Step Meeting List” is open source software. The following people have contributed to this plugin.

Contributors

“12 Step Meeting List” has been translated into 1 locale. Thank you to the translators for their contributions.

Translate “12 Step Meeting List” into your language.

Interested in development?

Browse the code, check out the SVN repository, or subscribe to the development log by RSS.

Changelog

3.2.8

  • Fixing undefined types bug (Minneapolis)

3.2.7

  • Fixing region typeahead (Dallas)

3.2.6

  • Fixing sort by distance bug (Connecticut)
  • Adding group address field (New Mexico)
  • Change notification and feedback email subject tweaks (Washington, DC)

3.2.5

  • Null address bug fix (San Francisco)

3.2.4

  • LGBTQ meeting type was not importing properly (Seattle)

3.2.3

  • Address fix for Maine

3.2.2

  • Add custom address overrides for your location (CAUK)

3.2.1

  • Adding English meeting type for Al-Anon (South Florida)

3.2

  • URLs now use region and district slugs, rather than IDs, for more readable URLs (Area 22)

3.1.15

  • Adding Hebrew meeting type (Israel)

3.1.14

  • Address geocoding fix part II (Maine)
  • Adding author field to import & export (Connecticut)

3.1.13

  • Bug saving locations on new meetings
  • Address geocoding fix (Maine)

3.1.12

  • Fixing search for groups with apostrophes

3.1.11

  • CSV security: user must be logged in or sharing must be open

3.1.10

  • PHP 5.3 compliance (Baltimore)

3.1.9

  • Hiding empty regions and districts (Northern Indiana)
  • When region or district filter doesn’t match any results, return nothing (Northern Indiana)

3.1.8

  • Select multiple types with modifier key down (Atlanta)
  • Upgrading the build tool to Laravel Mix, should fix NPM warning on Github

3.1.7

  • Updating Meeting Guide Google Play link

3.1.6

  • Adding geocode override (Regina)

3.1.5

  • Fixing Internet Explorer map error
  • Borrows Google Maps key from The Events Calendar if needed and available
  • Adding column aliases for import (you can now use ZIP for Postal Code, for example)

3.1.4

  • Adding type for “Digital Basket”

3.1.3

  • Fixing PHP notice when adding a new meeting
  • Adding Venmo column to CSV

3.1.2

  • Bug fix, thinks Google is the right thing but it’s really Mapbox (SoCal ACA)

3.1.1

  • Bug fix when saving a meeting if you have a database prefix (Ft Worth)
  • Paragraph spacing on no-SSL warning
  • Badging Import & Settings link if notices present
  • Adding link on admin page to enable maps
  • Removing empty map on meeting & location detail pages if maps not enabled
  • Map infowindow is back on location detail page

3.1.0

  • Mapbox support
  • Maps are now optional
  • Removed notice from main dashboard page