=== 12 Step Meeting List === Contributors: meetingguide, aasanjose Tags: meetings, aa, al-anon, na, 12-step, locations, groups Requires at least: 3.2 Tested up to: 4.7 Stable tag: 2.11 License: GPLv2 or later License URI: http://www.gnu.org/licenses/gpl-2.0.html This plugin is designed to help 12 step programs list their meetings and locations. It standardizes addresses, and displays in a list or map. == Description == This plugin is the easiest way to have your area's meetings listed in the [Meeting Guide mobile app](https://meetingguide.org/) for iOS and Android devices. It 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. [Arkansas](http://arkansascentraloffice.org/meetings/) 1. [Austin, TX](http://austinaa.org/meetings/) 1. [Baton Rouge, LA](http://aabatonrouge.org/meetings/) 1. [Bowling Green, KY](http://bowlinggreenaa.org/meetings/) 1. [Charleston, WV](http://aawvdist1.org/wordpress/?post_type=tsml_meeting) 1. [Continental Europe](http://alcoholics-anonymous.eu/meetings/) 1. [Corpus Christi, TX](http://www.cbiaa.org/meetings/) 1. [Davis, CA](http://aadavis.org/meetings/) 1. [DuPage County, IL](http://dist41.aa-nia.org/meetings/) 1. [East Bay, CA](http://eastbayaa.org/meetings) 1. [Elk Grove Village, IL](http://d15aa.org/d15aa.org/?post_type=meetings) 1. [Ft. Worth, TX](http://fortworthaa.org/?post_type=tsml_meeting) 1. [Greensboro, NC](http://nc23.org/meetings/) 1. [Joliet, IL](http://aadistrict51.org/meetings/) 1. [Midlands, UK (Polish)](http://intergrupamidlands.co.uk/meetings/) 1. [Kansas](https://ks-aa.org/meetings/) 1. [Lewis County, WA](http://lewiscountyaa.org/meetings/) 1. [Long Beach, CA](https://hacoaa.org/meetings/) 1. [Maine and New Brunswick](http://csoaamaine.org/meetings/) 1. [Maui, HI](http://aamaui.org/meetings) 1. [Mesa, AZ](http://aamesaaz.org/meetings/) 1. [Miami, FL](https://aamiamidade.org/meetings) 1. [Minneapolis, MN](http://aaminneapolis.org/meetings/) 1. [Modesto, CA](http://wp.cviaa.org/meetings/) 1. [Naples, FL](http://aanaples.org/meetings/) 1. [New Orleans, LA](http://www.aaneworleans.org/meetings/) 1. [New York, NY](http://meetings.nyintergroup.org/) 1. [Oahu, HI](http://oahucentraloffice.com/meetings/) 1. [Orlando, FL](http://cflintergroup.org/meetings/) 1. [Philadelphia, PA](http://www.aasepia.org/meetings/) 1. [Portland, OR](http://home.pdxaa.org/meetings/) 1. [Rochester, MN](http://aadistrict1.org/blog/meetings/) 1. [Sacramento, CA](http://aasacramento.org/meetings/) 1. [San Jose, CA](https://aasanjose.org/meetings) 1. [San Mateo, CA](http://aa-san-mateo.org/meetings) 1. [Santa Fe, NM](http://santafeaa.org/meetings/) 1. [Secular AA](https://www.secularaa.org/meetings/) 1. [Southern Colorado](http://www.puebloaa.org/meetings/) 1. [State College, PA](http://www.district43.com/meetings/) 1. [Tidewater Area, VA](http://www.tidewaterintergroup.org/meetings/) 1. [Toronto, Canada](https://aatoronto.org/meetings/) 1. [Tri Valley, CA](http://trivalleyaa.org/meetings/) 1. [Topeka, KS](http://aatopeka.org/meetings/) 1. [Tulsa, OK](http://district40aa.com/meetings) 1. [Vancouver, Canada](http://www.vancouveraa.ca/meetings/) 1. [Vienna, Austria](https://www.aavienna.com/meetings/) 1. [Virginia](https://aavirginia.org/meetings/) 1. [WAAFT](http://www.waaft.org/meetings/) 1. [Walnut Creek, CA](http://contracostaaa.org/meetings) 1. [Warsaw, IN](http://www.aadistrict4143.com/meetings/) 1. [Washington, DC](https://aa-dc.org/meetings) 1. [West Hawaii, HI](http://www.westhawaiiaa.org/meetings/) 1. [Western Slope, CA](http://westernsloped22.org/meetings/) 1. [Western Kentucky](http://wkintergroup.org/meetings/) 1. [Western Washington](http://area72aa.org/meetings/) 1. [Woodstock, IL](http://aa-nia-dist11.org/meetings/) **Adult Children of Alcoholics** 1. [Southern California](http://www.socalaca.org/meetings/?d=any) **Al-Anon** 1. [Lancaster, PA](http://lanclebalanon.org/meetings/?d=any) 1. [Orange County, CA](http://ocalanon-d60.org/meetings?d=any) 1. [Pennsylvania](http://pa-al-anon.org/meetings/) **Codependents Anonymous** 1. [Los Angeles](http://www.lacoda.org/) **Narcotics Anonymous** 1. [Chinook, CA](http://chinookna.org/meetings/) 1. [Maine](http://www.namaine.org/meetings/) 1. [Poland](http://anonimowinarkomani.org/meetings/) **Sex Addicts Anonymous** 1. [Indiana](http://indiana-saa.org/meetings/) [Let us know](mailto:wordpress@meetingguide.org) if you're using this plugin and would like to be listed here. = Notes = * The 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 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 return with "1000 Trancas Street, Napa, CA 94558, US." == 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: [youtube https://www.youtube.com/watch?v=Qqg1RPX-FTQ] == Frequently Asked Questions == = My meeting type isn't listed! = If it's a broadly-applicable meeting type, please [contact us](mailto:wordpress@meetingguide.org) so we can include it for you. We want to maintain consistency for the [mobile apps](https://meetingguide.org/), 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( 'ABSI' => 'As Bill Sees It', )); } Please note a few things about custom types: 1. Be careful with the codes ("ASBI" in the above example) as this gives you the ability to replace existing types. 1. Note that custom meeting types are not imported into the Meeting Guide app. 1. 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. 1. 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. = I don't like the new expandable regions dropdown menu! How do I remove it? = No problem, just add this CSS to your theme: #meetings .controls ul.dropdown-menu div.expand { display: none; } #meetings .controls ul.dropdown-menu ul.children { height: auto; } = How do I change the default search radius for location searches? = Add this to your functions.php. The value should be an existing value, ie 1, 5, 10, 25 or 50. $tsml_defaults['distance'] = 25; = How can I get the meeting list to display the full address, including city, state and country? = Add this to your functions.php. $tsml_street_only = false; = How can I have the plugin reformat the meeting list on the fly while importing it? = To uppercase the location of each meeting, for example, add this to your functions.php. if (!function_exists('tsml_import_reformat')) { function tsml_import_reformat($meetings) { //element 4 of each CSV row might be the meeting location (count starting with 0) foreach ($meetings as &$meeting) { $meeting[4] = mb_strtoupper($meeting[4]); } return $meetings; } } = Where are my meetings listed? = Your meetings will be listed on their special WordPress Archive page. Where that is depends on your Permalinks setup. The easiest way to find the link is to go to the **Meetings > Import & Settings** page and look for the link under "Where's My Info?" = How can I change some of the text on the template pages? = You can make use of the [gettext filter](https://codex.wordpress.org/Plugin_API/Filter_Reference/gettext) to override the plugin's translation strings. For example, if you wanted to replace 'Region' with 'Province,' 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 'Province'; } } return $translated_text; } add_filter('gettext', 'theme_override_tsml_strings', 20, 3); = 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](https://codex.wordpress.org/Child_Themes). 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. = Are there any 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. = 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, you should follow the instructions above for overriding the meeting detail and location detail pages and then drop some or all of these tags in your PHP: contact_1_name?> contact_1_email?> contact_1_phone?> = Can I run this as my main website homepage? = Sure. Try this code: add_action('pre_get_posts', 'tsml_front_page'); Also check out our [One Page Meeting List](https://github.com/meeting-guide/one-page-meeting-list) theme. == Screenshots == 1. Meeting list page 1. Meeting map 1. Meeting detail page 1. Edit meeting 1. Edit location == Changelog == = 2.11 = * Tweaking meeting types (Beginner -> Newcomer, Chips -> Birthday, Topic Discussion -> Discussion, removing Daily, adding often-requested literature types) * Expandable types list on meeting edit screen * Fallback for javascript errors on meeting edit screen = 2.10.6 = * Adding four new sites = 2.10.5 = * Removing Dompdf and TCPDF, can't seem to commit them to WordPress = 2.10.4 = * New plugin websites for readme * Re-hiding contacts in JSON feed * Basic framework for an autogenerated PDF = 2.10.3 = * Widgets can now be added to the meetings page * Adding classes to list group items on meeting and location detail pages * Fixing FAQ code formatting = 2.10.2 = * Version bump = 2.10.1 = * Fixing admin notices and email entry buttons on import page * Fixing search by region * Sending site language to Geocoding API = 2.10 = * Refactoring CSS and Javascript to reduce theme conflicts * More internationalization = 2.9.6 = * Mobile Safari now shows 'Search' button when searching * Mobile Safari search now can submit * Back to meetings links now working with plain permalink structure * Proper highlighting in search results = 2.9.5 = * Copy changes and bug fixes = 2.9.4 = * Adding setting to show the full address in the meeting list = 2.9.3 = * Removing vestige of dropdown on map button = 2.9.2 = * 'Upcoming' time bug fix = 2.9.1 = * New program: Adult Children of Alcoholics * Bug fix on Any Day view per AA Vienna * CSS layout tweaks = 2.9 = * New proximity search mode, courtesy of Washington Area Intergroup Association (WAIA) * Enabled Google maps in search results * Two new programs: Recovering Couples Anonymous and Sexual Compulsives Anonymous = 2.8.9 = * Per NYC, simplifying group last contact logic = 2.8.8 = * Region 'delete and reassign' dropdown now hierarchical * Apply address change to other meetings at this location now checked by default = 2.8.7 = * Fixing incorrect Men javascript string = 2.8.6 = * Open / Closed descriptions for Al-Anon = 2.8.5 = * Fixing "O other meetings at this location" = 2.8.4 = * Per Baton Rouge, directions link fix * Cache busting assets * Removing 'undefined' from query string on certain map links = 2.8.3 = * Tested with WordPress 4.7 = 2.8.2 = * Version bump = 2.8.1 = * Per Maine, updated FAQ instructions for expanding regions menu * Per Maine, importer allows CSVs with uneven cell counts * Per Toronto, fixed updated date in importer * Per Toronto, problematic address added to overrides * Fixed possible margin/padding bug on detail pages = 2.8 = * New look for meeting detail and location pages * New description for open and closed meetings, per Area 23 * Translated javascript strings per Polish AA in UK * Styling for nested regions dropdown * New white expand/collapse icons for themes with dark dropdown background colors