- blue_dark
- cosmos_dark
- dawn_dark
- feast_dark
- industrial_dark
- retro_dark
- spectrum_dark
- vernal_dark
- CFML Reference User Guide
- ColdFusion functions
  - ColdFusion functions by category
- Functions a-b
 - Abs
- ACos
- AddSOAPRequestHeader
- AddSOAPResponseHeader
- AjaxLink
- AjaxOnLoad
- ApplicationStop
- ArrayAppend
- ArrayAvg
- ArrayClear
- ArrayContains
- ArrayContainsNoCase
- ArrayDelete
- ArrayDeleteAt
- ArrayDeleteNoCase
- ArrayEach
- ArrayFilter
- ArrayFind
- ArrayFindAll
- ArrayFindAllNoCase
- ArrayFindNoCase
- ArrayInsertAt
- ArrayIsDefined
- ArrayIsEmpty
- ArrayLen
- ArrayMap
- ArrayMax
- ArrayMin
- ArrayNew
- ArrayPrepend
- ArrayReduce
- ArrayResize
- ArraySet
- ArraySetMetadata
- ArraySlice
- ArraySort
- ArraySum
- ArraySwap
- ArrayToList
- Asc
- ASin
- Atn
- AuthenticatedContext
- AuthenticatedUser
- BinaryDecode
- BinaryEncode
- BitAnd
- BitMaskClear
- BitMaskRead
- BitMaskSet
- BitNot
- BitOr
- BitSHLN
- BitSHRN
- BitXor
- BooleanFormat
 
- Abs
- Functions-c-d
    - CacheGet
- CacheGetAllIds
- CacheGetMetadata
- CacheGetProperties
- CacheGetSession
- CacheIdExists
- CachePut
- CacheRegionExists
- CacheRegionNew
- CacheRegionRemove
- CacheRemove
- CacheRemoveAll
- CacheSetProperties
- CallStackDump
- CallStackGet
- CanDeSerialize
- Canonicalize
- CanSerialize
- Ceiling
- CharsetDecode
- CharsetEncode
- Chr
- CJustify
- Compare
- CompareNoCase
- Cos
- CreateDate
- CreateDateTime
- CreateObject
- CreateObject: .NET object
- CreateObject: COM object
- CreateObject: component object
- CreateObject: CORBA object
- CreateObject: Java or EJB object
- CreateObject: web service object
- CreateODBCDate
- CreateODBCDateTime
- CreateODBCTime
- CreateSignedJWT
- CreateEncryptedJWT
- CreateTime
- CreateTimeSpan
- CreateUUID
- CSRFGenerateToken
- CSRFVerifyToken
- CSVRead
- CSVWrite
- CSVProcess
- DateAdd
- DateCompare
- DateConvert
- DateDiff
- DateFormat
- DatePart
- DateTimeFormat
- Day
- DayOfWeek
- DayOfWeekAsString
- DayOfYear
- DaysInMonth
- DaysInYear
- DE
- DecimalFormat
- DecodeForHTML
- DecodeFromURL
- DecrementValue
- Decrypt
- DecryptBinary
- DeleteClientVariable
- Deserialize
- DeserializeJSON
- DeserializeXML
- DirectoryCopy
- DirectoryCreate
- DirectoryDelete
- DirectoryExists
- DirectoryList
- DirectoryRename
- DollarFormat
- DotNetToCFType
- Duplicate
 
- Functions-e-g
    - EncodeForCSS
- EncodeForDN
- EncodeForHTML
- EncodeForHTMLAttribute
- EncodeForJavaScript
- EncodeForLDAP
- EncodeForURL
- EncodeForXML
- EncodeForXMLAttribute
- EncodeForXpath
- Encrypt
- EncryptBinary
- EntityDelete
- EntityLoad
- EntityLoadByExample
- EntityLoadByPK
- EntityMerge
- EntityNew
- EntityReload
- EntitySave
- EntityToQuery
- Evaluate
- Exp
- ExpandPath
- FileClose
- FileCopy
- FileDelete
- FileExists
- FileGetMimeType
- FileIsEOF
- FileMove
- FileOpen
- FileRead
- FileReadBinary
- FileReadLine
- FileSeek
- FileSetAccessMode
- FileSetAttribute
- FileSetLastModified
- FileSkipBytes
- FileUpload
- FileUploadAll
- FileWrite
- FileWriteLine
- Find
- FindNoCase
- FindOneOf
- FirstDayOfMonth
- Fix
- Floor
- FormatBaseN
- GeneratePBKDFKey
- GenerateSecretKey
- GetApplicationMetadata
- GetAuthUser
- GetBaseTagData
- GetBaseTagList
- GetBaseTemplatePath
- GetClientVariablesList
- GetComponentMetaData
- GetContextRoot
- GetCPUUsage
- GetCurrentTemplatePath
- GetCSPNonce
- GetDirectoryFromPath
- GetEncoding
- GetException
- GetFileFromPath
- GetFileInfo
- GetFreeSpace
- GetFunctionCalledName
- GetFunctionList
- GetGatewayHelper
- GetHttpRequestData
- GetHttpTimeString
- GetK2ServerDocCount
- GetK2ServerDocCountLimit
- GetLocale
- GetLocaleDisplayName
- GetLocalHostIP
- GetMetaData
- GetMetricData
- GetPageContext
- GetPropertyString
- GetPropertyFile
- GetPrinterInfo
- GetPrinterList
- GetProfileSections
- GetProfileString
- GetReadableImageFormats
- GetSafeHTML
- GetSAMLAuthRequest
- GetSAMLLogoutRequest
- Generate3DesKey
- GenerateSAMLSPMetadata
- GetSOAPRequest
- GetSOAPRequestHeader
- GetSOAPResponse
- GetSOAPResponseHeader
- GetSystemFreeMemory
- GetSystemTotalMemory
- GetTempDirectory
- GetTempFile
- GetTemplatePath
- GetTickCount
- GetTimeZoneInfo
- GetToken
- GetTotalSpace
- GetUserRoles
- GetVFSMetaData
- GetWriteableImageFormats
 
