How to Migrate Your Typepad to WordPress Before the Shutdown

The Clock Is Ticking –  migrate your Typepad to WordPress

For almost twenty years, **Typepad** has been the home of countless bloggers, hobbyists, and small businesses. It was one of the earliest platforms to make blogging accessible, and many creators have built a legacy there.

But time is running out. With the **official shutdown scheduled for September 30, 2025**, Typepad blogs will soon vanish unless action is taken. This deadline is not just about technology — it’s about protecting your voice, your content, and years of effort.

The good news? You can save everything by migrating to **WordPress**, the world’s most popular website platform. WordPress is secure, flexible, SEO-friendly, and future-proof.

This guide walks you through the entire process — from exporting your content to importing it into WordPress, fixing broken images, preserving SEO, and redesigning your site for growth.


Why WordPress Is the Best Destination

When a platform shuts down, you’re faced with choices: Ghost, Squarespace, Wix, Substack, or even just saving everything offline. But WordPress consistently stands out here’s why:

  1. Ownership – Your content is yours. No company shutdown can erase it.
  2. SEO power – Google loves WordPress’s clean structure and metadata options.
  3. Flexibility – Tens of thousands of themes and plugins let you build any type of site.
  4. Scalability – Works for a one-person blog or a full-scale digital magazine
  5. Community – Millions of users, developers, and resources at your fingertips.

If you want your blog to not only survive but grow, WordPress is the logical new home.

 

Typepad Blog to WordPress

Step 1: Export Your Blog from Typepad

Before Typepad closes its doors, export your data.

1. Log in to your Typepad dashboard.
2. Navigate to Settings → Import/Export.
3. Click Export to download your `.txt` archive. This file contains your posts, categories, and comments.
4. Download your images and attachments. Depending on how your blog was set up, they may be bundled or require manual download.
5. Save everything in multiple places (computer, external drive, and cloud storage).

⚠️ Pro Tip: Even if you’re not ready to migrate right now, export today. After September 30, 2025, you may lose access to your content forever.

 

 Step 2: Prepare Your New WordPress Site

With your Typepad export ready, it’s time to set up WordPress.

Choose a Hosting Provider

Good hosting ensures speed, security, and reliability. Popular options include:

  • Hostinger – Affordable and beginner-friendly.
  • Kinsta – Premium managed hosting for top performance, but really expensive

Install WordPress

Most hosting providers offer one-click WordPress installs. In minutes, your new site will be live.

Pick a Theme

Choose a lightweight, SEO-friendly theme:

  • Astra – Fast and flexible.
  • GeneratePress – Minimalist and reliable.
  • Kadence – Excellent for bloggers.

Install Key Plugins

  • Rank Math SEO** (or Yoast SEO) – Optimize search presence.
  • Redirection – Manage 301 redirects from old URLs.
  • Classic Editor – Helpful for fixing formatting.
  • Auto Upload Images** – Relinks image paths automatically.

Step 3: Import Your Typepad Content

Now transfer your exported content.

1. In WordPress, go to **Tools → Import**.
2. Select **Movable Type and Typepad Importer**.
3. Upload your `.txt` file.
4. Assign authors where needed.
5. Verify categories, tags, and comments.

This step usually works smoothly, but larger blogs may take longer.

Need Expert Help with Migrating Typepad to WordPress?

Hire a certified WordPress expert from Codeable to help you move your Typepad blog safely to WordPress with all posts, images, and SEO intact.

Get a Free Estimate

 Step 4: Fix Images and Media

One of the most common migration issues is broken images.

How to solve broken images during Typepad migration

  • Upload your images into the WordPress `/wp-content/uploads/` folder.
  • Use the Auto Upload Images plugin to automatically relink them.
  • Manually check featured images and older posts.

Restoring visuals is crucial because images carry both emotional, content and SEO weight.

Step 5: Preserve Your SEO

SEO preservation is non-negotiable if you want to maintain traffic.

Steps:

1. Map old URLs to new ones.

* Example:

* Old: `http://yourblog.typepad.com/2020/05/my-post.html`
* New: `https://yourblog.com/my-post/`
2. Use the **Redirection plugin** to set up permanent (301) redirects.
3. Update your sitemap and resubmit it in **Google Search Console**.
4. Monitor traffic and errors in Search Console.

Done correctly, you won’t lose rankings — you may even gain them.

 Step 6: Redesign & Customize

Migration is also an opportunity for a **fresh design**.

* Customize fonts, colors, and layouts through your theme.
* Add must-have pages: **About, Contact, Privacy Policy**.
* Use widgets to display **Recent Posts**, **Categories**, or an **Email Signup Form**.
* Consider tools like **Google Analytics** or **Microsoft Clarity** to track engagement.

Step 7: Test & Launch

Before announcing your migration, test thoroughly.

  • Check your site on **desktop, tablet, and mobile**.
  • Test forms, menus, and links.
  • Verify redirects work.
  • Optimize speed with caching (WP Rocket, LiteSpeed Cache).

Only after testing should you publicly announce the new site.

 Common Issues and Fixes

  • Formatting problems – Use the Classic Editor to tidy up.
  • Missing comments – Double-check export and re-import.
  • Duplicate posts – Delete extras manually.
  • Slow load speed – Optimize images and use a CDN.

Future-Proofing Your WordPress Blog

Once you’ve migrated, protect your investment:

  1.  Keep **WordPress, plugins, and themes updated**.
  2. Set up **automatic backups** (UpdraftPlus, AllInOneMigration).
  3. Continue publishing valuable content for SEO growth.
  4. Engage readers with **newsletters and social sharing tools**.

Why You Should Act Now

The shutdown date may feel far away, but migration projects often take longer than expected. By acting early, you avoid:

  • Last-minute panic if servers slow down near the deadline.
  • SEO loss due to rushed redirects.
  • Data gaps if you miss files during export.

