Category

Sports at the Beach hosts youth baseball and softball tournaments. The 95 acre facility, located near the Delaware beaches, draws teams primarily from the Northeast and Mid-Atlantic states. Inclind began its relationship with Sports at the Beach in 2001, designing and constructing both public and private websites. Since then, Sports at the Beach has flourished and has become the top attraction for youth baseball tournaments on the east coast other than Disney World’s sports complex in Florida.

From ColdFusion to Drupal
The main objective of the project was to migrate the website away from the aging ColdFusion language to a powerful PHP application founded on Drupal. The website was originally launched by Inclind in 2005 on ColdFusion 6, hosted on a dedicated Windows/MSSQL server. We re-architected the application in the Drupal 7 framework, leveraging it's combined capabilities of a CMS, CRM, and eCommerce system (via Drupal Commerce) to manage tournament products and tournament registrations, and provide a cleaner and more intuitive customer workflow from creating an account to registering a team and making registration payments.

Migrating Ten Years of History
Sports at the Beach database contains data going all the way back to 2002 when their very first system ran on top of an MS Access database (yep!). All of that history has been preserved and imported into their new system.

Utilizing Migrations, we were able to keep every single database record, normalize and clean the data for MySQL/Drupal, and fill in all the gaps that were lost over time either due to old bugs, mis-entries, or other anomalies. After a weeks worth of analysis of the MSSQL schema and data, we were able to craft a dozen Migration scripts to transpose the data over to MySQL. Since we use Migrations, we can quickly spot bad data coming in and stop and adjust the import, rollback and try again without any hassle. In the end, all of the 2 million database records made their way over. Migrating and importing a decade of content, users, orders, payments, registrations, tournaments, games and results took just around 3 hours (which is impressively fast for all that data to propagate through the Drupal ecosystem!).

Drupal Commerce & Event Registration System
The backbone of the site is a custom event registration system running on Drupal Commerce. Users who wish to sign their teams up for tournaments are actually submitting a registration for a tournament product, broken up by age brackets, and purchasing their slot on each respective tournament. To do this, we had to bypass the common workflow of E-Commerce and not require payment upfront. Customers are allowed to pay as they go, with payments set forth as business rules so they can pay in increments and retain their spot in the tournament. If no payment is made in the given payment schedules, the slot is released, and another registered team can claim the spot.

To do this, we customized the experience and changed the Drupal Commerce workflow to bypass the payment screen if the user was registering for a tournament. Since there are plans to have a full merch store as well, the original workflow occurs if the customer is only buying a t-shirt or other physical item. Through some custom code and permission, a customer can complete the checkout of a registration without making a payment. After they checkout, their registration is submitted, at which point they can continue to their account overview and make a deposit or pay the full balance.

This flexibility keeps a maintainable structure to not only converting users, but keeping tournament registrant lists flexible right up to the week before a tournament. Teams can hop in and hop out at any time, and other teams can be shifted into their place by staff members without any fuss.

Mobile First
Sports at the Beach's new website was designed from the ground up to be 'mobile first'- meaning we focused on the mobile aspect before polishing the desktop experience. Everyone attending tournaments can pull up the website on their phone or tablet device and check the day's schedule and game results, which is critically important as people find themselves less and less at a desktop computer and more on the go. Their new website is implemented in a responsive design fashion- the website reacts and responds to the display screen. Not sure what that is? Try resizing your browser on their website to see it in action. Staff can also login from anywhere on the premises and update scores or adjust the schedule on the spot without returning to the office.

Cloud Hosted
Our hosting company, Acquia, has come through for us again providing us with a lightning fast server for our Drupal application. Combined with technologies like Varnish and MemCached, Sports at the Beach can withstand traffic surges and spikes of thousands of users and still stay online, which is typical activity during a tournament in the summer. The user experience is extremely fast and we are aiming to make them even faster.

Many moving pieces were involved in this conversion process. To address the specifics on how we achieved certain aspects of the system under Drupal Commerce or custom data models (for you dev geeks), we will be writing more specific posts about how we accomplished those parts. But for now, check out the new Sports at the Beach website!

