@windy/Metric 
Major Windy class for conversion of units, that are used in Windy.com.
Enjoy methods like convertValue, convertNumber, listMetrics, howManyMetrics
Never ever, change users selected metric without their consent.
Type parameters 
| Name | Type | 
|---|---|
| T | extends string|number=string|number | 
Table of contents 
Constructors 
Properties 
Methods 
Constructors 
constructor 
• new Metric<T>(params): Metric<T>
Type parameters 
| Name | Type | 
|---|---|
| T | extends string|number=string|number | 
Parameters 
| Name | Type | 
|---|---|
| params | MetricInitParams | 
Returns 
Metric<T>
Properties 
backConv 
• Optional backConv: ConvObj
Backward conversion functions
cohesion 
• Optional cohesion: Object
Keeps cohesion in between multiple metric instances. For example setting in in rain will set in in snow also
Type declaration 
conv 
• conv: ConvObj
Conversion functions
defaults 
• defaults: MetricItem[]
Default metric for start-up [ metric, imperial, ??? ]
description 
• description: LegendDescription
Legend description
discreteLegend 
• Optional discreteLegend: Object
Some metrics have discrete legend. If so, these labels define it, where NumValue is numerical value, to grab color from color table
Type declaration 
| Name | Type | Description | 
|---|---|---|
| hasEqualItemsWidth? | boolean | Should all items in legend have same width? | 
| labels | [keyof MainLangFile | keyof PluginTranslations, `rgb(${number},${number},${number})`][] | Array of trans strings and clored string. For simplicity of sloution, the legned colors are hardcoded thus they do not react on 'users' defined color. This will be know bug and we will not handle this case. | 
ident 
• ident: keyof MetricTypes
Identifies metric
lines 
• lines: LegendLines
Array defining how the legend will look like
metric 
• metric: MetricItem
Actually selected metric
nativeSync 
• nativeSync: boolean
Sync the metric to native iOS/Android apps
separator 
• separator: "" | " "
number ' ' metric separator
Methods 
convertNumber 
▸ convertNumber(value, forcedPrecision?, metric?): T
produces converted number value without label
Parameters 
| Name | Type | 
|---|---|
| value | number | 
| forcedPrecision? | number | 
| metric? | MetricItem | 
Returns 
T
convertValue 
▸ convertValue(value, separator?, suffix?, forcedPrecision?): string
get value + label on a basis of user selected metric
Parameters 
| Name | Type | 
|---|---|
| value | number | 
| separator? | string | 
| suffix? | string | 
| forcedPrecision? | number | 
Returns 
string
cycleMetric 
▸ cycleMetric(): void
Cycles throu different metrics (for example after clicking on a legend)
Returns 
void
howManyMetrics 
▸ howManyMetrics(): number
How many metrics we have
Returns 
number
initProperties 
▸ initProperties(): void
Returns 
void
listMetrics 
▸ listMetrics(): MetricItem[]
List all avail units
Returns 
na 
▸ na(): string
Not available
Returns 
string
renderLegend 
▸ renderLegend(col, el, legend): void
color object is required for classic gradient metrics, discrete ones do not need it as colors are hardcoded for them
Parameters 
| Name | Type | 
|---|---|
| col | Color | 
| el | HTMLDivElement | 
| legend | Legend | 
Returns 
void
setMetric 
▸ setMetric(metric, ignoreCohesion?): void
Stores required metric into storage
Parameters 
| Name | Type | 
|---|---|
| metric | MetricItem | 
| ignoreCohesion? | boolean | 
Returns 
void