Early movers also benefit from the chance to redesign and optimize without pressure.

The September 30, 2025 shutdown is a hard deadline. Waiting puts your content at risk.

Migrating to WordPress ensures your posts, images, comments, and SEO survive — and thrive in a modern, flexible platform.

Whether you do it yourself with this guide or hire an expert, the key is to act now.

Need Expert Help with Migrating Typepad to WordPress?

Hire a certified WordPress expert from Codeable to help you move your Typepad blog safely to WordPress with all posts, images, and SEO intact.

Get a Free Estimate

Frequently Asked Questions About Migrating from Typepad to WordPress

1. When exactly is Typepad shutting down, and what happens after that date?
Typepad will officially shut down on September 30, 2025. After this date, the platform will no longer be accessible, meaning you won’t be able to log in, view, or manage your blog. If you don’t export your content before the shutdown, there’s a high chance it will be lost permanently. That’s why it’s critical to create backups and start your migration process well before the deadline. Migrating early also gives you time to test your new WordPress site without pressure.

2. Can I migrate my comments, images, and categories along with my posts?
Yes, WordPress supports importing not just blog posts but also comments, categories, and tags from your Typepad export file. Images are trickier — while many transfer automatically, some may break because of different storage paths. Fortunately, plugins like Auto Upload Images can repair those links, and manual uploads can fix any missing files. Spending time on this ensures your new site feels complete and consistent, preserving both the look and the community feel of your blog.

3. Will migrating to WordPress hurt my SEO rankings?
Not if you take the right steps. SEO is often tied to your URL structure, so the key is setting up proper 301 redirects from your old Typepad URLs to your new WordPress URLs. This tells Google and other search engines that your content has moved but still exists, protecting your authority and rankings. In some cases, a well-optimized WordPress setup can even improve your SEO performance thanks to faster load times, better mobile support, and enhanced metadata control.

4. How long does it usually take to migrate a blog from Typepad to WordPress?
The timeline depends on the size of your blog and your comfort with WordPress. A smaller blog with a few hundred posts can often be migrated in a single afternoon. Larger sites with thousands of entries, images, and comments may take a couple of days, especially if you’re fixing formatting or image issues. If you’re doing the migration yourself for the first time, give yourself extra time for testing and troubleshooting. Hiring an expert can shorten the process dramatically since they already know how to handle common pitfalls.

5. Should I consider hiring a WordPress expert, or is DIY good enough?
If you’re comfortable with technical setups, backups, and troubleshooting, you can absolutely migrate your blog on your own using this guide. However, if your blog is large, has complex formatting, or generates income, hiring a WordPress migration expert is often worth it. Experts ensure no posts or images are lost, all SEO redirects are properly configured, and your new site looks polished from day one. For many bloggers, the peace of mind and saved time outweigh the cost of professional help.

6. What if my Typepad export file is corrupted or incomplete?
Occasionally, export files may fail or skip certain content, especially if your blog is very large. The first step is to try the export process again and check if the file size changes. If problems persist, you may need to split your blog into smaller exports or use a manual copy-paste approach for certain posts. In the worst case, a migration expert can often use advanced tools to recover most of your data. That’s why it’s best to export as soon as possible, giving you time to check the files well before the shutdown.

7. Will all my old blog links shared on social media still work?
Not automatically. If someone clicks an old Typepad link after the shutdown, it will lead to an error unless you’ve set up redirects. By mapping old URLs to your new WordPress site, you ensure that readers following old links land on the correct post. This is especially important if your blog has backlinks from other websites, since losing those could harm your SEO. With proper redirects, your blog’s traffic remains intact, and your readers won’t notice a disruption.

8. Can I redesign my site during the migration process, or should I wait?
One of the best parts of moving to WordPress is the opportunity to modernize your design. You can absolutely launch with a new theme, better navigation, and an updated layout. In fact, many bloggers use migration as a chance to refresh their brand and improve user experience. That said, if you’re pressed for time, focus first on getting all your content migrated and SEO preserved — design updates can always follow later once your content is secure.

9. What if I already have a custom domain pointing to my Typepad blog?
If you’ve been using a custom domain (like yourblog.com) with Typepad, migration becomes easier. Once your WordPress site is set up, you can point that domain to your new hosting provider. This way, your readers will continue visiting the same URL, but it will now load your WordPress site instead of Typepad. If you don’t have a custom domain yet, consider registering one — it gives you independence from any blogging platform in the future.

10. Is WordPress difficult to manage after migration?
Not at all. While WordPress offers a huge amount of flexibility, the basics — writing posts, uploading images, and managing comments — are very straightforward. If you could use Typepad, you can learn WordPress quickly. There’s also a massive library of tutorials, forums, and documentation available. Plus, unlike Typepad, WordPress will continue evolving and improving, so you won’t face another sudden shutdown.

Best WordPress Themes for Lawyers and Law Firms

A strong online presence is vital for law firms seeking to grow their client base and communicate their expertise. WordPress themes tailored to law firms provide a variety of features that not only make a website look professional but also optimize it for the best user experience and search engine rankings.

With a responsive design, your website will offer an optimal experience for visitors, whether they are on a desktop, tablet, or smartphone. Additionally, SEO-friendly features integrated within these themes help improve the visibility of your website, making it easier for potential clients to find your services. Furthermore, customization options let you tailor the website to your specific branding needs without needing extensive technical expertise.

Top WordPress Themes for Lawyers

1. Lawna: Lawyer & Law Firm WordPress Theme

