nuxeo-development-framework 4.4.0 → 4.4.2

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.
@@ -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"]}
@@ -69,6 +69,20 @@ export class VersionsComponent {
69
69
  showVersion(version) {
70
70
  this.viewerFilesService.updateViewer.next(version);
71
71
  }
72
+ getFileSize(version) {
73
+ let file = version.properties['file:content'] || version.properties.content;
74
+ if (file.length) {
75
+ let length = +file.length;
76
+ if (length < 1000000) {
77
+ // trnasfer to KB
78
+ return (length / 1000).toFixed(2) + 'KB';
79
+ }
80
+ else {
81
+ // transafer to MB
82
+ return (length / (1000000)).toFixed(2) + 'MB';
83
+ }
84
+ }
85
+ }
72
86
  handleAction(event) {
73
87
  this.handleActions.emit(event);
74
88
  }
@@ -77,7 +91,7 @@ export class VersionsComponent {
77
91
  }
78
92
  }
79
93
  VersionsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VersionsComponent, deps: [{ token: i1.ViewerFilesService }, { token: i2.TranslationService }, { token: i3.DocumentsService }], target: i0.ɵɵFactoryTarget.Component });
80
- VersionsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VersionsComponent, selector: "cts-versions", inputs: { selectedVersion: "selectedVersion", file: "file", actions: "actions", currentTranslation: "currentTranslation", originTranslation: "originTranslation", historyTranslation: "historyTranslation", showUserCard: "showUserCard" }, outputs: { handleActions: "handleActions" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"flex flex-col\">\r\n<div class=\"viewer-attachments\">\r\n <div class=\"subheader\">\r\n <div> {{ currentTranslation | translate }}</div>\r\n\r\n </div>\r\n <div class=\"attachments-list\">\r\n <mat-list>\r\n <div class=\"mat-list-items\">\r\n <cts-item-list [item]=\"file\" [title]=\"file.title\" [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\"\r\n [actions]=\"actions\" (itemClicked)=\"showVersion(file)\" (actionclicked)=\"handleAction($event)\">\r\n <div class=\"description\">\r\n {{getVersion(file)}}\r\n -\r\n {{ file.lastModified | localizedDate : '' : (isArabic? 'ar-AR' : 'en-US') }}\r\n </div>\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments original-section\" *ngIf=\"versions.length > 0\" >\r\n <div class=\"subheader\">\r\n <div>{{ originTranslation | translate }}</div>\r\n </div>\r\n <div class=\"attachments-list\">\r\n <mat-list>\r\n <div class=\"mat-list-items\">\r\n <cts-item-list [item]=\"versions[versions.length -1]\" [title]=\"versions[versions.length -1].title\"\r\n [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\" [actions]=\"actions\"\r\n (itemClicked)=\"showVersion(versions[versions.length -1])\" (actionclicked)=\"handleAction($event)\">\r\n\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments\" [ngClass]=\"{'viewer-attachment-with-user-card' : showUserCard}\" *permission=\"{name: 'viewVersions', entity: file}\">\r\n <div class=\"subheader\">\r\n <div> {{ historyTranslation | translate }}</div>\r\n\r\n </div>\r\n <div class=\"attachments-list\" *ngIf=\"versions.length > 0\">\r\n <ng-container>\r\n <mat-list>\r\n <div class=\"mat-list-items\" *ngFor=\"let version of versions ;let cnt = count; let i = index\">\r\n <cts-item-list [item]=\"version\" [title]=\"version.title + '-' + getVersion(version)\" [iconname]=\"'description'\"\r\n [moreclasses]=\"'text-danger'\" (itemClicked)=\"showVersion(version)\" [actions]=\"actions\" (actionclicked)=\"handleAction($event)\">\r\n <div class=\"description\">\r\n {{getVersion(version)}}\r\n -\r\n {{ version.lastModified | localizedDate : '' : (isArabic? 'ar-AR' : 'en-US') }}\r\n <span class=\"version-contributor font-weight-bold\">\r\n\r\n {{\r\n version.properties.lastContributor.id === 'system' ?\r\n ('SYSTEM_ADMIN' | translate) : (\r\n isArabic ? (version.properties.lastContributor.fullNameAr ? version.properties.lastContributor.fullNameAr : (version.properties.lastContributor.properties.firstName + \" \" + version.properties.lastContributor.properties.lastName)) : \r\n ( version.properties.lastContributor.properties.firstName + \" \" + version.properties.lastContributor.properties.lastName)\r\n )\r\n }}\r\n <div class=\"contributor-card-details\" (click)=\"$event.stopPropagation()\" *ngIf=\"showUserCard\">\r\n <div class=\"user-img\">\r\n <img class=\"user-avatar\" [src]=\"version.properties.lastContributor.avatar\">\r\n </div>\r\n <div class=\"user-details\">\r\n <div class=\"user-name\">{{isArabic ? version.properties.lastContributor.fullNameAr : version.properties.lastContributor.fullName}}</div>\r\n <div class=\"user-position\">{{(isArabic && version.properties.lastContributor.jobGradeAr) ? version.properties.lastContributor.jobGradeAr : (version.properties.lastContributor.jobGrade ? version.properties.lastContributor.jobGrade : '--')}}</div>\r\n </div>\r\n </div>\r\n </span>\r\n </div>\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </ng-container>\r\n </div>\r\n <div class=\"version-loading\" *ngIf=\"fetching\">\r\n <mat-spinner color=\"warn\" [diameter]=\"25\"></mat-spinner>\r\n </div>\r\n <div *ngIf=\"(!fetching && versions.length === 0)\">\r\n <cts-no-data></cts-no-data>\r\n </div>\r\n</div>\r\n</div>\r\n<ng-template #noEntry>\r\n\r\n</ng-template>", styles: [".viewer-attachments .attachments-list .version-contributor{position:relative}.viewer-attachments .attachments-list .version-contributor .contributor-card-details{position:absolute;z-index:99999;display:none;min-width:250px;padding:28px 16px;align-items:center;grid-gap:8px;gap:8px;border-radius:4px;background:#FFF;cursor:default;box-shadow:0 -1px 4px #1c34541a,0 1px 4px -1px #1c345426}.viewer-attachments .attachments-list .version-contributor .contributor-card-details .user-img img{width:40px;height:40px;min-width:40px;border-radius:48px;border:1px solid var(--Outline-Card, #DCDCE4)}.viewer-attachments .attachments-list .version-contributor .contributor-card-details .user-details{text-align:start}.viewer-attachments .attachments-list .version-contributor .contributor-card-details .user-details .user-name{color:#234990;font-size:14px;font-family:\"semiBoldPoppins\";font-weight:bold}.viewer-attachments .attachments-list .version-contributor .contributor-card-details .user-details .user-position{color:#5d6481;font-size:12px}.viewer-attachments .attachments-list .version-contributor:hover .contributor-card-details{display:flex}.viewer-attachments .version-loading{display:flex;justify-content:center;padding:10px 0}\n"], components: [{ type: i4.MatList, selector: "mat-list, mat-action-list", inputs: ["disableRipple", "disabled"], exportAs: ["matList"] }, { type: i5.ItemListComponent, selector: "cts-item-list", inputs: ["item", "iconname", "title", "actions", "isselected", "moreclasses"], outputs: ["itemClicked", "actionclicked"] }, { type: i6.MatSpinner, selector: "mat-spinner", inputs: ["color"] }, { type: i7.NoDataComponent, selector: "cts-no-data", inputs: ["message", "border", "img"] }], directives: [{ type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.PermissionsDirective, selector: "[permission]", inputs: ["permission"] }, { type: i8.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i10.TranslatePipe, "localizedDate": i11.LocalizedDatePipe } });
94
+ VersionsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VersionsComponent, selector: "cts-versions", inputs: { selectedVersion: "selectedVersion", file: "file", actions: "actions", currentTranslation: "currentTranslation", originTranslation: "originTranslation", historyTranslation: "historyTranslation", showUserCard: "showUserCard" }, outputs: { handleActions: "handleActions" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"flex flex-col\">\r\n<div class=\"viewer-attachments\">\r\n <div class=\"subheader\">\r\n <div> {{ currentTranslation | translate }}</div>\r\n\r\n </div>\r\n <div class=\"attachments-list\">\r\n <mat-list>\r\n <div class=\"mat-list-items\">\r\n <cts-item-list [item]=\"file\" [title]=\"file.title\" [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\"\r\n [actions]=\"actions\" (itemClicked)=\"showVersion(file)\" (actionclicked)=\"handleAction($event)\">\r\n <div class=\"description\">\r\n <div class=\"file-size\">\r\n {{ getFileSize(file)}}\r\n </div>\r\n {{getVersion(file)}}\r\n -\r\n {{ file.lastModified | localizedDate : '' : (isArabic? 'ar-AR' : 'en-US') }}\r\n </div>\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments original-section\" *ngIf=\"versions.length > 0\" >\r\n <div class=\"subheader\">\r\n <div>{{ originTranslation | translate }}</div>\r\n </div>\r\n <div class=\"attachments-list\">\r\n <mat-list>\r\n <div class=\"mat-list-items\">\r\n <cts-item-list [item]=\"versions[versions.length -1]\" [title]=\"versions[versions.length -1].title\"\r\n [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\" [actions]=\"actions\"\r\n (itemClicked)=\"showVersion(versions[versions.length -1])\" (actionclicked)=\"handleAction($event)\">\r\n\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments\" [ngClass]=\"{'viewer-attachment-with-user-card' : showUserCard}\" *permission=\"{name: 'viewVersions', entity: file}\">\r\n <div class=\"subheader\">\r\n <div> {{ historyTranslation | translate }}</div>\r\n\r\n </div>\r\n <div class=\"attachments-list\" *ngIf=\"versions.length > 0\">\r\n <ng-container>\r\n <mat-list>\r\n <div class=\"mat-list-items\" *ngFor=\"let version of versions ;let cnt = count; let i = index\">\r\n <cts-item-list [item]=\"version\" [title]=\"version.title + '-' + getVersion(version)\" [iconname]=\"'description'\"\r\n [moreclasses]=\"'text-danger'\" (itemClicked)=\"showVersion(version)\" [actions]=\"actions\" (actionclicked)=\"handleAction($event)\">\r\n <div class=\"description\">\r\n <div class=\"file-size\">\r\n {{ getFileSize(version)}}\r\n </div>\r\n {{getVersion(version)}}\r\n -\r\n {{ version.lastModified | localizedDate : '' : (isArabic? 'ar-AR' : 'en-US') }}\r\n <span class=\"version-contributor font-weight-bold\">\r\n\r\n {{\r\n version.properties.lastContributor.id === 'system' ?\r\n ('SYSTEM_ADMIN' | translate) : (\r\n isArabic ? (version.properties.lastContributor.fullNameAr ? version.properties.lastContributor.fullNameAr : (version.properties.lastContributor.properties.firstName + \" \" + version.properties.lastContributor.properties.lastName)) : \r\n ( version.properties.lastContributor.properties.firstName + \" \" + version.properties.lastContributor.properties.lastName)\r\n )\r\n }}\r\n <div class=\"contributor-card-details\" (click)=\"$event.stopPropagation()\" *ngIf=\"showUserCard\">\r\n <div class=\"user-img\">\r\n <img class=\"user-avatar\" [src]=\"version.properties.lastContributor.avatar\">\r\n </div>\r\n <div class=\"user-details\">\r\n <div class=\"user-name\">{{isArabic ? version.properties.lastContributor.fullNameAr : version.properties.lastContributor.fullName}}</div>\r\n <div class=\"user-position\">{{(isArabic && version.properties.lastContributor.jobGradeAr) ? version.properties.lastContributor.jobGradeAr : (version.properties.lastContributor.jobGrade ? version.properties.lastContributor.jobGrade : '--')}}</div>\r\n </div>\r\n </div>\r\n </span>\r\n </div>\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </ng-container>\r\n </div>\r\n <div class=\"version-loading\" *ngIf=\"fetching\">\r\n <mat-spinner color=\"warn\" [diameter]=\"25\"></mat-spinner>\r\n </div>\r\n <div *ngIf=\"(!fetching && versions.length === 0)\">\r\n <cts-no-data></cts-no-data>\r\n </div>\r\n</div>\r\n</div>\r\n<ng-template #noEntry>\r\n\r\n</ng-template>", styles: [".viewer-attachments .attachments-list .version-contributor{position:relative}.viewer-attachments .attachments-list .version-contributor .contributor-card-details{position:absolute;z-index:99999;display:none;min-width:250px;padding:28px 16px;align-items:center;grid-gap:8px;gap:8px;border-radius:4px;background:#FFF;cursor:default;box-shadow:0 -1px 4px #1c34541a,0 1px 4px -1px #1c345426}.viewer-attachments .attachments-list .version-contributor .contributor-card-details .user-img img{width:40px;height:40px;min-width:40px;border-radius:48px;border:1px solid var(--Outline-Card, #DCDCE4)}.viewer-attachments .attachments-list .version-contributor .contributor-card-details .user-details{text-align:start}.viewer-attachments .attachments-list .version-contributor .contributor-card-details .user-details .user-name{color:#234990;font-size:14px;font-family:\"semiBoldPoppins\";font-weight:bold}.viewer-attachments .attachments-list .version-contributor .contributor-card-details .user-details .user-position{color:#5d6481;font-size:12px}.viewer-attachments .attachments-list .version-contributor:hover .contributor-card-details{display:flex}.viewer-attachments .attachments-list .mat-list-items .description .file-size{display:none}.viewer-attachments .version-loading{display:flex;justify-content:center;padding:10px 0}\n"], components: [{ type: i4.MatList, selector: "mat-list, mat-action-list", inputs: ["disableRipple", "disabled"], exportAs: ["matList"] }, { type: i5.ItemListComponent, selector: "cts-item-list", inputs: ["item", "iconname", "title", "actions", "isselected", "moreclasses"], outputs: ["itemClicked", "actionclicked"] }, { type: i6.MatSpinner, selector: "mat-spinner", inputs: ["color"] }, { type: i7.NoDataComponent, selector: "cts-no-data", inputs: ["message", "border", "img"] }], directives: [{ type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.PermissionsDirective, selector: "[permission]", inputs: ["permission"] }, { type: i8.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i10.TranslatePipe, "localizedDate": i11.LocalizedDatePipe } });
81
95
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VersionsComponent, decorators: [{
82
96
  type: Component,
83
97
  args: [{
@@ -102,4 +116,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
102
116
  }], handleActions: [{
103
117
  type: Output
104
118
  }] } });