- Functions-h-im
    - Hash
- HMac
- Hour
- HQLMethods
- HTMLCodeFormat
- HTMLEditFormat
- IIf
- ImageAddBorder
- ImageBlur
- ImageClearRect
- ImageCopy
- ImageCreateCaptcha
- ImageCrop
- ImageDrawArc
- ImageDrawBeveledRect
- ImageDrawCubicCurve
- ImageDrawLine
- ImageDrawLines
- ImageDrawOval
- ImageDrawPoint
- ImageDrawQuadraticCurve
- ImageDrawRect
- ImageDrawRoundRect
- ImageDrawText
- ImageFlip
- ImageGetBlob
- ImageGetBufferedImage
- ImageGetEXIFMetadata
- ImageGetEXIFTag
- ImageGetHeight
- ImageGetIPTCMetadata
- ImageGetIPTCTag
- ImageGetMetadata
- ImageGetWidth
- ImageGrayscale
- ImageInfo
- ImageMakeColorTransparent
- ImageMakeTranslucent
- ImageNegative
- ImageNew
- ImageOverlay
- ImagePaste
- ImageRead
- ImageReadBase64
- ImageResize
- ImageRotate
- ImageRotateDrawingAxis
- ImageScaleToFit
- ImageSetAntialiasing
- ImageSetBackgroundColor
- ImageSetDrawingColor
- ImageSetDrawingStroke
- ImageSetDrawingTransparency
- ImageSharpen
- ImageShear
- ImageShearDrawingAxis
- ImageTranslate
- ImageTranslateDrawingAxis
- ImageWrite
- ImageWriteBase64
- ImageXORDrawingMode
 
- Functions-in-k
    - IncrementValue
- InputBaseN
- Insert
- Int
- InterruptThread
- InvalidateOauthAccesstoken
- Invoke
- InitSAMLAuthRequest
- InitSAMLLogoutRequest
- InvokeCFClientFunction
- IsArray
- IsAuthenticated
- IsAuthorized
- IsBinary
- IsBoolean
- IsClosure
- IsCustomFunction
- IsDate
- IsDateObject
- IsDDX
- IsDebugMode
- IsDefined
- IsImage
- IsImageFile
- IsInstanceOf
- IsIPv6
- IsJSON
- IsK2ServerABroker
- IsK2ServerDocCountExceeded
- IsK2ServerOnline
- IsLeapYear
- IsLocalHost
- IsNull
- IsNumeric
- IsNumericDate
- IsObject
- isOnline
- IsPDFArchive
- IsPDFFile
- IsPDFObject
- IsProtected
- IsQuery
- isSamlLogoutResponse
- isSafeHTML
- IsSimpleValue
- IsSOAPRequest
- IsSpreadsheetFile
- IsSpreadsheetObject
- IsStruct
- isThreadInterrupted
- IsUserInAnyRole
- IsUserInRole
- IsUserLoggedIn
- IsValid
- IsValidOauthAccesstoken
- IsWDDX
- IsXML
- IsXmlAttribute
- IsXmlDoc
- IsXmlElem
- IsXmlNode
- IsXmlRoot
- JavaCast
- JSStringFormat
 
- Functions-l
    - LCase
- Left
- Len
- ListAppend
- ListChangeDelims
- ListContains
- ListContainsNoCase
- ListDeleteAt
- ListEach
- ListFilter
- ListFind
- ListFindNoCase
- ListFirst
- ListGetAt
- ListGetDuplicates
- ListInsertAt
- ListLast
- ListLen
- ListMap
- ListPrepend
- ListQualify
- ListReduce
- ListRemoveDuplicates
- ListRest
- ListSetAt
- ListSort
- ListToArray
- ListValueCount
- ListValueCountNoCase
- LJustify
- Location
- Log
- Log10
- LSCurrencyFormat
- LSDateFormat
- LSDateTimeFormat
- LSEuroCurrencyFormat
- LSIsCurrency
- LSIsDate
- LSIsNumeric
- LSNumberFormat
- LSParseCurrency
- LSParseDateTime
- LSParseEuroCurrency
- LSParseNumber
- LSTimeFormat
- LTrim
 
- Functions-m-r
    - Max