Lawna is a sleek, modern theme designed specifically for law firms. With a variety of pre-designed demos, it offers flexibility in customizing the look and feel of your website. Lawna includes essential features like:

  • SEO Optimization: The theme follows best practices for SEO, ensuring your site is search engine-friendly.
  • Responsive Design: Ensures your website looks great on any device.
  • Attorney Profiles: Easily showcase your team’s qualifications and specialties.
  • Customizable Layouts: You can adjust the layout to suit your firm’s branding.
  • Lead Generation Forms: Integrated contact forms for capturing client information.

Lawyers website

View Lawna Theme on ThemeForest

2. Libero: A Theme for Lawyers and Law Firms

Libero offers a sleek, professional design that suits any law firm. This theme comes with several customization options and is ideal for lawyers looking for a clean, modern look. Key features include:

  • Multiple Demos: You can easily select a demo layout that fits your firm’s image.
  • SEO-Optimized: Built with SEO-friendly code for higher search engine rankings.
  • Mobile-Friendly: The theme adapts to all screen sizes.
  • Client Testimonials Section: Helps build trust by showcasing client feedback.
  • Booking Integration: Integrates with booking systems to help clients schedule consultations.

Lawyers wbiste - Libero theme

View Libero Theme on ThemeForest

3. Lawhere: Lawyer & Law Firm WordPress Theme

Lawhere is another top-notch theme tailored for legal professionals. It features a professional, polished design that is both easy to navigate and visually appealing. Features include:

  • Customizable Service Pages: Showcase your firm’s areas of expertise with dedicated service pages.
  • Attorney Team Profiles: Display each team member’s qualifications and areas of expertise.
  • Responsive and SEO Optimized: Great for mobile devices and search engine visibility.
  • Appointment Booking System: Let clients book consultations online.
  • Contact Forms: Easy-to-use contact forms to get client inquiries.

Lawn Firm - Lawhere Website WordPress Theme

View Lawhere Theme on ThemeForest

4. Ensaf: Attorney & Lawyer WordPress Theme

Ensaf is a robust and responsive WordPress theme built for law firms. With its clean, modern design, it offers a professional online presence. Key features include:

  • Drag-and-Drop Builder: Customize your site easily with the built-in page builder.
  • SEO-Friendly: Ensaf includes features designed to improve search engine ranking.
  • Responsive Design: Ensures a seamless experience across all devices.
  • Attorney Profiles: Highlight your team’s experience and specialties.
  • Booking & Contact Forms: Includes integrated booking and contact forms for easy client interaction.

Law firm Website theme

View Ensaf Theme on ThemeForest

 

These themes are designed to highlight the core services, build trust through testimonials, and showcase attorney profiles—all while ensuring the site is mobile-friendly and SEO-optimized. In this guide, we’ll explore the top WordPress themes for law firms, each offering unique features to elevate your firm’s online presence.

Key Features to Consider When Choosing a Law Firm Theme

When selecting a WordPress theme for your law firm website, here are the key features you should keep in mind:

  • SEO Optimization: An SEO-friendly theme ensures that your website has the right structure to be indexed properly by search engines like Google, making it easier for prospective clients to find you.
  • Responsive Design: Your website should look professional on all devices, from desktops to smartphones. A responsive design guarantees a seamless user experience, increasing user engagement.
  • Customization Options: Look for themes that allow you to customize the layout, fonts, colors, and images to match your firm’s branding. A unique design will set your firm apart from the competition.
  • Attorney Profiles: An essential feature is the ability to showcase your team of attorneys. Include detailed profiles with photos, qualifications, and practice areas.
  • Client Testimonials: Trust is key in the legal industry, and displaying testimonials from satisfied clients can increase your firm’s credibility and attract new business.
  • Appointment Booking System: Many law firms benefit from having an online appointment booking system integrated into their website, making it easy for clients to schedule consultations directly.
  • Lead Capture Forms: Capture potential client details by integrating contact forms that allow visitors to get in touch quickly.

Frequently Asked Questions About Lawyer WordPress Themes

  1. How do I customize a law firm WordPress theme?
    • Customizing a WordPress theme is simple with drag-and-drop page builders included in most themes. You can easily adjust layouts, colors, fonts, and images without needing coding skills.
  2. Is SEO optimization included with these themes?
    • Yes, many law firm themes are built with SEO best practices in mind. They include clean code, fast loading speeds, and compatibility with popular SEO plugins like Yoast SEO.
  3. How do I add attorney profiles to my website?
    • Most WordPress themes for law firms include predefined sections where you can add individual attorney profiles. You can fill out fields with their name, bio, photo, and practice areas to personalize their profiles.
  4. Can I integrate an appointment booking system?
    • Yes, many law firm themes allow integration with appointment booking plugins like Bookly or Amelia, allowing clients to book consultations directly through your website.
  5. Are these themes mobile-friendly?
    • All the themes mentioned here are responsive, meaning they automatically adjust to different screen sizes and devices, offering a great user experience for visitors on smartphones, tablets, or desktops.

Ready to Build Your Law Firm’s Online Presence?

If you don’t have a website, it’s time to change that. Get a FREE ESTIMATE for a custom-built, professional law firm website that will not only look great but also bring in new clients. Let’s create a website that reflects your expertise and sets you apart from competitors.

Start Building Your Website Today

Get Free Estimate

Phone Number Field in Contact Form 7

Why Add a Phone Number Field to Your Contact Form?

A phone number field in your contact form offers several advantages:

  • Improve Communication: Allowing visitors to submit their phone numbers helps you reach out to potential leads quickly and personally.
  • Better Lead Conversion: Collecting phone numbers enables faster follow-ups, improving your chances of converting visitors into customers.
  • Enhance Customer Support: If you offer customer support, having a phone number in the form can help resolve issues faster by allowing you to call the customer directly.

Step 1: Add a Basic Phone Number Field in Contact Form 7