105
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"versions.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/versions/versions.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/versions/versions.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAoC,YAAY,EAAa,MAAM,eAAe,CAAC;;;;;;;;;;;;;AAOpH;;;;;;;;;;;;GAYG;AAMH,MAAM,OAAO,iBAAiB;IAuB5B,YACU,kBAAsC,EACtC,kBAAuC,EACvC,YAA8B;QAF9B,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,uBAAkB,GAAlB,kBAAkB,CAAqB;QACvC,iBAAY,GAAZ,YAAY,CAAkB;QAfxC,uBAAkB,GAAG,gBAAgB,CAAC;QAEtC,sBAAiB,GAAG,eAAe,CAAC;QAEpC,uBAAkB,GAAG,gBAAgB,CAAC;QAC7B,iBAAY,GAAG,KAAK,CAAC,CAAC,2BAA2B;QAE1D,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;QACnC,aAAQ,GAAG,EAAE,CAAC;QACd,aAAQ,GAAG,KAAK,CAAC;QAEjB,aAAQ,GAAG,KAAK,CAAC;IAMb,CAAC;IACL,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,YAAY;YAC3C,OAAO,CAAC,IAAI,CAAC,aAAa,EAAE;YAC5B,IAAI,CAAC,WAAW,EAAE,CAAC;SACpB;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,gBAAgB,GAAI,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YACzE,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAC;QACtB,CAAC,CAAC,CAAA;QACF,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,UAAU,CAAC,OAAO;QAChB,IAAI,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,CAAE,OAAO,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAE,OAAO,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7K,IAAI,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,CAAE,OAAO,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAE,OAAO,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7K,OAAO,GAAG,MAAM,IAAI,MAAM,EAAE,CAAC;IAC/B,CAAC;IACD,WAAW;QACT,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YAC9D,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YACvC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YACtB,yBAAyB;YACzB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QAExB,CAAC,EAAE,GAAG,CAAC,EAAE;YACP,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACxB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,WAAW,CAAC,OAAO;QACjB,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACrD,CAAC;IAED,YAAY,CAAC,KAAK;QAChB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAChC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;IACrE,CAAC;;+GAvEU,iBAAiB;mGAAjB,iBAAiB,kWCzB9B,o0IAyFc;4FDhED,iBAAiB;kBAL7B,SAAS;mBAAC;oBACT,QAAQ,EAAE,cAAc;oBACxB,WAAW,EAAE,2BAA2B;oBACxC,SAAS,EAAE,CAAC,2BAA2B,CAAC;iBACzC;yKAIC,eAAe;sBADd,KAAK;gBAIN,IAAI;sBADH,KAAK;gBAIN,OAAO;sBADN,KAAK;gBAGN,kBAAkB;sBADjB,KAAK;gBAGN,iBAAiB;sBADhB,KAAK;gBAGN,kBAAkB;sBADjB,KAAK;gBAEG,YAAY;sBAApB,KAAK;gBAEN,aAAa;sBADZ,MAAM","sourcesContent":["import { Component, Input, Output, OnChanges, OnInit, SimpleChanges, EventEmitter, OnDestroy } from '@angular/core';\r\nimport { DocumentsService } from '../../../documents/services/documents.service';\r\nimport { ViewerFilesService } from '../../services/viewer-files.service';\r\nimport { TranslationService } from '../../../../core/services/translation/translation.service';\r\nimport { Subscription } from 'rxjs';\r\n\r\n\r\n/**\r\n * A component that views document versions\r\n * @title\r\n * Viewer Versions\r\n *\r\n * @example\r\n *\r\n * <cts-versions\r\n *   [file]=\"file\"\r\n *   [actions]=\"menu_actions\"\r\n *   (handleActions)=\"handleActionOnVersion($event)\"\r\n * ></cts-versions>\r\n */\r\n@Component({\r\n  selector: 'cts-versions',\r\n  templateUrl: './versions.component.html',\r\n  styleUrls: ['./versions.component.scss']\r\n})\r\nexport class VersionsComponent implements OnInit, OnChanges , OnDestroy {\r\n  /** Current selected version (in viewer) */\r\n  @Input()\r\n  selectedVersion;\r\n  /** Document object */\r\n  @Input()\r\n  file;\r\n/** Actions on Version */\r\n  @Input()\r\n  actions?: string[];\r\n  @Input()\r\n  currentTranslation = 'viewer.current';\r\n  @Input()\r\n  originTranslation = 'viewer.origin';\r\n  @Input()\r\n  historyTranslation = 'viewer.history';\r\n  @Input() showUserCard = false; // flage to show user cards\r\n  @Output()\r\n  handleActions = new EventEmitter();\r\n  versions = [];\r\n  isArabic = false;\r\n  langSubscription : Subscription;\r\n  fetching = false;\r\n  constructor(\r\n    private viewerFilesService: ViewerFilesService,\r\n    private trnaslationService : TranslationService,\r\n    private documentsApi: DocumentsService\r\n\r\n  ) { }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.file && changes.file.currentValue &&\r\n      changes.file.previousValue) {\r\n      this.getVersions();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.langSubscription =  this.trnaslationService.isArabic$.subscribe(res => {\r\n      this.isArabic = res;\r\n    })\r\n    this.getVersions();\r\n  }\r\n\r\n  getVersion(version) {\r\n    let majVer = version.properties.major_version ? version.properties.major_version : ( version.properties['uid:major_version'] ?  version.properties['uid:major_version'] : 0);\r\n    let minVer = version.properties.minor_version ? version.properties.minor_version : ( version.properties['uid:minor_version'] ?  version.properties['uid:minor_version'] : 0);\r\n    return `${majVer}.${minVer}`;\r\n  }\r\n  getVersions() {\r\n    this.fetching = true;\r\n    this.documentsApi.getVersions(this.file.uid).subscribe((data) => {\r\n      this.versions = data.entries.reverse();\r\n      this.fetching = false;\r\n      // this.versions.shift();\r\n      this.fetching = false;\r\n\r\n    }, err => {\r\n      this.fetching = false;\r\n    });\r\n  }\r\n\r\n  showVersion(version) {\r\n    this.viewerFilesService.updateViewer.next(version);\r\n  }\r\n\r\n  handleAction(event) {\r\n    this.handleActions.emit(event)\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.langSubscription ? this.langSubscription.unsubscribe() : null;\r\n  }\r\n}\r\n","<div class=\"flex flex-col\">\r\n<div class=\"viewer-attachments\">\r\n  <div class=\"subheader\">\r\n    <div> {{ currentTranslation | translate }}</div>\r\n\r\n  </div>\r\n  <div class=\"attachments-list\">\r\n    <mat-list>\r\n      <div class=\"mat-list-items\">\r\n        <cts-item-list [item]=\"file\" [title]=\"file.title\" [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\"\r\n          [actions]=\"actions\" (itemClicked)=\"showVersion(file)\" (actionclicked)=\"handleAction($event)\">\r\n          <div class=\"description\">\r\n            {{getVersion(file)}}\r\n            -\r\n            {{ file.lastModified | localizedDate : '' : (isArabic? 'ar-AR' : 'en-US') }}\r\n          </div>\r\n        </cts-item-list>\r\n      </div>\r\n    </mat-list>\r\n  </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments original-section\" *ngIf=\"versions.length > 0\" >\r\n  <div class=\"subheader\">\r\n    <div>{{ originTranslation | translate }}</div>\r\n  </div>\r\n  <div class=\"attachments-list\">\r\n    <mat-list>\r\n      <div class=\"mat-list-items\">\r\n        <cts-item-list [item]=\"versions[versions.length -1]\" [title]=\"versions[versions.length -1].title\"\r\n          [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\" [actions]=\"actions\"\r\n          (itemClicked)=\"showVersion(versions[versions.length -1])\" (actionclicked)=\"handleAction($event)\">\r\n\r\n        </cts-item-list>\r\n      </div>\r\n    </mat-list>\r\n  </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments\" [ngClass]=\"{'viewer-attachment-with-user-card' : showUserCard}\" *permission=\"{name: 'viewVersions', entity: file}\">\r\n  <div class=\"subheader\">\r\n    <div> {{ historyTranslation | translate }}</div>\r\n\r\n  </div>\r\n  <div class=\"attachments-list\" *ngIf=\"versions.length > 0\">\r\n    <ng-container>\r\n     <mat-list>\r\n        <div class=\"mat-list-items\" *ngFor=\"let version of versions ;let cnt = count; let i = index\">\r\n          <cts-item-list [item]=\"version\" [title]=\"version.title + '-' + getVersion(version)\" [iconname]=\"'description'\"\r\n            [moreclasses]=\"'text-danger'\" (itemClicked)=\"showVersion(version)\" [actions]=\"actions\" (actionclicked)=\"handleAction($event)\">\r\n            <div class=\"description\">\r\n              {{getVersion(version)}}\r\n              -\r\n              {{ version.lastModified | localizedDate : '' : (isArabic? 'ar-AR' : 'en-US') }}\r\n              <span class=\"version-contributor font-weight-bold\">\r\n\r\n                {{\r\n                version.properties.lastContributor.id === 'system' ?\r\n                ('SYSTEM_ADMIN' | translate) : (\r\n                  isArabic ? (version.properties.lastContributor.fullNameAr ? version.properties.lastContributor.fullNameAr : (version.properties.lastContributor.properties.firstName + \" \" + version.properties.lastContributor.properties.lastName)) : \r\n                  ( version.properties.lastContributor.properties.firstName + \" \" + version.properties.lastContributor.properties.lastName)\r\n                )\r\n                }}\r\n                <div class=\"contributor-card-details\" (click)=\"$event.stopPropagation()\" *ngIf=\"showUserCard\">\r\n                  <div class=\"user-img\">\r\n                      <img class=\"user-avatar\" [src]=\"version.properties.lastContributor.avatar\">\r\n                  </div>\r\n                  <div class=\"user-details\">\r\n                      <div class=\"user-name\">{{isArabic  ? version.properties.lastContributor.fullNameAr : version.properties.lastContributor.fullName}}</div>\r\n                      <div class=\"user-position\">{{(isArabic && version.properties.lastContributor.jobGradeAr) ? version.properties.lastContributor.jobGradeAr : (version.properties.lastContributor.jobGrade ? version.properties.lastContributor.jobGrade : '--')}}</div>\r\n                  </div>\r\n              </div>\r\n              </span>\r\n            </div>\r\n          </cts-item-list>\r\n        </div>\r\n      </mat-list>\r\n    </ng-container>\r\n  </div>\r\n  <div class=\"version-loading\" *ngIf=\"fetching\">\r\n    <mat-spinner color=\"warn\" [diameter]=\"25\"></mat-spinner>\r\n  </div>\r\n  <div  *ngIf=\"(!fetching && versions.length === 0)\">\r\n    <cts-no-data></cts-no-data>\r\n  </div>\r\n</div>\r\n</div>\r\n<ng-template #noEntry>\r\n\r\n</ng-template>"]}
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"versions.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/versions/versions.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/versions/versions.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, OnChanges, OnInit, SimpleChanges, EventEmitter, OnDestroy } from '@angular/core';\r\nimport { DocumentsService } from '../../../documents/services/documents.service';\r\nimport { ViewerFilesService } from '../../services/viewer-files.service';\r\nimport { TranslationService } from '../../../../core/services/translation/translation.service';\r\nimport { Subscription } from 'rxjs';\r\n\r\n\r\n/**\r\n * A component that views document versions\r\n * @title\r\n * Viewer Versions\r\n *\r\n * @example\r\n *\r\n * <cts-versions\r\n *   [file]=\"file\"\r\n *   [actions]=\"menu_actions\"\r\n *   (handleActions)=\"handleActionOnVersion($event)\"\r\n * ></cts-versions>\r\n */\r\n@Component({\r\n  selector: 'cts-versions',\r\n  templateUrl: './versions.component.html',\r\n  styleUrls: ['./versions.component.scss']\r\n})\r\nexport class VersionsComponent implements OnInit, OnChanges , OnDestroy {\r\n  /** Current selected version (in viewer) */\r\n  @Input()\r\n  selectedVersion;\r\n  /** Document object */\r\n  @Input()\r\n  file;\r\n/** Actions on Version */\r\n  @Input()\r\n  actions?: string[];\r\n  @Input()\r\n  currentTranslation = 'viewer.current';\r\n  @Input()\r\n  originTranslation = 'viewer.origin';\r\n  @Input()\r\n  historyTranslation = 'viewer.history';\r\n  @Input() showUserCard = false; // flage to show user cards\r\n  @Output()\r\n  handleActions = new EventEmitter();\r\n  versions = [];\r\n  isArabic = false;\r\n  langSubscription : Subscription;\r\n  fetching = false;\r\n  constructor(\r\n    private viewerFilesService: ViewerFilesService,\r\n    private trnaslationService : TranslationService,\r\n    private documentsApi: DocumentsService\r\n\r\n  ) { }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.file && changes.file.currentValue &&\r\n      changes.file.previousValue) {\r\n      this.getVersions();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.langSubscription =  this.trnaslationService.isArabic$.subscribe(res => {\r\n      this.isArabic = res;\r\n    })\r\n    this.getVersions();\r\n  }\r\n\r\n  getVersion(version) {\r\n    let majVer = version.properties.major_version ? version.properties.major_version : ( version.properties['uid:major_version'] ?  version.properties['uid:major_version'] : 0);\r\n    let minVer = version.properties.minor_version ? version.properties.minor_version : ( version.properties['uid:minor_version'] ?  version.properties['uid:minor_version'] : 0);\r\n    return `${majVer}.${minVer}`;\r\n  }\r\n  getVersions() {\r\n    this.fetching = true;\r\n    this.documentsApi.getVersions(this.file.uid).subscribe((data) => {\r\n      this.versions = data.entries.reverse();\r\n      this.fetching = false;\r\n      // this.versions.shift();\r\n      this.fetching = false;\r\n\r\n    }, err => {\r\n      this.fetching = false;\r\n    });\r\n  }\r\n\r\n  showVersion(version) {\r\n    this.viewerFilesService.updateViewer.next(version);\r\n  }\r\n\r\n  getFileSize(version){\r\n    let file = version.properties['file:content'] || version.properties.content;\r\n    if(file.length){\r\n      let length = +file.length;\r\n      if(length < 1000000){\r\n        // trnasfer to KB\r\n        return (length/1000).toFixed(2) + 'KB'\r\n      }else{\r\n        // transafer to MB\r\n        return (length/(1000000)).toFixed(2) + 'MB'\r\n      }\r\n    }\r\n  }\r\n\r\n  handleAction(event) {\r\n    this.handleActions.emit(event)\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.langSubscription ? this.langSubscription.unsubscribe() : null;\r\n  }\r\n}\r\n","<div class=\"flex flex-col\">\r\n<div class=\"viewer-attachments\">\r\n  <div class=\"subheader\">\r\n    <div> {{ currentTranslation | translate }}</div>\r\n\r\n  </div>\r\n  <div class=\"attachments-list\">\r\n    <mat-list>\r\n      <div class=\"mat-list-items\">\r\n        <cts-item-list [item]=\"file\" [title]=\"file.title\" [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\"\r\n          [actions]=\"actions\" (itemClicked)=\"showVersion(file)\" (actionclicked)=\"handleAction($event)\">\r\n          <div class=\"description\">\r\n            <div class=\"file-size\">\r\n              {{ getFileSize(file)}}\r\n             </div>\r\n            {{getVersion(file)}}\r\n            -\r\n            {{ file.lastModified | localizedDate : '' : (isArabic? 'ar-AR' : 'en-US') }}\r\n          </div>\r\n        </cts-item-list>\r\n      </div>\r\n    </mat-list>\r\n  </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments original-section\" *ngIf=\"versions.length > 0\" >\r\n  <div class=\"subheader\">\r\n    <div>{{ originTranslation | translate }}</div>\r\n  </div>\r\n  <div class=\"attachments-list\">\r\n    <mat-list>\r\n      <div class=\"mat-list-items\">\r\n        <cts-item-list [item]=\"versions[versions.length -1]\" [title]=\"versions[versions.length -1].title\"\r\n          [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\" [actions]=\"actions\"\r\n          (itemClicked)=\"showVersion(versions[versions.length -1])\" (actionclicked)=\"handleAction($event)\">\r\n\r\n        </cts-item-list>\r\n      </div>\r\n    </mat-list>\r\n  </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments\" [ngClass]=\"{'viewer-attachment-with-user-card' : showUserCard}\" *permission=\"{name: 'viewVersions', entity: file}\">\r\n  <div class=\"subheader\">\r\n    <div> {{ historyTranslation | translate }}</div>\r\n\r\n  </div>\r\n  <div class=\"attachments-list\" *ngIf=\"versions.length > 0\">\r\n    <ng-container>\r\n     <mat-list>\r\n        <div class=\"mat-list-items\" *ngFor=\"let version of versions ;let cnt = count; let i = index\">\r\n          <cts-item-list [item]=\"version\" [title]=\"version.title + '-' + getVersion(version)\" [iconname]=\"'description'\"\r\n            [moreclasses]=\"'text-danger'\" (itemClicked)=\"showVersion(version)\" [actions]=\"actions\" (actionclicked)=\"handleAction($event)\">\r\n            <div class=\"description\">\r\n              <div class=\"file-size\">\r\n                {{ getFileSize(version)}}\r\n               </div>\r\n              {{getVersion(version)}}\r\n              -\r\n              {{ version.lastModified | localizedDate : '' : (isArabic? 'ar-AR' : 'en-US') }}\r\n              <span class=\"version-contributor font-weight-bold\">\r\n\r\n                {{\r\n                version.properties.lastContributor.id === 'system' ?\r\n                ('SYSTEM_ADMIN' | translate) : (\r\n                  isArabic ? (version.properties.lastContributor.fullNameAr ? version.properties.lastContributor.fullNameAr : (version.properties.lastContributor.properties.firstName + \" \" + version.properties.lastContributor.properties.lastName)) : \r\n                  ( version.properties.lastContributor.properties.firstName + \" \" + version.properties.lastContributor.properties.lastName)\r\n                )\r\n                }}\r\n                <div class=\"contributor-card-details\" (click)=\"$event.stopPropagation()\" *ngIf=\"showUserCard\">\r\n                  <div class=\"user-img\">\r\n                      <img class=\"user-avatar\" [src]=\"version.properties.lastContributor.avatar\">\r\n                  </div>\r\n                  <div class=\"user-details\">\r\n                      <div class=\"user-name\">{{isArabic  ? version.properties.lastContributor.fullNameAr : version.properties.lastContributor.fullName}}</div>\r\n                      <div class=\"user-position\">{{(isArabic && version.properties.lastContributor.jobGradeAr) ? version.properties.lastContributor.jobGradeAr : (version.properties.lastContributor.jobGrade ? version.properties.lastContributor.jobGrade : '--')}}</div>\r\n                  </div>\r\n              </div>\r\n              </span>\r\n            </div>\r\n          </cts-item-list>\r\n        </div>\r\n      </mat-list>\r\n    </ng-container>\r\n  </div>\r\n  <div class=\"version-loading\" *ngIf=\"fetching\">\r\n    <mat-spinner color=\"warn\" [diameter]=\"25\"></mat-spinner>\r\n  </div>\r\n  <div  *ngIf=\"(!fetching && versions.length === 0)\">\r\n    <cts-no-data></cts-no-data>\r\n  </div>\r\n</div>\r\n</div>\r\n<ng-template #noEntry>\r\n\r\n</ng-template>"]}
@@ -42,6 +42,7 @@ export class DocumentUploadComponent {
42
42
  this.minSize = 1000;
43
43
  /** Params to be sent with body when creating a document */
44
44
  this.docParams = {};
45
+ this.checkPdfContent = false;
45
46
  /** Can upload multiple files at once */
46
47
  this.multiple = false;
47
48
  /** should create document after batch upload */
@@ -75,10 +76,7 @@ export class DocumentUploadComponent {
75
76
  }
76
77
  isTypeChecked(file) {
77
78
  let arr = this.allowedTypes.split(',');
78
- if (arr.indexOf(file.type) > -1) {
79
- return true;
80
- }
81
- else if (arr.indexOf(this.getFileExtension(file.name)) > -1) {
79
+ if ((arr.indexOf(file.type) > -1) || (arr.indexOf(this.getFileExtension(file.name)) > -1)) {
82
80
  return true;
83
81
  }
84
82
  else {
@@ -101,6 +99,24 @@ export class DocumentUploadComponent {
101
99
  return false;
102
100
  }
103
101
  }
102
+ checkFileContent(file) {
103
+ if (this.checkPdfContent) {
104
+ let reader = new FileReader();
105
+ let blob = file.slice(0, 8);
106
+ reader.readAsText(blob);
107
+ reader.onload = (e) => {
108
+ var data = ((e.target.result).toString()).substr(0, 8);
109
+ var regex = new RegExp("%PDF-1.[0-7]");
110
+ if (!data.match(regex)) {
111
+ this.customToastrService.show('error', 'error', 'ERRORS.UNVALID_PDF', {}, this.allowedTypes.replace(/./gi, '').toUpperCase());
112
+ return false;
113
+ }
114
+ else {
115
+ return true;
116
+ }
117
+ };
118
+ }
119
+ }
104
120
  uploadDocument(files) {
105
121
  let selectedFiles = Object.keys(files).map(key => files[key]);
106
122
  selectedFiles = selectedFiles.filter(file => {
@@ -110,6 +126,29 @@ export class DocumentUploadComponent {
110
126
  }
111
127
  }
112
128
  });
129
+ if (selectedFiles.length) {
130
+ if (this.checkPdfContent) {
131
+ let reader = new FileReader();
132
+ let blob = files[0].slice(0, 8);
133
+ reader.readAsText(blob);
134
+ reader.onload = (e) => {
135
+ var data = ((e.target.result).toString()).substr(0, 8);
136
+ var regex = new RegExp("%PDF-1.[0-7]");
137
+ if (!data.match(regex)) {
138
+ this.customToastrService.show('error', 'error', 'ERRORS.UNVALID_PDF', {}, this.allowedTypes.replace(/./gi, '').toUpperCase());
139
+ return false;
140
+ }
141
+ else {
142
+ this.uploadFiles(selectedFiles);
143
+ }
144
+ };
145
+ }
146
+ else {
147
+ this.uploadFiles(selectedFiles);
148
+ }
149
+ }
150
+ }
151
+ uploadFiles(selectedFiles) {
113
152
  if (selectedFiles.length) {
114
153
  this.uploading = true;
115
154
  this.documentsApi.uploadBatch(selectedFiles)
@@ -145,7 +184,7 @@ export class DocumentUploadComponent {
145
184
  }
146
185
  }
147
186
  DocumentUploadComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: DocumentUploadComponent, deps: [{ token: i1.DocumentsService }, { token: i2.CustomToastrService }], target: i0.ɵɵFactoryTarget.Component });
148
- DocumentUploadComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: DocumentUploadComponent, selector: "app-document-upload", inputs: { allowedTypes: "allowedTypes", params: "params", path: "path", maxSize: "maxSize", minSize: "minSize", docParams: "docParams", multiple: "multiple", createDocument: "createDocument", allowedMaxNumberOfFiles: "allowedMaxNumberOfFiles", showAllowedTypesInErrorMess: "showAllowedTypesInErrorMess" }, outputs: { uploadSuccess: "uploadSuccess", uploadError: "uploadError" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }], ngImport: i0, template: "<input type=\"file\" class=\"hidden\" #fileInput [accept]=\"allowedTypes\" [multiple]=\"multiple\"\r\n (change)=\"uploadDocument($event.target.files)\">\r\n<div #template [ngClass]=\"{'hidden': template.childNodes.length == 0}\" (click)=\"triggerUpload()\"\r\n class=\"upload-container\">\r\n <ng-content></ng-content>\r\n</div>\r\n<div *ngIf=\"template.childNodes.length == 0\" class=\"default-upload\" (click)=\"triggerUpload()\">\r\n <div class=\"upload-section\" style=\"color:#465573;\">\r\n <mat-icon class=\"upload-icon\">upload</mat-icon>\r\n <h3 class=\"upload-title\">\r\n {{'documents.uploadDocuments'| translate }}</h3>\r\n <p class=\"upload-desc\">\r\n {{'documents.maxSize'| translate }} {{maxSize | FileSize}}</p>\r\n </div>\r\n <div>\r\n <mat-icon class=\"m-2\" style=\"color:#465573;\">file_copy</mat-icon>\r\n </div>\r\n</div>\r\n<mat-progress-bar mode=\"indeterminate\" *ngIf=\"uploading\"></mat-progress-bar>\r\n", styles: [".bi{margin:0!important}.memo-sorting-wrapper{width:265px;margin:0 10px;height:100%;display:flex}.memo-sorting-wrapper .sorting-direction{width:65px;height:40px;background-color:#465573;color:#fff;font-size:20px;display:flex;justify-content:center;align-items:center;cursor:pointer}.memo-sorting-wrapper .memo-sorting-trigger{width:calc(100% - 65px);height:100%;background-color:transparent;border:1px solid lightgrey;display:flex;justify-content:space-between;align-items:center;padding:0 15px;font-size:14px}.memo-sorting-wrapper .memo-sorting-trigger i{font-size:16px;color:gray}.memo-sorting-menu{width:200px}.my-button{border:1px solid #465573;color:#465573;border-radius:5px;background-color:transparent;font-weight:bold;min-width:80px;height:40px}.my-button.reset{border:none}.my-button:hover{color:#fff;background-color:#465573}.my-button:hover.reset{color:#465573;border:1px solid #465573;background-color:#fff}.app-property-value .app-input-wrapper label{color:#646f85;font-size:13px;margin-bottom:5px}.app-property-value .app-input-wrapper label .text-danger{font-size:16px;line-height:14px;margin:0 5px!important}.app-property-value .app-input-wrapper .form-control{border:1px solid #ccc;border-radius:5px;background-color:#8f98aa1a;height:40px}.app-property-value .app-input-wrapper .form-control:disabled{background-color:#e9ecef!important}.app-property-value .app-input-wrapper .form-control:focus{border:1px solid #1a96c6;box-shadow:0 0 4px #79c3c26b!important}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers{list-style:none;padding:0;margin:0;font-size:14px}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers .error{margin-top:5px}.autocomplete-container .input-container input:focus,hijri-gregorian-datepicker .form-group .input-group .form-control:focus,.ng-select.ng-select-focused .ng-select-container{border:1px solid #1a96c6!important;box-shadow:0 0 4px #79c3c26b!important}input::placeholder{font-size:12px}.form-control:focus{box-shadow:none!important}.mat-stepper-horizontal{margin-top:-25px}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header.cdk-program-focused{background-color:transparent}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-icon-selected{background-color:transparent;color:#fff;background-image:linear-gradient(to right,#0dbab5,#1a96c6)}@media only screen and (max-width: 576px){.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-label .mat-step-text-label{white-space:pre-wrap;overflow:visible}}.mat-stepper-horizontal .mat-horizontal-content-container{overflow:visible}@media only screen and (max-width: 768px){.mat-stepper-horizontal .mat-horizontal-content-container{padding:0 0 24px}}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:after,.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:before{display:none}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:before{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);left:0}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:after{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);right:0}.form-wrapper{padding:30px 15px;border:1px solid #dde0e2}.form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.form-wrapper .buttons-wrapper button:hover{opacity:.7}.form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.form-wrapper .upload-wrapper button span{margin:0 10px}.renameFileComponent .form-wrapper{padding:30px 15px;border:none!important}.renameFileComponent .form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.renameFileComponent .form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.renameFileComponent .form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.renameFileComponent .form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.renameFileComponent .form-wrapper .buttons-wrapper button:hover{opacity:.7}.renameFileComponent .form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.renameFileComponent .form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.renameFileComponent .form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.renameFileComponent .form-wrapper .upload-wrapper button span{margin:0 10px}.my-dynamic-viewer{display:flex;align-items:center;font-size:12px;min-height:30px}.my-dynamic-viewer .my-label{font-size:12px;font-weight:500;width:150px;word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-label{width:50%}}.my-dynamic-viewer .my-value{width:calc(100% - 150px);word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-value{width:50%}}.my-dynamic-viewer .direction-img{font-size:14px}.my-dynamic-viewer .direction-img .incoming{display:none}.my-dynamic-viewer .direction-img .outgoing{display:none}.my-dynamic-viewer .direction-img .internal{display:none}.my-dynamic-viewer.draft .my-value{color:#596973}.my-dynamic-viewer.inProgress .my-value{color:#3c3cf0}.my-dynamic-viewer.registered .my-value{color:#4f008c}.my-dynamic-viewer.archived .my-value{color:#fbb62c}.my-dynamic-viewer.closed .my-value{color:#00dca5}.my-dynamic-viewer.approved .my-value{color:#06a57e}.my-dynamic-viewer.assigned .my-value{color:#fd6670}.my-dynamic-viewer.sent .my-value{color:#3c3cf0}.my-dynamic-viewer.published .my-value{color:#00dca5}.my-dynamic-viewer.Outgoing .my-value{display:flex}.my-dynamic-viewer.Outgoing .my-value .direction-img .outgoing{color:#fbb62c;margin:1px 5px;display:flex}.my-dynamic-viewer.Outgoing .my-value .text{margin:0 5px}.my-dynamic-viewer.Internal .my-value{display:flex}.my-dynamic-viewer.Internal .my-value .direction-img .internal{color:#3c3cf0;margin:1px 5px;display:flex}.my-dynamic-viewer.Internal .my-value .text{margin:0 5px}.my-dynamic-viewer.Incoming .my-value{display:flex}.my-dynamic-viewer.Incoming .my-value .direction-img .incoming{color:#00dca5;display:flex}.my-dynamic-viewer.Incoming .my-value .text{margin:-3px 5px 0}.my-dynamic-viewer.vertical{display:block}.my-dynamic-viewer.vertical .my-label{width:auto}.my-dynamic-viewer.vertical .my-value{width:auto}.my-dynamic-viewer.with-out-label{width:100%!important}.upload-container{display:flex;flex:1;justify-content:space-between;cursor:pointer;width:100%;height:100%}.default-upload{display:flex;padding:8px 16px;flex:1;justify-content:space-between;background:#d8d8fc;cursor:pointer}.upload-section{display:flex;align-items:center;justify-content:center;justify-content:space-between}.upload-icon{margin:0 8px}.upload-title{font-size:16px;border-color:#465573;border-left:1px solid;padding-left:8px;margin:0}.rtl .upload-title{border-left:0px;border-right:1px solid;padding-left:0;padding-right:8px}.upload-desc{font-size:12px;padding-left:8px;opacity:.6;margin:0}.rtl .upload-desc{padding-left:0;padding-right:8px}\n"], components: [{ type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i4.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "mode", "value", "bufferValue"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }], directives: [{ type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i6.TranslatePipe, "FileSize": i7.FileSizePipe }, encapsulation: i0.ViewEncapsulation.None });
187
+ DocumentUploadComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: DocumentUploadComponent, selector: "app-document-upload", inputs: { allowedTypes: "allowedTypes", params: "params", path: "path", maxSize: "maxSize", minSize: "minSize", docParams: "docParams", checkPdfContent: "checkPdfContent", multiple: "multiple", createDocument: "createDocument", allowedMaxNumberOfFiles: "allowedMaxNumberOfFiles", showAllowedTypesInErrorMess: "showAllowedTypesInErrorMess" }, outputs: { uploadSuccess: "uploadSuccess", uploadError: "uploadError" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }], ngImport: i0, template: "<input type=\"file\" class=\"hidden\" #fileInput [accept]=\"allowedTypes\" [multiple]=\"multiple\"\r\n (change)=\"uploadDocument($event.target.files)\">\r\n<div #template [ngClass]=\"{'hidden': template.childNodes.length == 0}\" (click)=\"triggerUpload()\"\r\n class=\"upload-container\">\r\n <ng-content></ng-content>\r\n</div>\r\n<div *ngIf=\"template.childNodes.length == 0\" class=\"default-upload\" (click)=\"triggerUpload()\">\r\n <div class=\"upload-section\" style=\"color:#465573;\">\r\n <mat-icon class=\"upload-icon\">upload</mat-icon>\r\n <h3 class=\"upload-title\">\r\n {{'documents.uploadDocuments'| translate }}</h3>\r\n <p class=\"upload-desc\">\r\n {{'documents.maxSize'| translate }} {{maxSize | FileSize}}</p>\r\n </div>\r\n <div>\r\n <mat-icon class=\"m-2\" style=\"color:#465573;\">file_copy</mat-icon>\r\n </div>\r\n</div>\r\n<mat-progress-bar mode=\"indeterminate\" *ngIf=\"uploading\"></mat-progress-bar>\r\n", styles: [".bi{margin:0!important}.memo-sorting-wrapper{width:265px;margin:0 10px;height:100%;display:flex}.memo-sorting-wrapper .sorting-direction{width:65px;height:40px;background-color:#465573;color:#fff;font-size:20px;display:flex;justify-content:center;align-items:center;cursor:pointer}.memo-sorting-wrapper .memo-sorting-trigger{width:calc(100% - 65px);height:100%;background-color:transparent;border:1px solid lightgrey;display:flex;justify-content:space-between;align-items:center;padding:0 15px;font-size:14px}.memo-sorting-wrapper .memo-sorting-trigger i{font-size:16px;color:gray}.memo-sorting-menu{width:200px}.my-button{border:1px solid #465573;color:#465573;border-radius:5px;background-color:transparent;font-weight:bold;min-width:80px;height:40px}.my-button.reset{border:none}.my-button:hover{color:#fff;background-color:#465573}.my-button:hover.reset{color:#465573;border:1px solid #465573;background-color:#fff}.app-property-value .app-input-wrapper label{color:#646f85;font-size:13px;margin-bottom:5px}.app-property-value .app-input-wrapper label .text-danger{font-size:16px;line-height:14px;margin:0 5px!important}.app-property-value .app-input-wrapper .form-control{border:1px solid #ccc;border-radius:5px;background-color:#8f98aa1a;height:40px}.app-property-value .app-input-wrapper .form-control:disabled{background-color:#e9ecef!important}.app-property-value .app-input-wrapper .form-control:focus{border:1px solid #1a96c6;box-shadow:0 0 4px #79c3c26b!important}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers{list-style:none;padding:0;margin:0;font-size:14px}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers .error{margin-top:5px}.autocomplete-container .input-container input:focus,hijri-gregorian-datepicker .form-group .input-group .form-control:focus,.ng-select.ng-select-focused .ng-select-container{border:1px solid #1a96c6!important;box-shadow:0 0 4px #79c3c26b!important}input::placeholder{font-size:12px}.form-control:focus{box-shadow:none!important}.mat-stepper-horizontal{margin-top:-25px}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header.cdk-program-focused{background-color:transparent}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-icon-selected{background-color:transparent;color:#fff;background-image:linear-gradient(to right,#0dbab5,#1a96c6)}@media only screen and (max-width: 576px){.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-label .mat-step-text-label{white-space:pre-wrap;overflow:visible}}.mat-stepper-horizontal .mat-horizontal-content-container{overflow:visible}@media only screen and (max-width: 768px){.mat-stepper-horizontal .mat-horizontal-content-container{padding:0 0 24px}}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:after,.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:before{display:none}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:before{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);left:0}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:after{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);right:0}.form-wrapper{padding:30px 15px;border:1px solid #dde0e2}.form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.form-wrapper .buttons-wrapper button:hover{opacity:.7}.form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.form-wrapper .upload-wrapper button span{margin:0 10px}.renameFileComponent .form-wrapper{padding:30px 15px;border:none!important}.renameFileComponent .form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.renameFileComponent .form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.renameFileComponent .form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.renameFileComponent .form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.renameFileComponent .form-wrapper .buttons-wrapper button:hover{opacity:.7}.renameFileComponent .form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.renameFileComponent .form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.renameFileComponent .form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.renameFileComponent .form-wrapper .upload-wrapper button span{margin:0 10px}.my-dynamic-viewer{display:flex;align-items:center;font-size:12px;min-height:30px}.my-dynamic-viewer .my-label{font-size:12px;font-weight:500;width:150px;word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-label{width:50%}}.my-dynamic-viewer .my-value{width:calc(100% - 150px);word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-value{width:50%}}.my-dynamic-viewer .direction-img{font-size:14px}.my-dynamic-viewer .direction-img .incoming{display:none}.my-dynamic-viewer .direction-img .outgoing{display:none}.my-dynamic-viewer .direction-img .internal{display:none}.my-dynamic-viewer.draft .my-value{color:#596973}.my-dynamic-viewer.inProgress .my-value{color:#3c3cf0}.my-dynamic-viewer.registered .my-value{color:#4f008c}.my-dynamic-viewer.archived .my-value{color:#fbb62c}.my-dynamic-viewer.closed .my-value{color:#00dca5}.my-dynamic-viewer.approved .my-value{color:#06a57e}.my-dynamic-viewer.assigned .my-value{color:#fd6670}.my-dynamic-viewer.sent .my-value{color:#3c3cf0}.my-dynamic-viewer.published .my-value{color:#00dca5}.my-dynamic-viewer.Outgoing .my-value{display:flex}.my-dynamic-viewer.Outgoing .my-value .direction-img .outgoing{color:#fbb62c;margin:1px 5px;display:flex}.my-dynamic-viewer.Outgoing .my-value .text{margin:0 5px}.my-dynamic-viewer.Internal .my-value{display:flex}.my-dynamic-viewer.Internal .my-value .direction-img .internal{color:#3c3cf0;margin:1px 5px;display:flex}.my-dynamic-viewer.Internal .my-value .text{margin:0 5px}.my-dynamic-viewer.Incoming .my-value{display:flex}.my-dynamic-viewer.Incoming .my-value .direction-img .incoming{color:#00dca5;display:flex}.my-dynamic-viewer.Incoming .my-value .text{margin:-3px 5px 0}.my-dynamic-viewer.vertical{display:block}.my-dynamic-viewer.vertical .my-label{width:auto}.my-dynamic-viewer.vertical .my-value{width:auto}.my-dynamic-viewer.with-out-label{width:100%!important}.upload-container{display:flex;flex:1;justify-content:space-between;cursor:pointer;width:100%;height:100%}.default-upload{display:flex;padding:8px 16px;flex:1;justify-content:space-between;background:#d8d8fc;cursor:pointer}.upload-section{display:flex;align-items:center;justify-content:center;justify-content:space-between}.upload-icon{margin:0 8px}.upload-title{font-size:16px;border-color:#465573;border-left:1px solid;padding-left:8px;margin:0}.rtl .upload-title{border-left:0px;border-right:1px solid;padding-left:0;padding-right:8px}.upload-desc{font-size:12px;padding-left:8px;opacity:.6;margin:0}.rtl .upload-desc{padding-left:0;padding-right:8px}\n"], components: [{ type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i4.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "mode", "value", "bufferValue"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }], directives: [{ type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i6.TranslatePipe, "FileSize": i7.FileSizePipe }, encapsulation: i0.ViewEncapsulation.None });
149
188
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: DocumentUploadComponent, decorators: [{
150
189
  type: Component,
151
190
  args: [{
@@ -166,6 +205,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
166
205
  type: Input
167
206
  }], docParams: [{
168
207
  type: Input
208
+ }], checkPdfContent: [{
209
+ type: Input
169
210
  }], multiple: [{
170
211
  type: Input
171
212
  }], createDocument: [{
@@ -182,4 +223,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
182
223
  type: ViewChild,
183
224
  args: ['fileInput']
184
225
  }] } });