- Mid
- Min
- Minute
- Month
- MonthAsString
- Now
- NumberFormat
- ObjectEquals
- ObjectLoad
- ObjectSave
- OnWSAuthenticate
- ORMClearSession
- ORMCloseAllSessions
- ORMCloseSession
- ORMEvictCollection
- ORMEvictEntity
- ORMEvictQueries
- ORMExecuteQuery
- ORMFlush
- ORMFlushall
- ORMGetSession
- ORMGetSessionFactory
- ORMIndex
- ORMIndexPurge
- ORMReload
- ORMSearch
- ORMSearchOffline
- ParagraphFormat
- ParameterExists
- ParseDateTime
- Pi
- PrecisionEvaluate
- ProcessSAMLResponse
- ProcessSAMLLogoutRequest
- Quarter
- PreserveSingleQuotes
- QueryAddColumn
- QueryAddRow
- QueryConvertForGrid
- QueryExecute
- QueryFilter
- QueryGetResult
- QueryGetRow
- QueryKeyExists
- QueryMap
- QueryNew
- QueryReduce
- QuerySetCell
- QuotedValueList
- QueryEach
- Rand
- Randomize
- RandRange
- ReEscape
- REFind
- REFindNoCase
- ReleaseComObject
- REMatch
- REMatchNoCase
- RemoveCachedQuery
- RemoveChars
- RepeatString
- Replace
- ReplaceList
- ReplaceNoCase
- REReplace
- REReplaceNoCase
- RestDeleteApplication
- RestSetResponse
- RestInitApplication
- Reverse
- Right
- RJustify
- Round
- RTrim
 
- Functions-s
    - Second
- SendGatewayMessage
- SendSAMLLogoutResponse
- Serialize
- SerializeJSON
- SerializeXML
- SessionInvalidate
- SessionRotate
- SessionGetMetaData
- SessionInvalidate
- SessionRotate
- SetDay
- SetEncoding
- SetHour
- SetLocale
- SetMonth
- SetProfileString
- SetPropertyString
- SetVariable
- SetYear
- Sgn
- Sin
- Sleep
- SpanExcluding
- SpanIncluding
- SpreadsheetAddAutoFilter
- SpreadsheetAddColumn
- SpreadsheetAddFreezePane
- SpreadsheetAddImage
- SpreadsheetAddInfo
- SpreadsheetAddPageBreaks
- SpreadsheetAddRow
- SpreadsheetAddRows
- SpreadsheetAddSplitPane
- SpreadsheetCreateSheet
- SpreadsheetDeleteColumn
- SpreadsheetDeleteColumns
- SpreadsheetDeleteRow
- SpreadsheetDeleteRows
- SpreadsheetFormatCell
- SpreadsheetFormatColumn
- SpreadsheetFormatCellRange
- SpreadsheetFormatColumn
- SpreadsheetFormatColumns
- SpreadsheetFormatRow
- SpreadsheetFormatRows
- SpreadsheetGetCellComment
- SpreadsheetGetCellFormula
- SpreadsheetGetCellValue
- SpreadsheetGetColumnCount
- SpreadsheetInfo
- SpreadsheetMergeCells
- SpreadsheetNew
- SpreadsheetRead
- SpreadsheetReadBinary
- SpreadsheetRemoveSheet
- SpreadsheetSetActiveSheet
- SpreadsheetSetActiveSheetNumber
- SpreadsheetSetCellComment
- SpreadsheetSetCellFormula
- SpreadsheetSetCellValue
- SpreadsheetSetColumnWidth
- SpreadsheetSetFooter
- SpreadsheetSetHeader
- SpreadsheetSetRowHeight
- SpreadsheetShiftColumns
- SpreadsheetShiftRows
- SpreadsheetWrite
- StreamingSpreadsheetNew
- StreamingSpreadsheetCleanup
- StreamingSpreadsheetRead
- StreamingSpreadsheetProcess
- SpreadsheetSetFooterImage
- SpreadsheetSetHeaderImage
- SpreadsheetSetFittoPage
- SpreadsheetUngroupColumns
- SpreadsheetGroupColumns
- SpreadsheetUngroupRows
- SpreadsheetGroupRows
- SpreadsheetRemoveColumnBreak
- SpreadsheetSetColumnBreak
- SpreadsheetRemoveRowBreak
- SpreadsheetSetRowBreak
- SpreadsheetRemovePrintGridlines
- SpreadsheetAddPrintGridlines
- SpreadsheetGetColumnWidth
- SpreadsheetSetColumnHidden
- SpreadsheetSetRowHidden
- SpreadsheetisColumnHidden
- SpreadsheetisRowHidden
- SpreadsheetisStreamingXmlFormat
- SpreadsheetisXmlFormat
- SpreadsheetisBinaryFormat
- SpreadsheetRenameSheet
- SpreadsheetRemoveSheetNumber
- SpreadsheetGetLastRowNumber
- SpreadsheetGetPrintOrientation
- Sqr
- StripCR
- StructAppend
- StructClear
- StructCopy
- StructCount
- StructDelete
- StructEach
- StructFilter
- StructFind
- StructFindKey
- StructFindValue
- StructGet
- StructGetMetadata
- StructInsert
- StructIsEmpty
- StructKeyArray
- StructKeyExists
- StructKeyList
- StructMap
- StructNew
- StructReduce
- StructSetMetadata
- StructSort
- StructToSorted
- StructUpdate
- StructValueArray
- StoreSetMetadata
- StoreGetACL
- StoreGetMetadata
- StoreAddACL
- StoreSetACL
 
