diff options
| author | Eleanor Eng <eleanor_eng@brown.edu> | 2019-05-04 16:44:22 -0400 | 
|---|---|---|
| committer | Eleanor Eng <eleanor_eng@brown.edu> | 2019-05-04 16:44:40 -0400 | 
| commit | cecd09917f23fc83c87cffc4fddf5fe1f8331bac (patch) | |
| tree | ab7144d36046aaada287c2ce14d2fe7722585dce /src/client/northstar/operations/HistogramOperation.ts | |
| parent | 0bf0b028b1af8b9481e369c754277af5fb8b3fcd (diff) | |
| parent | 1ccabe155cb4f23c0aa7e37f91cd4a303008b8c7 (diff) | |
merge with master
Diffstat (limited to 'src/client/northstar/operations/HistogramOperation.ts')
| -rw-r--r-- | src/client/northstar/operations/HistogramOperation.ts | 51 | 
1 files changed, 39 insertions, 12 deletions
| diff --git a/src/client/northstar/operations/HistogramOperation.ts b/src/client/northstar/operations/HistogramOperation.ts index 760106023..5c9c832c0 100644 --- a/src/client/northstar/operations/HistogramOperation.ts +++ b/src/client/northstar/operations/HistogramOperation.ts @@ -1,7 +1,4 @@  import { action, computed, observable, trace } from "mobx"; -import { Document } from "../../../fields/Document"; -import { FieldWaiting } from "../../../fields/Field"; -import { KeyStore } from "../../../fields/KeyStore";  import { CurrentUserUtils } from "../../../server/authentication/models/current_user_utils";  import { ColumnAttributeModel } from "../core/attribute/AttributeModel";  import { AttributeTransformationModel } from "../core/attribute/AttributeTransformationModel"; @@ -16,14 +13,16 @@ import { AggregateFunction, AggregateParameters, Attribute, AverageAggregatePara  import { ModelHelpers } from "../model/ModelHelpers";  import { ArrayUtil } from "../utils/ArrayUtil";  import { BaseOperation } from "./BaseOperation"; +import { Doc } from "../../../new_fields/Doc"; +import { Cast, NumCast } from "../../../new_fields/Types";  export class HistogramOperation extends BaseOperation implements IBaseFilterConsumer, IBaseFilterProvider {      public static Empty = new HistogramOperation("-empty schema-", new AttributeTransformationModel(new ColumnAttributeModel(new Attribute())), new AttributeTransformationModel(new ColumnAttributeModel(new Attribute())), new AttributeTransformationModel(new ColumnAttributeModel(new Attribute())));      @observable public FilterOperand: FilterOperand = FilterOperand.AND; -    @observable public Links: Document[] = []; -    @observable public BrushLinks: { l: Document, b: Document }[] = []; +    @observable public Links: Doc[] = []; +    @observable public BrushLinks: { l: Doc, b: Doc }[] = [];      @observable public BrushColors: number[] = []; -    @observable public FilterModels: FilterModel[] = []; +    @observable public BarFilterModels: FilterModel[] = [];      @observable public Normalization: number = -1;      @observable public X: AttributeTransformationModel; @@ -50,17 +49,24 @@ export class HistogramOperation extends BaseOperation implements IBaseFilterCons          throw new Error("Method not implemented.");      } + +    @computed public get FilterModels() { +        return this.BarFilterModels; +    }      @action      public AddFilterModels(filterModels: FilterModel[]): void { -        filterModels.filter(f => f !== null).forEach(fm => this.FilterModels.push(fm)); +        filterModels.filter(f => f !== null).forEach(fm => this.BarFilterModels.push(fm));      }      @action      public RemoveFilterModels(filterModels: FilterModel[]): void { -        ArrayUtil.RemoveMany(this.FilterModels, filterModels); +        ArrayUtil.RemoveMany(this.BarFilterModels, filterModels);      }      @computed      public get FilterString(): string { +        if (this.OverridingFilters.length > 0) { +            return "(" + this.OverridingFilters.filter(fm => fm != null).map(fm => fm.ToPythonString()).join(" || ") + ")"; +        }          let filterModels: FilterModel[] = [];          return FilterModel.GetFilterModelsRecursive(this, new Set<IBaseFilterProvider>(), filterModels, true);      } @@ -70,15 +76,36 @@ export class HistogramOperation extends BaseOperation implements IBaseFilterCons          trace();          let brushes: string[] = [];          this.BrushLinks.map(brushLink => { -            let brushHistogram = brushLink.b.GetT(KeyStore.Data, HistogramField); -            if (brushHistogram && brushHistogram !== FieldWaiting) { +            let brushHistogram = Cast(brushLink.b.data, HistogramField); +            if (brushHistogram) {                  let filterModels: FilterModel[] = []; -                brushes.push(FilterModel.GetFilterModelsRecursive(brushHistogram.Data, new Set<IBaseFilterProvider>(), filterModels, false)); +                brushes.push(FilterModel.GetFilterModelsRecursive(brushHistogram.HistoOp, new Set<IBaseFilterProvider>(), filterModels, false));              }          });          return brushes;      } +    _stackedFilters: (FilterModel[])[] = []; +    @action +    public DrillDown(up: boolean) { +        if (!up) { +            if (!this.BarFilterModels.length) +                return; +            this._stackedFilters.push(this.BarFilterModels.map(f => f)); +            this.OverridingFilters.length = 0; +            this.OverridingFilters.push(...this._stackedFilters[this._stackedFilters.length - 1]); +            this.BarFilterModels.map(fm => fm).map(fm => this.RemoveFilterModels([fm])); +            //this.updateHistogram(); +        } else { +            this.OverridingFilters.length = 0; +            if (this._stackedFilters.length) { +                this.OverridingFilters.push(...this._stackedFilters.pop()!); +            } +            // else  +            //     this.updateHistogram(); +        } +    } +      private getAggregateParameters(histoX: AttributeTransformationModel, histoY: AttributeTransformationModel, histoValue: AttributeTransformationModel) {          let allAttributes = new Array<AttributeTransformationModel>(histoX, histoY, histoValue);          allAttributes = ArrayUtil.Distinct(allAttributes.filter(a => a.AggregateFunction !== AggregateFunction.None)); @@ -120,7 +147,7 @@ export class HistogramOperation extends BaseOperation implements IBaseFilterCons      @action      public async Update(): Promise<void> { -        this.BrushColors = this.BrushLinks.map(e => e.l.GetNumber(KeyStore.BackgroundColor, 0)); +        this.BrushColors = this.BrushLinks.map(e => NumCast(e.l.backgroundColor));          return super.Update();      }  } | 