Adding a phone number field to your form is simple. Here’s how to do it:

Step 1.1: Open Your Contact Form in Contact Form 7

  1. From your WordPress dashboard, go to Contact > Contact Forms.
  2. Select the form you want to edit, or create a new form by clicking Add New.

Step 1.2: Add the Phone Number Field

  1. In the form editor, place the following code where you want the phone number field to appear:
<label for="phone">Phone Number</label>
[tel* phone id:phone]

Here’s what each part of the code means:

  • [tel* phone]: This shortcode creates a required phone number field. The * makes the field mandatory, meaning the user must fill it out before submitting the form.
  • id:phone: This gives the phone number field a unique ID, which can be useful for styling and other purposes.
  • label for="phone": This ensures that the label is associated with the phone number field for better accessibility.

Step 1.3: Save the Form

Once you’ve added the phone number field, click Save to store the changes.


Step 2: Customize the Phone Number Field

If you want to customize the phone number field further, there are several options you can use to improve the user experience and the validation process.

Step 2.1: Add Placeholder Text

To make it clear to users what format the phone number should be in, you can add placeholder text in the input field.

<label for="phone">Phone Number</label>
[tel* phone id:phone placeholder "Enter your phone number"]

This will display the text “Enter your phone number” inside the phone number field, giving users a hint of what to type.

Step 2.2: Format the Phone Number Field

To make sure the phone number is entered in the correct format, you can use a regular expression (regex) to validate the field.

<label for="phone">Phone Number</label>
[tel* phone id:phone placeholder "Enter your phone number" pattern="^[\+]?[0-9]{1,4}?[0-9]{7,10}$"]

This regex allows for phone numbers that may optionally start with a “+” (international code) and ensures that the number entered is between 7 to 10 digits long.

Step 2.3: Use JavaScript to Mask the Phone Number

For a more user-friendly approach, you can use a JavaScript library like Inputmask to create a mask for phone number entry. This can help format the number as the user types it, making it easier to collect consistent data.

<img src="" data-wp-preserve="%3Cscript%20src%3D%22https%3A%2F%2Fcdnjs.cloudflare.com%2Fajax%2Flibs%2Finputmask%2F5.0.6-beta.28%2Finputmask.min.js%22%3E%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="&lt;script&gt;" title="&lt;script&gt;" />

 

document.getElementById('phone').inputmask('(999) 999-9999'); // Example mask

This script will display the phone number in the format (123) 456-7890 as the user types it.


Step 3: Add Validation for the Phone Number Field

To ensure the phone number is entered correctly, it’s important to validate the input. Contact Form 7 provides built-in validation for the required fields, but you can add custom validation to check for a valid phone number.

Step 3.1: Use JavaScript for Phone Number Validation

If you want more advanced validation (for example, to ensure the phone number contains only numbers or follows a specific format), you can use JavaScript to check the value before submitting the form.

document.addEventListener('wpcf7submit', function(event) {
  var phoneNumber = document.getElementById('phone').value;
  var phoneRegex = /^[\+]?[0-9]{1,4}?[0-9]{7,10}$/;

  if (!phoneRegex.test(phoneNumber)) {
    alert('Please enter a valid phone number.');
    event.preventDefault(); // Prevent form submission
  }
}, false);

This script listens for the form submission event and checks the phone number against the specified regex pattern. If the phone number doesn’t match, the form submission is prevented, and an error message is shown.


Step 4: Style the Phone Number Field

You can style the phone number field to match the design of your site using custom CSS. Here’s an example of styling the phone number input field:

#phone {
  font-size: 16px;
  padding: 10px;
  width: 100%;
  border: 2px solid #ccc;
  border-radius: 5px;
  box-sizing: border-box;
}

#phone:focus {
  border-color: #0073e6;
}

FAQ: Common Questions About the Phone Number Field in Contact Form 7

1. Can I make the phone number field optional?

Yes! Simply remove the * from the [tel* phone] shortcode to make it optional:

<label for="phone">Phone Number</label>
[tel phone id:phone placeholder "Enter your phone number"]

2. How do I add country codes to the phone number field?

To allow users to enter their country code, you can add a dropdown field with country codes and then combine it with the phone number field. Here’s an example:

<label for="country-code">Country Code</label>
[select country-code "US +1" "CA +1" "UK +44" "IN +91"]

<label for="phone">Phone Number</label>
[tel* phone id:phone placeholder "Enter your phone number"]

You can then use JavaScript to combine the selected country code with the phone number value.

3. Can I use a phone number field in multiple forms?

Yes! The phone number field can be used in any form created with Contact Form 7. Simply add the same [tel* phone] shortcode to other forms where you need to collect phone numbers.

4. How can I validate international phone numbers?

For international phone number validation, you can use a more advanced regex pattern that allows for varying phone number formats based on the country. You can also use third-party libraries like libphonenumber to validate and format international numbers.

5. Can I use a phone number field in the Contact Form 7 email?

Yes! You can include the phone number field in the email body by using the corresponding form tag, for example:

Phone Number: [phone]

Adding a phone number field to your Contact Form 7 form is a simple but powerful way to collect contact information from your website visitors. Whether you’re collecting phone numbers for customer support, sales, or general inquiries, the customization options available in Contact Form 7 ensure you can tailor the phone number field to fit your needs.

From basic phone fields to advanced validation and styling, you now have all the tools you need to create effective phone number fields in Contact Form 7.


Need Help with Customizing Contact Form 7?

Hire a certified WordPress expert from Codeable to help you customize your Contact Form 7 fields and enhance your form functionality.

Get a Free Estimate

How to Connect Contact Form 7 to Google Sheets

