jpwdesigns / craft-hubspot-forms
HubSpot API Forms for Craft 5
Installs: 119
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 1
Type:craft-plugin
pkg:composer/jpwdesigns/craft-hubspot-forms
Requires
- php: ^8.0
- craftcms/cms: ^5.0
- hubspot/api-client: ^11.3
This package is auto-updated.
Last update: 2025-10-11 16:07:08 UTC
README
Plugin that allows you to render HubSpot forms from their API
Requirements
This plugin requires Craft CMS 5.0.0 or later.
Installation
To install the plugin, follow these instructions.
-
Open your terminal and go to your Craft project:
cd /path/to/project
-
Then tell Composer to load the plugin:
composer require robuust/craft-hubspot-forms
-
In the Control Panel, go to Settings → Plugins and click the “Install” button for HubSpot API Forms.
Config
Create a file called hubspot-api-forms.php
in you Craft config folder with the following contents:
<?php return [ // General 'accessToken' => 'YOUR_ACCESS_TOKEN', // Optional: Set the maximum number of forms to fetch from HubSpot API (default: 150) 'limit' => 150, ];
Usage
Create a new "HubSpot Form" field and add it to the desired element's field layout. Now when editing such element you can select a HubSpot form to use.
In your front-end templates you can render this as a form.
Example
Here is an example that renders a HubSpot form. You can change and style this example any way you want.
{% macro fieldType(field) %} {% if field.hidden %} hidden {% elseif field.fieldType == 'single_line_text' %} text {% elseif field.fieldType == 'phone' %} tel {% else %} {{ field.fieldType }} {% endif %} {% endmacro %} {% import _self as utils %} <form action="https://forms.hubspot.com/uploads/form/v2/{{ form.portalId }}/{{ form.form.id }}" method="post" accept-charset="utf-8" > <div class="grid grid-cols-1 gap-6 lg:grid-cols-2 lg:gap-10"> {% for fieldGroup in form.form.fieldGroups %} {% if fieldGroup.richText is defined %} <div class="col-span-2"> {{ fieldGroup.richText }} </div> {% endif %} {% for field in fieldGroup.fields|default([]) %} {% if field.hidden %} {{ hiddenInput(field.name, craft.app.request.absoluteUrl) }} {% else %} <div class="col-span-1 flex flex-col gap-2"> <label for="{{ field.name }}" class="text-primary-800 font-bold" > {{ field.label }}{% if field.required %} *{% endif %} </label> {% if field.fieldType == 'multi_line_text' %} <textarea id="{{ field.name }}" name="{{ field.name }}" {% if field.required %}required{% endif %} class="rounded-xl border-none h-24 px-6 resize-none focus:outline-none focus:ring-transparent" ></textarea> {% else %} <input id="{{ field.name }}" type="{{ utils.fieldType(field)|spaceless }}" name="{{ field.name }}" {% if field.required %}required{% endif %} class="rounded-xl border-none h-12 px-6 focus:outline-none focus:ring-transparent" > {% endif %} </div> {% endif %} {% endfor %} {% endfor %} <div class="col-span-2"> <button type="submit" aria-label="{{ form.form.displayOptions.submitButtonText }}" class="button button-secondary" > {{ form.form.displayOptions.submitButtonText }} </button> </div> </div> </form>