- Functions-t-z
    - Tan
- ThreadJoin
- ThreadTerminate
- Throw
- TimeFormat
- ToBase64
- ToBinary
- ToScript
- ToString
- Trace
- Transactionandconcurrency
- TransactionCommit
- TransactionRollback
- TransactionSetSavePoint
- Trim
- UCase
- URLDecode
- URLEncodedFormat
- URLSessionFormat
- Val
- ValueList
- VerifyClient
- Week
- Wrap
- WriteDump
- WriteLog
- WriteOutput
- WSGetAllChannels
- WSGetSubscribers
- WSPublish
- WSSendMessage
- XmlChildPos
- XmlElemNew
- XmlFormat
- XmlGetNodeType
- XmlNew
- XmlParse
- XmlSearch
- XmlTransform
- XmlValidate
- Year
- YesNoFormat
 
 
- ColdFusion tags
  - ColdFusion tag summary
- ColdFusion tags by category
    - Application framework tags
- Communications tags
- Database manipulation tags
- Data output tags
- Debugging tags
- Exception handling tags
- Extensibility tags
- File management tags
- Flow-control tags
- Forms tags
- Internet Protocol tags
- Page processing tags
- Security tags
- Variable manipulation tags
- Other tags
 
- Tags a-b
- Tags c
    - cfcache
- cfcalendar
- cfcase
- cfcatch
- cfchart
      - cfchart tag in ColdFusion
- Get started with cfchart
- Customize a chart using cfchart
- Advanced cfchart customization options
- Create an area chart in ColdFusion
- Create line charts in ColdFusion
- Create bar charts in ColdFusion
- Create floating bar charts in ColdFusion
- Create histograms in ColdFusion
- Create pie charts in ColdFusion
- Create funnel charts in ColdFusion
- Create pyramid charts in ColdFusion
- Create curve charts in ColdFusion
- Create boxplots in ColdFusion
- Create donut charts in ColdFusion
- Create bubble charts in ColdFusion
- Create scatterplots in ColdFusion
- Create radar charts in ColdFusion
- Other chart types in ColdFusion (Cone, Cylinder, Piano, and Bullet)
- Advanced customization options in cfchart
 
- cfchartdata
- cfchartseries
- cfchartset
- cfclient
- cfclientsettings
- cfcol
- cfcollection
- cfcomponent
- cfcontent
- cfcontinue
- cfcookie
 
- Tags f
    - cffeed
- cffile
- cffile action = "append"
- cffile action = "copy"
- cffile action = "delete"
- cffile action = "move"
- cffile action = "read"
- cffile action = "readBinary"
- cffile action = "rename"
- cffile action = "upload"
- cffile action = "uploadAll"
- cffile action = "write"
- cffileupload
- cffinally
- cfflush
- cfform
- cfformgroup
- cfformitem
- cfftp
- cfftp: Connection: file and directory operations
- cfftp: Opening and closing FTP server connections
- cfftp : Opening and closing secure FTP server connections
- cfftp action = "listDir"
- cffunction
 
- Tags g-h
- Tags i
- Tags j-l
    - cfjava
- cflayout
- cflayoutarea
- cfldap
- cflocation
- cflock
- cflog
- cflogin
- cfloginuser
- cflogout
- cfloop
- cfloop : conditional loop
- cfloop : index loop
- cfloop : looping over a COM collection or structure
- cfloop : looping over a date or time range
- cfloop : looping over a list, a file, or an array
- cfloop : looping over a query
 
- Tags m-o
    - cfmail
- cfmailparam
- cfmailpart
- cfmap
- cfmapitem
- cfmediaplayer
- cfmenu
- cfmenuitem
- cfmessagebox
- cfmodule
- cfNTauthenticate
- cfoauth
- cfobject
- cfobject: .NET object
- cfobject: COM object
- cfobject: component object
- cfobject: CORBA object
- cfobject: Java or EJB object
- cfobject: web service object
- cfobjectcache
- cfoutput
 
- Tags p-q
- Tags r-s
- Tags t
- Tags u-z
 
- CFML Reference
  - Reserved words and variables
- Ajax JavaScript functions
    - Ajax JavaScript functions
- Function summary Ajax
- ColdFusion.Ajax.submitForm
- ColdFusion.Autosuggest.getAutosuggestObject
- ColdFusion.Layout.enableSourceBind
- ColdFusion.MessageBox.getMessageBoxObject
- ColdFusion.ProgressBar.getProgressBarObject
- ColdFusion.MessageBox.isMessageBoxDefined
- JavaScriptFunctionsinColdFusion9Update1
 
- ColdFusion ActionScript functions
- ColdFusion mobile functions
- Application.cfc reference
- Script functions implemented as CFCs
- ColdFusion Flash Form style reference
    - Styles valid for all controls
- Styles for cfform
- Styles for cfformgroup with horizontal or vertical type attributes
- Styles for box-style cfformgroup elements
- Styles for cfformgroup with accordion type attribute
- Styles for cfformgroup with tabnavigator type attribute
- Styles for cfformitem with hrule or vrule type attributes
- Styles for cfinput with radio, checkbox, button, image, or submit type attributes
- Styles for cftextarea tag and cfinput with text, password, or hidden type attributes
- Styles for cfselect with size attribute value of 1
- Styles for cfselect with size attribute value greater than 1
- Styles for cfcalendar tag and cfinput with dateField type attribute
- Styles for the cfgrid tag
- Styles for the cftree tag
- ColdFusion Flash Form Style Reference
 
