nuxeo-development-framework 4.4.0 → 4.4.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/bundles/nuxeo-development-framework.umd.js +1 -1
- package/bundles/nuxeo-development-framework.umd.js.map +1 -1
- package/esm2015/lib/components/charts/components/data-chart.component.js +2 -2
- package/fesm2015/nuxeo-development-framework.js +1 -1
- package/fesm2015/nuxeo-development-framework.js.map +1 -1
- package/package.json +2 -2
|
@@ -84,7 +84,7 @@ export class DataChartComponent extends BaseChartComponent {
|
|
|
84
84
|
_labels.add(item.key);
|
|
85
85
|
return item.docCount;
|
|
86
86
|
});
|
|
87
|
-
return Object.assign(Object.assign(Object.assign({ label: (meta === null || meta === void 0 ? void 0 : meta.label) || '', backgroundColor: [...metaColors, ...defaultColors, ...randomColors], borderWidth: 0 }, baseDataset), metaDataset), { data: data });
|
|
87
|
+
return Object.assign(Object.assign(Object.assign({ label: (meta === null || meta === void 0 ? void 0 : meta.label) ? this._translateService.instant(meta === null || meta === void 0 ? void 0 : meta.label) : '', backgroundColor: [...metaColors, ...defaultColors, ...randomColors], borderWidth: 0 }, baseDataset), metaDataset), { data: data });
|
|
88
88
|
});
|
|
89
89
|
return {
|
|
90
90
|
labels: Array.from(_labels.values()),
|
|
@@ -166,4 +166,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
166
166
|
}], onDataReady: [{
|
|
167
167
|
type: Output
|
|
168
168
|
}] } });
|
|
169
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-chart.component.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/charts/components/data-chart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output\r\n} from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { ChartData, ChartDataset, ChartType, Color } from 'chart.js';\r\nimport _ from 'lodash';\r\nimport { BehaviorSubject, forkJoin, Observable, of } from 'rxjs';\r\nimport {\r\n  distinctUntilChanged,\r\n  filter,\r\n  finalize,\r\n  map,\r\n  switchMap,\r\n  takeUntil,\r\n} from 'rxjs/operators';\r\nimport { CHART_MAIN_COLOR, COLORS_COUNT } from '../chart.const';\r\nimport {\r\n  CustomChartOptions,\r\n  DataSourceConfig,\r\n  DataSourceResult,\r\n  StatisticBucket,\r\n  StatisticRequestConfig,\r\n} from '../models';\r\nimport { StatisticService } from '../services';\r\nimport { createColorVariants, isObject } from '../utility';\r\nimport { BaseChartComponent } from './base-chart.component';\r\n\r\n@Component({\r\n  selector: 'app-data-chart',\r\n  template: `\r\n    <app-chart\r\n      *ngIf=\"chartData$ | async as data\"\r\n      [type]=\"type\"\r\n      [data]=\"data\"\r\n      [options]=\"options\"\r\n      [plugins]=\"plugins\"\r\n      [width]=\"width\"\r\n      [height]=\"height\"\r\n      [legend]=\"legend\"\r\n      [fontFamily]=\"fontFamily\"\r\n      [fontSize]=\"fontSize\"\r\n      [responsive]=\"responsive\"\r\n      (onReady)=\"onReady.emit($event)\"\r\n    ></app-chart>\r\n  `,\r\n  styles: [],\r\n})\r\nexport class DataChartComponent<TType extends ChartType>\r\n  extends BaseChartComponent<TType>\r\n  implements OnInit\r\n{\r\n  private _dataSource: DataSourceConfig<TType>;\r\n  @Input() set dataSource(obj) {\r\n    const isEqual = _.isEqual(obj, this._dataSource);\r\n    this._dataSource = obj;\r\n    if (obj && !isEqual && this._isInitialized) {\r\n      this._rebuildDataSub.next({});\r\n    }\r\n  }\r\n\r\n  get dataSource() {\r\n    return this._dataSource;\r\n  }\r\n\r\n  @Input() options: CustomChartOptions<TType>;\r\n\r\n  @Input() dataset: Omit<ChartDataset<TType>, 'data'>;\r\n\r\n  @Input() translatePrefix = 'STATISTICS';\r\n\r\n  @Input() bindValue: string;\r\n\r\n  @Input() colors: Color[];\r\n\r\n  @Input() updateOnLangChange = true;\r\n\r\n  @Input() set updateData(params: Record<string, any>) {\r\n    this._rebuildDataSub.next(_.isObject(params) ? params : {});\r\n  }\r\n\r\n  @Input() transformData: (data: DataSourceResult<TType>[]) => ChartData<TType>;\r\n\r\n  @Output() onDataReady = new EventEmitter<DataSourceResult<TType>[]>();\r\n\r\n  chartData$: Observable<ChartData>;\r\n\r\n  private _rebuildDataSub = new BehaviorSubject<Record<string, any>>(null);\r\n  private _rebuildTrigger$ = this._rebuildDataSub.asObservable();\r\n  private _isInitialized = false;\r\n\r\n  private readonly _defaultParams = {\r\n    pageSize: 1,\r\n  };\r\n\r\n  constructor(\r\n    private _translateService: TranslateService,\r\n    private _statisticService: StatisticService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this._statisticService.prepareConfig({\r\n      translatePrefix: this.translatePrefix,\r\n      bindValue: this.bindValue,\r\n    });\r\n\r\n    this.chartData$ = this._rebuildTrigger$.pipe(\r\n      filter(Boolean),\r\n      switchMap((params) => this._preparedData(params))\r\n    );\r\n    this._subscribeToLanguage();\r\n  }\r\n\r\n  private _subscribeToLanguage() {\r\n    this._translateService.onLangChange\r\n      .pipe(\r\n        distinctUntilChanged((pre, next) => pre.lang == next.lang),\r\n        filter(() => this._isInitialized && this.updateOnLangChange),\r\n        takeUntil(this.destroy$)\r\n      )\r\n      .subscribe((_) => {\r\n        this._rebuildDataSub.next({});\r\n      });\r\n  }\r\n\r\n  private _preparedData(params: Record<string, any> = {}) {\r\n    const dataSources$ = this.dataSource.map((dataSource) => {\r\n      const _observables$ = dataSource.config.map((config) =>\r\n        this._fetchStatistic(config, params)\r\n      );\r\n      return forkJoin({\r\n        results: forkJoin(_observables$).pipe(\r\n          map((results) => results.reduce((acc, curr) => acc.concat(curr), []))\r\n        ),\r\n        meta: of({\r\n          label: dataSource.label,\r\n          dataset: dataSource.dataset,\r\n          colors: dataSource.colors,\r\n        }),\r\n      }).pipe(\r\n        finalize(() => {\r\n          this._isInitialized = true;\r\n        })\r\n      ) as Observable<DataSourceResult<TType>>;\r\n    });\r\n\r\n    return forkJoin(dataSources$).pipe(\r\n      map((res) => {\r\n        this.onDataReady.emit(res);\r\n        return this.transformData ? this.transformData(res) : this._prepareChartData(res);\r\n      })\r\n    );\r\n  }\r\n\r\n  private _prepareChartData(res: DataSourceResult<TType>[]): ChartData<ChartType> {\r\n    const _labels = new Set<string>();\r\n\r\n    const _datasets = res.map(({ results, meta }) => {\r\n      const baseDataset = isObject<TType>(this.dataset) ? this.dataset : {};\r\n      const metaDataset = isObject<TType>(meta?.dataset) ? meta.dataset : {};\r\n\r\n      const metaColors = Array.isArray(meta?.colors) ? meta?.colors : [];\r\n      const defaultColors = Array.isArray(this?.colors) ? this.colors : [];\r\n      const randomColors =\r\n        !meta?.colors && !this.colors ? this._generateColors(COLORS_COUNT) : [];\r\n\r\n      const data = results.map((item) => {\r\n        _labels.add(item.key);\r\n        return item.docCount;\r\n      });\r\n\r\n      return {\r\n        label: meta?.label || '',\r\n        backgroundColor: [...metaColors, ...defaultColors, ...randomColors],\r\n        borderWidth: 0,\r\n        ...baseDataset,\r\n        ...metaDataset,\r\n        data: data,\r\n      };\r\n    });\r\n\r\n    return {\r\n      labels: Array.from(_labels.values()),\r\n      datasets: _datasets,\r\n    };\r\n  }\r\n\r\n  private _fetchStatistic(\r\n    config: StatisticRequestConfig,\r\n    overridesParams: Record<string, any> = {}\r\n  ): Observable<StatisticBucket[]> {\r\n    const _params = Object.assign(\r\n      {},\r\n      this._defaultParams,\r\n      config?.params || {},\r\n      overridesParams\r\n    );\r\n\r\n    return this._translateService\r\n      .get(this.translatePrefix || 'STATISTICS')\r\n      .pipe(switchMap((_) => this._statisticService.prepareStatistic(config, _params)));\r\n  }\r\n\r\n  private _generateColors(length: number) {\r\n    const color = this._getMainColor() || CHART_MAIN_COLOR;\r\n    return [].concat(\r\n      createColorVariants(color, length, 'shade'),\r\n      createColorVariants(color, length, 'tint')\r\n    );\r\n  }\r\n\r\n  private _getMainColor(cssVar = '--main-color') {\r\n    const root = document.documentElement;\r\n    return getComputedStyle(root).getPropertyValue(cssVar).trim();\r\n  }\r\n}\r\n"]}
|
|
169
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-chart.component.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/charts/components/data-chart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output\r\n} from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { ChartData, ChartDataset, ChartType, Color } from 'chart.js';\r\nimport _ from 'lodash';\r\nimport { BehaviorSubject, forkJoin, Observable, of } from 'rxjs';\r\nimport {\r\n  distinctUntilChanged,\r\n  filter,\r\n  finalize,\r\n  map,\r\n  switchMap,\r\n  takeUntil,\r\n} from 'rxjs/operators';\r\nimport { CHART_MAIN_COLOR, COLORS_COUNT } from '../chart.const';\r\nimport {\r\n  CustomChartOptions,\r\n  DataSourceConfig,\r\n  DataSourceResult,\r\n  StatisticBucket,\r\n  StatisticRequestConfig,\r\n} from '../models';\r\nimport { StatisticService } from '../services';\r\nimport { createColorVariants, isObject } from '../utility';\r\nimport { BaseChartComponent } from './base-chart.component';\r\n\r\n@Component({\r\n  selector: 'app-data-chart',\r\n  template: `\r\n    <app-chart\r\n      *ngIf=\"chartData$ | async as data\"\r\n      [type]=\"type\"\r\n      [data]=\"data\"\r\n      [options]=\"options\"\r\n      [plugins]=\"plugins\"\r\n      [width]=\"width\"\r\n      [height]=\"height\"\r\n      [legend]=\"legend\"\r\n      [fontFamily]=\"fontFamily\"\r\n      [fontSize]=\"fontSize\"\r\n      [responsive]=\"responsive\"\r\n      (onReady)=\"onReady.emit($event)\"\r\n    ></app-chart>\r\n  `,\r\n  styles: [],\r\n})\r\nexport class DataChartComponent<TType extends ChartType>\r\n  extends BaseChartComponent<TType>\r\n  implements OnInit\r\n{\r\n  private _dataSource: DataSourceConfig<TType>;\r\n  @Input() set dataSource(obj) {\r\n    const isEqual = _.isEqual(obj, this._dataSource);\r\n    this._dataSource = obj;\r\n    if (obj && !isEqual && this._isInitialized) {\r\n      this._rebuildDataSub.next({});\r\n    }\r\n  }\r\n\r\n  get dataSource() {\r\n    return this._dataSource;\r\n  }\r\n\r\n  @Input() options: CustomChartOptions<TType>;\r\n\r\n  @Input() dataset: Omit<ChartDataset<TType>, 'data'>;\r\n\r\n  @Input() translatePrefix = 'STATISTICS';\r\n\r\n  @Input() bindValue: string;\r\n\r\n  @Input() colors: Color[];\r\n\r\n  @Input() updateOnLangChange = true;\r\n\r\n  @Input() set updateData(params: Record<string, any>) {\r\n    this._rebuildDataSub.next(_.isObject(params) ? params : {});\r\n  }\r\n\r\n  @Input() transformData: (data: DataSourceResult<TType>[]) => ChartData<TType>;\r\n\r\n  @Output() onDataReady = new EventEmitter<DataSourceResult<TType>[]>();\r\n\r\n  chartData$: Observable<ChartData>;\r\n\r\n  private _rebuildDataSub = new BehaviorSubject<Record<string, any>>(null);\r\n  private _rebuildTrigger$ = this._rebuildDataSub.asObservable();\r\n  private _isInitialized = false;\r\n\r\n  private readonly _defaultParams = {\r\n    pageSize: 1,\r\n  };\r\n\r\n  constructor(\r\n    private _translateService: TranslateService,\r\n    private _statisticService: StatisticService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this._statisticService.prepareConfig({\r\n      translatePrefix: this.translatePrefix,\r\n      bindValue: this.bindValue,\r\n    });\r\n\r\n    this.chartData$ = this._rebuildTrigger$.pipe(\r\n      filter(Boolean),\r\n      switchMap((params) => this._preparedData(params))\r\n    );\r\n    this._subscribeToLanguage();\r\n  }\r\n\r\n  private _subscribeToLanguage() {\r\n    this._translateService.onLangChange\r\n      .pipe(\r\n        distinctUntilChanged((pre, next) => pre.lang == next.lang),\r\n        filter(() => this._isInitialized && this.updateOnLangChange),\r\n        takeUntil(this.destroy$)\r\n      )\r\n      .subscribe((_) => {\r\n        this._rebuildDataSub.next({});\r\n      });\r\n  }\r\n\r\n  private _preparedData(params: Record<string, any> = {}) {\r\n    const dataSources$ = this.dataSource.map((dataSource) => {\r\n      const _observables$ = dataSource.config.map((config) =>\r\n        this._fetchStatistic(config, params)\r\n      );\r\n      return forkJoin({\r\n        results: forkJoin(_observables$).pipe(\r\n          map((results) => results.reduce((acc, curr) => acc.concat(curr), []))\r\n        ),\r\n        meta: of({\r\n          label: dataSource.label,\r\n          dataset: dataSource.dataset,\r\n          colors: dataSource.colors,\r\n        }),\r\n      }).pipe(\r\n        finalize(() => {\r\n          this._isInitialized = true;\r\n        })\r\n      ) as Observable<DataSourceResult<TType>>;\r\n    });\r\n\r\n    return forkJoin(dataSources$).pipe(\r\n      map((res) => {\r\n        this.onDataReady.emit(res);\r\n        return this.transformData ? this.transformData(res) : this._prepareChartData(res);\r\n      })\r\n    );\r\n  }\r\n\r\n  private _prepareChartData(res: DataSourceResult<TType>[]): ChartData<ChartType> {\r\n    const _labels = new Set<string>();\r\n\r\n    const _datasets = res.map(({ results, meta }) => {\r\n      const baseDataset = isObject<TType>(this.dataset) ? this.dataset : {};\r\n      const metaDataset = isObject<TType>(meta?.dataset) ? meta.dataset : {};\r\n\r\n      const metaColors = Array.isArray(meta?.colors) ? meta?.colors : [];\r\n      const defaultColors = Array.isArray(this?.colors) ? this.colors : [];\r\n      const randomColors =\r\n        !meta?.colors && !this.colors ? this._generateColors(COLORS_COUNT) : [];\r\n\r\n      const data = results.map((item) => {\r\n        _labels.add(item.key);\r\n        return item.docCount;\r\n      });\r\n\r\n      return {\r\n        label: meta?.label ? this._translateService.instant(meta?.label) :  '',\r\n        backgroundColor: [...metaColors, ...defaultColors, ...randomColors],\r\n        borderWidth: 0,\r\n        ...baseDataset,\r\n        ...metaDataset,\r\n        data: data,\r\n      };\r\n    });\r\n\r\n    return {\r\n      labels: Array.from(_labels.values()),\r\n      datasets: _datasets,\r\n    };\r\n  }\r\n\r\n  private _fetchStatistic(\r\n    config: StatisticRequestConfig,\r\n    overridesParams: Record<string, any> = {}\r\n  ): Observable<StatisticBucket[]> {\r\n    const _params = Object.assign(\r\n      {},\r\n      this._defaultParams,\r\n      config?.params || {},\r\n      overridesParams\r\n    );\r\n\r\n    return this._translateService\r\n      .get(this.translatePrefix || 'STATISTICS')\r\n      .pipe(switchMap((_) => this._statisticService.prepareStatistic(config, _params)));\r\n  }\r\n\r\n  private _generateColors(length: number) {\r\n    const color = this._getMainColor() || CHART_MAIN_COLOR;\r\n    return [].concat(\r\n      createColorVariants(color, length, 'shade'),\r\n      createColorVariants(color, length, 'tint')\r\n    );\r\n  }\r\n\r\n  private _getMainColor(cssVar = '--main-color') {\r\n    const root = document.documentElement;\r\n    return getComputedStyle(root).getPropertyValue(cssVar).trim();\r\n  }\r\n}\r\n"]}
|
|
@@ -33284,7 +33284,7 @@ class DataChartComponent extends BaseChartComponent {
|
|
|
33284
33284
|
_labels.add(item.key);
|
|
33285
33285
|
return item.docCount;
|
|
33286
33286
|
});
|
|
33287
|
-
return Object.assign(Object.assign(Object.assign({ label: (meta === null || meta === void 0 ? void 0 : meta.label) || '', backgroundColor: [...metaColors, ...defaultColors, ...randomColors], borderWidth: 0 }, baseDataset), metaDataset), { data: data });
|
|
33287
|
+
return Object.assign(Object.assign(Object.assign({ label: (meta === null || meta === void 0 ? void 0 : meta.label) ? this._translateService.instant(meta === null || meta === void 0 ? void 0 : meta.label) : '', backgroundColor: [...metaColors, ...defaultColors, ...randomColors], borderWidth: 0 }, baseDataset), metaDataset), { data: data });
|
|
33288
33288
|
});
|
|
33289
33289
|
return {
|
|
33290
33290
|
labels: Array.from(_labels.values()),
|