Release Log
=======
2024-11-06
=======
2024-11-06
Type: Bug Fix
Part of: @hubspot/cms-dev-server@0.18.0
Fix issue with secrets not getting loaded locally when running against a theme
Miscellaneous improvements and bug fixes
2024-10-21
Type: Enhancement
Part of: @hubspot/cms-dev-server@0.17.0
Upgrade to Vite@5
2024-10-15
Type: Enhancement
Part of:@hubspot/cms-dev-server@0.16.14
Add viewport meta tag to improve mobile viewing experience Add local module meta validation
2024-10-09
Type: Enhancement
Part of: @hubspot/cms-components@0.16.12
and @hubspot/cms-dev-server@0.16.12
Upgrade React@18.3.1
2024-10-07
Type: Enhancement
Part of: @hubspot/cms-components@0.16.11
Add enforcement of the required occurrence
property for RepeatedFieldGroup
2024-08-26
Type: Enhancement
Part of: @hubspot/cms-components@0.16.7
Miscellaneous TypeScript type improvements
2024-08-16
Type: Enhancement
Part of: @hubspot/cms-components@0.16.6
Add support for limitedOptions
, useLargeLabel
, and groupDisplayType
for the FieldGroup
, ColorField
, and FontField
components
Add support for the buttons
option for the display
property and add preset
property for the ChoiceField
Add support for the links
property on all field components
2024-08-07
Type: Enhancement
Part of: @hubspot/cms-components@0.16.4
Add support for the alternateName
property for FontField
and ColorField
2024-07-31
Type: Enhancement
Part of: @hubspot/cms-components@0.16.3
TypeScript type improvements
2024-07-24
Type: Enhancement
Part of: @hubspot/cms-dev-server@0.16.1
Improvements to locally used secrets within .env file
Part of: @hubspot/cms-components@0.16.1
Add support for groupOccurrenceMeta
property for RepeatedFieldGroup
2024-07-19
Type: Bug Fix
Part of: @hubspot/cms-components@0.15.16
- @hubspot/cms-components@0.16.0
Miscellaneous improvements and bug fixes
2024-06-24
Type: Enhancement
Part of: @hubspot/cms-components@0.15.14
and @hubspot/cms-components@0.15.15
Update field TypeScript types and improve field validation
2024-06-13
Type: Enhancement
Part of: @hubspot/cms-components@0.15.12
TypeScript type improvements Add withRequest helper function Add support for required
property for field type generation
2024-05-17
Type: Enhancement
Part of: @hubspot/cms-dev-server@0.15.11
Improvements to generated types Add support for custom component type generation
2024-05-14
Type: Enhancement
Part of: @hubspot/cms-dev-server@0.15.10
Miscellaneous bug fixes
Part of: @hubspot/cms-components@0.15.10
TypeScript type improvements for module fields
2024-05-02
Type: Enhancement
Part of: @hubspot/cms-dev-server@0.15.9
Improved error messaging for proxy domains
Part of: @hubspot/cms-components@0.15.9
Add withContact helper function
2024-04-27
Type: Bug Fix
Part of: @hubspot/cms-dev-server@0.15.8
Fix issue with proxying pages on hs-sites domain
Type Enhancement
Part of: @hubspot/cms-dev-server@0.15.8
Adds --generateFieldsTypes
to dev server, which generates Typescript types based on fields.(jsx|json) files exported by module components.
2024-04-18
Type Enhancement
Part of: @hubspot/cms-dev-server@0.15.3
Support proxying of calls to serverless functions
Type Bug Fix
Part of: @hubspot/cms-dev-server@0.15.2
Support hsproject.json in parent(s) directory
Type Bug Fix
Prevent CloudFlare infinite loop for some users
Part of: @hubspot/cms-dev-server@0.15.1
2024-04-11
Type: Feature
Part of: @hubspot/cms-components@0.14.14
and @hubspot/cms-dev-server@0.14.14
Release @hubspot/cms-components
: <Form />
component
2024-03-27
Type: Feature Release
Part of: @hubspot/cms-components@0.14.15
and @hubspot/cms-dev-server@0.14.15
- Release
RichText
andCta
components from@hubspot/cms-components
- Fix serialization issues in the proxy and
preview/module
routes
2024-03-26
Type: Enhancement
Part of: Platform Change
Fail a build if a module has validation errors (such as a field missing a required value, or two fields with the same path)
2024-03-25
Part of: @hubspot/cms-components@0.14.14
and @hubspot/cms-dev-server@0.14.14
Added allow_inline_form_editing
property to FormField
Fix to pass cookies along in local dev server proxy (to make contact work)
2024-03-25
Type: Debugging, Fix Part of: Build and server
Added browser-side logging for any GraphQL query that contains dataQueryResult.errors
or if an unknown exception occurs.
Fixed some npm packages that would break the build.
2024-03-14
Part of: @hubspot/cms-components@0.14.13
(and earlier versions missed below) plus build & server changes
Minify CSS
Added /preview/module/{moduleName}
routes to dev server home page.
Fixes /preview/module/{moduleName}
on EU hublet
Small fix for LinkField
rel attribute
Preparing Icon and RichText components
2024-02-21
Type: Feature
Added hublDataTemplate
API
Added /preview/module/{moduleName}
route in cms-dev-server
for local development experience of hublDataTemplate
2024-02-21
Type: Feature
Part of: @hubspot/cms-components@0.14.6
Added support for wrapperClassName
prop to <Island>
2024-02-08
Type Feature
Validate locally found hsproject.json
file platformVersion
against external auth endpoint
2024-02-06
Type Bug Fix
Part of: @hubspot/cms-components@0.14.2
Change: Support showOpacity
on ColorField
.
2024-01-19
Type: Security fix
Part of: @hubspot/cms-components@0.13.11
(and our internal build code that uses that)
Make sure that more globals in inline script elements (like __hsServerPageUrl
, __hsSS
, etc) are escaped so that malacious input like 'alert('got you')
or </script><script>alert('got you')</script>
are fully escaped.
2024-01-02
Type: Bug Fix
Part of: @hubspot/cms-dev-server@0.13.9
Fixed proxying of root urls
Type: Bug Fix
Part of: @hubspot/cms-dev-server@0.13.8
Fixed props passed to a JS partial when proxying a page
2023-12-19
Type: Enhancement
Part of: @hubspot/cms-dev-server@0.13.7
Change: Add field validation output to console and dev server render
Example Usage: No change, user will see fields validation error overlay when viewing the "module" route in the dev server and errors/warnings in the developer console for proxy and module routes. Field Validation - Watch Video
Type: Bug Fix
Part of: @hubspot/cms-dev-server@0.13.6
Change: Fix prop shape for GraphQL query data result for use with Storybook.
Type: Security Fix, Enhancement
Part of: Platform Release
Change: Ensure that serialized island props have </script>
escaped to prevent XSS attacks with user generated content that maliciously closes the inline script block and tries to inject JS code.
2023-12-06
Type: Bug Fix
Part of: @hubspot/cms-components@0.13.0
Fix <ImageField>
, <EmbedField>
, and others to take a resizable
prop instead of the incorrect "resizeable" spelling.
2023-11-14
Type: Enhancement
Part of: @hubspot/cms-components@0.12.0
Change: Add Audio
field component for new audioplayer
field type
2023-11-08
Type: Bug Fix
Part of: @hubspot/cms-components@0.11.3
Change: Add support for propertyAliasesPaths
Example Usage: When defining fields one can use the new property like so:
<ColorField
name="test"
label="test label"
propertyAliasesPaths={{
color: ['color'],
}}
/>
<ColorField
name="test"
label="test label"
propertyAliasesPaths={{
color: ['color'],
}}
/>
Will result in:
{
"type": "color",
"name": "test",
"label": "test label",
"aliases_mapping": {
"property_aliases_paths": {
"color": [
"color",
],
},
},
}
{
"type": "color",
"name": "test",
"label": "test label",
"aliases_mapping": {
"property_aliases_paths": {
"color": [
"color",
],
},
},
}
Type: Enhancement
Part of: @hubspot/cms-components@0.11.1
Change: Added <RichTextFieldWrapper />
component.
Example Usage:
import { RichTextFieldWrapper } from '@hubspot/cms-components';
function SomeTextComponent({ fieldValues }) {
const { richTextFieldName: richTextValue } = fieldValues;
return (
<RichTextFieldWrapper
// Pass in a rich text field's value
fieldValue={richTextValue}
// optional, changes the wrapper element (defaults to div)
tag="article"
// Also supports other standard React attributes for HTML
// like id, className, on*, style, data-*, aria-*, etc
/>
);
}
import { RichTextFieldWrapper } from '@hubspot/cms-components';
function SomeTextComponent({ fieldValues }) {
const { richTextFieldName: richTextValue } = fieldValues;
return (
<RichTextFieldWrapper
// Pass in a rich text field's value
fieldValue={richTextValue}
// optional, changes the wrapper element (defaults to div)
tag="article"
// Also supports other standard React attributes for HTML
// like id, className, on*, style, data-*, aria-*, etc
/>
);
}
All props other than fieldValue
and tag
are applied to the tag
element as HTML Attributes.
Type: Bug Fix
Part of: @hubspot/cms-components@0.11.1
Change: Add support for inheritedValueDefaultValuePath
and inheritedValuePropertyValuePaths
within Fields definitions.
Example Usage: When defining fields one can use the two new properties like so:
<TextField
name="test"
label="test label"
inheritedValueDefaultValuePath="fields.bodyFont"
inheritedValuePropertyValuePaths={{
color: 'module.secondary_color.color',
}}
/>
<TextField
name="test"
label="test label"
inheritedValueDefaultValuePath="fields.bodyFont"
inheritedValuePropertyValuePaths={{
color: 'module.secondary_color.color',
}}
/>
Will result in:
{
"name": "test",
"inherited_value": {
"default_value_path": "fields.bodyFont",
"property_value_paths": {
"color": "module.secondary_color.color",
},
},
...
}
{
"name": "test",
"inherited_value": {
"default_value_path": "fields.bodyFont",
"property_value_paths": {
"color": "module.secondary_color.color",
},
},
...
}
Type: Enhancement
Part of: @hubspot/cms-components@0.11.0
Added secrets integration. See documentation for more information and example usage
2023-10-16
Type: Small tweak
Part of: @hubspot/cms-components@0.10.4
Added data-hs-island
attribute to island wrapper elements.
Type: Bug Fix
Part of: @hubspot/cms-components@0.10.3
Change: Support locked
in FieldGroup and RepeatedFieldGroup
Type: Bug Fix
Part of: @hubspot/cms-components@0.10.3
Change: Support helpText
and inlineHelpText
in FieldGroup
and RepeatedFieldGroup
2023-10-02
Type: Bug Fix
Part of: @hubspot/cms-components@0.10.2
Change: Correct types for SpacingLimitType, SpacingValueType, and Advanced Visibility
Type: Bug Fix
Part of: @hubspot/cms-components@0.10.2
Change: Add support for visibility in RepeatedFieldGroup
Type: Enhancement
Part of: @hubspot/cms-components@0.10.2
Change: Add useIsDebug
, logInfoDebugOnly
, logWarnDebugOnly
, and logErrorDebugOnly
Example Usage: When visiting your page, useIsDebug
will return true and the logging functions with log when you set hsDebug
to true in your query parameters. e.g. "mydomain.com/home?hsDebug=true". Note that use of hsDebug
will disable pre-rendering for that page while it is in use.
import { useIsDebug, logInfoDebugOnly } from '@hubspot/cms-components'
function PicardComponent() {
const isDebug = useIsDebug();
const picardCommand = isDebug ? 'make it so' : 'engage';
return (
<>
<h1>{`${picardCommand}`}</h1>
</>
);
}
const TestLogInfoDebugComponent = ({ logArgs }) => {
logInfoDebugOnly(...logArgs);
return null;
};
import { useIsDebug, logInfoDebugOnly } from '@hubspot/cms-components'
function PicardComponent() {
const isDebug = useIsDebug();
const picardCommand = isDebug ? 'make it so' : 'engage';
return (
<>
<h1>{`${picardCommand}`}</h1>
</>
);
}
const TestLogInfoDebugComponent = ({ logArgs }) => {
logInfoDebugOnly(...logArgs);
return null;
};
Type: Bug Fix
Part of: @hubspot/cms-dev-server@0.10.1
Change: Add babel macros support to storybook server
2023-09-26
Type: Enhancement
Part of: @hubspot/cms-dev-server@0.10.0
Added help/--help
command to the development server.
Example usage:
>hs-cms-dev-server help
HubSpot CMS Dev Server
Usage: hs-cms-dev-server <path> [options]
Mandatory:
<path> Path to the directory containing your assets.
Options:
-c, --config Path to alternate hubspot.config.yaml configuration.
-a, --account The account name or id to use for the dev server.
--ssl Enables SSL for the dev server, serving it over an https:// URL.
--storybook Launches a Storybook dev server.
For more information on HubSpot CMS JS Rendering, visit:
https://github.hubspot.com/cms-react/
>hs-cms-dev-server help
HubSpot CMS Dev Server
Usage: hs-cms-dev-server <path> [options]
Mandatory:
<path> Path to the directory containing your assets.
Options:
-c, --config Path to alternate hubspot.config.yaml configuration.
-a, --account The account name or id to use for the dev server.
--ssl Enables SSL for the dev server, serving it over an https:// URL.
--storybook Launches a Storybook dev server.
For more information on HubSpot CMS JS Rendering, visit:
https://github.hubspot.com/cms-react/
Type: Bug Fix
Part of: @hubspot/cms-components@0.10.0
Change: Add support for visibility in FieldGroup
Type: Bug Fix
Part of: @hubspot/cms-components@0.10.0
Change: Add support for limits
for the "Spacing" field type.
Type: Bug Fix
Part of: @hubspot/cms-components@0.10.0
Change: Add support for resizable
, show_advanced_options
, and show_preview
for the "Video" field type.
Type: Enhancement
Part of: Platform Release
Change: Added support for meta.json
icons via file imports
Example usage:
import reactIcon from './react-icon.svg';
export const meta = {
label: `Module`,
icon: reactIcon,
};
import reactIcon from './react-icon.svg';
export const meta = {
label: `Module`,
icon: reactIcon,
};