- ColdFusion event gateway reference
    - ColdFusion Event Gateway reference
- addEvent
- CFEvent
- CFEventclass
- Constructor
- Gateway development interfaces and classes
- getStatus
- setCFCPath
- setCFCMethod
- getOriginatorID
- getLogger
- getBuddyList
- getBuddyInfo
- IM gateway message sending commands
- IM Gateway GatewayHelper class methods
- onIncomingMessage
- onIMServerMessage
- onBuddyStatus
- onAddBuddyResponse
- onAddBuddyRequest
- IM Gateway CFC incoming message methods
- IM gateway methods and commands
- CFML CFEvent structure
- warn
- info
- setOriginatorID
- data command
- submit Multi command
- submit command
- setGatewayType
- setGatewayID
- setData
- setCFCListeners
- outgoingMessage
- getStatusTimeStamp
- numberOfMessagesReceived
- numberOfMessagesSent
- removeBuddy
- removeDeny
- removePermit
- setNickName
- setPermitMode
- setStatus
- SMS Gateway CFEvent structure and commands
- SMS Gateway incoming message CFEvent structure
- getStatusAsString
- getProtocolName
- getPermitMode
- getPermitList
- getNickName
- getName
- getDenyList
- getCustomAwayMessage
- getQueueSize
- getMaxQueueSize
- getHelper
- getGatewayType
- getGatewayServices
- getGatewayID_1
- getGatewayID
- getData
- getCFCTimeout
- setCFCTimeout
- getCFCPath
- getCFCMethod
- GatewayServices class
- Gateway interface
- GatewayHelper interface
- addPermit
- addDeny
- addBuddy
- error
- debug
- Logger class
- stop
- start
- CFML event gateway SendGatewayMessage data parameter
- restart
- fatal
- SMS gateway message sending commands
 
- ColdFusion C++ CFX Reference
- ColdFusion Java CFX reference
- WDDX JavaScript Objects
 
- Cloud services
  - ColdFusion and GCP Storage
- ColdFusion and GCP Firestore
- ColdFusion and GCP PubSub
- ColdFusion and Amazon S3
- ColdFusion and DynamoDB
- ColdFusion and Amazon SQS
- ColdFusion and Amazon SNS
- ColdFusion and MongoDB
- ColdFusion and Azure Blob
- ColdFusion and Azure Service Bus
- Multi-cloud storage services
- Multi-cloud RDS databases
- ColdFusion and Azure Cosmos DB
 
Overview
Themes enhance the visual appeal and consistency of ColdFusion charts. Themes allow developers to maintain a uniform look and feel across multiple charts by defining styling properties. By applying themes, you can customize elements such as colors, fonts, and other chart elements to align with your organization’s design language and guidelines.
ColdFusion supports categorical, sequential, and diverging colors across themes.
Creating themes allows you to design unique chart styles tailored to specific use cases or audiences. With ColdFusion, you can create custom themes for creating charts that are both visually engaging and informative.
Additionally, you can modify the themes to update your charts on-the-fly without significant redevelopment effort.
ColdFusion themes
In ColdFusion, themes control the non-data components of a chart, such as text, backgrounds, gridlines, and other visual elements.
Location of ColdFusion themes
The themes are in CF_HOME/cfusion/charting/themes.
Key elements of a theme
A theme includes settings for visual styling, palettes, and specific chart types such as pie, line, radar, and area charts.
In graph properties, the properties subtitle, source, and nodata are not supported at present in charting. Some of them are present in the theme file because they might be introduced in future.
The graph customization properties cover background colors, text configurations for titles, subtitles, and sources, as well as styling for graphs without data. Scales manage axis styling, including guides, ticks, and labels, with optional refinements for minor guides and ticks.
Scrollbars are defined for both horizontal and vertical orientations, specifying bar and handle sizes. The legend section adjusts layout, margins, and appearance, including styling for markers, headers, and footers.
The chart settings control data point representation and interactions, with dynamic adjustments for chart area margins. Various chart types like Pie, Bubble, Bar, Line, and Area have specific configurations, including border and value box settings, tooltip customization, and legend and scale management.
Note: The properties are not exhaustive.
Use ColdFusion built-in themes
ColdFusion provides the following built-in themes:
- blue_light
- cosmos_light
- dawn_light
- feast_light
- industrial_light
- retro_light
- spectrum_light
- vernal_light
Apply a theme to a Chart
In this scenario, you’ll apply a theme, vernal_dark, out of the box, to a chart. In the cfchart tag, the attribute "theme" allows you to specify any of the 16 built-in themes to style your chart.
Example 1- vernal_dark theme
<cfchart type="bar" title="Monetary reserves (2024)" showlegend=FALSE theme="vernal_dark" 
width="600" height="400" format="html"> 
    <cfchartseries color="green"> 
    <cfchartdata item="India" value=10> 
    <cfchartdata item="USA" value=20> 
    <cfchartdata item="France" value=30> 
    <cfchartdata item="Australia" value=20> 
    <cfchartdata item="Japan" value=40> 
    </cfchartseries> 
