Class TJSStyleManager
Index
Constructors
Accessors
Methods
Constructors
constructor
- new TJSStyleManager(
opts?: {
docKey: string;
document?: Document;
selector?: string;
version?: number;
},
): TJSStyleManager Parameters
Optional
opts: { docKey: string; document?: Document; selector?: string; version?: number }Options.
docKey: string
Required key providing a link to a specific style sheet element.
Optional
document?: DocumentTarget document to load styles into.
Optional
selector?: stringSelector element.
Optional
version?: numberAn integer representing the version / level of styles being managed.
Returns TJSStyleManager
Accessors
cssText
- get cssText(): string
Returns string
Provides an accessor to get the
cssText
for the style sheet.
version
- get version(): number
Returns number
Returns the version of this instance.
Methods
clone
- clone(document?: Document): TJSStyleManager
Provides a copy constructor to duplicate an existing TJSStyleManager instance into a new document.
Note: This is used to support the
PopOut
module.Parameters
Optional
document: DocumentTarget browser document to clone into.
Returns TJSStyleManager
New style manager instance.
get
getProperty
removeProperties
removeProperty
setProperties
- setProperties(rules: { [key: string]: string }, overwrite?: boolean): void
Set rules by property / value; useful for CSS variables.
Parameters
- rules: { [key: string]: string }
An object with property / value string pairs to load.
Optional
overwrite: booleanWhen true overwrites any existing values.
Returns void
- rules: { [key: string]: string }
Provides a managed dynamic style sheet / element useful in configuring global CSS variables. When creating an instance of TJSStyleManager you must provide a "document key" / string for the style element added. The style element can be accessed via
document[docKey]
.Instances of TJSStyleManager can also be versioned by supplying a positive integer greater than or equal to
1
via the 'version' option. This version number is assigned to the associated style element. When a TJSStyleManager instance is created and there is an existing instance with a version that is lower than the current instance all CSS rules are removed letting the higher version to take precedence. This isn't a perfect system and requires thoughtful construction of CSS variables exposed, but allows multiple independently compiled TRL packages to load the latest CSS variables. It is recommended to always setoverwrite
option of TJSStyleManager.setProperty and TJSStyleManager.setProperties tofalse
when loading initial values.