@datagrok-libraries/statistics 1.10.0 → 1.12.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +5 -0
- package/css/styles.css +234 -0
- package/package.json +3 -2
- package/src/mpo/dialogs/desirability-mode-dialog.d.ts +14 -0
- package/src/mpo/dialogs/desirability-mode-dialog.d.ts.map +1 -0
- package/src/mpo/dialogs/desirability-mode-dialog.js +198 -0
- package/src/mpo/editors/desirability-editor-factory.d.ts +16 -0
- package/src/mpo/editors/desirability-editor-factory.d.ts.map +1 -0
- package/src/mpo/editors/desirability-editor-factory.js +11 -0
- package/src/mpo/editors/mpo-categorical-editor.d.ts +24 -0
- package/src/mpo/editors/mpo-categorical-editor.d.ts.map +1 -0
- package/src/mpo/editors/mpo-categorical-editor.js +113 -0
- package/src/mpo/editors/mpo-line-editor.d.ts +47 -0
- package/src/mpo/editors/mpo-line-editor.d.ts.map +1 -0
- package/src/mpo/editors/mpo-line-editor.js +600 -0
- package/src/mpo/mpo-profile-editor.d.ts +42 -6
- package/src/mpo/mpo-profile-editor.d.ts.map +1 -1
- package/src/mpo/mpo-profile-editor.js +369 -59
- package/src/mpo/mpo.d.ts +53 -3
- package/src/mpo/mpo.d.ts.map +1 -1
- package/src/mpo/mpo.js +92 -16
- package/src/mpo/utils.d.ts +6 -0
- package/src/mpo/utils.d.ts.map +1 -0
- package/src/mpo/utils.js +17 -0
- package/src/mpo/mpo-line-editor.d.ts +0 -10
- package/src/mpo/mpo-line-editor.d.ts.map +0 -1
- package/src/mpo/mpo-line-editor.js +0 -258
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import * as ui from 'datagrok-api/ui';
|
|
2
|
+
import { Subject } from 'rxjs';
|
|
3
|
+
export class MpoCategoricalEditor {
|
|
4
|
+
constructor(prop, design = false, showControls = false) {
|
|
5
|
+
this.onChanged = new Subject();
|
|
6
|
+
this.supportsModeDialog = true;
|
|
7
|
+
this.desirabilityInputs = [];
|
|
8
|
+
this.form = null;
|
|
9
|
+
this.columnCategories = null;
|
|
10
|
+
this._prop = prop;
|
|
11
|
+
this.design = design;
|
|
12
|
+
this.showControls = showControls;
|
|
13
|
+
this.root = ui.divV([], 'statistics-mpo-cat-editor');
|
|
14
|
+
this.buildForm();
|
|
15
|
+
}
|
|
16
|
+
buildForm() {
|
|
17
|
+
var _a;
|
|
18
|
+
const categories = (_a = this._prop.categories) !== null && _a !== void 0 ? _a : [];
|
|
19
|
+
if (this.form) {
|
|
20
|
+
ui.empty(this.root);
|
|
21
|
+
this.form = null;
|
|
22
|
+
this.desirabilityInputs = [];
|
|
23
|
+
}
|
|
24
|
+
if (this.design)
|
|
25
|
+
this.buildDesignForm(categories);
|
|
26
|
+
else
|
|
27
|
+
this.buildViewForm(categories);
|
|
28
|
+
}
|
|
29
|
+
createDesirabilityInput(label, cat) {
|
|
30
|
+
var _a;
|
|
31
|
+
const input = ui.input.float(label, { value: (_a = cat.desirability) !== null && _a !== void 0 ? _a : 0.5, min: 0, max: 1, format: '#0.000',
|
|
32
|
+
onValueChanged: (value) => {
|
|
33
|
+
cat.desirability = value;
|
|
34
|
+
this.onChanged.next(this._prop);
|
|
35
|
+
},
|
|
36
|
+
});
|
|
37
|
+
this.desirabilityInputs.push(input);
|
|
38
|
+
return input;
|
|
39
|
+
}
|
|
40
|
+
buildViewForm(categories) {
|
|
41
|
+
for (const cat of categories)
|
|
42
|
+
this.createDesirabilityInput(cat.name, cat);
|
|
43
|
+
this.form = ui.form(this.desirabilityInputs);
|
|
44
|
+
this.root.append(this.form);
|
|
45
|
+
}
|
|
46
|
+
buildDesignForm(categories) {
|
|
47
|
+
const header = ui.divH([
|
|
48
|
+
ui.divText('Name', 'statistics-mpo-cat-col-header statistics-mpo-cat-name'),
|
|
49
|
+
ui.divText('Score', 'statistics-mpo-cat-col-header statistics-mpo-cat-desirability'),
|
|
50
|
+
...(this.showControls ? [ui.div([], { style: { width: '40px' } })] : []),
|
|
51
|
+
], 'statistics-mpo-cat-row statistics-mpo-cat-header-row');
|
|
52
|
+
const rows = categories.map((cat, idx) => this.buildCategoryRow(cat, idx));
|
|
53
|
+
this.form = ui.divV([header, ...rows]);
|
|
54
|
+
this.root.append(this.form);
|
|
55
|
+
}
|
|
56
|
+
buildCategoryRow(cat, idx) {
|
|
57
|
+
const nameInput = this.columnCategories ?
|
|
58
|
+
ui.input.choice('', { items: this.columnCategories, nullable: true, value: cat.name || null,
|
|
59
|
+
onValueChanged: (v) => {
|
|
60
|
+
cat.name = v !== null && v !== void 0 ? v : '';
|
|
61
|
+
this.onChanged.next(this._prop);
|
|
62
|
+
},
|
|
63
|
+
}) :
|
|
64
|
+
ui.input.string('', { value: cat.name, onValueChanged: (v) => {
|
|
65
|
+
cat.name = v;
|
|
66
|
+
this.onChanged.next(this._prop);
|
|
67
|
+
} });
|
|
68
|
+
nameInput.root.classList.add('statistics-mpo-cat-name');
|
|
69
|
+
const desInput = this.createDesirabilityInput('', cat);
|
|
70
|
+
desInput.root.classList.add('statistics-mpo-cat-desirability');
|
|
71
|
+
const elements = [nameInput.root, desInput.root];
|
|
72
|
+
if (this.showControls) {
|
|
73
|
+
const add = ui.icons.add(() => {
|
|
74
|
+
const newCat = { name: this.columnCategories ? '' : `Category ${this._prop.categories.length + 1}`, desirability: 1 };
|
|
75
|
+
this._prop.categories.splice(idx + 1, 0, newCat);
|
|
76
|
+
this.buildForm();
|
|
77
|
+
this.onChanged.next(this._prop);
|
|
78
|
+
});
|
|
79
|
+
const del = ui.icons.delete(() => {
|
|
80
|
+
this._prop.categories.splice(idx, 1);
|
|
81
|
+
this.buildForm();
|
|
82
|
+
this.onChanged.next(this._prop);
|
|
83
|
+
});
|
|
84
|
+
elements.push(ui.divH([add, del], 'statistics-mpo-control-buttons'));
|
|
85
|
+
}
|
|
86
|
+
return ui.divH(elements, 'statistics-mpo-cat-row');
|
|
87
|
+
}
|
|
88
|
+
redrawAll(notify = true) {
|
|
89
|
+
this.buildForm();
|
|
90
|
+
if (notify)
|
|
91
|
+
this.onChanged.next(this._prop);
|
|
92
|
+
}
|
|
93
|
+
setChoices(choices) {
|
|
94
|
+
this.columnCategories = choices;
|
|
95
|
+
this.buildForm();
|
|
96
|
+
}
|
|
97
|
+
setColumn(col) {
|
|
98
|
+
var _a, _b;
|
|
99
|
+
if (!col)
|
|
100
|
+
return;
|
|
101
|
+
this.columnCategories = col.isCategorical ? [...col.categories] : null;
|
|
102
|
+
const existing = new Map((_b = (_a = this._prop.categories) === null || _a === void 0 ? void 0 : _a.map((c) => [c.name, c.desirability])) !== null && _b !== void 0 ? _b : []);
|
|
103
|
+
this._prop.categories = col.categories.map((c) => {
|
|
104
|
+
var _a;
|
|
105
|
+
return ({
|
|
106
|
+
name: c,
|
|
107
|
+
desirability: (_a = existing.get(c)) !== null && _a !== void 0 ? _a : 1,
|
|
108
|
+
});
|
|
109
|
+
});
|
|
110
|
+
this.buildForm();
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mpo-categorical-editor.js","sourceRoot":"","sources":["mpo-categorical-editor.ts"],"names":[],"mappings":"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","sourcesContent":["import * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\n\nimport {Subject} from 'rxjs';\nimport {CategoricalDesirability} from '../mpo';\n\nexport class MpoCategoricalEditor {\n  root: HTMLDivElement;\n  onChanged = new Subject<CategoricalDesirability>();\n  supportsModeDialog: boolean = true;\n\n  private _prop: CategoricalDesirability;\n  private design: boolean;\n  private showControls: boolean;\n  private desirabilityInputs: DG.InputBase[] = [];\n  private form: HTMLElement | null = null;\n  private columnCategories: string[] | null = null;\n\n  constructor(prop: CategoricalDesirability, design = false, showControls = false) {\n    this._prop = prop;\n    this.design = design;\n    this.showControls = showControls;\n    this.root = ui.divV([], 'statistics-mpo-cat-editor');\n    this.buildForm();\n  }\n\n  private buildForm(): void {\n    const categories = this._prop.categories ?? [];\n\n    if (this.form) {\n      ui.empty(this.root);\n      this.form = null;\n      this.desirabilityInputs = [];\n    }\n\n    if (this.design)\n      this.buildDesignForm(categories);\n    else\n      this.buildViewForm(categories);\n  }\n\n  private createDesirabilityInput(\n    label: string,\n    cat: {name: string; desirability: number},\n  ): DG.InputBase {\n    const input = ui.input.float(label, {value: cat.desirability ?? 0.5, min: 0, max: 1, format: '#0.000',\n      onValueChanged: (value: number) => {\n        cat.desirability = value;\n        this.onChanged.next(this._prop);\n      },\n    });\n    this.desirabilityInputs.push(input);\n    return input;\n  }\n\n  private buildViewForm(categories: {name: string; desirability: number}[]): void {\n    for (const cat of categories)\n      this.createDesirabilityInput(cat.name, cat);\n\n    this.form = ui.form(this.desirabilityInputs);\n    this.root.append(this.form);\n  }\n\n  private buildDesignForm(categories: {name: string; desirability: number}[]): void {\n    const header = ui.divH([\n      ui.divText('Name', 'statistics-mpo-cat-col-header statistics-mpo-cat-name'),\n      ui.divText('Score', 'statistics-mpo-cat-col-header statistics-mpo-cat-desirability'),\n      ...(this.showControls ? [ui.div([], {style: {width: '40px'}})] : []),\n    ], 'statistics-mpo-cat-row statistics-mpo-cat-header-row');\n\n    const rows = categories.map((cat, idx) => this.buildCategoryRow(cat, idx));\n\n    this.form = ui.divV([header, ...rows]);\n    this.root.append(this.form);\n  }\n\n  private buildCategoryRow(\n    cat: {name: string; desirability: number},\n    idx: number,\n  ): HTMLElement {\n    const nameInput = this.columnCategories ?\n      ui.input.choice('', {items: this.columnCategories, nullable: true, value: cat.name || null,\n        onValueChanged: (v) => {\n          cat.name = v ?? '';\n          this.onChanged.next(this._prop);\n        },\n      }) :\n      ui.input.string('', {value: cat.name, onValueChanged: (v) => {\n        cat.name = v;\n        this.onChanged.next(this._prop);\n      }});\n    nameInput.root.classList.add('statistics-mpo-cat-name');\n\n    const desInput = this.createDesirabilityInput('', cat);\n    desInput.root.classList.add('statistics-mpo-cat-desirability');\n\n    const elements: HTMLElement[] = [nameInput.root, desInput.root];\n\n    if (this.showControls) {\n      const add = ui.icons.add(() => {\n        const newCat = {name: this.columnCategories ? '' : `Category ${this._prop.categories.length + 1}`, desirability: 1};\n        this._prop.categories.splice(idx + 1, 0, newCat);\n        this.buildForm();\n        this.onChanged.next(this._prop);\n      });\n\n      const del = ui.icons.delete(() => {\n        this._prop.categories.splice(idx, 1);\n        this.buildForm();\n        this.onChanged.next(this._prop);\n      });\n\n      elements.push(ui.divH([add, del], 'statistics-mpo-control-buttons'));\n    }\n\n    return ui.divH(elements, 'statistics-mpo-cat-row');\n  }\n\n  redrawAll(notify: boolean = true): void {\n    this.buildForm();\n    if (notify)\n      this.onChanged.next(this._prop);\n  }\n\n  setChoices(choices: string[]): void {\n    this.columnCategories = choices;\n    this.buildForm();\n  }\n\n  setColumn(col: DG.Column | null): void {\n    if (!col)\n      return;\n\n    this.columnCategories = col.isCategorical ? [...col.categories] : null;\n    const existing = new Map(this._prop.categories?.map((c) => [c.name, c.desirability]) ?? []);\n    this._prop.categories = col.categories.map((c: string) => ({\n      name: c,\n      desirability: existing.get(c) ?? 1,\n    }));\n    this.buildForm();\n  }\n}\n"]}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import * as DG from 'datagrok-api/dg';
|
|
2
|
+
import { DesirabilityLine, NumericalDesirability } from '../mpo';
|
|
3
|
+
import { Subject } from 'rxjs';
|
|
4
|
+
export declare class MpoDesirabilityLineEditor {
|
|
5
|
+
root: HTMLDivElement;
|
|
6
|
+
onChanged: Subject<DesirabilityLine>;
|
|
7
|
+
supportsModeDialog: boolean;
|
|
8
|
+
private _prop;
|
|
9
|
+
private barsLayer?;
|
|
10
|
+
private pendingBarValues?;
|
|
11
|
+
private stage?;
|
|
12
|
+
private layer?;
|
|
13
|
+
private konvaLine?;
|
|
14
|
+
private pointsGroup?;
|
|
15
|
+
private barValues?;
|
|
16
|
+
private redrawFn;
|
|
17
|
+
private specialHandle?;
|
|
18
|
+
onParamsChanged?: (prop: NumericalDesirability) => void;
|
|
19
|
+
private ignoreNextClick;
|
|
20
|
+
private dragScaleX;
|
|
21
|
+
private dragScaleY;
|
|
22
|
+
private _width;
|
|
23
|
+
private _height;
|
|
24
|
+
constructor(prop: NumericalDesirability, width: number, height: number);
|
|
25
|
+
private ensureDefaultLine;
|
|
26
|
+
private updateDragScales;
|
|
27
|
+
private isInPlotArea;
|
|
28
|
+
private initKonva;
|
|
29
|
+
get line(): DesirabilityLine;
|
|
30
|
+
private computeLine;
|
|
31
|
+
private drawAxes;
|
|
32
|
+
getMinX(): number;
|
|
33
|
+
getMaxX(): number;
|
|
34
|
+
getDefaultMean(): number;
|
|
35
|
+
getDefaultSigma(): number;
|
|
36
|
+
getDefaultX0(): number;
|
|
37
|
+
getDefaultK(): number;
|
|
38
|
+
redrawAll(notify?: boolean): void;
|
|
39
|
+
resize(width: number, height: number): void;
|
|
40
|
+
drawBars(values?: number[]): void;
|
|
41
|
+
private enableCurveDrag;
|
|
42
|
+
private addSpecialHandle;
|
|
43
|
+
private showPointEditor;
|
|
44
|
+
setRange(min: number, max: number): void;
|
|
45
|
+
setColumn(col: DG.Column | null): void;
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=mpo-line-editor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mpo-line-editor.d.ts","sourceRoot":"","sources":["mpo-line-editor.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAGtC,OAAO,EAAC,gBAAgB,EAAE,qBAAqB,EAAC,MAAM,QAAQ,CAAC;AAC/D,OAAO,EAAC,OAAO,EAAC,MAAM,MAAM,CAAC;AA2D7B,qBAAa,yBAAyB;IACpC,IAAI,iBAA4C;IAChD,SAAS,4BAAmC;IAC5C,kBAAkB,EAAE,OAAO,CAAQ;IAEnC,OAAO,CAAC,KAAK,CAAwB;IACrC,OAAO,CAAC,SAAS,CAAC,CAAc;IAChC,OAAO,CAAC,gBAAgB,CAAC,CAAW;IAEpC,OAAO,CAAC,KAAK,CAAC,CAAc;IAC5B,OAAO,CAAC,KAAK,CAAC,CAAc;IAE5B,OAAO,CAAC,SAAS,CAAC,CAAa;IAC/B,OAAO,CAAC,WAAW,CAAC,CAAc;IAClC,OAAO,CAAC,SAAS,CAAC,CAAW;IAE7B,OAAO,CAAC,QAAQ,CAA8B;IAE9C,OAAO,CAAC,aAAa,CAAC,CAAe;IACrC,eAAe,CAAC,EAAE,CAAC,IAAI,EAAE,qBAAqB,KAAK,IAAI,CAAC;IAGxD,OAAO,CAAC,eAAe,CAAS;IAChC,OAAO,CAAC,UAAU,CAAK;IACvB,OAAO,CAAC,UAAU,CAAK;IACvB,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,OAAO,CAAS;gBAEZ,IAAI,EAAE,qBAAqB,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM;IAYtE,OAAO,CAAC,iBAAiB;IASzB,OAAO,CAAC,gBAAgB;IAOxB,OAAO,CAAC,YAAY;YASN,SAAS;IAwPvB,IAAI,IAAI,IAAI,gBAAgB,CAE3B;IAED,OAAO,CAAC,WAAW;IAoCnB,OAAO,CAAC,QAAQ;IAkBhB,OAAO,IAAI,MAAM;IAIjB,OAAO,IAAI,MAAM;IAIjB,cAAc,IAAI,MAAM;IAIxB,eAAe,IAAI,MAAM;IAIzB,YAAY,IAAI,MAAM;IAItB,WAAW,IAAI,MAAM;IAIrB,SAAS,CAAC,MAAM,GAAE,OAAc,GAAG,IAAI;IAqBvC,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI;IAe3C,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE;IAgE1B,OAAO,CAAC,eAAe;IAoEvB,OAAO,CAAC,gBAAgB;IA2DxB,OAAO,CAAC,eAAe;IAoCvB,QAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,IAAI;IAkCxC,SAAS,CAAC,GAAG,EAAE,EAAE,CAAC,MAAM,GAAG,IAAI,GAAG,IAAI;CAOvC"}
|