</cfchart> 
		
	
Output
Example 2- vernal_light theme
<cfchart type="bar" title="Monetary reserves (2024)" showlegend=FALSE theme="vernal_light" 
width="600" height="400" format="html"> 
    <cfchartseries color="green"> 
    <cfchartdata item="India" value=10> 
    <cfchartdata item="USA" value=20> 
    <cfchartdata item="France" value=30> 
    <cfchartdata item="Australia" value=20> 
    <cfchartdata item="Japan" value=40> 
    </cfchartseries> 
</cfchart> 
		
	
Output
Apply themes to multiple Charts
In this scenario, using the cfchartset tag, you will do the following:
- Apply a theme to multiple charts.
- Apply multiple themes to multiple charts.
Apply a theme to multiple charts
Specify a theme in the "theme" attribute in cfchartset. This will apply the specified theme to all the charts defined in the tag.
In this scenario, you’ll create four charts in a 2x2 layout and apply the blue_dark theme to the charts.
<cfscript>
      legend={"vertical-align":"middle","layout"="3x1","align"="right"};
</cfscript>
<cfchartset format="html" height="600" width="800" layout="2x2">
    <cfchart type="line" seriesplacement="stacked" showlegend=TRUE title="Air quality daily monitoring (line chart)"
    legend="#legend#" theme="blue_dark">
        <cfchartseries serieslabel="Ambient">
             <cfchartdata item="Day 1" value="1"/>
             <cfchartdata item="Day 2" value="2"/>
             <cfchartdata item="Day 3" value="3"/>
             <cfchartdata item="Day 4" value="4"/>
             <cfchartdata item="Day 5" value="5"/>
       </cfchartseries>
       <cfchartseries serieslabel="Indoor"> 
             <cfchartdata item="Day 1" value="4"/>
             <cfchartdata item="Day 2" value="5"/>
             <cfchartdata item="Day 3" value="1"/>
             <cfchartdata item="Day 4" value="2"/>
             <cfchartdata item="Day 5" value="3"/>
       </cfchartseries>
       <cfchartseries serieslabel="Stack emission">
             <cfchartdata item="Day 1" value="2"/>
             <cfchartdata item="Day 2" value="3"/>
             <cfchartdata item="Day 3" value="4"/>
             <cfchartdata item="Day 4" value="5"/>
             <cfchartdata item="Day 5" value="1"/>
       </cfchartseries>
    </cfchart>
    <cfchart type="area" seriesplacement="stacked" showlegend=TRUE title="Air quality daily monitoring (area chart)"
     legend="#legend#" theme="blue_light">
       <cfchartseries serieslabel="Ambient">
             <cfchartdata item="Day 1" value="1"/>
             <cfchartdata item="Day 2" value="2"/>
             <cfchartdata item="Day 3" value="3"/>
             <cfchartdata item="Day 4" value="4"/>
             <cfchartdata item="Day 5" value="5"/>
       </cfchartseries>
       <cfchartseries serieslabel="Indoor">
             <cfchartdata item="Day 1" value="4"/>
             <cfchartdata item="Day 2" value="5"/>
             <cfchartdata item="Day 3" value="1"/>
             <cfchartdata item="Day 4" value="2"/>
             <cfchartdata item="Day 5" value="3"/>
       </cfchartseries>
       <cfchartseries serieslabel="Stack emission">
             <cfchartdata item="Day 1" value="2"/>
             <cfchartdata item="Day 2" value="3"/>
             <cfchartdata item="Day 3" value="4"/>
             <cfchartdata item="Day 4" value="5"/>
             <cfchartdata item="Day 5" value="1"/>
       </cfchartseries>
    </cfchart>
    <cfchart type="bar" seriesplacement="stacked" title="Air quality daily monitoring (stacked bar chart)"
    legend="#legend#" theme="vernal_light">
       <cfchartseries>
             <cfchartdata item="Day 1" value="1"/>
             <cfchartdata item="Day 2" value="2"/>
             <cfchartdata item="Day 3" value="3"/>
             <cfchartdata item="Day 4" value="4"/>
             <cfchartdata item="Day 5" value="5"/>
       </cfchartseries>
       <cfchartseries>
             <cfchartdata item="Day 1" value="4"/>
             <cfchartdata item="Day 2" value="5"/>
             <cfchartdata item="Day 3" value="1"/>
             <cfchartdata item="Day 4" value="2"/>
             <cfchartdata item="Day 5" value="3"/>
       </cfchartseries>
       <cfchartseries>
             <cfchartdata item="Day 1" value="2"/>
             <cfchartdata item="Day 2" value="3"/>
             <cfchartdata item="Day 3" value="4"/>
             <cfchartdata item="Day 4" value="5"/>
             <cfchartdata item="Day 5" value="1"/>
       </cfchartseries>
    </cfchart>
    <cfchart type="radar" seriesplacement="stacked" title="Air quality daily monitoring (radar chart)"
    legend="#legend#" theme="vernal_dark">
       <cfchartseries>
             <cfchartdata item="Day 1" value="1"/>
             <cfchartdata item="Day 2" value="2"/>
             <cfchartdata item="Day 3" value="3"/>
             <cfchartdata item="Day 4" value="4"/>
             <cfchartdata item="Day 5" value="5"/>
       </cfchartseries>
       <cfchartseries>
             <cfchartdata item="Day 1" value="4"/>
             <cfchartdata item="Day 2" value="5"/>
             <cfchartdata item="Day 3" value="1"/>
             <cfchartdata item="Day 4" value="2"/>
             <cfchartdata item="Day 5" value="3"/>
       </cfchartseries>
       <cfchartseries>
             <cfchartdata item="Day 1" value="2"/>
             <cfchartdata item="Day 2" value="3"/>
             <cfchartdata item="Day 3" value="4"/>
             <cfchartdata item="Day 4" value="5"/>
             <cfchartdata item="Day 5" value="1"/>
       </cfchartseries>
    </cfchart>
