Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/susiwen8/echarts-vscode-extension
VSCode extension for Apache ECharts
https://github.com/susiwen8/echarts-vscode-extension
echarts typescript vscode-extension
Last synced: 3 months ago
JSON representation
VSCode extension for Apache ECharts
- Host: GitHub
- URL: https://github.com/susiwen8/echarts-vscode-extension
- Owner: susiwen8
- Created: 2020-01-01T00:59:53.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2023-01-07T15:21:07.000Z (about 2 years ago)
- Last Synced: 2024-08-02T07:14:58.087Z (6 months ago)
- Topics: echarts, typescript, vscode-extension
- Language: TypeScript
- Homepage:
- Size: 4.65 MB
- Stars: 35
- Watchers: 2
- Forks: 1
- Open Issues: 20
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
- awesome-echarts - echarts-vscode-extension - vscode extension for Apache ECharts autocompletion (Tools / VSCode Extensions)
README
# echarts-vscode-extension
![logo](./images/logo.png)
This is unofficial vscode extension for [Apache ECharts](https://github.com/apache/echarts)
## Install
* `ext install vscode-echarts-extension`
* Marketplace [![](https://vsmarketplacebadge.apphb.com/version/susiwen8.vscode-echarts-extension.svg)](https://marketplace.visualstudio.com/items?itemName=susiwen8.vscode-echarts-extension) [![](https://vsmarketplacebadge.apphb.com/installs/susiwen8.vscode-echarts-extension.svg)](https://marketplace.visualstudio.com/items?itemName=susiwen8.vscode-echarts-extension)## Commands
This extension provides 2 commands
* `echarts.activate`: extension provides completion when matched case occur
* `echarts.deactivate`: extension never show completionPS: From 0.1.2, extension won't provide completion at first, because JS file may not import `echarts`. User need to execute `echarts.activate` at command panel.
## Example
![example](./gif/example.gif)## Problems
* ~~All options information were received by ajax, useless when there were no Internet.~~ Cache response data (Update: json file store at local)
* ~~Due to Apache server response speed, sometime connection timeout.~~(Trying Netlify, but JSON files are so big and may have other known issues)(Update: json file store at local)
* ~~Use closest node to determine CompletionItem which sometime is inaccurate.~~ Solution: Use [acorn](https://github.com/acornjs/acorn) to generate AST and find closest node by using [acorn-walk](https://github.com/acornjs/acorn/tree/master/acorn-walk)
* ~~Don't support completion when object inside object~~ Find out all ancestors option
* All options must be in one root object (There is nothing I can do about it, it has to be :man_shrugging:)## Suggestion
For the purpose of functionnality, I strongly recommend that putting echarts option object at seperated js file, and put options in same object.
(Actually, this will reduce losts of work, make my life much easy :stuck_out_tongue_winking_eye:)## Documentation
Documentation generate from [here](https://github.com/susiwen8/incubator-echarts-doc/tree/api).## TypeScript support
I want to thanks [David Sherret](https://github.com/dsherret) for doing an amazing project [ts-ast-viewer](https://github.com/dsherret/ts-ast-viewer). I have took the core function `getDescendantAtRange` to this project which can find out which node the cursor in.## TODO
- [x] Downgrade
- [x] Optimization
- [x] Object inside Object ex. title.textStyle
- [ ] Replace Apache api (WIP, trying Netlify and reduce json file size)
- [x] base on option value type to provide helpful snippet text.
- [x] Check if type of value were correct.
- [x] Provide english documentation
- [ ] Provide chinese documentation
- [x] Convert HTML to Markdown (documentation)
- [x] Check if value were resonable.
- [ ] HoverProvider
- [x] More command
- [x] TypeScript support
- [ ] Add default value for option
- [ ] New option data structure