Contact Form 7 is a powerful WordPress plugin that makes it easy to add forms to your website. However, sometimes you may want to automate the process of storing form submissions in a Google Sheets document for easier management, collaboration, and analysis. In this tutorial, we’ll dive deep into how to connect Contact Form 7 to Google Sheets using the CF7 Google Sheets Connector plugin.

Why Use Google Sheets with Contact Form 7?

Storing form submissions in Google Sheets provides a lot of benefits:

  • Easy Data Access: You can view and organize your form submissions in a Google Sheet anytime, from anywhere.
  • Collaboration: Share the Google Sheet with your team for instant collaboration and tracking.
  • Automation: Google Sheets offers various features and integrations that can automate tasks, like notifications or data analysis.
How to Connect Contact Form 7 to Google Sheets
How to Connect Contact Form 7 to Google Sheets

Step 1: Set Up Google Sheets API

Before you can connect Contact Form 7 to Google Sheets, you need to configure the Google Sheets API. Follow these steps:

1.1 Create a Project in Google Cloud Console

  1. Visit the Google Cloud Console.
  2. In the top left, click on the Select a Project dropdown and then click New Project.
  3. Name your project (e.g., “Contact Form 7 Integration”).
  4. Click Create to create your new project.

1.2 Enable Google Sheets API

  1. In the Google Cloud Console, go to APIs & Services > Library.
  2. Search for “Google Sheets API” and click on it.
  3. Click Enable to activate the API for your project.

1.3 Enable Google Drive API

Since you’ll be interacting with Google Sheets through a spreadsheet stored in Google Drive, you also need to enable the Google Drive API:

  1. In the same Library section, search for “Google Drive API”.
  2. Click Enable to activate the Drive API for your project.

1.4 Create OAuth Credentials

To authenticate the connection between WordPress and Google Sheets, you’ll need to create OAuth credentials:

  1. Go to APIs & Services > Credentials.
  2. Click Create Credentials, then select OAuth 2.0 Client IDs.
  3. If prompted, set up the OAuth consent screen. Fill in the required fields such as the Application name and Support email.
  4. Under Scopes, select the appropriate scopes for your integration (Google Sheets and Google Drive).
  5. In the Create OAuth client ID section, choose Web application as the application type.
  6. For Authorized redirect URIs, enter the redirect URI provided by the CF7 Google Sheets Connector plugin (this will be shown during setup).
  7. Click Create and download the credentials.json file. Keep this file safe, as it contains sensitive information.

Step 2: Install and Configure the CF7 Google Sheets Connector Plugin

  1. Go to Plugins > Add New in your WordPress admin panel.
  2. Search for “CF7 Google Sheets Connector”.
  3. Click Install Now and then Activate.

Once activated, the plugin will add a new settings section where you can configure the integration with Google Sheets.

Step 3: Authenticate the Plugin with Google

Now, you need to authenticate the plugin using the credentials.json file you downloaded earlier:

  1. Go to Contact Form 7 > Google Sheets Connector settings in your WordPress admin panel.
  2. You will see an option to Authenticate with Google. Click on it.
  3. Upload the credentials.json file you downloaded from the Google Cloud Console.
  4. Follow the on-screen prompts to authorize the plugin to access your Google Sheets and Drive data.
  5. Once authenticated, you’ll be prompted to select the Google Sheet you want to connect to. Choose the spreadsheet where you want to store your form submissions.

Step 4: Map Contact Form 7 Fields to Google Sheets Columns

With the Google Sheet connected, it’s time to map your form fields to the columns in the Google Sheet.

  1. In the plugin settings, you will see a section where you can map each form field to the columns in your Google Sheet.
  2. Match each field in your Contact Form 7 form with the corresponding column in the Google Sheet:
    • For example:
      • Name field in your form → Name column in your sheet
      • Email field in your form → Email column in your sheet
      • Message field in your form → Message column in your sheet
  3. Save the mappings.

If your form has custom fields, make sure each one corresponds to a column in the Google Sheet. If needed, add more columns to your sheet.

Step 5: Test the Integration

Once everything is set up, it’s time to test whether the integration works:

  1. Go to the page on your site where the Contact Form 7 form is located.
  2. Fill out the form with some test data (e.g., Name, Email, and Message).
  3. Submit the form.
  4. Go to your Google Sheet and check if the form submission appears as a new row.

If the submission doesn’t show up, ensure that:

  • The API credentials are correct and properly authenticated.
  • The Google Sheet has the correct permissions to allow data from the plugin.
  • The form field mappings are accurate.

Troubleshooting

If the integration isn’t working as expected, here are a few things to check:

  • API Credentials: Ensure that the OAuth credentials are correct and that the API is enabled for both Google Sheets and Google Drive.
  • Permissions: Verify that your Google Sheet has the right permissions (it should be accessible by the plugin).
  • Field Mappings: Double-check that each field in the form is mapped to the correct column in the Google Sheet.

 

 

Need Help Customizing Your Contact Form 7 Integration?

Hire a certified WordPress expert from Codeable to help you set up or customize your Contact Form 7 to Google Sheets integration.

Get a Free Estimate

How to Add a Custom Gradient Background to the Footer in Blocksy

A stylish footer is more than just a place for links—it’s a chance to leave a lasting impression. If you’re using the Blocksy theme on WordPress and want to create a custom gradient background for your footer, you’re in the right place.

This guide will show you how to add a gradient footer using both Blocksy Customizer and custom CSS. Whether you’re a beginner or a pro, you’ll find multiple ways to create a beautiful footer that stands out.


Why Use a Gradient Background for Your Footer?

A gradient footer can transform the overall design of your website. But it’s not just about looks—it can improve the user experience and branding when done correctly.

Benefits of a Gradient Footer:

  • Visually Appealing: Gradients make your footer look modern and professional.
  • Brand Consistency: Using brand colors keeps your design cohesive.
  • Section Separation: It helps clearly separate content from the footer area.
  • Highlight Important Links: A well-designed footer can draw attention to CTAs.

