Generate HubSpot module fields.json
from fields.js
- Why?
- Main features and advantages to other solutions
- General recommendations
- Quick start
- field.js structure
- Example
- Content tab fields vs Style tab fields
- Changelog
- When you create and maintain
fields.json
files for modules, they can easily become long, challenging to read, and hard to update as time goes by.hubspot-fields-js
provides a convenient way to work with these files in your HubSpot modules. This tool ensures ease of use and simplifies the process of updating these files over time. - One of the biggest advantages is the ability to abstract fields into partials. This allows for the creation of a library of field groups that can be reused across all modules. This leads to a more consistent organization and naming of options, making it easier for users to establish muscle memory and have a positive overall experience.
- Developers can now fully implement the module in their local development environment, which is the final step in bringing HubSpot CMS development to their local setup. This provides developers with extensive opportunities to enhance their work.
- No issues with module
IDs
in the version control system (git
) when using multiple HubSpot accounts in development. For example, a few developer sandboxes and a production HubSpot account. - There is great potential for automation and code generation. Using
JS
you can easily automate any task you desire.
- All fields have thorough documentation both externally and within the code.
- The fields in fields.js come with predefined default values (same as in HubSpot), which helps reduce the amount of code needed. If you're happy with a default value, you can simply skip adding it.
- The API abstraction is kept to a minimum, using JSON-like JavaScript. If you are already familiar with HubSpot's
fields.json
, you do not need to learn much more as the main field structure is essentially the same. - You don't need any additional dependencies such as some JS task runners to start. All you need is
Node.js
to compile yourfields.js
files. But for more convenience, you can use our hubspot-cms-lib or any other task runner on your choice. - ❗All fields are fully documented with
JSDoc
syntax, providing complete support for code completion and documentation in code editors. You no longer need to refer to HubSpot documentation to comprehend field meanings or available options/values.hubspot-fields-js
includes all necessary information within your code editor.
- Add
modules/../fields.json
to.gitignore
- Create modules on your local environment, not in HubSpot design tools
- Ignore adding any module
id
inmeta.json
from the start. Keep it simple:
{
"global" : false,
"host_template_types" : [ "PAGE", "BLOG_POST", "BLOG_LISTING" ],
"is_available_for_new_content" : true
}
- Check our hubspot-cms-lib to get the full potential of
hubspot-fields-js
and much more benefits:- "Watch" process for all HubSpot CMS theme files plus compiling
felds.js
and uploadingfields.json
. - JS
ES6
/CSS/SASS compilers with the possibility to configure any options on a theme base. - HubSpot CLI
upload
,fetch
andwatch
commands integrated with other scripts. - Custom HubSpot multi-account authentication for easier work with multiple accounts.
- "Watch" process for all HubSpot CMS theme files plus compiling
- Install
hubspot-fields-js
package
npm install @resultify/hubspot-fields-js
- Create a new module
- Create
fields.js
file in the module folder - Add fields to
fields.js
file - Compile
fields.js
tofields.json
by running commandnode path/to/module/fields.js
- Upload module to HubSpot
Each field or group consists of:
- Label
- Name
- Parameters based on the HubSpot fields documentation
import {
group,
styleGroup,
init,
moduleFields as fi
} from '@resultify/hubspot-fields-js'
init( // initialize module and write to JSON (fields.json)
fi.text( // add text field
'Text', // label
'text', // name
{
help_text: 'Help text',
display_width: 'half_width',
allow_new_line: true
// ...all other parameters based on the HubSpot fields documentation
}
),
styleGroup(
fi.color('Text color', 'text_color')
)
)
import {
group,
styleGroup,
init,
moduleFields as fi
} from '@resultify/hubspot-fields-js'
init( // initialize module and write to JSON (fields.json)
group( // add group
'Group', // group label
'group', // group name
{
// group options (group unique options)
},
// add all childrens...
fi.text('Text', 'text'),
fi.image('Image', 'image'),
group('Group2', 'group2', {},
fi.text('Text2', 'text2')
)
)
)
import {
group,
styleGroup,
init,
moduleFields as fi
} from '@resultify/hubspot-fields-js'
init(
fi.boolean('Boolean', 'boolean_field', {
display: 'toggle',
default: true,
help_text: 'tooltip',
required: true
}),
fi.choice('Choice', 'choice_field', {
choices: [
['value1', 'Value 1'],
['value2', 'Value 2']
],
default: 'value1',
display: 'radio',
inline_help_text: 'Choice help text',
}),
fi.color('Color', 'color_field', {
show_opacity: false,
default: {
color: '#FF0201'
},
visibility: {
controlling_field_path: 'boolean_field',
operator: 'EQUAL',
controlling_value_regex: 'true'
}
}),
fi.font('Font', 'font_field', {
default: {
font: 'Open Sans',
fallback: 'sans-serif',
font_set: 'GOOGLE',
color: '#FF00FF',
variant: '600'
}
}),
fi.icon('Icon', 'icon_field'),
fi.image('Image', 'image_field', {
occurrence: {
max: 10
}
}),
fi.link('Link', 'link_field', {
default: {
url: {
type: 'CONTENT'
}
},
required: true,
occurrence: {}
}),
fi.number('Number', 'number_field', {
suffix: '%',
max: 1000,
step: 1,
occurrence: {
min: 2,
default: 4
},
default: []
}),
fi.richtext('Rich text', 'richtext_field', {
default: '<h1>Default rich text</h1>'
}),
fi.text('Text', 'text_field', {
show_emoji_picker: true,
default: 'Default text',
placeholder: 'Placeholder'
}),
fi.url('URL', 'url_field')
)
Check more examples in partials
folder.
Content tab | Style tab | Universal |
---|---|---|
✅ Date | ✅ Gradient | ✅ Boolean |
✅ Date and time | ✅ Spacing | ✅ Choice |
✅ Embed | ✅ Background image | ✅ Number |
✅ Link | ✅ Border | ✅ Color |
✅ Rich text | ✅ Alignment | ✅ Icon |
✅ Simple menu | ✅ Text alignment | ✅ Image |
✅ Text | ✅ Font | |
✅ Url | ||
✅ Blog | ||
✅ CRM object | ||
✅ CRM object property | ||
✅ CTA | ||
✅ Email addres | ||
✅ File | ||
✅ Followup email | ||
✅ Form | ||
✅ HubDB row | ||
✅ HubDB table | ||
✅ Logo | ||
✅ Meeting | ||
✅ Menu | ||
✅ Page | ||
✅ Tag | ||
✅ Video |
✅ - implemented / ❌ - not implemented