Skip to content

Latest commit

 

History

History
275 lines (196 loc) · 10.6 KB

js-api.md

File metadata and controls

275 lines (196 loc) · 10.6 KB

JavaScript API

Datagrok JS API allows to control all aspects of the Datagrok platform. The API can be used either from ad-hoc scripts (Functions | Scripts | New JavaScript Script) or from packages.

This document covers the following areas:

API structure

There are three entry points to the API:

  • grok for easy discoverability of the functionality,
  • ui for building user interfaces, and
  • DG for instantiating classes directly.

Grok

grok is the entry point for most of the commonly used functionality in the platform. It is structured in a way to make the discovery of the capabilities very easy, especially with IntelliSense. You would just type grok., then select the most appropriate choice the IntelliSense gives you, and so on. For instance, let’s imagine that you want to construct a dataframe from a CSV file. You would see the following choices after you typed grok.: [shell, chem, data, data, ml]. What we want to do it related to data, so we would type grok.data and see the following choices: [demo, query, compareTables, parseCsv, upload]. Obviously, we should choose parseCsv; when we select it, IntelliSense will help us with the parameters as well. This is the preferred way for using the API for both ad-hoc scripting and more complex development, since the resulting code is streamlined and easily readable. However, in cases where the fluent API does not cover your particular use case, or sometimes for performance reasons, you will need to work with classes from the DG namespace.

UI

Building a UI is a special form of programming, and many languages were invented for that purpose only (HTML, XAML, JSX) . We have prioritized the following aspects when choosing our approach: simplicity, discoverability, readability.

ui.dialog('Windows')
  .add(ui.span(['People of Earth, your attention, please… ']))
  .onOK(() => { grok.shell.info('OK!'); })
  .show();

DG

Check out JS API Class Reference

Shell

Datarok visual shell is used to get access to top-level views, tables, methods, and platform states.

Learn more here: Datagrok Shell reference

Data manipulation

Dataframe

Use DataFrame, Column , ColumnList, and Row classes for table manipulation.

demog = grok.testData('demog', 5000);
demog.cols.remove('sex');
foo = demog.cols.addNew('foo', 'int');
demog.rows.removeAt(1, 3);
demog.rows.insertAt(2, 2);
demog.rows.addNew(['Spiderman', 'studyX', 'NYC', 32, 'Spider', 'Net', new Date(2020), 180, 80, 666]);
demog.rows.addNew().subj = 'Iron Man';

// alternative ways of setting values
foo.set(1, 777);
demog.set('age', 1, 44);

BitSet

Each DataFrame is associated with two bitsets: selection and filter.

// bit set (same applies to filter)
demog.selection.invert();
demog.selection.set(5, false);
demog.selection.findNext(0, false);

DataFrame code snippets:

Views

Control views via the following methods:

grok.shell.addTableView(table);

Dock an arbitrary visual element in a platform:

let e = document.createElement('DIV');
e.innerText = 'This element has been created in JavaScript';
grok.shell.dockElement(e, 'JS', 'left', 0.5);

Registering functions

Pretty much anything in Datagrok is a function, it is a concept that connects together scripts written in different languages, predictive models, statistical functions, query transformations, data flows, and many other features.

The following code registers a "jsConcat" function that becomes a first-class citizen in the platform (i.e., it can be used from console, gets registered in help, there could be an optional audit trail associated with the invocations, etc)

To test the newly registered function, enter "jsConcat(42, 33)" in the Console.

grok.functions.register({
    signature: 'String jsConcat(int foo, int bar)',
    run: (foo, bar) => `${foo}_${bar}`});

The code below registers two functions, "jsWidget" and "jsSuggestCountryName". To test jsWidget, create a new Dashboard, and click on "Widget" under "Widgets".

grok.functions.register({
    signature: 'Widget jsWidget()',
    tags: 'Widgets',
    run: function() {
        let e = document.createElement('DIV');
        function update() {
            let date = new Date();
            e.innerText = date.toTimeString();
        }
        window.setTimeout(update, 1000);

        return new ui.Widget(e);
    }});

grok.functions.register({
  signature: 'List<String> jsSuggestCountryName(String text)',
  isAsync: true,
  run: async function(text) {
    let response = await fetch('https://restcountries.eu/rest/v2/name/' + text);
    return response.status === 200 ? (await response.json()).map(country => country['name']) : [];
  }
});

Internally, JavaScript-based applications are functions that are annotated accordingly.

Code snippets:

Events

We are exposing events coming out of the platform as a stream via the Rx.JS library that makes it easy to compose asynchronous or callback-based code. The API makes easy to subscribe to either global, or instance-related events:

   // global event when user changes the current project
   grok.events.onCurrentProjectChanged.subscribe(_ =>
       grok.shell.info(`Current project changed: ${grok.shell.project.name}`));

   // subscribing to DataFrame events
   demog = grok.data.testData('demog', 5000);
   demog.onValuesChanged.subscribe((_) => grok.shell.info('values changed'));

Event-related code snippets:

To figure out what events are coming out of the platform, use the Inspector tool. Open it (Alt+I), go to the "Client Log" tab, and perform the action that you want to intercept. In the panel, you will see one or more of the events, click on them to inspect event parameters. To simplify the development process, we also generate JavaScript code for handling this particular event, copy-paste it from the property panel into your code if needed.

inspector-events

User-defined types

Define your own classes, and integrate them easily by providing a meta-class that extends DG.EntityMeta. This will provide native support for context actions, rendering, drag-and drop, tooltips, and favorites.

Code snippets:

Docking

The platform provides full support for docking windows.

grok.shell.dockManager.dock(ui.divText('first'), DG.DOCK_TYPE.RIGHT, null, 'First');

Docking code snippets:

REST API

Use grok.dapi entry point for managing server-based objects, such as datasets, connection, users, credentials, jobs, packages, etc.

See also HttpDataSource subclasses.

Code snippets:

Machine learning

Use grok.ml entry point for machine learning-related routines.

Code snippets:

Cheminformatics

Use grok.chem entry point for cheminformatics-related routines.

Code snippets:

Videos

JS API

See also: