Settings Interface

The collection of Settings that supply the run-time configuration of a Workspace. The Settings object comprises a collection of named SettingsDictionary objects. Methods like getSetting, getString, and getArray provide access to the value of an individual Setting by searching the dictionaries in order by their SettingsPriority to find the highest-priority setting with the requested SettingName. Most methods that retrieve Setting values validate them against their SettingSchemas to ensure that they are of the correct type. A SettingsDictionary can be added or removed using addDictionary and dropDictionary. Because Settings can change at any time during the session, you should avoid caching their values wherever possible. If you must cache them (for example, to display in a user interface), you should listen for the onSettingsChanged event to be notified of potential changes.

Settings are accessed via settings. They are defined at the application level by appWorkspace, but individual iModels may supply additional iModel-specific settings or overrides for application-level settings. When working in the context of a specific iModel, use workspace's settings property. Any settings not overridden by the iModel will fall back to the settings defined in appWorkspace.

Application settings are loaded into appWorkspace when the session begins (i.e., when startup is invoked), and unloaded when it ends (in shutdown). They are read from JSON5 files delivered with the application. The application should register any additional SettingsDictionary's '(and their corresponding SettingGroupSchemas) at this time.

iModel-specific settings are stored in the iModel's property table and loaded into workspace when the iModel is first opened. You can add and remove a SettingsDictionary from the property table using saveSettingDictionary and deleteSettingDictionary.

See the learning article for a detailed overiew and examples.

@see appWorkspace application-wide settings, and workspace for settings specific to a given iModel.

Methods

Name Description
addDictionary(props: SettingsDictionaryProps, settings: SettingsContainer): void Add a new SettingsDictionary with the priority, name, and WorkspaceDb specified by props and setting values supplied by settings.  
addDirectory(directory: string, priority: number): void Invokes addFile for all files in directory with the extension ".json" or ".json5".  
addFile(fileName: string, priority: number): void Parses the contents of a local JSON5 file as a SettingsContainer and invokes addDictionary to  
addJson(props: SettingsDictionaryProps, settingsJson: string): void Parses settingsJson as a SettingsContainer and invokes addDictionary to add a SettingsDictionary with the specified props.  
dropDictionary(props: SettingsDictionarySource): void Removes a previously-added SettingsDictionary.  
getArray<T extends JSONSchemaType>(settingName: string): undefined | T[]    
getArray<T extends JSONSchemaType>(settingName: string, defaultValue: T[]): T[] Look up the value of an array Setting named settingName, returning defaultValue if no such value is defined.  
getBoolean(settingName: string, defaultValue?: boolean): undefined | boolean    
getBoolean(settingName: string, defaultValue: boolean): boolean Look up the value of a boolean Setting named settingName, returning defaultValue if no such value is defined.  
getDictionary(source: SettingsDictionarySource): undefined | SettingsDictionary Find a SettingsDictionary with the same name and WorkspaceDb as source.  
getNumber(settingName: string): undefined | number    
getNumber(settingName: string, defaultValue: number): number Look up the value of a numeric Setting named settingName, returning defaultValue if no such value is defined.  
getObject<T extends object>(settingName: string): undefined | T    
getObject<T extends object>(settingName: string, defaultValue: T): T Look up the value of an object Setting named settingName, returning defaultValue if no such value is defined.  
getSetting<T extends JSONSchemaType>(settingName: string, defaultValue?: T): undefined | T Looks up the highest priority setting value for a SettingName, falling back to a default value if no value for the setting is found.  
getSettingEntries<T extends JSONSchemaType>(settingName: string): Iterable<{ dictionary: SettingsDictionary, value: T }, any, any> Obtain an iterator over all of the values in the dictionaries for the Setting identified by settingName, ordered by SettingsPriority.  
getSettingValues<T extends JSONSchemaType>(settingName: string): Iterable<T, any, any> Obtain an iterator over all of the values in the dictionaries for the Setting identified by settingName, ordered by SettingsPriority.  
getString(settingName: string, defaultValue?: string): undefined | string    
getString(settingName: string, defaultValue: string): string Look up the value of a string Setting named settingName, returning defaultValue if no such value is defined.  

Properties

Name Type Description
dictionaries Readonly ReadonlyArray<SettingsDictionary> The set of settings dictionaries from which Setting values are obtained, sorted by SettingsPriority.  
onSettingsChanged Readonly BeEvent<() => void> Event raised whenever a SettingsDictionary is added or removed.  

Defined in

Last Updated: 16 January, 2025