npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

anychart-v7-to-v8-migration-tool

v1.0.39

Published

[<img src="https://cdn.anychart.com/images/logo-transparent-segoe.png?2" width="234px" alt="AnyChart - Robust JavaScript/HTML5 Chart library any project">](https://anychart.com)

Downloads

44

Readme

AnyChart 7.x to 8.x Migration Tool

AnyChart migration tool is a utility script that helps to migrate JavaScript code of AnyChart 7.14.x to AnyChart 8.x.

IMPORTANT NOTE 1:

AnyChart made a number of adjustments moving from version 7 to 8. This migration tool can do a lot but it does not guarantee 100% migration. Some things can not be changes automatically and need manual coding. See the list of such cases in Manual migration section.

IMPORTANT NOTE 2:

This migration tool change API methods, enums and parameters of AnyChart API version 7.14.3 to version 8.0. It may work on earlier 7.x version but the numer of errors is more likely.

IMPORTANT NOTE 3:

We did our best to create this tool but it is not a panacea. If you don't want to change your code automatically, please see the List of changes section and figure out how your code is affected and what needs to be changed.

Modes

AnyChart migration tool is available in three ways

  • Online script at https://migration.anychart.com/

  • You own Web-Server that does the same as the script above but it is deployed on your side.

  • Console Utility script - you can choose a file or a folder, script will look for AnyChart code and replace everything, use with caution.

Installation

To install migration tool with npm:

npm install anychart-v7-to-v8-migration-tool -g

Running as Web Server

To run web server on port 3000 navigate to migration tool folder and run:

anychart-v7-to-v8-migration-tool-server -p 3000

To show help message navigate to migration tool folder and run:

anychart-v7-to-v8-migration-tool-server --help

Running as Console Utility

To process a file:

anychart-v7-to-v8-migration-tool-cli path_to_file

To process all files in a folder:

anychart-v7-to-v8-migration-tool-cli path_to_directory -r

To show help console script help:

anychart-v7-to-v8-migration-tool-cli --help

API Changes

Stacking Settings

The ordering in which the series are stacked is changed and now goes in other direction. To restore the previous behavior stackDirection() method has been added. Set 'reverse' to make the order match 7.x:

| 7.x Version | 8.x Version | | ------------- | ------------- | | chart.yScale() | chart.yScale().stackDirection('reverse') |

State Settings

The API for select and hover settings has been refactored: methods like hoverFill() are replaced with hovered().fill(), selectFill() - with selected().fill() and so on. The order of the parameters and behavior is the same.

These changes allow to clone/copy the settings from the state to state easily.

See the full list of replaced methods:

Common API Methods

| 7.x Version | 8.x Version | | ------------- | ------------- | | hover/selectFill() | hovered/selected().fill() | | hover/selectStroke() | hovered/selected().stroke() | | hover/selectLabels() | hovered/selected().labels() | | hover/selectMarkers() | hovered/selected().markers() |

Specific API Methods

| 7.x Version | 8.x Version | | ------------- | ------------- | | hover/selectNegativeFill() | hovered/selected().negativeFill() | | hover/selectRisingFill() | hovered/selected().risingFill() | | hover/selectFallingFill() | hovered/selected().fallingFill() | | hover/selectLowStroke() | hovered/selected().lowStroke() | | hover/selectHighStroke() | hovered/selected().highStroke() | | hover/selectNegativeStroke() | hovered/selected().negativeStroke() | | hover/selectRisingStroke() | hovered/selected().risingStroke() | | hover/selectFallingStroke() | hovered/selected().fallingStroke() | | hover/selectMedianStroke() | hovered/selected().medianStroke() | | hover/selectStemStroke() | hovered/selected().stemStroke() | | hover/selectWhiskerStroke() | hovered/selected().whiskerStroke() | | hover/selectHatchFill() | hovered/selected().hatchFill() | | hover/selectNegativeHatchFill() | hovered/selected().negativeHatchFill() | | hover/selectRisingHatchFill() | hovered/selected().risingHatchFill() | | hover/selectFallingHatchFill() | hovered/selected().fallingHatchFill() | | hover/selectWhiskerWidth() | hovered/selected().whiskerWidth() | | hover/selectType() | hovered/selected().type() | | hover/selectSize() | hovered/selected().size() | | hover/selectTrend() | hovered/selected().trend() | | hover/selectGrid() | hovered/selected().grid() | | hover/selectEmptyFill() | hovered/selected().emptyFill() | | hover/selectEmptyHatchFill() | hovered/selected().emptyHatchFill() | | - | hovered/selected().fontFamily() | | - | hovered/selected().fontStyle() | | - | hovered/selected().fontVariant() | | - | hovered/selected().fontWeight() | | - | hovered/selected().fontSize() | | - | hovered/selected().dummyFill() | | - | hovered/selected().dummyStroke() | | - | hovered/selected().headers() | | hover/selectLowerLabels() | hovered/selected().lowerLabels() | | hover/selectUpperLabels() | hovered/selected().upperLabels() | | hover/selectOutlierMarkers() | hovered/selected().outlierMarkers() |

Grids API

Grids API has been changed completely and can not be migrated automatically:

  1. Single grid() method is replaced with xGrid() and yGrid() methods.

7.x Version Code

chart.grid(0).stroke("#9E9E9E", 2, "5 2 5");
chart.grid(1).layout('vertical').stroke("#9E9E9E", 1, "5 1 5");

8.x.x

chart.xGrid().stroke("#9E9E9E", 2, "5 2 5");
chart.yGrid().stroke("#9E9E9E", 1, "5 1 5");
  1. Single minorGrid() method is replaced with yMinorGrid() and xMinorGrid() methods.

7.x Version Code

chart.minorGrid(0).stroke("#9E9E9E", 2, "5 2 5");
chart.minorGrid(1).layout('vertical').stroke("#9E9E9E", 1, "5 1 5");

8.x.x

chart.xMinorGrid().stroke("#9E9E9E", 2, "5 2 5");
chart.yMinorGrid().stroke("#9E9E9E", 1, "5 1 5");
  1. oddFill() and evenFill() methods are replaced with fill() method that now accepts palette()

7.x Version Code

var chart = anychart.polar();
chart.grid()
        // coloring odd cells of the grid
        .evenFill('white 0.9')
        // coloring even cells of the grid
        .oddFill('lightgray 0.3')
        // set layout type
        .layout('curcuit')
        .stroke('white');

8.x.x

var chart = anychart.polar();
chart.yGrid().palette(['lightgray 0.3', 'white 0.9']);

Context Menu Customization

Context menu API has been changed completely and can not be migrated automatically. Objects with IDs are now used instead of arrays. Please refer to Context Menu article to learn how to use the context menu in version 8.x.

7.14.3 Version Code

chart.contextMenu().itemsFormatter(function () {
    // Adding custom item to the top of context menu.
    this.unshift({
        text: "My custom item"
    });

    return this;
});

8.x Version Code

chart.contextMenu().itemsFormatter(function (items) {
    // Adding custom item to the top of context menu.
    items["my-custom-item"] = {
        index: 0,
        text: "Show help info",
        href: "https://docs.anychart.com/"
    };

    return items;
});

Data Mapping API

Improved API of mapAs() method, now it accepts only one parameter instead for four old version. You don't need to pass undefined as first parameter for object based data sets.

7.x Version Code

var dataSet = anychart.data.set([
  {platform: 'Mobile', views: 100},
  {platform: 'Tablet', views: 200},
  {platform: 'Desktop', views: 300}
]);
var mapping = dataSet.mapAs(undefined, {x: 'platform', value: 'views'});

8.x.x

var dataSet = anychart.data.set([
  {platform: 'Mobile', views: 100},
  {platform: 'Tablet', views: 200},
  {platform: 'Desktop', views: 300}
]);
var mapping = dataSet.mapAs({x: 'platform', value: 'views'});

Dropped Enums API

There are two changes in enums API:

  1. Enums no longer can be set by name, only string values can be used.
  2. Enums string values are changed from camel case to dash case.

7.x Version Code

chart.legend().itemsLayout(anychart.enums.LegendLayout.HORIZONTAL_EXPANDABLE);

8.x Version Code

chart.legend().itemsLayout('horizontal-expandable');

Deprecated API Drop

Version 8.x drops a number of deprecated methods. Which means that you may have used these methods and the library only showed warnings. With upgrading to version 8.x using these methods is no longer possible.

See the list of dropped methods and their replacement below:

Text Formatting

| 7.x Version | 8.x Version | | ------------- | ------------- | | anychart.utils.formatDateTime() | anychart.format.dateTime() | | textFormatter()/contentFormatter() | format() | | itemsTextFormatter() | itemsFormat() | | titleFormatter() | titleFormat() | | copyFormatter() | copyFormat() | | unionTextFormatter() | unionFormat() | | getDataValue() | getData() | | getTokenValue() | getData() | | getSeriesMeta() | getMeta() |

Interactivity Settings

| Old Version | New Version | | ------------- | ------------- | | allowPointsSelect() | selectionMode() | | isFloating() | positionMode() | | mouseWheel() | zoomOnMouseWheel() |

Palettes

| Old Version | New Version | | ------------- | ------------- | | colorAt() | itemAt() | | colors() | items() | | markerAt() | itemAt() | | markers() | items() |

Sparkline API

| Old Version | New Version | | ------------- | ------------- | | chart.type() | chart.seriesType() |

Misc

| Old Version | New Version | | ------------- | ------------- | | anychart.server() | anychart.exports.server() | | getGroupingUnit() | getCurrentDataInterval() |

Gantt Data Grid

| Old Version | New Version | | ------------- | ------------- | | cellFill() | rowFill() | | cellOddFill() | rowOddFill() | | cellEvenFill() | rowEvenFill() | | titleHeight() | headerHeight() |

Constructors and Standalones

| Old Version | New Version | | ------------- | ------------- | | anychart.circularGauge() | anychart.gauges.circular() | | anychart.ui.background() | anychart.standalones.background() | | anychart.ui.colorRange() | anychart.standalones.colorRange() | | anychart.ui.dataGrid() | anychart.standalones.dataGrid() | | anychart.ui.label() | anychart.standalones.label() | | anychart.ui.labelsFactory() | anychart.standalones.labelsFactory() | | anychart.ui.legend() | anychart.standalones.legend() | | anychart.ui.markersFactory() | anychart.standalones.markersFactory() | | anychart.ui.scroller() | anychart.standalones.scroller() | | anychart.ui.table() | anychart.standalones.table() | | anychart.ui.projectTimeline() | anychart.standalones.projectTimeline() | | anychart.ui.resourceTimeline() | anychart.standalones.resourceTimeline() | | anychart.ui.title() | anychart.standalones.title() | | anychart.axes.linear() | anychart.standalones.axes.linear() | | anychart.axes.polar() | anychart.standalones.axes.polar() | | anychart.axes.radar() | anychart.standalones.axes.radar() | | anychart.axes.radial() | anychart.standalones.axes.radial() | | anychart.axisMarkers.line() | anychart.standalones.axisMarkers.line() | | anychart.axisMarkers.range() | anychart.standalones.axisMarkers.range() | | anychart.axisMarkers.text() | anychart.standalones.axisMarkers.text() | | anychart.grids.linear() | anychart.standalones.grids.linear() | | anychart.grids.polar() | anychart.standalones.grids.polar() | | anychart.grids.radar() | anychart.standalones.grids.radar() | | anychart.ganttToolbar() | anychart.ui.ganttToolbar() | | anychart.toolbar() | anychart.ui.ganttToolbar() |

License

?? AnyChart.com - JavaScript charts. Released under the Apache 2.0 License.