ECharts Widget
by SHANGHAI YUM TOWN FOOD CO. https://www.yumtown.cn , LTD. https://www.yumtown.cn
                                Odoo
                            
                    $ 53.02
| Availability | 
                            
                             Odoo Online
                              Odoo.sh  On Premise | 
| Lines of code | 45 | 
| Technical Name | 
                    echarts_widget | 
| License | OPL-1 | 
| Website | https://www.yumtown.cn | 
| Versions | 12.0 13.0 14.0 15.0 16.0 17.0 18.0 | 
Display echarts in Odoo's form view, support all chart types.
Screenshots
 
     
    User Guide
Step 1: Add a calculated field to the model and return the JSON format
# model.py
_inherit = 'modelName'
chart = fields.Char(string='Exchange rate chart', compute='_compute_chart')
def _compute_chart(self):
# You can query internal and external data sources through Odoo's ORM methods, SQL statements, etc., and then return data in JSON format
option = {
    'xAxis': {
        'type': 'category',
        'data': [
            '2010-01-01', '2023-03-25', '2023-03-26', '2023-03-27',
            '2023-03-28', '2023-03-29', '2023-03-30', '2023-03-31',
            '2023-04-01', '2023-04-02', '2023-04-03', '2023-04-04',
            '2023-04-05', '2023-04-06', '2023-04-07', '2023-04-08',
            '2023-04-09', '2023-04-10', '2023-04-11', '2023-04-12',
            '2023-04-13', '2023-04-14', '2023-04-15', '2023-04-16',
            '2023-04-17', '2023-04-18', '2023-04-19', '2023-04-20',
            '2023-04-21', '2023-04-22', '2023-04-23', '2023-06-06'
        ]
    },
    'yAxis': {'type': 'value'},
    'series': [
        {
            'data': [
                1.2834, 1.5289, 1.2834, 1.4365, 1.3256, 1.4526, 1.6523,
                1.5234, 1.2548, 1.5434, 1.3154, 1.4253, 1.3521, 1.5234,
                1.5321, 1.1235, 1.3215, 1.3543, 1.5214, 1.4531, 1.3245,
                1.4531, 1.3245, 1.1532, 1.5563, 1.3541, 1.5213, 1.3515,
                1.5312, 1.5313, 1.2145, 1.5289
            ],
            'type': 'line',
            'smooth': True
        }
    ]
}
options = json.dumps(option).replace('True', 'true').replace('False', 'false')
self.chart = options
        
    Step 2: Add calculated fields to the Form view, using the echarts widget
<script type="text/javascript" src="/module_name/static/src/js/chart.js"/>
<field name="chart" widget="echarts" style="height:300px;"/>
        
        
            Notes: You can set the height of the echarts chart via the style property.
        
    eCharts chart function & callback
            The echarts setOption attribute can be supplemented /module_name/static/src/js/chart.js
        
        
if ($('div[name="chart"]>div').length > 0) {
    let chart = echarts.getInstanceByDom($('div[name="chart"]>div')[0])
    chart.setOption(
        {
            title: {
                text: 'Displays a floating line chart of all exchange rates for the current currency'
            },
            tooltip: {
                trigger: 'axis'
            },
        }
    )
}
        
    All options of the chart after combining calculated fields with JavaScript are set as follows
{
    title: {
        text: 'Displays a floating line chart of all exchange rates for the current currency'
    },
    tooltip: {
        trigger: 'axis'
    },
    xAxis: {
        type: 'category',
        data: [
            '2010-01-01', '2023-03-25', '2023-03-26', '2023-03-27',
            '2023-03-28', '2023-03-29', '2023-03-30', '2023-03-31',
            '2023-04-01', '2023-04-02', '2023-04-03', '2023-04-04',
            '2023-04-05', '2023-04-06', '2023-04-07', '2023-04-08',
            '2023-04-09', '2023-04-10', '2023-04-11', '2023-04-12',
            '2023-04-13', '2023-04-14', '2023-04-15', '2023-04-16',
            '2023-04-17', '2023-04-18', '2023-04-19', '2023-04-20',
            '2023-04-21', '2023-04-22', '2023-04-23', '2023-06-06'
        ]
    },
    yAxis: {type: 'value'},
    series: [
        {
            data: [
                1.2834, 1.5289, 1.2834, 1.4365, 1.3256, 1.4526, 1.6523,
                1.5234,1.2548, 1.5434, 1.3154, 1.4253, 1.3521, 1.5234,
                1.5321, 1.1235, 1.3215, 1.3543, 1.5214, 1.4531,
                1.3245, 1.4531, 1.3245, 1.1532, 1.5563, 1.3541,
                1.5213, 1.3515, 1.5312, 1.5313, 1.2145, 1.5289],
            type: 'line',
            smooth: true
        }
    ]
}
        
    Reference content
- Odoo demo module: echarts_widget_demo
- 
                eCharts
                - Website: https://echarts.apache.org/en/index.html
- Examples: https://echarts.apache.org/examples/en/index.html
- Options reference: https://echarts.apache.org/en/option.html
 
Support
- email: it@yumtown.com.cn
Odoo Proprietary License v1.0 This software and associated files (the "Software") may only be used (executed, modified, executed after modifications) if you have purchased a valid license from the authors, typically via Odoo Apps, or if you have received a written agreement from the authors of the Software (see the COPYRIGHT file). You may develop Odoo modules that use the Software as a library (typically by depending on it, importing it and using its resources), but without copying any source code or material from the Software. You may distribute those modules under the license of your choice, provided that this license is compatible with the terms of the Odoo Proprietary License (For example: LGPL, MIT, or proprietary licenses similar to this one). It is forbidden to publish, distribute, sublicense, or sell copies of the Software or modified copies of the Software. The above copyright notice and this permission notice must be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Please log in to comment on this module