</cfchartset>
		
	
Output
Change the theme to blue_light and you get the following output:
Apply multiple themes to multiple charts
Instead of applying the same theme to multiple charts, the cfchart tag allows you to add different themes to each chart. This means, as many number of charts, as many themes are applied to the charts. The charts appear as a stack.
<cfscript>
      legend={"vertical-align":"middle","layout"="3x1","align"="right"};
</cfscript>
    <cfchart type="line" seriesplacement="stacked" showlegend=TRUE title="Air quality daily monitoring (line chart)"
    legend="#legend#" theme="blue_dark" format="html" width="600" height="400">
        <cfchartseries serieslabel="Ambient">
             <cfchartdata item="Day 1" value="1"/>
             <cfchartdata item="Day 2" value="2"/>
             <cfchartdata item="Day 3" value="3"/>
             <cfchartdata item="Day 4" value="4"/>
             <cfchartdata item="Day 5" value="5"/>
       </cfchartseries>
       <cfchartseries serieslabel="Indoor">
             <cfchartdata item="Day 1" value="4"/>
             <cfchartdata item="Day 2" value="5"/>
             <cfchartdata item="Day 3" value="1"/>
             <cfchartdata item="Day 4" value="2"/>
             <cfchartdata item="Day 5" value="3"/>
       </cfchartseries>
       <cfchartseries serieslabel="Stack emission">
             <cfchartdata item="Day 1" value="2"/>
             <cfchartdata item="Day 2" value="3"/>
             <cfchartdata item="Day 3" value="4"/>
             <cfchartdata item="Day 4" value="5"/>
             <cfchartdata item="Day 5" value="1"/>
       </cfchartseries>
    </cfchart>
    <cfchart type="area" seriesplacement="stacked" showlegend=TRUE title="Air quality daily monitoring (area chart)"
     legend="#legend#" theme="cosmos_light" format="html" width="600" height="400">
       <cfchartseries serieslabel="Ambient">
             <cfchartdata item="Day 1" value="1"/>
             <cfchartdata item="Day 2" value="2"/>
             <cfchartdata item="Day 3" value="3"/>
             <cfchartdata item="Day 4" value="4"/>
             <cfchartdata item="Day 5" value="5"/>
       </cfchartseries>
       <cfchartseries serieslabel="Indoor">
             <cfchartdata item="Day 1" value="4"/>
             <cfchartdata item="Day 2" value="5"/>
             <cfchartdata item="Day 3" value="1"/>
             <cfchartdata item="Day 4" value="2"/>
             <cfchartdata item="Day 5" value="3"/>
       </cfchartseries>
       <cfchartseries serieslabel="Stack emission">
             <cfchartdata item="Day 1" value="2"/>
             <cfchartdata item="Day 2" value="3"/>
             <cfchartdata item="Day 3" value="4"/>
             <cfchartdata item="Day 4" value="5"/>
             <cfchartdata item="Day 5" value="1"/>
       </cfchartseries>
    </cfchart>
    <cfchart type="bar" seriesplacement="stacked" title="Air quality daily monitoring (stacked bar chart)"
    legend="#legend#" theme="vernal_light" format="html" width="600" height="400">
       <cfchartseries>
             <cfchartdata item="Day 1" value="1"/>
             <cfchartdata item="Day 2" value="2"/>
             <cfchartdata item="Day 3" value="3"/>
             <cfchartdata item="Day 4" value="4"/>
             <cfchartdata item="Day 5" value="5"/>
       </cfchartseries>
       <cfchartseries>
             <cfchartdata item="Day 1" value="4"/>
             <cfchartdata item="Day 2" value="5"/>
             <cfchartdata item="Day 3" value="1"/>
             <cfchartdata item="Day 4" value="2"/>
             <cfchartdata item="Day 5" value="3"/>
       </cfchartseries>
       <cfchartseries>
             <cfchartdata item="Day 1" value="2"/>
             <cfchartdata item="Day 2" value="3"/>
             <cfchartdata item="Day 3" value="4"/>
             <cfchartdata item="Day 4" value="5"/>
             <cfchartdata item="Day 5" value="1"/>
       </cfchartseries>
    </cfchart>
    <cfchart type="radar" seriesplacement="stacked" title="Air quality daily monitoring (radar chart)"
    legend="#legend#" theme="vernal_dark" format="html" width="600" height="400">
       <cfchartseries>
             <cfchartdata item="Day 1" value="1"/>
             <cfchartdata item="Day 2" value="2"/>
             <cfchartdata item="Day 3" value="3"/>
             <cfchartdata item="Day 4" value="4"/>
             <cfchartdata item="Day 5" value="5"/>
       </cfchartseries>
       <cfchartseries>
             <cfchartdata item="Day 1" value="4"/>
             <cfchartdata item="Day 2" value="5"/>
             <cfchartdata item="Day 3" value="1"/>
             <cfchartdata item="Day 4" value="2"/>
             <cfchartdata item="Day 5" value="3"/>
       </cfchartseries>
       <cfchartseries>
             <cfchartdata item="Day 1" value="2"/>
             <cfchartdata item="Day 2" value="3"/>
             <cfchartdata item="Day 3" value="4"/>
             <cfchartdata item="Day 4" value="5"/>
             <cfchartdata item="Day 5" value="1"/>
       </cfchartseries>
    </cfchart>
		
	