185
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"document-upload.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/documents/components/document-upload/document-upload.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/documents/components/document-upload/document-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';\r\nimport { combineLatest } from 'rxjs';\r\nimport { CustomToastrService } from '../../../custom-toastr/services/custom-toastr.service';\r\nimport { DocumentsService } from '../../services/documents.service';\r\n\r\n/**\r\n * Document upload is a reusable API integrated upload button component,\r\n * that can be configured to suit the needs of required implementation,\r\n * it is possible to upload batch and create a document, or just upload a batch and\r\n * consume it any other way.\r\n *\r\n * @title\r\n * Document Upload\r\n *\r\n * @example\r\n *\r\n * <app-document-upload\r\n *   [allowedTypes]=\"'application/pdf'\"\r\n *   [createDocument]=\"false\"\r\n *   (uploadSuccess)=\"onUploadSuccess($event)\"\r\n *   (uploadError)=\"onUploadError($event)\"\r\n * >\r\n *   <button> UPLOAD FILE </button>\r\n * </app-document-upload>\r\n */\r\n@Component({\r\n  selector: 'app-document-upload',\r\n  templateUrl: './document-upload.component.html',\r\n  styleUrls: ['./document-upload.component.scss'],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class DocumentUploadComponent {\r\n  /** Allowed Upload Types */\r\n  @Input()\r\n  allowedTypes = 'application/pdf,application/vnd.ms-powerpoint,application/vnd.openxmlformats-officedocument.presentationml.presentation';\r\n  /** Params to be sent with properties when creating a document */\r\n  @Input()\r\n  params = {};\r\n  /** Path in witch a document will be created */\r\n  @Input()\r\n  path;\r\n  /** Max allowed upload size */\r\n  @Input()\r\n  maxSize = 1145728;\r\n    /** min allowed upload size */\r\n    @Input()\r\n    minSize = 1000;\r\n\r\n  /** Params to be sent with body when creating a document */\r\n  @Input()\r\n  docParams = {};\r\n  /** Can upload multiple files at once */\r\n  @Input()\r\n  multiple = false;\r\n  /** should create document after batch upload */\r\n  @Input()\r\n  createDocument = true;\r\n  /** Max allowed number of files size */\r\n  @Input()\r\n  allowedMaxNumberOfFiles = 10;\r\n\r\n  @Input()\r\n  showAllowedTypesInErrorMess = true;\r\n  /** Event emitted on document upload success, it will have document or batch object based on configuration */\r\n  @Output()\r\n  uploadSuccess = new EventEmitter();\r\n  /** Event emitted when an error occurs while attempting upload */\r\n  @Output()\r\n  uploadError = new EventEmitter();\r\n  uploading = false;\r\n  @ViewChild('fileInput') fileInput;\r\n\r\n  constructor(\r\n    private documentsApi: DocumentsService,\r\n    private customToastrService: CustomToastrService\r\n  ) { }\r\n\r\n  triggerUpload(): void {\r\n    this.fileInput.nativeElement.click();\r\n  }\r\n\r\n  isSizeChecked(file) {\r\n    if(file.size > this.maxSize){\r\n      this.customToastrService.show(\r\n        'error',\r\n        'error',\r\n        'ERRORS.SIZE',\r\n        {},\r\n        `${(this.maxSize / (1024 * 1024)).toFixed(2)}MB` \r\n      );\r\n    this.uploadError.next('errors.size');\r\n    return false;\r\n    }else if(file.size <= this.minSize){\r\n      this.customToastrService.show(\r\n        'error',\r\n        'error',\r\n        'ERRORS.MIN_SIZE',\r\n        {},\r\n        `${(this.minSize / (1000)).toFixed(2)}KB` \r\n      );\r\n    this.uploadError.next('errors.size');\r\n    return false;\r\n    }else{\r\n      return true\r\n    }\r\n  }\r\n\r\n  isTypeChecked(file) {\r\n    let arr = this.allowedTypes.split(',');\r\n    if (arr.indexOf(file.type) > -1)\r\n      {return true}\r\n    else if(arr.indexOf(this.getFileExtension(file.name)) > -1){\r\n      return true\r\n    }\r\n    else {\r\n      if(this.showAllowedTypesInErrorMess){\r\n        this.customToastrService.show(\r\n          'error',\r\n          'error',\r\n          'ERRORS.TYPE',\r\n          {},\r\n          this.allowedTypes.replace(/image|application/gi, '').replace(/[/]/g, '').toUpperCase()\r\n        );\r\n      }else{\r\n        this.customToastrService.show(\r\n          'error',\r\n          'error',\r\n          'ERRORS.WRONG_TYPE');\r\n      }\r\n      this.uploadError.next('errors.type');\r\n      return false;\r\n    }\r\n  }\r\n\r\n  isMaxNumberOfFiles(selectedFiles) {\r\n    if (selectedFiles.length <= this.allowedMaxNumberOfFiles)\r\n      return true\r\n    else {\r\n      this.customToastrService.show(\r\n        'error',\r\n        'error',\r\n        'ERRORS.MAX_NUMBER_OF_FILES',\r\n        {},\r\n        this.allowedMaxNumberOfFiles\r\n      );\r\n      this.uploadError.next('errors.maxNumberOfFiles');\r\n      return false;\r\n    }\r\n  }\r\n\r\n  uploadDocument(files): void {\r\n    let selectedFiles = Object.keys(files).map(key => files[key]);\r\n    selectedFiles = selectedFiles.filter(file => {\r\n      if (this.isMaxNumberOfFiles(selectedFiles)) {\r\n        if (this.isSizeChecked(file) && this.isTypeChecked(file)) {\r\n          return file;\r\n        }\r\n      }\r\n    });\r\n    if (selectedFiles.length) {\r\n      this.uploading = true;\r\n\r\n      this.documentsApi.uploadBatch(selectedFiles)\r\n        .subscribe((files) => {\r\n          if (this.createDocument) {\r\n            combineLatest([\r\n              ...files.map((file) => this.documentsApi.createDoc(file, this.path, this.params, this.docParams))\r\n            ]).subscribe(docs => {\r\n              docs.forEach(doc => {\r\n                this.uploadSuccess.next(doc);\r\n              });\r\n              this.uploading = false;\r\n              this.fileInput.nativeElement.value = '';\r\n            });\r\n          } else {\r\n            files.forEach(doc => {\r\n              this.uploadSuccess.next(doc);\r\n            });\r\n            this.uploading = false;\r\n            this.fileInput.nativeElement.value = '';\r\n          }\r\n\r\n\r\n        }, (err) => {\r\n          this.uploadError.next(err);\r\n          this.uploading = false;\r\n          this.fileInput.nativeElement.value = '';\r\n        });\r\n    }\r\n\r\n  }\r\n\r\n  getFileExtension(name){\r\n    let extension = name.split('.')[1];\r\n    return ('.' + extension);\r\n  }\r\n\r\n}\r\n","<input type=\"file\" class=\"hidden\" #fileInput [accept]=\"allowedTypes\" [multiple]=\"multiple\"\r\n  (change)=\"uploadDocument($event.target.files)\">\r\n<div #template [ngClass]=\"{'hidden': template.childNodes.length == 0}\" (click)=\"triggerUpload()\"\r\n  class=\"upload-container\">\r\n  <ng-content></ng-content>\r\n</div>\r\n<div *ngIf=\"template.childNodes.length == 0\" class=\"default-upload\" (click)=\"triggerUpload()\">\r\n  <div class=\"upload-section\" style=\"color:#465573;\">\r\n    <mat-icon class=\"upload-icon\">upload</mat-icon>\r\n    <h3 class=\"upload-title\">\r\n      {{'documents.uploadDocuments'| translate }}</h3>\r\n    <p class=\"upload-desc\">\r\n      {{'documents.maxSize'| translate }} {{maxSize | FileSize}}</p>\r\n  </div>\r\n  <div>\r\n    <mat-icon class=\"m-2\" style=\"color:#465573;\">file_copy</mat-icon>\r\n  </div>\r\n</div>\r\n<mat-progress-bar mode=\"indeterminate\" *ngIf=\"uploading\"></mat-progress-bar>\r\n"]}
226
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"document-upload.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/documents/components/document-upload/document-upload.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/documents/components/document-upload/document-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';\r\nimport { combineLatest } from 'rxjs';\r\nimport { CustomToastrService } from '../../../custom-toastr/services/custom-toastr.service';\r\nimport { DocumentsService } from '../../services/documents.service';\r\n\r\n/**\r\n * Document upload is a reusable API integrated upload button component,\r\n * that can be configured to suit the needs of required implementation,\r\n * it is possible to upload batch and create a document, or just upload a batch and\r\n * consume it any other way.\r\n *\r\n * @title\r\n * Document Upload\r\n *\r\n * @example\r\n *\r\n * <app-document-upload\r\n *   [allowedTypes]=\"'application/pdf'\"\r\n *   [createDocument]=\"false\"\r\n *   (uploadSuccess)=\"onUploadSuccess($event)\"\r\n *   (uploadError)=\"onUploadError($event)\"\r\n * >\r\n *   <button> UPLOAD FILE </button>\r\n * </app-document-upload>\r\n */\r\n@Component({\r\n  selector: 'app-document-upload',\r\n  templateUrl: './document-upload.component.html',\r\n  styleUrls: ['./document-upload.component.scss'],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class DocumentUploadComponent {\r\n  /** Allowed Upload Types */\r\n  @Input()\r\n  allowedTypes = 'application/pdf,application/vnd.ms-powerpoint,application/vnd.openxmlformats-officedocument.presentationml.presentation';\r\n  /** Params to be sent with properties when creating a document */\r\n  @Input()\r\n  params = {};\r\n  /** Path in witch a document will be created */\r\n  @Input()\r\n  path;\r\n  /** Max allowed upload size */\r\n  @Input()\r\n  maxSize = 1145728;\r\n  /** min allowed upload size */\r\n  @Input()\r\n  minSize = 1000;\r\n\r\n  /** Params to be sent with body when creating a document */\r\n  @Input()\r\n  docParams = {};\r\n\r\n  @Input() checkPdfContent = false;\r\n  /** Can upload multiple files at once */\r\n  @Input()\r\n  multiple = false;\r\n  /** should create document after batch upload */\r\n  @Input()\r\n  createDocument = true;\r\n  /** Max allowed number of files size */\r\n  @Input()\r\n  allowedMaxNumberOfFiles = 10;\r\n\r\n  @Input()\r\n  showAllowedTypesInErrorMess = true;\r\n  /** Event emitted on document upload success, it will have document or batch object based on configuration */\r\n  @Output()\r\n  uploadSuccess = new EventEmitter();\r\n  /** Event emitted when an error occurs while attempting upload */\r\n  @Output()\r\n  uploadError = new EventEmitter();\r\n  uploading = false;\r\n  @ViewChild('fileInput') fileInput;\r\n\r\n  constructor(\r\n    private documentsApi: DocumentsService,\r\n    private customToastrService: CustomToastrService\r\n  ) { }\r\n\r\n  triggerUpload(): void {\r\n    this.fileInput.nativeElement.click();\r\n  }\r\n\r\n  isSizeChecked(file) {\r\n    if (file.size > this.maxSize) {\r\n      this.customToastrService.show(\r\n        'error',\r\n        'error',\r\n        'ERRORS.SIZE',\r\n        {},\r\n        `${(this.maxSize / (1024 * 1024)).toFixed(2)}MB`\r\n      );\r\n      this.uploadError.next('errors.size');\r\n      return false;\r\n    } else if (file.size <= this.minSize) {\r\n      this.customToastrService.show(\r\n        'error',\r\n        'error',\r\n        'ERRORS.MIN_SIZE',\r\n        {},\r\n        `${(this.minSize / (1000)).toFixed(2)}KB`\r\n      );\r\n      this.uploadError.next('errors.size');\r\n      return false;\r\n    } else {\r\n      return true\r\n    }\r\n  }\r\n\r\n  isTypeChecked(file) {\r\n    let arr = this.allowedTypes.split(',');\r\n    if ((arr.indexOf(file.type) > -1) || (arr.indexOf(this.getFileExtension(file.name)) > -1)) {\r\n        return true\r\n    }\r\n    else {\r\n      if (this.showAllowedTypesInErrorMess) {\r\n        this.customToastrService.show(\r\n          'error',\r\n          'error',\r\n          'ERRORS.TYPE',\r\n          {},\r\n          this.allowedTypes.replace(/image|application/gi, '').replace(/[/]/g, '').toUpperCase()\r\n        );\r\n      } else {\r\n        this.customToastrService.show(\r\n          'error',\r\n          'error',\r\n          'ERRORS.WRONG_TYPE');\r\n      }\r\n      this.uploadError.next('errors.type');\r\n      return false;\r\n    }\r\n  }\r\n\r\n  isMaxNumberOfFiles(selectedFiles) {\r\n    if (selectedFiles.length <= this.allowedMaxNumberOfFiles)\r\n      return true\r\n    else {\r\n      this.customToastrService.show(\r\n        'error',\r\n        'error',\r\n        'ERRORS.MAX_NUMBER_OF_FILES',\r\n        {},\r\n        this.allowedMaxNumberOfFiles\r\n      );\r\n      this.uploadError.next('errors.maxNumberOfFiles');\r\n      return false;\r\n    }\r\n  }\r\n\r\n  checkFileContent(file){\r\n    if (this.checkPdfContent) {\r\n      let reader = new FileReader();\r\n      let blob = file.slice(0, 8);\r\n      reader.readAsText(blob);\r\n      reader.onload = (e) => {\r\n        var data: string = ((e.target.result).toString()).substr(0, 8);\r\n        var regex = new RegExp(\"%PDF-1.[0-7]\");\r\n        if (!data.match(regex)) {\r\n          this.customToastrService.show(\r\n            'error',\r\n            'error',\r\n            'ERRORS.UNVALID_PDF',\r\n            {},\r\n            this.allowedTypes.replace(/./gi, '').toUpperCase()\r\n          );\r\n          return false;\r\n        } else {\r\n          return true\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n uploadDocument(files): void {\r\n    let selectedFiles = Object.keys(files).map(key => files[key]);\r\n    selectedFiles = selectedFiles.filter(file => {\r\n      if (this.isMaxNumberOfFiles(selectedFiles)) {\r\n        if (this.isSizeChecked(file) &&  this.isTypeChecked(file)) {\r\n          return file;\r\n        }\r\n      }\r\n    });\r\n\r\n    if(selectedFiles.length){\r\n      if(this.checkPdfContent){\r\n          let reader = new FileReader();\r\n          let blob = files[0].slice(0, 8);\r\n          reader.readAsText(blob);\r\n          reader.onload = (e) => {\r\n            var data: string = ((e.target.result).toString()).substr(0, 8);\r\n            var regex = new RegExp(\"%PDF-1.[0-7]\");\r\n            if (!data.match(regex)) {\r\n              this.customToastrService.show(\r\n                'error',\r\n                'error',\r\n                'ERRORS.UNVALID_PDF',\r\n                {},\r\n                this.allowedTypes.replace(/./gi, '').toUpperCase()\r\n              );\r\n              return false;\r\n            } else {\r\n              this.uploadFiles(selectedFiles)\r\n            }\r\n          }\r\n      }else{\r\n        this.uploadFiles(selectedFiles)\r\n      }\r\n    }\r\n\r\n\r\n  }\r\n\r\n  uploadFiles(selectedFiles){\r\n    if (selectedFiles.length) {\r\n      this.uploading = true;\r\n\r\n      this.documentsApi.uploadBatch(selectedFiles)\r\n        .subscribe((files) => {\r\n          if (this.createDocument) {\r\n            combineLatest([\r\n              ...files.map((file) => this.documentsApi.createDoc(file, this.path, this.params, this.docParams))\r\n            ]).subscribe(docs => {\r\n              docs.forEach(doc => {\r\n                this.uploadSuccess.next(doc);\r\n              });\r\n              this.uploading = false;\r\n              this.fileInput.nativeElement.value = '';\r\n            });\r\n          } else {\r\n            files.forEach(doc => {\r\n              this.uploadSuccess.next(doc);\r\n            });\r\n            this.uploading = false;\r\n            this.fileInput.nativeElement.value = '';\r\n          }\r\n\r\n\r\n        }, (err) => {\r\n          this.uploadError.next(err);\r\n          this.uploading = false;\r\n          this.fileInput.nativeElement.value = '';\r\n        });\r\n    }\r\n  }\r\n\r\n  getFileExtension(name) {\r\n    let extension = name.split('.')[1];\r\n    return ('.' + extension);\r\n  }\r\n\r\n}\r\n","<input type=\"file\" class=\"hidden\" #fileInput [accept]=\"allowedTypes\" [multiple]=\"multiple\"\r\n  (change)=\"uploadDocument($event.target.files)\">\r\n<div #template [ngClass]=\"{'hidden': template.childNodes.length == 0}\" (click)=\"triggerUpload()\"\r\n  class=\"upload-container\">\r\n  <ng-content></ng-content>\r\n</div>\r\n<div *ngIf=\"template.childNodes.length == 0\" class=\"default-upload\" (click)=\"triggerUpload()\">\r\n  <div class=\"upload-section\" style=\"color:#465573;\">\r\n    <mat-icon class=\"upload-icon\">upload</mat-icon>\r\n    <h3 class=\"upload-title\">\r\n      {{'documents.uploadDocuments'| translate }}</h3>\r\n    <p class=\"upload-desc\">\r\n      {{'documents.maxSize'| translate }} {{maxSize | FileSize}}</p>\r\n  </div>\r\n  <div>\r\n    <mat-icon class=\"m-2\" style=\"color:#465573;\">file_copy</mat-icon>\r\n  </div>\r\n</div>\r\n<mat-progress-bar mode=\"indeterminate\" *ngIf=\"uploading\"></mat-progress-bar>\r\n"]}
@@ -35,7 +35,7 @@ export class DocumentsComponent {
35
35
  }
