Axibase Charts Extension for VSCode
data:image/s3,"s3://crabby-images/ab147/ab147807cb8d4097537f12cf8c5d02c0e788e559" alt=""
data:image/s3,"s3://crabby-images/0a0b8/0a0b8ea2328acfcf13adc92b5e29800c4796319b" alt=""
Axibase Charts extension for Microsoft Visual Studio Code is a design tool that simplifies portal development and data exploration using the Axibase Charts library of declarative graphics.
The extension implements the following functionality:
Installation
- Open VSCode and click the Extensions tab in the left menu.
- Search for
axibase
in the VSCode Extensions Marketplace.
- Install the extension and reload VSCode.
data:image/s3,"s3://crabby-images/925c1/925c121180ec3107ecf5753d66301fd8af0c8b73" alt=""
Requirements
Support
Include VSCode and extension version when opening issues on Github.
VSCode version is displayed in the main menu, on the About Visual Studio Code dialog window.
data:image/s3,"s3://crabby-images/d5edb/d5edb572373d92ca6e07508d6cd549ba92ff6948" alt=""
Locate extension version on the Extensions tab located in the main menu.
data:image/s3,"s3://crabby-images/71f63/71f63c7d5b3d8289f0c2693c21525566c875fc4b" alt=""
Introduction
Build portals with Axibase Charts.
Create files with the extension .config
.
To display available completions, press Ctrl+Space
on PC or ⌃Space
on Mac.
data:image/s3,"s3://crabby-images/9631b/9631b42896449adc6b4ec3712f0b9296e4ad3f66" alt="Completion list screenshot"
Live Preview
The extension shows a preview of the portal in the VSCode interface by requesting data from the target server.
To configure the target server, open Preferences > Settings and enter axibase
in the search box.
Specify connection properties.
data:image/s3,"s3://crabby-images/eaad8/eaad82b6efb3584111eeff29c17d6f70d9955c66" alt=""
Click Show Preview in the upper-right corner to view the current portal.
data:image/s3,"s3://crabby-images/ed1d0/ed1d031ef223e2fa7ecca5c64f4766e91647975c" alt=""
The portal is rendered based on the configuration displayed in the Editor pane, even if the text is not saved.
Enter user password, if connecting for the first time.
data:image/s3,"s3://crabby-images/83c2a/83c2a0b7fe9aa76ca8ffaea32635ae0ff2ce146f" alt=""
SSL Certificates
VSCode does not allow secure connections to servers with untrusted (self-signed) SSL certificates.
To resolve certificate validation errors:
Add the self-signed SSL certificate from the target server to root CAs on the operating system where VSCode is installed. Restart VSCode.
Start VSCode with code --ignore-certificate-errors
command to skip certificate validation.
To launch VScode with code --ignore-certificate-errors
, add code to PATH
by typing ⇧⌘P
, then ShelC
on Mac.
data:image/s3,"s3://crabby-images/35eeb/35eebc17996af44aa178f2c292301bd76df03f5b" alt=""
Syntax Highlighting
Syntax highlighting uses colors defined in VSCode themes. To choose a different theme, for example Light+(default light)
, open File > Preferences > Color Theme.
data:image/s3,"s3://crabby-images/47eee/47eee2ce733c2bbcd0417eac48b0e9c8ab75406f" alt="Screenshot of highlighted syntax"
data:image/s3,"s3://crabby-images/d438d/d438d79f928cd51c8bb1f12eeca97847d34e06b2" alt="GIF animation showing updating indents"
Snippets
{widget_name}
: Creates a new [widget]
section with a pre-configured sample widget.
configuration
: Creates a new [configuration]
section with child [group]
section and initial settings.
for
: Creates a new for
loop with corresponding endfor
.
if
: Creates a new if
statement with corresponding endif
.
series {type}
: Possible {type}
values are with tags
, detail
, averaged
. Creates a new [series]
section.
portal: 3x2
: Creates a new portal with 6
widgets organized into 3
columns and 2
rows.
Validation
Unknown alias
.
[series]
alias = s1
[series]
value = value('a1')
Incomplete for
, csv
, var
, list
, script
, if
block.
list values = value1, value2,
value3, value4
# no matching endlist
Malformed csv
definition.
csv servers =
name, price
vps, 5
vds, 5, 4 /* wrong number of columns */
endcsv
Unmatched tags endcsv
, endif
, endfor
, endvar
, endscript
, endlist
.
var array = [
"value1", "value2"
]
endlist
# endlist can not finish var statement
Undefined variable in for
loop.
for server in servers
[series]
entity = @{srv} /* for variable is server, but srv is used */
endfor
Undefined collection in for
loop.
list servers = vps, vds
for server in serverc /* misspelling */
[series]
entity = @{server}
endfor
else
or elseif
statement without corresponding if
.
for item in collection
[series]
# no 'if' keyword
elseif item == 'vps'
metric = vps
else
metric = vds
endif
endfor
Duplicate variable definition.
list collection = value1, value2
var collection = [ "value1", "value2" ]
# duplicate variable name
for server in servers
for server in servers
# duplicate variable name
endfor
endfor
Duplicate settings.
[series]
entity = server
entity = srv /* duplicate setting */
metric = cpu_busy
Required setting missing.
[widget]
# type is required
[series]
...
[series]
entity = server
# metric is required
[widget]
Misspelled setting.
[wigdet]
# "wigdet" instead of "widget"
type = chart
[series]
startime = now
# "startime" instead of "starttime"
for
finishes before if
.
for server in servers
[series]
if server == 'vps'
entity = 'vds'
else
entity = 'vps'
endfor
# if must be finished inside the for
endif
Setting is interpreted as a tag.
[tags]
server_name = 'vds'
time-span = 1 hour
# time-span will be interpreted as a tag
JavaScript errors if axibaseCharts.validateFunctions
is true
:
script
widget = hello() // widget is allowed variable, since it comes from Charts
// hello() is unknown function, the plugin warns about it
endscript
[series]
value = 5 + ; // forgotten operand
User Defined Completions
Snippets
To display the list of pre-configured snippets, press Ctrl+Shift+P
on PC or ⇧⌘P
on Mac and enter Insert Snippet
.
data:image/s3,"s3://crabby-images/76c11/76c11ae21f66875c2606b51fe592641b0bf70df3" alt="Snippets list screenshot"
To add a new snippet, refer to VSCode Documentation.
To add new snippets to the extension use snippets/snippets.json
file using pre-configured snippets as examples.