@datagrok-libraries/statistics 1.10.0 → 1.12.0

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.
@@ -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,46 @@
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
+ drawBars(values?: number[]): void;
40
+ private enableCurveDrag;
41
+ private addSpecialHandle;
42
+ private showPointEditor;
43
+ setRange(min: number, max: number): void;
44
+ setColumn(col: DG.Column | null): void;
45
+ }
46
+ //# 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,iBAAY;IAChB,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;IAkPvB,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,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"}