Team Member
Subheader #1
We love puns, but we really did hit it out of the park on this upgrade and migration
Published on
Article Photo
Author
Team Inclind
Article Type
News Article (unrelated to clients)
{
    "jsonapi": {
        "version": "1.0",
        "meta": {
            "links": {
                "self": {
                    "href": "http:\/\/jsonapi.org\/format\/1.0\/"
                }
            }
        }
    },
    "data": {
        "type": "node--article",
        "id": "77a1c3db-48fb-41ec-bc13-427f9d1d98aa",
        "links": {
            "self": {
                "href": "https:\/\/backend.inclind.com\/jsonapi\/articles\/77a1c3db-48fb-41ec-bc13-427f9d1d98aa?resourceVersion=id%3A320"
            }
        },
        "attributes": {
            "internalId": 320,
            "isPublished": true,
            "title": "Inclind Hits a Grand Slam with Sports at the Beach\u0027s New Website",
            "created": "2022-07-17T19:11:01+00:00",
            "changed": "2024-05-09T18:11:31+00:00",
            "promote": false,
            "sticky": false,
            "metatag": [
                {
                    "tag": "meta",
                    "attributes": {
                        "name": "title",
                        "content": "Inclind Hits a Grand Slam with Sports at the Beach\u0027s New"
                    }
                },
                {
                    "tag": "meta",
                    "attributes": {
                        "name": "description",
                        "content": "Sports at the Beach hosts youth baseball and softball tournaments. The 95 acre facility, located near the Delaware beaches, draws teams primarily from the"
                    }
                },
                {
                    "tag": "meta",
                    "attributes": {
                        "name": "abstract",
                        "content": "Delaware Drupal web development company specializing in custom Drupal development, real estate and rental brokerage websites, internet marketing and ecommerce"
                    }
                },
                {
                    "tag": "link",
                    "attributes": {
                        "rel": "canonical",
                        "href": "https:\/\/www.inclind.com\/news\/inclind-hits-grand-slam-sports-beachs-new-website"
                    }
                },
                {
                    "tag": "meta",
                    "attributes": {
                        "name": "robots",
                        "content": "index, follow"
                    }
                },
                {
                    "tag": "meta",
                    "attributes": {
                        "property": "og:site_name",
                        "content": "Inclind"
                    }
                },
                {
                    "tag": "meta",
                    "attributes": {
                        "property": "og:url",
                        "content": "https:\/\/www.inclind.com\/news\/inclind-hits-grand-slam-sports-beachs-new-website"
                    }
                },
                {
                    "tag": "meta",
                    "attributes": {
                        "property": "og:title",
                        "content": "Inclind Hits a Grand Slam with Sports at the Beach\u0027s New Website"
                    }
                },
                {
                    "tag": "meta",
                    "attributes": {
                        "property": "og:description",
                        "content": "Delaware Drupal web development company specializing in custom Drupal development, real estate and rental brokerage websites, internet marketing and ecommerce"
                    }
                },
                {
                    "tag": "meta",
                    "attributes": {
                        "property": "place:location:latitude",
                        "content": "38.77513"
                    }
                },
                {
                    "tag": "meta",
                    "attributes": {
                        "property": "place:location:longitude",
                        "content": "-75.13974"
                    }
                },
                {
                    "tag": "meta",
                    "attributes": {
                        "property": "og:street_address",
                        "content": "119 W. Third St., Suite 6"
                    }
                },
                {
                    "tag": "meta",
                    "attributes": {
                        "property": "og:locality",
                        "content": "Lewes"
                    }
                },
                {
                    "tag": "meta",
                    "attributes": {
                        "property": "og:region",
                        "content": "Delaware"
                    }
                },
                {
                    "tag": "meta",
                    "attributes": {
                        "property": "og:postal_code",
                        "content": "19958"
                    }
                },
                {
                    "tag": "meta",
                    "attributes": {
                        "property": "og:country_name",
                        "content": "United States"
                    }
                },
                {
                    "tag": "meta",
                    "attributes": {
                        "property": "og:email",
                        "content": "hello@inclind.com"
                    }
                },
                {
                    "tag": "meta",
                    "attributes": {
                        "property": "og:phone_number",
                        "content": "(800) 604-8139"
                    }
                }
            ],
            "path": {
                "alias": "\/news\/inclind-hits-grand-slam-sports-beachs-new-website",
                "pid": 558,
                "langcode": "en"
            },
            "body": {
                "value": "\u003Cp\u003E\u003Ca href=\u0022https:\/\/www.sportsatthebeach.com\/\u0022\u003ESports at the Beach\u003C\/a\u003E hosts youth baseball and softball tournaments. The 95 acre facility, located near the Delaware beaches, draws teams primarily from the Northeast and Mid-Atlantic states. Inclind began its relationship with Sports at the Beach in 2001, designing and constructing both public and private websites. Since then, Sports at the Beach has flourished and has become the top attraction for youth baseball tournaments on the east coast other than Disney World\u2019s sports complex in Florida.\u003C\/p\u003E\u003Cp\u003EFrom ColdFusion to Drupal\u003Cbr\u003EThe main objective of the project was to migrate the website away from the aging ColdFusion language to a powerful PHP application founded on Drupal. The website was originally launched by Inclind in 2005 on ColdFusion 6, hosted on a dedicated Windows\/MSSQL server. We re-architected the application in the Drupal 7 framework, leveraging it\u0027s combined capabilities of a CMS, CRM, and eCommerce system (via Drupal Commerce) to manage tournament products and tournament registrations, and provide a cleaner and more intuitive customer workflow from creating an account to registering a team and making registration payments.\u003C\/p\u003E\u003Cp\u003EMigrating Ten Years of History\u003Cbr\u003ESports at the Beach database contains data going all the way back to 2002 when their very first system ran on top of an MS Access database (yep!). All of that history has been preserved and imported into their new system.\u003C\/p\u003E\u003Cp\u003EUtilizing Migrations, we were able to keep every single database record, normalize and clean the data for MySQL\/Drupal, and fill in all the gaps that were lost over time either due to old bugs, mis-entries, or other anomalies. After a weeks worth of analysis of the MSSQL schema and data, we were able to craft a dozen Migration scripts to transpose the data over to MySQL. Since we use Migrations, we can quickly spot bad data coming in and stop and adjust the import, rollback and try again without any hassle. In the end, all of the 2 million database records made their way over. Migrating and importing a decade of content, users, orders, payments, registrations, tournaments, games and results took just around 3 hours (which is impressively fast for all that data to propagate through the Drupal ecosystem!).\u003C\/p\u003E\u003Cp\u003EDrupal Commerce \u0026amp; Event Registration System\u003Cbr\u003EThe backbone of the site is a custom event registration system running on Drupal Commerce. Users who wish to sign their teams up for tournaments are actually submitting a registration for a tournament product, broken up by age brackets, and purchasing their slot on each respective tournament. To do this, we had to bypass the common workflow of E-Commerce and not require payment upfront. Customers are allowed to pay as they go, with payments set forth as business rules so they can pay in increments and retain their spot in the tournament. If no payment is made in the given payment schedules, the slot is released, and another registered team can claim the spot.\u003C\/p\u003E\u003Cp\u003ETo do this, we customized the experience and changed the Drupal Commerce workflow to bypass the payment screen if the user was registering for a tournament. Since there are plans to have a full merch store as well, the original workflow occurs if the customer is only buying a t-shirt or other physical item. Through some custom code and permission, a customer can complete the checkout of a registration without making a payment. After they checkout, their registration is submitted, at which point they can continue to their account overview and make a deposit or pay the full balance.\u003C\/p\u003E\u003Cp\u003EThis flexibility keeps a maintainable structure to not only converting users, but keeping tournament registrant lists flexible right up to the week before a tournament. Teams can hop in and hop out at any time, and other teams can be shifted into their place by staff members without any fuss.\u003C\/p\u003E\u003Cp\u003EMobile First\u003Cbr\u003ESports at the Beach\u0027s new website was designed from the ground up to be \u0027mobile first\u0027- meaning we focused on the mobile aspect before polishing the desktop experience. Everyone attending tournaments can pull up the website on their phone or tablet device and check the day\u0027s schedule and game results, which is critically important as people find themselves less and less at a desktop computer and more on the go. Their new website is implemented in a responsive design fashion- the website reacts and responds to the display screen. Not sure what that is? Try resizing your browser on their website to see it in action. Staff can also login from anywhere on the premises and update scores or adjust the schedule on the spot without returning to the office.\u003C\/p\u003E\u003Cp\u003ECloud Hosted\u003Cbr\u003EOur hosting company, Acquia, has come through for us again providing us with a lightning fast server for our Drupal application. Combined with technologies like Varnish and MemCached, Sports at the Beach can withstand traffic surges and spikes of thousands of users and still stay online, which is typical activity during a tournament in the summer. The user experience is extremely fast and we are aiming to make them even faster.\u003C\/p\u003E\u003Cp\u003EMany moving pieces were involved in this conversion process. To address the specifics on how we achieved certain aspects of the system under Drupal Commerce or custom data models (for you dev geeks), we will be writing more specific posts about how we accomplished those parts. But for now, check out the new Sports at the Beach website!\u003C\/p\u003E",
                "format": "basic_html",
                "processed": "\u003Cp\u003E\u003Ca href=\u0022https:\/\/www.sportsatthebeach.com\/\u0022\u003ESports at the Beach\u003C\/a\u003E hosts youth baseball and softball tournaments. The 95 acre facility, located near the Delaware beaches, draws teams primarily from the Northeast and Mid-Atlantic states. Inclind began its relationship with Sports at the Beach in 2001, designing and constructing both public and private websites. Since then, Sports at the Beach has flourished and has become the top attraction for youth baseball tournaments on the east coast other than Disney World\u2019s sports complex in Florida.\u003C\/p\u003E\u003Cp\u003EFrom ColdFusion to Drupal\u003Cbr\u003EThe main objective of the project was to migrate the website away from the aging ColdFusion language to a powerful PHP application founded on Drupal. The website was originally launched by Inclind in 2005 on ColdFusion 6, hosted on a dedicated Windows\/MSSQL server. We re-architected the application in the Drupal 7 framework, leveraging it\u0027s combined capabilities of a CMS, CRM, and eCommerce system (via Drupal Commerce) to manage tournament products and tournament registrations, and provide a cleaner and more intuitive customer workflow from creating an account to registering a team and making registration payments.\u003C\/p\u003E\u003Cp\u003EMigrating Ten Years of History\u003Cbr\u003ESports at the Beach database contains data going all the way back to 2002 when their very first system ran on top of an MS Access database (yep!). All of that history has been preserved and imported into their new system.\u003C\/p\u003E\u003Cp\u003EUtilizing Migrations, we were able to keep every single database record, normalize and clean the data for MySQL\/Drupal, and fill in all the gaps that were lost over time either due to old bugs, mis-entries, or other anomalies. After a weeks worth of analysis of the MSSQL schema and data, we were able to craft a dozen Migration scripts to transpose the data over to MySQL. Since we use Migrations, we can quickly spot bad data coming in and stop and adjust the import, rollback and try again without any hassle. In the end, all of the 2 million database records made their way over. Migrating and importing a decade of content, users, orders, payments, registrations, tournaments, games and results took just around 3 hours (which is impressively fast for all that data to propagate through the Drupal ecosystem!).\u003C\/p\u003E\u003Cp\u003EDrupal Commerce \u0026amp; Event Registration System\u003Cbr\u003EThe backbone of the site is a custom event registration system running on Drupal Commerce. Users who wish to sign their teams up for tournaments are actually submitting a registration for a tournament product, broken up by age brackets, and purchasing their slot on each respective tournament. To do this, we had to bypass the common workflow of E-Commerce and not require payment upfront. Customers are allowed to pay as they go, with payments set forth as business rules so they can pay in increments and retain their spot in the tournament. If no payment is made in the given payment schedules, the slot is released, and another registered team can claim the spot.\u003C\/p\u003E\u003Cp\u003ETo do this, we customized the experience and changed the Drupal Commerce workflow to bypass the payment screen if the user was registering for a tournament. Since there are plans to have a full merch store as well, the original workflow occurs if the customer is only buying a t-shirt or other physical item. Through some custom code and permission, a customer can complete the checkout of a registration without making a payment. After they checkout, their registration is submitted, at which point they can continue to their account overview and make a deposit or pay the full balance.\u003C\/p\u003E\u003Cp\u003EThis flexibility keeps a maintainable structure to not only converting users, but keeping tournament registrant lists flexible right up to the week before a tournament. Teams can hop in and hop out at any time, and other teams can be shifted into their place by staff members without any fuss.\u003C\/p\u003E\u003Cp\u003EMobile First\u003Cbr\u003ESports at the Beach\u0027s new website was designed from the ground up to be \u0027mobile first\u0027- meaning we focused on the mobile aspect before polishing the desktop experience. Everyone attending tournaments can pull up the website on their phone or tablet device and check the day\u0027s schedule and game results, which is critically important as people find themselves less and less at a desktop computer and more on the go. Their new website is implemented in a responsive design fashion- the website reacts and responds to the display screen. Not sure what that is? Try resizing your browser on their website to see it in action. Staff can also login from anywhere on the premises and update scores or adjust the schedule on the spot without returning to the office.\u003C\/p\u003E\u003Cp\u003ECloud Hosted\u003Cbr\u003EOur hosting company, Acquia, has come through for us again providing us with a lightning fast server for our Drupal application. Combined with technologies like Varnish and MemCached, Sports at the Beach can withstand traffic surges and spikes of thousands of users and still stay online, which is typical activity during a tournament in the summer. The user experience is extremely fast and we are aiming to make them even faster.\u003C\/p\u003E\u003Cp\u003EMany moving pieces were involved in this conversion process. To address the specifics on how we achieved certain aspects of the system under Drupal Commerce or custom data models (for you dev geeks), we will be writing more specific posts about how we accomplished those parts. But for now, check out the new Sports at the Beach website!\u003C\/p\u003E",
                "summary": ""
            },
            "articleType": "news",
            "author": "Team Inclind",
            "authorTitle": null,
            "challenge": null,
            "introText": null,
            "location": null,
            "f_metatag": null,
            "publishDate": "2013-01-23",
            "result": null,
            "solution": null,
            "subheader1": "We love puns, but we really did hit it out of the park on this upgrade and migration",
            "subheader2": null
        },
        "relationships": {
            "contentType": {
                "data": null,
                "links": {
                    "self": {
                        "href": "https:\/\/backend.inclind.com\/jsonapi\/articles\/77a1c3db-48fb-41ec-bc13-427f9d1d98aa\/relationships\/contentType?resourceVersion=id%3A320"
                    }
                }
            },
            "category": {
                "data": {
                    "type": "catTerm",
                    "id": "1c393ecc-d2a4-4630-afc0-83f831c30ac9",
                    "meta": {
                        "drupal_internal__target_id": 4
                    }
                },
                "links": {
                    "related": {
                        "href": "https:\/\/backend.inclind.com\/jsonapi\/articles\/77a1c3db-48fb-41ec-bc13-427f9d1d98aa\/category?resourceVersion=id%3A320"
                    },
                    "self": {
                        "href": "https:\/\/backend.inclind.com\/jsonapi\/articles\/77a1c3db-48fb-41ec-bc13-427f9d1d98aa\/relationships\/category?resourceVersion=id%3A320"
                    }
                }
            },
            "companyRef": {
                "data": null,
                "links": {
                    "related": {
                        "href": "https:\/\/backend.inclind.com\/jsonapi\/articles\/77a1c3db-48fb-41ec-bc13-427f9d1d98aa\/companyRef?resourceVersion=id%3A320"
                    },
                    "self": {
                        "href": "https:\/\/backend.inclind.com\/jsonapi\/articles\/77a1c3db-48fb-41ec-bc13-427f9d1d98aa\/relationships\/companyRef?resourceVersion=id%3A320"
                    }
                }
            },
            "image": {
                "data": {
                    "type": "images",
                    "id": "d7076fcc-6e09-4b20-abd5-83ebadeac14c",
                    "meta": {
                        "drupal_internal__target_id": 166
                    }
                },
                "links": {
                    "related": {
                        "href": "https:\/\/backend.inclind.com\/jsonapi\/articles\/77a1c3db-48fb-41ec-bc13-427f9d1d98aa\/image?resourceVersion=id%3A320"
                    },
                    "self": {
                        "href": "https:\/\/backend.inclind.com\/jsonapi\/articles\/77a1c3db-48fb-41ec-bc13-427f9d1d98aa\/relationships\/image?resourceVersion=id%3A320"
                    }
                }
            },
            "slides": {
                "data": [],
                "links": {
                    "related": {
                        "href": "https:\/\/backend.inclind.com\/jsonapi\/articles\/77a1c3db-48fb-41ec-bc13-427f9d1d98aa\/slides?resourceVersion=id%3A320"
                    },
                    "self": {
                        "href": "https:\/\/backend.inclind.com\/jsonapi\/articles\/77a1c3db-48fb-41ec-bc13-427f9d1d98aa\/relationships\/slides?resourceVersion=id%3A320"
                    }
                }
            },
            "teamMember": {
                "data": [
                    {
                        "type": "node--person",
                        "id": "87407245-73a3-43f8-9f44-9e70f40a0e1a",
                        "meta": {
                            "drupal_internal__target_id": 120
                        }
                    }
                ],
                "links": {
                    "related": {
                        "href": "https:\/\/backend.inclind.com\/jsonapi\/articles\/77a1c3db-48fb-41ec-bc13-427f9d1d98aa\/teamMember?resourceVersion=id%3A320"
                    },
                    "self": {
                        "href": "https:\/\/backend.inclind.com\/jsonapi\/articles\/77a1c3db-48fb-41ec-bc13-427f9d1d98aa\/relationships\/teamMember?resourceVersion=id%3A320"
                    }
                }
            },
            "tags": {
                "data": [],
                "links": {
                    "related": {
                        "href": "https:\/\/backend.inclind.com\/jsonapi\/articles\/77a1c3db-48fb-41ec-bc13-427f9d1d98aa\/tags?resourceVersion=id%3A320"
                    },
                    "self": {
                        "href": "https:\/\/backend.inclind.com\/jsonapi\/articles\/77a1c3db-48fb-41ec-bc13-427f9d1d98aa\/relationships\/tags?resourceVersion=id%3A320"
                    }
                }
            },
            "topic": {
                "data": [
                    {
                        "type": "topicTerm",
                        "id": "1a993f8f-ee53-4048-ba7a-94e301547386",
                        "meta": {
                            "drupal_internal__target_id": 2
                        }
                    },
                    {
                        "type": "topicTerm",
                        "id": "dc2c8a07-38a3-46e7-a5a9-93dc46b3b799",
                        "meta": {
                            "drupal_internal__target_id": 16
                        }
                    },
                    {
                        "type": "topicTerm",
                        "id": "8c44c30c-7ffe-44a0-bbfb-7642ac8d3b3c",
                        "meta": {
                            "drupal_internal__target_id": 17
                        }
                    }
                ],
                "links": {
                    "related": {
                        "href": "https:\/\/backend.inclind.com\/jsonapi\/articles\/77a1c3db-48fb-41ec-bc13-427f9d1d98aa\/topic?resourceVersion=id%3A320"
                    },
                    "self": {
                        "href": "https:\/\/backend.inclind.com\/jsonapi\/articles\/77a1c3db-48fb-41ec-bc13-427f9d1d98aa\/relationships\/topic?resourceVersion=id%3A320"
                    }
                }
            }
        }
    },
    "links": {
        "self": {
            "href": "https:\/\/backend.inclind.com\/jsonapi\/articles\/77a1c3db-48fb-41ec-bc13-427f9d1d98aa?resourceVersion=id%3A320"
        }
    }
}