Best Practice: Stick with 2-3 colors that blend well together for a subtle and professional look.

gradient footers


Method 1: Adding a Gradient Footer Using the Blocksy Customizer (No Code)

The easiest way to add a gradient footer in Blocksy is through the WordPress Customizer. This method works without needing to touch any code and is ideal for beginners.

Steps to Add a Gradient Footer with the Blocksy Customizer:

  1. Log into Your WordPress Dashboard.
  2. Go to Appearance > Customize > Footer.
  3. Click on the Footer Design section.
  4. Select the footer area you want to edit (Main Footer, Widgets Section, or Footer Bar).
  5. Locate the Background Color Settings.
  6. Click the Gradient option.
  7. Pick your gradient colors and adjust the angle for the desired effect.
  8. Click Publish to save your changes.

Pro Tip: Stick to lighter gradients for a minimal look and avoid complex color combinations that can distract users.


Method 2: Adding a Gradient Footer Using Custom CSS (Free Version)

If you’re using the free version of Blocksy and the Customizer doesn’t support gradients directly, you can achieve the same effect with CSS code.

Steps to Add a Gradient Footer Using CSS:

  1. Log in to Your WordPress Dashboard.
  2. Go to Appearance > Customize > Additional CSS.
  3. Paste the following CSS code:
/* Custom Gradient Footer for Blocksy */
#colophon {
    background: linear-gradient(135deg, #ff7e5f, #feb47b);
    color: white;
    padding: 20px;
}
  1. Adjust the gradient colors by changing the hex codes.
  2. Click Publish to apply the changes.

Tip: If you need more complex gradients, use CSS gradient generators like CSS Gradient to generate the code.


Method 3: Adding a Multi-Color Gradient Footer Using CSS

Want to create a vibrant multi-color gradient? You can easily do it by adding more color stops in your CSS.

/* Multi-Color Gradient Footer */
#colophon {
    background: linear-gradient(120deg, #ff7e5f, #feb47b, #86a8e7, #91eae4);
    padding: 20px;
    color: white;
}

Key Adjustments for Multi-Color Gradients:

  • #ff7e5f: Coral Pink
  • #feb47b: Peach
  • #86a8e7: Sky Blue
  • #91eae4: Aqua

Pro Tip: Use 3-4 colors for a modern gradient. Too many colors can overwhelm your footer design.


Method 4: Creating an Animated Gradient Footer (Advanced CSS)

If you want to add some movement to your footer, you can create a dynamic gradient animation using CSS.

/* Animated Gradient Footer */
@keyframes gradientAnimation {
    0% {background-position: 0% 50%;}
    50% {background-position: 100% 50%;}
    100% {background-position: 0% 50%;}
}

#colophon {
    background: linear-gradient(270deg, #ff7e5f, #feb47b, #86a8e7, #91eae4);
    background-size: 400% 400%;
    animation: gradientAnimation 15s ease infinite;
    padding: 20px;
    color: white;
}

Pro Tip: Use subtle animations and keep performance in mind. Avoid fast transitions that might feel distracting.


Method 5: Using Blocksy Pro for Advanced Gradient Features

If you have the Blocksy Pro version, it comes with advanced gradient controls built into the Customizer.

How to Enable Gradient Footers with Blocksy Pro:

  1. Install and Activate Blocksy Pro.
  2. Go to Appearance > Customize > Footer.
  3. Click on the footer section you want to edit.
  4. Enable Advanced Styling Options.
  5. Choose Gradient Background.
  6. Adjust the gradient angle, colors, and intensity.
  7. Publish the changes.

Why Upgrade? Blocksy Pro offers more control, such as:

  • Multiple Gradient Stops.
  • Transparency Controls.
  • Hover Effects.

Best Gradient Color Combinations for Footers

Choosing the right colors can make or break your gradient design. Here are some tested gradient combinations for a footer that works well with Blocksy:

Gradient StyleHex CodesColor Theme
Warm Sunset#ff7e5f, #feb47bPeach & Coral
Cool Ocean#2193b0, #6dd5edBlue Gradient
Modern Grey#bdc3c7, #2c3e50Monochrome
Nature Green#11998e, #38ef7dGreen Gradient
Retro Purple & Pink#8e44ad, #f39c12Purple to Pink
Midnight Sky#000428, #004e92Dark Blue

Pro Tip: Stick with colors that match your brand identity for a cohesive design.


Troubleshooting: Gradient Footer Not Working?

If your gradient footer isn’t displaying as expected:

  • Clear Cache: Try clearing your WordPress and browser cache.
  • Update Blocksy: Ensure you’re running the latest version of Blocksy.
  • Check CSS Conflicts: Ensure no conflicting CSS rules override your gradient.
  • Responsive Check: Test the footer on mobile devices for full compatibility.

Final Thoughts

A custom gradient footer can elevate the look of your Blocksy site significantly. Whether you use Blocksy Pro or CSS tweaks, you can create beautiful gradient effects that boost branding and user engagement.

✅ Want to take your WordPress design to the next level? Hire a WordPress Expert on Codeable for professional customizations.


FAQ Section

How do I make my Blocksy footer full-width?

Go to Appearance > Customize > Footer and select Full Width Layout.

Can I create a gradient button in the Blocksy footer?

Yes! You can style buttons with gradient backgrounds using similar CSS code.

Is CSS better than using the Customizer for gradients?

The Customizer is great for simple gradients, but CSS gives you more control and creativity.

Will a gradient footer slow down my website?

No, if you use CSS gradients instead of image-based gradients.

Can I add gradients to other sections like the header?

Yes! Use the same CSS techniques for your header or any other section.

What’s the best gradient tool for beginners?