Output-partial
Create a custom theme
Creating a custom theme in ColdFusion involves defining a theme object with custom properties for chart appearance and applying it globally or to specific charts.
Understand ColdFusion themes
A theme in ColdFusion is a JSON object that specifies styles for chart elements like titles, legends, axis lines, and series. Themes allow you to maintain a consistent look across multiple charts.
Create a custom theme object
Apart from using a built-in theme, you can create your own theme.
In this example, you’ll use the theme, vernal_light, and based on it, you’ll create your own theme.
Open the theme in any code editor and save the theme as my_custom_theme.json or any other name. Then you’ll add the custom theme to a cfchart chart and gradually make incremental changes to the theme.
Note: If using .txt file, the contents must be a valid json. If the file theme_name doesn't have an extension, the file will still be valid, provided it's in an acceptable json format.
Naming a custom theme
The name of the theme in the theme attribute should be exactly the same as the name of the file located in the directory, for example, if the file name of the theme in directory is 'theme_name.json', then the extension will have to be mentioned in the value of the attribute like theme="theme_name.json", if the file name has no extension, eg. 'theme_name', then the value need to be theme="theme_name".
Location of the custom theme
You can place custom themes in the following locations:
- In the same location as the cfm file.
- In CFHOME/cfusion/charting/themes folder.
- In any location on your computer. However, the absolute or relative path needs to be specified in application.cfc. For example, this.chartThemeDirectory = ExpandPath("..\custom_theme_folder\theme_file").
After creating a custom theme file, specify the full name of the file, for example, theme_name.json, in either of the three location mentioned above. In contrary, if you are specifiying a built-in theme, you can use the theme, for example, vernal_light, without any extension.
Change Chart background
Change the background color of the chart by changing the hex code in the property "background-color" in "graph" in the file my_custom_theme.json.
"graph": { 
    "background-color": "#95cceb",
		
	
The following output appears:
Change Chart title properties
Next, you’ll modify the font size, color, padding at the top and bottom of the title, and background color of the chart title. The properties are present in:
"title": { 
            "font-size": 14, 
            "bold": 1, 
            "color": "#fff", 
            "background-color": "", 
            "padding": 6, 
            "adjustLayout": true 
}
		
	
Change the properties, as shown below:
"title": {
            "font-size": 24,
            "bold": 1,
            "color": "##cc6475",
            "background-color": "#d8e0f4",
            "padding": 16,
            "adjustLayout": true
        }
		
	
The change produces the following output:
Toggle visibility of guides
Make the chart guides invisible. Use the property, "visible": 1 or 0 to toggle the guide’s visibility.
"guide": { 
            "visible": 0
		
	
After you set "visible": 0, the guides no longer display.
Similarly, toggle the visibility again and modify other properties, such as guide width, style, color, or transparency.
"guide": {
                "visible": 1,
                "line-width": 2,
                "line-style": "dotted",
                "line-color": "#0d083a",
                "alpha": 0.8
}
		
	
Which produces the following output:
Change x-axis and y-axis data labels
Since the properties are chart-specific, navigate to the vbar object in the theme file. In the vbar object, the scaleX and scaleY properties allow you to style the data labels in the chart.
"vbar": {
        "scaleX": {
            "guide": {
                "visible": false
            },
            "item": {
                "fontColor": "#ec397a",
                "fontSize": "15px"
            }
        },
        "scaleY": {
            "item": {
                "fontColor": "#ec397a",
                "fontSize": "15px"
            }
        }
    }
		
	
To apply the data label styling, change the fontColor and fontSize properties.
"fontColor": "#ec397a", "fontSize": "15px"
The following chart displays:
After adding the customizations to the theme json file, add the name of the file to the theme attribute, as shown below: 
<cfscript>
    yAxis={"label"={"text":"Reserves($)","color":"##d249c4","fontSize": '24px'}}
</cfscript>
<cfchart type="bar" title="Monetary reserves (2025)" showlegend=FALSE theme="my_custom_theme.json"
 width="600" height="400"  format="html">
    <cfchartseries color="##0f689a" animate="#animation#">
        <cfchartdata item="India" value=10>
        <cfchartdata item="USA" value=20>
        <cfchartdata item="France" value=30>
        <cfchartdata item="Australia" value=20>
        <cfchartdata item="Japan" value=40>
    </cfchartseries>
</cfchart>