36
36
  }
37
37
  DocumentsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: DocumentsComponent, deps: [{ token: i1.CustomToastrService }], target: i0.ɵɵFactoryTarget.Component });
38
- DocumentsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: DocumentsComponent, selector: "app-documents", inputs: { ancestorId: "ancestorId", quickFilters: "quickFilters", params: "params", provider: "provider", path: "path", canUploadRoles: "canUploadRoles", multiple: "multiple", maxSize: "maxSize" }, ngImport: i0, template: "<app-card>\r\n <h3 class=\"title text-lg font-bold\">\r\n {{ \"documents.title\" | translate }}\r\n </h3>\r\n\r\n\r\n <div class=\"body\">\r\n <app-document-upload [multiple]=\"multiple\" *appHasRole=\"canUploadRoles\" [docParams]=\"{type:documentConstants.documentTypes.attachment}\"\r\n [path]=\"this.path\" [params]=\"this.params\" (uploadSuccess)=\"onSuccess($event)\" (uploadError)=\"onError($event)\">\r\n </app-document-upload>\r\n <app-documents-list [quickFilters]=\"quickFilters\" [notifier]=\"notifier\" [ancestorId]=\"ancestorId\"\r\n [provider]=\"provider\" (deleteSuccess)=\"onDelete($event)\">\r\n </app-documents-list>\r\n\r\n </div>\r\n</app-card>\r\n", styles: [""], components: [{ type: i2.CardComponent, selector: "app-card", inputs: ["noBody", "dark"] }, { type: i3.DocumentUploadComponent, selector: "app-document-upload", inputs: ["allowedTypes", "params", "path", "maxSize", "minSize", "docParams", "multiple", "createDocument", "allowedMaxNumberOfFiles", "showAllowedTypesInErrorMess"], outputs: ["uploadSuccess", "uploadError"] }, { type: i4.DocumentsListComponent, selector: "app-documents-list", inputs: ["ancestorId", "provider", "disablePagination", "containerClasses", "itemsClasses", "items", "notifier", "canPreview", "batchList", "dontDelete", "canDelete", "quickFilters", "memoView"], outputs: ["deleteSuccess", "documentsCount", "documentSelect"] }], directives: [{ type: i5.AppHasRoleDirective, selector: "[appHasRole]", inputs: ["appHasRole"] }], pipes: { "translate": i6.TranslatePipe } });
38
+ DocumentsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: DocumentsComponent, selector: "app-documents", inputs: { ancestorId: "ancestorId", quickFilters: "quickFilters", params: "params", provider: "provider", path: "path", canUploadRoles: "canUploadRoles", multiple: "multiple", maxSize: "maxSize" }, ngImport: i0, template: "<app-card>\r\n <h3 class=\"title text-lg font-bold\">\r\n {{ \"documents.title\" | translate }}\r\n </h3>\r\n\r\n\r\n <div class=\"body\">\r\n <app-document-upload [multiple]=\"multiple\" *appHasRole=\"canUploadRoles\" [docParams]=\"{type:documentConstants.documentTypes.attachment}\"\r\n [path]=\"this.path\" [params]=\"this.params\" (uploadSuccess)=\"onSuccess($event)\" (uploadError)=\"onError($event)\">\r\n </app-document-upload>\r\n <app-documents-list [quickFilters]=\"quickFilters\" [notifier]=\"notifier\" [ancestorId]=\"ancestorId\"\r\n [provider]=\"provider\" (deleteSuccess)=\"onDelete($event)\">\r\n </app-documents-list>\r\n\r\n </div>\r\n</app-card>\r\n", styles: [""], components: [{ type: i2.CardComponent, selector: "app-card", inputs: ["noBody", "dark"] }, { type: i3.DocumentUploadComponent, selector: "app-document-upload", inputs: ["allowedTypes", "params", "path", "maxSize", "minSize", "docParams", "checkPdfContent", "multiple", "createDocument", "allowedMaxNumberOfFiles", "showAllowedTypesInErrorMess"], outputs: ["uploadSuccess", "uploadError"] }, { type: i4.DocumentsListComponent, selector: "app-documents-list", inputs: ["ancestorId", "provider", "disablePagination", "containerClasses", "itemsClasses", "items", "notifier", "canPreview", "batchList", "dontDelete", "canDelete", "quickFilters", "memoView"], outputs: ["deleteSuccess", "documentsCount", "documentSelect"] }], directives: [{ type: i5.AppHasRoleDirective, selector: "[appHasRole]", inputs: ["appHasRole"] }], pipes: { "translate": i6.TranslatePipe } });
39
39
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: DocumentsComponent, decorators: [{
40
40
  type: Component,
41
41
  args: [{