Try CSS Gradient for easy code generation.

Do gradients affect SEO?

No, gradients don’t affect SEO directly but readability matters, so ensure contrast is high.


Now you’re ready to create stunning gradient footers in Blocksy! 🚀

Need Help Customizing Your WordPress Footer?

Hire a certified WordPress expert from Codeable to create a stunning gradient footer tailored to your site.

Get a Free Estimate

How to fix: ACF now automatically escapes unsafe HTML when rendered by the_field or the ACF shortcode

Escaping the Maze: Mastering ACF’s New HTML Escape Mechanics 🚀

Hello, fellow WordPress aficionados! 🌟 Let’s talk about a game-changer in our beloved ACF PRO that’s causing both excitement and a bit of head-scratching in the community. Yes, you guessed it: ACF now automatically escapes unsafe HTML when rendered by the_field() or the ACF shortcode. Fear not! I’m here to demystify this update and arm you with the knowledge (and code) to tackle any challenges head-on.

Quick Recap: What’s ACF PRO Again? 🧐

For the uninitiated, Advanced Custom Fields (ACF) PRO is the powerhouse behind customizing WordPress sites, allowing you to add custom fields to your pages, posts, and even custom post types. It’s like giving your car a nitro boost but for your website.

The Update: Safety First! 🔐

ACF PRO’s latest update is like a superhero upgrade for your site’s security, automatically escaping unsafe HTML in fields. This means that it helps prevent nasty things like XSS attacks by ensuring that only clean, safe HTML is output through your custom fields.

  • The Update in a Nutshell: Automatically escapes unsafe HTML.
  • Affected Functions: the_field(), ACF shortcode.
  • Why It Matters: Enhances security, and minimizes XSS attack risks.

ACF will soon escape unsafe HTML that is rendered by the_field()

Breaking it Down: The Impact 🎯

So, what does this mean for you, the developer, designer, or site owner? Let’s dissect:

  • Pros: Enhanced security, peace of mind, reduced plugin reliance for sanitization.
  • Cons: Potential impact on fields that intentionally output HTML for functionality.

Looking to resolve the issue of unsafe HTML rendering with ACF PRO? Get expert assistance from Codeable’s WordPress developers today!

Find Developer

The Solution Space: Adapting to Change 🛠

Fear not! Adapting is our forte. Here’s how you can embrace this update without breaking a sweat:

1. Understanding the Change


// Before the update
echo get_field('custom_html_field');

// After the update
echo htmlspecialchars(get_field('custom_html_field'), ENT_QUOTES, 'UTF-8');


 

2. Safe HTML Output

If your field needs to output HTML safely, consider using wp_kses_post():

echo wp_kses_post(get_field('custom_html_field'));

 

3. Custom Sanitization

Need more control? Roll out your custom sanitization function:

function my_custom_sanitizer($content) {
   // Custom sanitization logic here
   return $content;
}

echo my_custom_sanitizer(get_field('custom_html_field'));

 

4. Whitelisting HTML Tags

Use wp_kses() to allow specific tags:

$allowed_tags = [
    'a' => [
        'href' => [],
        'title' => []
    ],
    'br' => [],
    'em' => [],
    'strong' => [],
];

echo wp_kses(get_field('custom_html_field'), $allowed_tags);

 

Navigating ACF PRO’s HTML Escape Functionality 🧭

Deep Dive: The the_field() Conundrum

Imagine you’ve got a custom field designed to embed YouTube videos directly into your posts. Previously, you’d add the iframe into your ACF field, and voila, it’d render seamlessly. Now, with automatic escaping in play, your iframe turns into a visible chunk of HTML code, rather than the intended video player.

The Problem:


<!-- What you entered in ACF -->
<iframe width="560" height="315" src="https://www.youtube.com/embed/dQw4w9WgXcQ" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>

<!-- What renders on your site -->
&lt;iframe width="560" height="315" src="https://www.youtube.com/embed/dQw4w9WgXcQ" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen&gt;&lt;/iframe&gt;

The Solution:

Leverage WordPress’ wp_oembed_get() to safely embed videos, bypassing the need to directly input iframes into ACF fields:



// Fetch video URL from ACF field
$video_url = get_field('video_url');

// Use WordPress oEmbed functionality
echo wp_oembed_get($video_url);


 

 

This method ensures your embeds remain functional, sidestepping direct HTML input and keeping your site secure.

Scenario 2: Custom HTML in Text Fields

You’re using ACF to add custom HTML content to a page—perhaps a uniquely styled call-to-action (CTA) block. Post-update, your HTML is being escaped, stripping away the intended design and functionality.

Before the Update:


<div class="cta-block">
   <?php the_field('custom_html_cta'); ?>
</div>

 

Adapting:

Option 1: Use wp_kses_post() for Basic HTML

For basic HTML elements:


<div class="cta-block">
    <?php echo wp_kses_post(get_field('custom_html_cta')); ?>;
</div>

 

Option 2: Custom Allow-List with wp_kses()

When specific HTML elements and attributes are needed:


$allowed_html = array(
    'div' => array(
        'class' => array(),
    ),
    'a' => array(
        'href' => array(),
        'class' => array(),
        'title' => array(),
    ),
    'span' => array(
        'class' => array(),
    ),
    // Add more tags and attributes as needed
);

echo wp_kses(get_field('custom_html_cta'), $allowed_html);


Advanced Use Case: Dynamic Content with ACF and JavaScript

You’re injecting JavaScript via ACF fields for dynamic content customization. The update complicates direct script injection due to automatic escaping.

The Safe Path Forward:

Enqueue Scripts Properly

  1. Store your JavaScript code in external .js files.
  2. Enqueue these scripts using wp_enqueue_script() within your theme’s functions.php, or trigger them conditionally within your template files.

// Example: Enqueuing a custom script
function my_custom_scripts() {
    if (get_field('activate_custom_behavior', 'option')) { // Assuming 'option' page setting
        wp_enqueue_script('my-custom-script', get_template_directory_uri() . '/js/my-custom-script.js', array('jquery'), null, true);
    }
}
add_action('wp_enqueue_scripts', 'my_custom_scripts');


You can also use ACF fields to pass configuration or data to these scripts via localized script variables (wp_localize_script()).

// Localize script with data from ACF fields
function my_localized_script_data() {
    wp_localize_script('my-custom-script', 'MyScriptParams', array(
        'dynamicData' => get_field('dynamic_data', 'option'),
    ));
}
add_action('wp_enqueue_scripts', 'my_localized_script_data');

Given the constraints and the nature of your request, I’ll extend the content with more examples and delve deeper into practical scenarios. Let’s get into the nitty-gritty of working around ACF PRO’s HTML auto-escape functionality, ensuring your WordPress projects remain both dynamic and secure.

Navigating ACF PRO’s HTML Escape Functionality 🧭
Deep Dive: The the_field() Conundrum
Imagine you’ve got a custom field designed to embed YouTube videos directly into your posts. Previously, you’d add the iframe into your ACF field, and voila, it’d render seamlessly. Now, with automatic escaping in play, your iframe turns into a visible chunk of HTML code, rather than the intended video player.

The Problem:

<!-- What you entered in ACF -->
<iframe width="560" height="315" src="https://www.youtube.com/embed/dQw4w9WgXcQ" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>

<!-- What renders on your site -->
&lt;iframe width="560" height="315" src="https://www.youtube.com/embed/dQw4w9WgXcQ" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen&gt;&lt;/iframe&gt;

The Solution:
Leverage WordPress’ wp_oembed_get() to safely embed videos, bypassing the need to directly input iframes into ACF fields:


// Fetch video URL from ACF field
$video_url = get_field('video_url');

// Use WordPress oEmbed functionality
echo wp_oembed_get($video_url);

This method ensures your embeds remain functional, sidestepping direct HTML input and keeping your site secure.

Scenario 2: Custom HTML in Text Fields
You’re using ACF to add custom HTML content to a page—perhaps a uniquely styled call-to-action (CTA) block. Post-update, your HTML is being escaped, stripping away the intended design and functionality.

Before the Update:


<div class="cta-block">
    <?php the_field('custom_html_cta'); ?>
</div>

Adapting:
Option 1: Use wp_kses_post() for Basic HTML

For basic HTML elements:

<div class="cta-block">
    <?php echo wp_kses_post(get_field('custom_html_cta')); ?>
</div>

Option 2: Custom Allow-List with wp_kses()

When specific HTML elements and attributes are needed:


$allowed_html = array(
    'div' => array(
        'class' => array(),
    ),
    'a' => array(
        'href' => array(),
        'class' => array(),
        'title' => array(),
    ),
    'span' => array(
        'class' => array(),
    ),
    // Add more tags and attributes as needed
);

echo wp_kses(get_field('custom_html_cta'), $allowed_html);

Advanced Use Case: Dynamic Content with ACF and JavaScript
You’re injecting JavaScript via ACF fields for dynamic content customization. The update complicates direct script injection due to automatic escaping.

The Safe Path Forward:
Enqueue Scripts Properly

Store your JavaScript code in external .js files.
Enqueue these scripts using wp_enqueue_script() within your theme’s functions.php, or trigger them conditionally within your template files.

// Example: Enqueuing a custom script
function my_custom_scripts() {
    if (get_field('activate_custom_behavior', 'option')) { // Assuming 'option' page setting
        wp_enqueue_script('my-custom-script', get_template_directory_uri() . '/js/my-custom-script.js', array('jquery'), null, true);
    }
}
add_action('wp_enqueue_scripts', 'my_custom_scripts');

Use ACF fields to pass configuration or data to these scripts via localized script variables (wp_localize_script()).


// Localize script with data from ACF fields
function my_localized_script_data() {
    wp_localize_script('my-custom-script', 'MyScriptParams', array(
        'dynamicData' => get_field('dynamic_data', 'option'),
    ));
}
add_action('wp_enqueue_scripts', 'my_localized_script_data');

This approach maintains security while offering dynamic, JavaScript-driven content customization.

Embracing Change: A Path Forward

The transition to automatic HTML escaping in ACF PRO represents a significant shift towards enhancing security and reliability in WordPress development. By adapting your workflows to embrace these changes—leveraging WordPress core functions for sanitization, and strategically managing HTML and JavaScript content—you ensure your projects remain both innovative and secure.

While the journey may require rethinking certain practices, the destination—a more secure, dynamic web—is undoubtedly worth it. Armed with these strategies and examples, you’re well-equipped to navigate the nuances of ACF PRO’s latest update, transforming potential obstacles into opportunities for growth and innovation.

FAQs 🚀

  • Q: Will this break my site?
    • A: Not necessarily. Test your fields, especially those outputting HTML.
  • Q: Can I disable this feature?
    • A: It’s not recommended due to security concerns, but customizing output methods can bypass automatic escaping.
  • Q: What if I need to output JavaScript?
    • A: Carefully. Consider enqueuing scripts rather than embedding them directly.

Looking to resolve the issue of unsafe HTML rendering with ACF PRO? Get expert assistance from Codeable’s WordPress developers today!

Find Developer

Wrapping Up: Secure, Customize, Thrive 🌟

This update is a significant step toward more secure, robust WordPress sites. With the tips and tricks shared, you’re well-equipped to adapt and continue creating dynamic, interactive, and safe web experiences.

Stay curious, stay secure, and most importantly, stay awesome! 💪