axidio-styleguide-library1-v2 0.6.6 → 0.6.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/ax-table/ax-table.component.mjs +10 -21
- package/esm2022/lib/chart-header-v2/chart-header-v2.component.mjs +1 -2
- package/esm2022/lib/chart-header-v3/chart-header-v3.component.mjs +2 -2
- package/esm2022/lib/group-chart/group-chart.component.mjs +4 -4
- package/esm2022/lib/horizontal-grouped-bar-with-scroll-zoom/horizontal-grouped-bar-with-scroll-zoom.component.mjs +3 -3
- package/fesm2022/axidio-styleguide-library1-v2.mjs +16 -28
- package/fesm2022/axidio-styleguide-library1-v2.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -229,22 +229,8 @@ export class AxTableComponent {
|
|
|
229
229
|
this.clickEvent.emit(data);
|
|
230
230
|
}
|
|
231
231
|
getCellAlignment(value, index) {
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
// return 'textalign-right';
|
|
235
|
-
// }
|
|
236
|
-
if (this.isColumnNumeric(value)) {
|
|
237
|
-
return 'textalign-right';
|
|
238
|
-
}
|
|
239
|
-
if (value === null || value === undefined) {
|
|
240
|
-
return 'textalign-left';
|
|
241
|
-
}
|
|
242
|
-
const strValue = String(value).trim();
|
|
243
|
-
// Detect numeric, date, or alphanumeric ending with numbers
|
|
244
|
-
const isNumber = !isNaN(Number(strValue));
|
|
245
|
-
const isDate = !isNaN(Date.parse(strValue));
|
|
246
|
-
const isAlphaNumericWithTrailingNumber = /^[A-Za-z]*\d+[A-Za-z0-9]*$/.test(strValue);
|
|
247
|
-
if (isNumber || isDate) {
|
|
232
|
+
const header = this.tableHeadList[index];
|
|
233
|
+
if (this.isColumnNumeric(header)) {
|
|
248
234
|
return 'textalign-right';
|
|
249
235
|
}
|
|
250
236
|
return 'textalign-left';
|
|
@@ -256,13 +242,16 @@ export class AxTableComponent {
|
|
|
256
242
|
return 'textalign-left';
|
|
257
243
|
}
|
|
258
244
|
isColumnNumeric(header) {
|
|
259
|
-
|
|
245
|
+
const listToCheck = this.currentList.length > 0 ? this.currentList : this.itemList;
|
|
246
|
+
if (!listToCheck || listToCheck.length === 0) {
|
|
247
|
+
return false;
|
|
248
|
+
}
|
|
249
|
+
return listToCheck.some(row => {
|
|
260
250
|
const value = row[header];
|
|
261
|
-
if (value === null || value === undefined)
|
|
251
|
+
if (value === null || value === undefined || value === '')
|
|
262
252
|
return false;
|
|
263
253
|
const str = String(value).trim();
|
|
264
|
-
|
|
265
|
-
if (!isNaN(Number(str)))
|
|
254
|
+
if (!isNaN(Number(str)) && str !== '')
|
|
266
255
|
return true;
|
|
267
256
|
return false;
|
|
268
257
|
});
|
|
@@ -283,4 +272,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
283
272
|
}], clickEvent: [{
|
|
284
273
|
type: Output
|
|
285
274
|
}] } });
|
|
286
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ax-table.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/ax-table/ax-table.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/ax-table/ax-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';\r\nimport ChartHelper from '../chart-helper';\r\n\r\ninterface TableMetaData {\r\n  title?: string;\r\n  isPaginationHidden?: boolean;\r\n  isHeaderVisible?: boolean;\r\n  isSearchHidden?: boolean;\r\n  isHeaderAlignedToCenter?: boolean;\r\n  isHeaderSortHidden?: boolean;\r\n  isFirstColumnHeaderHidden?: boolean;\r\n  isAllAlignedToRight?: boolean;\r\n  hasDrillDown?: boolean;\r\n  headerColor?: string;\r\n  headerTextColor?: string;\r\n}\r\n\r\ninterface TableData {\r\n  data: any[];\r\n  featureInfo:any;\r\n  metaData: TableMetaData;\r\n  highlightedTexts?: string[];\r\n}\r\n\r\ntype SortDirection = 'asc' | 'desc';\r\n\r\n@Component({\r\n  selector: 'lib-ax-table',\r\n  templateUrl: './ax-table.component.html',\r\n  styleUrls: ['./ax-table.component.less', '../common-styles.less'],\r\n})\r\nexport class AxTableComponent implements OnInit {\r\n  @Input() tableData!: TableData;\r\n  @Input() customChartConfiguration: any;\r\n  @Output() clickEvent = new EventEmitter<any>();\r\n\r\n  isHeaderVisible = true;\r\n  isUserSort = false;\r\n\r\n  isRia: boolean = false;\r\n\r\n\r\n  tableHeadList: string[] = [];\r\n  itemList: any[] = [];\r\n  masterList: any[] = [];\r\n  currentList: any[] = [];\r\n\r\n  readonly DEFAULT_PAGE_SIZE = 10;\r\n  readonly MAX_PAGES_TO_SHOW = 5;\r\n  \r\n  currentPage = 1;\r\n  pageSize = this.DEFAULT_PAGE_SIZE;\r\n  totalItems = 0;\r\n  totalPages = 1;\r\n  goToPageNumber = 1;\r\n  pagesToShow: number[] = [];\r\n\r\n  sortDirection: SortDirection = 'asc';\r\n  sortColumn = '';\r\n\r\n  chartConfiguration: any = {};\r\n  defaultConfiguration: any = {};\r\n\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {\r\n    this.isRia = this.tableData?.featureInfo?.uiConfiguration?.customChartConfiguration?.isRia ?? false;\r\n    this.initializeComponent();\r\n  }\r\n\r\n  private initializeComponent(): void {\r\n    this.extractTableHeaders();\r\n    this.mergeConfigurations();\r\n    this.initializeData();\r\n    this.updateHeaderVisibility();\r\n  }\r\n\r\n  private extractTableHeaders(): void {\r\n    if (this.tableData?.data?.length > 0) {\r\n      this.tableHeadList = Object.keys(this.tableData.data[0]);\r\n    }\r\n  }\r\n\r\n  private mergeConfigurations(): void {\r\n    for (const key in this.defaultConfiguration) {\r\n      this.chartConfiguration[key] = ChartHelper.getValueByConfigurationType(\r\n        key,\r\n        this.defaultConfiguration,\r\n        this.customChartConfiguration\r\n      );\r\n    }\r\n  }\r\n\r\n  private initializeData(): void {\r\n    this.masterList = [...this.tableData.data];\r\n    this.itemList = [...this.masterList];\r\n    this.totalItems = this.itemList.length;\r\n    this.calculateTotalPages();\r\n    this.generatePagesToShow();\r\n\r\n    if (this.tableData.metaData.isPaginationHidden) {\r\n      this.currentList = this.itemList;\r\n    } else {\r\n      this.loadPage();\r\n    }\r\n  }\r\n\r\n  private updateHeaderVisibility(): void {\r\n    if (this.tableData.metaData.isHeaderVisible !== undefined) {\r\n      this.isHeaderVisible = this.tableData.metaData.isHeaderVisible;\r\n    }\r\n  }\r\n\r\n  private loadPage(): void {\r\n    const startIndex = (this.currentPage - 1) * this.pageSize;\r\n    const endIndex = startIndex + this.pageSize;\r\n    this.currentList = this.itemList.slice(startIndex, endIndex);\r\n  }\r\n\r\n  private calculateTotalPages(): void {\r\n    this.totalPages = Math.ceil(this.totalItems / this.pageSize);\r\n    this.goToPageNumber = this.currentPage;\r\n  }\r\n\r\n  private generatePagesToShow(): void {\r\n    this.pagesToShow = [];\r\n    \r\n    let startPage = Math.max(\r\n      1,\r\n      this.currentPage - Math.floor(this.MAX_PAGES_TO_SHOW / 2)\r\n    );\r\n    let endPage = Math.min(\r\n      this.totalPages,\r\n      startPage + this.MAX_PAGES_TO_SHOW - 1\r\n    );\r\n\r\n    if (endPage - startPage + 1 < this.MAX_PAGES_TO_SHOW) {\r\n      startPage = Math.max(1, endPage - this.MAX_PAGES_TO_SHOW + 1);\r\n    }\r\n\r\n    for (let i = startPage; i <= endPage; i++) {\r\n      this.pagesToShow.push(i);\r\n    }\r\n  }\r\n\r\n  private onPaginationChange(): void {\r\n    this.loadPage();\r\n    this.goToPageNumber = this.currentPage;\r\n    this.generatePagesToShow();\r\n  }\r\n\r\n  goToFirstPage(): void {\r\n    if (this.currentPage !== 1) {\r\n      this.currentPage = 1;\r\n      this.onPaginationChange();\r\n    }\r\n  }\r\n\r\n  goToPreviousPage(): void {\r\n    if (this.currentPage > 1) {\r\n      this.currentPage--;\r\n      this.onPaginationChange();\r\n    }\r\n  }\r\n\r\n  goToNextPage(): void {\r\n    if (this.currentPage < this.totalPages) {\r\n      this.currentPage++;\r\n      this.onPaginationChange();\r\n    }\r\n  }\r\n\r\n  goToLastPage(): void {\r\n    if (this.currentPage !== this.totalPages) {\r\n      this.currentPage = this.totalPages;\r\n      this.onPaginationChange();\r\n    }\r\n  }\r\n\r\n  goToPage(page: number): void {\r\n    if (page >= 1 && page <= this.totalPages && page !== this.currentPage) {\r\n      this.currentPage = page;\r\n      this.onPaginationChange();\r\n    }\r\n  }\r\n\r\n  goToSpecificPage(): void {\r\n    if (this.goToPageNumber == null) {\r\n      this.goToPageNumber = this.currentPage;\r\n      return;\r\n    }\r\n\r\n    const pageNum = parseInt(this.goToPageNumber.toString(), 10);\r\n\r\n    if (isNaN(pageNum) || pageNum < 1) {\r\n      this.goToPageNumber = 1;\r\n    } else if (pageNum > this.totalPages) {\r\n      this.goToPageNumber = this.totalPages;\r\n    }\r\n\r\n    this.currentPage = this.goToPageNumber;\r\n    this.onPaginationChange();\r\n  }\r\n\r\n  sortByColumn(columnId: string): void {\r\n    if (columnId === 'viewDetails' || this.tableData.metaData.isHeaderSortHidden) {\r\n      return;\r\n    }\r\n\r\n    this.isUserSort = true;\r\n\r\n    if (columnId !== this.sortColumn) {\r\n      this.sortColumn = columnId;\r\n      this.sortDirection = 'asc';\r\n    } else {\r\n      this.sortDirection = this.sortDirection === 'asc' ? 'desc' : 'asc';\r\n    }\r\n\r\n    this.performSort(columnId);\r\n    this.resetPaginationAfterSort();\r\n  }\r\n\r\n  private performSort(columnId: string): void {\r\n    this.itemList.sort((a, b) => {\r\n      const comparison = this.compareValues(a[columnId], b[columnId]);\r\n      return this.sortDirection === 'asc' ? comparison : -comparison;\r\n    });\r\n  }\r\n\r\n  private compareValues(v1: any, v2: any): number {\r\n    const num1 = parseFloat(v1);\r\n    const num2 = parseFloat(v2);\r\n\r\n    if (!isNaN(num1) && !isNaN(num2)) {\r\n      return num1 - num2;\r\n    }\r\n\r\n    return v1 < v2 ? -1 : v1 > v2 ? 1 : 0;\r\n  }\r\n\r\n  private resetPaginationAfterSort(): void {\r\n    this.currentPage = 1;\r\n    this.totalItems = this.itemList.length;\r\n    this.calculateTotalPages();\r\n    this.generatePagesToShow();\r\n    this.loadPage();\r\n  }\r\n\r\n  checkIfColumnCurrentlyBeingSorted(columnId: string): boolean {\r\n    return this.sortColumn === columnId;\r\n  }\r\n\r\n  getSortDirection(): string {\r\n    return this.sortDirection === 'asc' ? 'arrow-up' : 'arrow-down';\r\n  }\r\n\r\n  onEnter(event: Event): void {\r\n    const searchText = (event.target as HTMLInputElement).value;\r\n    \r\n    this.itemList = this.filterItems(searchText);\r\n    this.resetPaginationAfterSearch();\r\n  }\r\n\r\n  private filterItems(searchText: string): any[] {\r\n    if (!searchText) {\r\n      return [...this.masterList];\r\n    }\r\n\r\n    const lowerSearchText = searchText.toLowerCase();\r\n\r\n    return this.masterList.filter(item => \r\n      this.tableHeadList.some(header => {\r\n        const value = item[header];\r\n        if (value == null) return false;\r\n        \r\n        const searchableString = String(value).toLowerCase();\r\n        return searchableString.includes(lowerSearchText);\r\n      })\r\n    );\r\n  }\r\n\r\n  private resetPaginationAfterSearch(): void {\r\n    this.currentPage = 1;\r\n    this.totalItems = this.itemList.length;\r\n    this.calculateTotalPages();\r\n    this.generatePagesToShow();\r\n    this.loadPage();\r\n  }\r\n\r\n  getWidthById(columnId: string, index: number): string {\r\n     if (index === 0) {\r\n    return '10%'; // or '80px' for fixed width\r\n  }\r\n  \r\n    if (this.tableHeadList.length === 3) {\r\n      return index === 1 ? '60%' : '20%';\r\n    }\r\n    \r\n    const width = 100 / this.tableHeadList.length;\r\n    return `${width}%`;\r\n  }\r\n\r\n  preventNegative(event: KeyboardEvent): void {\r\n    const invalidKeys = ['-', '+', 'e', 'E'];\r\n    if (invalidKeys.includes(event.key)) {\r\n      event.preventDefault();\r\n    }\r\n  }\r\n\r\n  validateNumberInput(event: KeyboardEvent): boolean {\r\n    const charCode = event.which || event.keyCode;\r\n    if (charCode > 31 && (charCode < 48 || charCode > 57)) {\r\n      return false;\r\n    }\r\n    return true;\r\n  }\r\n\r\n  handleClick(data: any): void {\r\n    this.clickEvent.emit(data);\r\n  }\r\ngetCellAlignment(value: any, index: number): string {\r\n  // If all columns should be right aligned globally\r\n  // if (this.tableData.metaData.isAllAlignedToRight) {\r\n  //   return 'textalign-right';\r\n  // }\r\n\r\n  if (this.isColumnNumeric(value)) {\r\n    return 'textalign-right';\r\n  }\r\n  if (value === null || value === undefined) {\r\n    return 'textalign-left';\r\n  }\r\n   \r\n\r\n  const strValue = String(value).trim();\r\n\r\n  // Detect numeric, date, or alphanumeric ending with numbers\r\n  const isNumber = !isNaN(Number(strValue));\r\n  const isDate = !isNaN(Date.parse(strValue));\r\n  const isAlphaNumericWithTrailingNumber = /^[A-Za-z]*\\d+[A-Za-z0-9]*$/.test(strValue);\r\n\r\n  if (isNumber || isDate) {\r\n    return 'textalign-right';\r\n  }\r\n  return 'textalign-left';\r\n}\r\n\r\ngetHeaderAlignment(header: string, index: number): string {\r\n  if (this.isColumnNumeric(header)) {\r\n    return 'textalign-right';\r\n  }\r\n  return 'textalign-left';\r\n}\r\nisColumnNumeric(header: string): boolean {\r\n  return this.currentList.some(row => {\r\n    const value = row[header];\r\n\r\n    if (value === null || value === undefined) return false;\r\n\r\n    const str = String(value).trim();\r\n\r\n    // numeric values like 1, 23, 93.55\r\n    if (!isNaN(Number(str))) return true;\r\n\r\n    return false;\r\n  });\r\n}\r\n\r\n\r\n    shouldShowPagination(): boolean {\r\n    return !this.tableData?.metaData?.isPaginationHidden;\r\n  }\r\n}","<div class=\"d-flex align-items-center justify-content-between w-100\" [class.isria]=\"isRia\">\r\n  <div class=\"d-flex align-items-center gap-2\">\r\n    <lib-header-alt [title]=\"tableData.metaData.title\" [isria]=\"isRia\" *ngIf=\"!isHeaderVisible\"></lib-header-alt>\r\n  </div>\r\n\r\n  <input type=\"text\" *ngIf=\"!tableData.metaData.isSearchHidden\"\r\n    class=\"form-control custom-input medium-font-size textbox-ax-common\" [class.isria]=\"isRia\" id=\"exampleInputEmail1\" autocomplete=\"off\"\r\n    placeholder=\"  Search  \" aria-describedby=\"emailHelp\" (keyup)=\"onEnter($event)\" />\r\n</div>\r\n\r\n<div class=\"popup-body-for-scroll\"  [class.isria]=\"isRia\">\r\n  <div class=\"table-wrapper\">\r\n    <div class=\"table-responsive border\">\r\n      <table class=\"table table-bordered table-hover align-middle mb-0\">\r\n        <thead class=\"table-dark\">\r\n          <tr class=\"table-header\">\r\n            <th *ngFor=\"let header of tableHeadList; index as i\"  [ngClass]=\"getHeaderAlignment(header, i)\" [style.width]=\"getWidthById(header, i)\" [style.backgroundColor]=\"tableData.metaData.headerColor\"\r\n              [style.color]=\"tableData.metaData.headerTextColor\" (click)=\"sortByColumn(header)\" [ngStyle]=\"{ height: isRia ? '45px' : null , fontSize:isRia ? '14px' : null }\">\r\n              <span *ngIf=\"\r\n              (!tableData.metaData.isFirstColumnHeaderHidden && i == 0) || i > 0\r\n            \" [ngClass]=\"\r\n              !tableData.metaData.isHeaderSortHidden\r\n                ? 'cursor-pointer'\r\n                : 'cursor-default'\r\n            \">{{ header }}</span>\r\n              <i *ngIf=\"\r\n              (!isUserSort || checkIfColumnCurrentlyBeingSorted(header)) &&\r\n              !tableData.metaData.isHeaderSortHidden\r\n            \" class=\"sort-icons fa\" [ngClass]=\"\r\n              !isUserSort\r\n                ? 'fa-sort'\r\n                : sortDirection == 'asc'\r\n                ? 'fa-sort-asc'\r\n                : 'fa-sort-desc'\r\n            \"></i>\r\n            </th>\r\n          </tr>\r\n        </thead>\r\n\r\n        <tbody>\r\n          <tr *ngFor=\"let store of currentList\" [ngClass]=\"\r\n          tableData?.highlightedTexts?.includes(store[tableHeadList[0]])\r\n            ? 'font-weight-bold'\r\n            : ''\r\n        \">\r\n            <td (click)=\"handleClick(store)\" class=\"table-cell\" *ngFor=\"let header of tableHeadList; index as i\"\r\n              [style.width]=\"getWidthById(header, i)\" \r\n               [ngClass]=\"getCellAlignment(store[header], i)\"\r\n              [style.cursor]=\"\r\n            (tableData.metaData.hasDrillDown && !isRia) ? 'pointer' : 'default'\r\n          \">\r\n              <span>{{ store[header] }}</span>\r\n            </td>\r\n          </tr>\r\n          <tr *ngIf=\"!currentList || currentList.length === 0\"> <td [attr.colspan]=\"tableHeadList.length\" class=\"text-center\"> No data available </td> </tr>\r\n        </tbody>\r\n      </table>\r\n    </div>\r\n    <div class=\"pagination-bar mt-0\" [class.isria]=\"isRia\" *ngIf=\"shouldShowPagination()\">\r\n      <span>Go To</span>\r\n      <input type=\"number\" class=\"page-input\" min=\"1\" [max]=\"totalPages\" (keyup.enter)=\"goToSpecificPage()\" [(ngModel)]=\"goToPageNumber\"\r\n        (keypress)=\"preventNegative($event)\"\r\n      >\r\n\r\n      <span> {{ (currentList.length > 0 ? ((currentPage - 1) * pageSize + 1) : 0) }} -\r\n        {{ ((currentPage - 1) * pageSize + currentList.length) }} of\r\n        {{ totalItems | number }}</span>\r\n\r\n      <button [disabled]=\"currentPage === 1\" (click)=\"goToFirstPage()\" class=\"pagination-btn\" title=\"First Page\">\r\n        <i class=\"bi bi-chevron-double-left\"></i>\r\n      </button>\r\n      <button [disabled]=\"currentPage === 1\" (click)=\"goToPreviousPage()\" class=\"pagination-btn\" title=\"Previous Page\">\r\n        <i class=\"bi bi-chevron-left\"></i>\r\n      </button>\r\n      <button [disabled]=\"currentPage === totalPages\" (click)=\"goToNextPage()\" class=\"pagination-btn\" title=\"Next Page\">\r\n        <i class=\"bi bi-chevron-right\"></i>\r\n      </button>\r\n      <button [disabled]=\"currentPage === totalPages\" (click)=\"goToLastPage()\" class=\"pagination-btn\" title=\"Last Page\">\r\n        <i class=\"bi bi-chevron-double-right\"></i>\r\n      </button>\r\n    </div>\r\n  </div>\r\n</div>"]}
|
|
275
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ax-table.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/ax-table/ax-table.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/ax-table/ax-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';\r\nimport ChartHelper from '../chart-helper';\r\n\r\ninterface TableMetaData {\r\n  title?: string;\r\n  isPaginationHidden?: boolean;\r\n  isHeaderVisible?: boolean;\r\n  isSearchHidden?: boolean;\r\n  isHeaderAlignedToCenter?: boolean;\r\n  isHeaderSortHidden?: boolean;\r\n  isFirstColumnHeaderHidden?: boolean;\r\n  isAllAlignedToRight?: boolean;\r\n  hasDrillDown?: boolean;\r\n  headerColor?: string;\r\n  headerTextColor?: string;\r\n}\r\n\r\ninterface TableData {\r\n  data: any[];\r\n  featureInfo:any;\r\n  metaData: TableMetaData;\r\n  highlightedTexts?: string[];\r\n}\r\n\r\ntype SortDirection = 'asc' | 'desc';\r\n\r\n@Component({\r\n  selector: 'lib-ax-table',\r\n  templateUrl: './ax-table.component.html',\r\n  styleUrls: ['./ax-table.component.less', '../common-styles.less'],\r\n})\r\nexport class AxTableComponent implements OnInit {\r\n  @Input() tableData!: TableData;\r\n  @Input() customChartConfiguration: any;\r\n  @Output() clickEvent = new EventEmitter<any>();\r\n\r\n  isHeaderVisible = true;\r\n  isUserSort = false;\r\n\r\n  isRia: boolean = false;\r\n\r\n\r\n  tableHeadList: string[] = [];\r\n  itemList: any[] = [];\r\n  masterList: any[] = [];\r\n  currentList: any[] = [];\r\n\r\n  readonly DEFAULT_PAGE_SIZE = 10;\r\n  readonly MAX_PAGES_TO_SHOW = 5;\r\n  \r\n  currentPage = 1;\r\n  pageSize = this.DEFAULT_PAGE_SIZE;\r\n  totalItems = 0;\r\n  totalPages = 1;\r\n  goToPageNumber = 1;\r\n  pagesToShow: number[] = [];\r\n\r\n  sortDirection: SortDirection = 'asc';\r\n  sortColumn = '';\r\n\r\n  chartConfiguration: any = {};\r\n  defaultConfiguration: any = {};\r\n\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {\r\n    this.isRia = this.tableData?.featureInfo?.uiConfiguration?.customChartConfiguration?.isRia ?? false;\r\n    this.initializeComponent();\r\n  }\r\n\r\n  private initializeComponent(): void {\r\n    this.extractTableHeaders();\r\n    this.mergeConfigurations();\r\n    this.initializeData();\r\n    this.updateHeaderVisibility();\r\n  }\r\n\r\n  private extractTableHeaders(): void {\r\n    if (this.tableData?.data?.length > 0) {\r\n      this.tableHeadList = Object.keys(this.tableData.data[0]);\r\n    }\r\n  }\r\n\r\n  private mergeConfigurations(): void {\r\n    for (const key in this.defaultConfiguration) {\r\n      this.chartConfiguration[key] = ChartHelper.getValueByConfigurationType(\r\n        key,\r\n        this.defaultConfiguration,\r\n        this.customChartConfiguration\r\n      );\r\n    }\r\n  }\r\n\r\n  private initializeData(): void {\r\n    this.masterList = [...this.tableData.data];\r\n    this.itemList = [...this.masterList];\r\n    this.totalItems = this.itemList.length;\r\n    this.calculateTotalPages();\r\n    this.generatePagesToShow();\r\n\r\n    if (this.tableData.metaData.isPaginationHidden) {\r\n      this.currentList = this.itemList;\r\n    } else {\r\n      this.loadPage();\r\n    }\r\n  }\r\n\r\n  private updateHeaderVisibility(): void {\r\n    if (this.tableData.metaData.isHeaderVisible !== undefined) {\r\n      this.isHeaderVisible = this.tableData.metaData.isHeaderVisible;\r\n    }\r\n  }\r\n\r\n  private loadPage(): void {\r\n    const startIndex = (this.currentPage - 1) * this.pageSize;\r\n    const endIndex = startIndex + this.pageSize;\r\n    this.currentList = this.itemList.slice(startIndex, endIndex);\r\n  }\r\n\r\n  private calculateTotalPages(): void {\r\n    this.totalPages = Math.ceil(this.totalItems / this.pageSize);\r\n    this.goToPageNumber = this.currentPage;\r\n  }\r\n\r\n  private generatePagesToShow(): void {\r\n    this.pagesToShow = [];\r\n    \r\n    let startPage = Math.max(\r\n      1,\r\n      this.currentPage - Math.floor(this.MAX_PAGES_TO_SHOW / 2)\r\n    );\r\n    let endPage = Math.min(\r\n      this.totalPages,\r\n      startPage + this.MAX_PAGES_TO_SHOW - 1\r\n    );\r\n\r\n    if (endPage - startPage + 1 < this.MAX_PAGES_TO_SHOW) {\r\n      startPage = Math.max(1, endPage - this.MAX_PAGES_TO_SHOW + 1);\r\n    }\r\n\r\n    for (let i = startPage; i <= endPage; i++) {\r\n      this.pagesToShow.push(i);\r\n    }\r\n  }\r\n\r\n  private onPaginationChange(): void {\r\n    this.loadPage();\r\n    this.goToPageNumber = this.currentPage;\r\n    this.generatePagesToShow();\r\n  }\r\n\r\n  goToFirstPage(): void {\r\n    if (this.currentPage !== 1) {\r\n      this.currentPage = 1;\r\n      this.onPaginationChange();\r\n    }\r\n  }\r\n\r\n  goToPreviousPage(): void {\r\n    if (this.currentPage > 1) {\r\n      this.currentPage--;\r\n      this.onPaginationChange();\r\n    }\r\n  }\r\n\r\n  goToNextPage(): void {\r\n    if (this.currentPage < this.totalPages) {\r\n      this.currentPage++;\r\n      this.onPaginationChange();\r\n    }\r\n  }\r\n\r\n  goToLastPage(): void {\r\n    if (this.currentPage !== this.totalPages) {\r\n      this.currentPage = this.totalPages;\r\n      this.onPaginationChange();\r\n    }\r\n  }\r\n\r\n  goToPage(page: number): void {\r\n    if (page >= 1 && page <= this.totalPages && page !== this.currentPage) {\r\n      this.currentPage = page;\r\n      this.onPaginationChange();\r\n    }\r\n  }\r\n\r\n  goToSpecificPage(): void {\r\n    if (this.goToPageNumber == null) {\r\n      this.goToPageNumber = this.currentPage;\r\n      return;\r\n    }\r\n\r\n    const pageNum = parseInt(this.goToPageNumber.toString(), 10);\r\n\r\n    if (isNaN(pageNum) || pageNum < 1) {\r\n      this.goToPageNumber = 1;\r\n    } else if (pageNum > this.totalPages) {\r\n      this.goToPageNumber = this.totalPages;\r\n    }\r\n\r\n    this.currentPage = this.goToPageNumber;\r\n    this.onPaginationChange();\r\n  }\r\n\r\n  sortByColumn(columnId: string): void {\r\n    if (columnId === 'viewDetails' || this.tableData.metaData.isHeaderSortHidden) {\r\n      return;\r\n    }\r\n\r\n    this.isUserSort = true;\r\n\r\n    if (columnId !== this.sortColumn) {\r\n      this.sortColumn = columnId;\r\n      this.sortDirection = 'asc';\r\n    } else {\r\n      this.sortDirection = this.sortDirection === 'asc' ? 'desc' : 'asc';\r\n    }\r\n\r\n    this.performSort(columnId);\r\n    this.resetPaginationAfterSort();\r\n  }\r\n\r\n  private performSort(columnId: string): void {\r\n    this.itemList.sort((a, b) => {\r\n      const comparison = this.compareValues(a[columnId], b[columnId]);\r\n      return this.sortDirection === 'asc' ? comparison : -comparison;\r\n    });\r\n  }\r\n\r\n  private compareValues(v1: any, v2: any): number {\r\n    const num1 = parseFloat(v1);\r\n    const num2 = parseFloat(v2);\r\n\r\n    if (!isNaN(num1) && !isNaN(num2)) {\r\n      return num1 - num2;\r\n    }\r\n\r\n    return v1 < v2 ? -1 : v1 > v2 ? 1 : 0;\r\n  }\r\n\r\n  private resetPaginationAfterSort(): void {\r\n    this.currentPage = 1;\r\n    this.totalItems = this.itemList.length;\r\n    this.calculateTotalPages();\r\n    this.generatePagesToShow();\r\n    this.loadPage();\r\n  }\r\n\r\n  checkIfColumnCurrentlyBeingSorted(columnId: string): boolean {\r\n    return this.sortColumn === columnId;\r\n  }\r\n\r\n  getSortDirection(): string {\r\n    return this.sortDirection === 'asc' ? 'arrow-up' : 'arrow-down';\r\n  }\r\n\r\n  onEnter(event: Event): void {\r\n    const searchText = (event.target as HTMLInputElement).value;\r\n    \r\n    this.itemList = this.filterItems(searchText);\r\n    this.resetPaginationAfterSearch();\r\n  }\r\n\r\n  private filterItems(searchText: string): any[] {\r\n    if (!searchText) {\r\n      return [...this.masterList];\r\n    }\r\n\r\n    const lowerSearchText = searchText.toLowerCase();\r\n\r\n    return this.masterList.filter(item => \r\n      this.tableHeadList.some(header => {\r\n        const value = item[header];\r\n        if (value == null) return false;\r\n        \r\n        const searchableString = String(value).toLowerCase();\r\n        return searchableString.includes(lowerSearchText);\r\n      })\r\n    );\r\n  }\r\n\r\n  private resetPaginationAfterSearch(): void {\r\n    this.currentPage = 1;\r\n    this.totalItems = this.itemList.length;\r\n    this.calculateTotalPages();\r\n    this.generatePagesToShow();\r\n    this.loadPage();\r\n  }\r\n\r\n  getWidthById(columnId: string, index: number): string {\r\n     if (index === 0) {\r\n    return '10%'; // or '80px' for fixed width\r\n  }\r\n  \r\n    if (this.tableHeadList.length === 3) {\r\n      return index === 1 ? '60%' : '20%';\r\n    }\r\n    \r\n    const width = 100 / this.tableHeadList.length;\r\n    return `${width}%`;\r\n  }\r\n\r\n  preventNegative(event: KeyboardEvent): void {\r\n    const invalidKeys = ['-', '+', 'e', 'E'];\r\n    if (invalidKeys.includes(event.key)) {\r\n      event.preventDefault();\r\n    }\r\n  }\r\n\r\n  validateNumberInput(event: KeyboardEvent): boolean {\r\n    const charCode = event.which || event.keyCode;\r\n    if (charCode > 31 && (charCode < 48 || charCode > 57)) {\r\n      return false;\r\n    }\r\n    return true;\r\n  }\r\n\r\n  handleClick(data: any): void {\r\n    this.clickEvent.emit(data);\r\n  }\r\ngetCellAlignment(value: any, index: number): string {\r\n  const header = this.tableHeadList[index];\r\n  \r\n  if (this.isColumnNumeric(header)) {\r\n    return 'textalign-right';\r\n  }\r\n  \r\n  return 'textalign-left';\r\n}\r\n\r\ngetHeaderAlignment(header: string, index: number): string {\r\n  if (this.isColumnNumeric(header)) {\r\n    return 'textalign-right';\r\n  }\r\n  return 'textalign-left';\r\n}\r\nisColumnNumeric(header: string): boolean {\r\n  const listToCheck = this.currentList.length > 0 ? this.currentList : this.itemList;\r\n  \r\n  if (!listToCheck || listToCheck.length === 0) {\r\n    return false;\r\n  }\r\n  \r\n  return listToCheck.some(row => {\r\n    const value = row[header];\r\n\r\n    if (value === null || value === undefined || value === '') return false;\r\n\r\n    const str = String(value).trim();\r\n\r\n    if (!isNaN(Number(str)) && str !== '') return true;\r\n\r\n    return false;\r\n  });\r\n}\r\n\r\n\r\n    shouldShowPagination(): boolean {\r\n    return !this.tableData?.metaData?.isPaginationHidden;\r\n  }\r\n}","<div class=\"d-flex align-items-center justify-content-between w-100\" [class.isria]=\"isRia\">\r\n  <div class=\"d-flex align-items-center gap-2\">\r\n    <lib-header-alt [title]=\"tableData.metaData.title\" [isria]=\"isRia\" *ngIf=\"!isHeaderVisible\"></lib-header-alt>\r\n  </div>\r\n\r\n  <input type=\"text\" *ngIf=\"!tableData.metaData.isSearchHidden\"\r\n    class=\"form-control custom-input medium-font-size textbox-ax-common\" [class.isria]=\"isRia\" id=\"exampleInputEmail1\" autocomplete=\"off\"\r\n    placeholder=\"  Search  \" aria-describedby=\"emailHelp\" (keyup)=\"onEnter($event)\" />\r\n</div>\r\n\r\n<div class=\"popup-body-for-scroll\"  [class.isria]=\"isRia\">\r\n  <div class=\"table-wrapper\">\r\n    <div class=\"table-responsive border\">\r\n      <table class=\"table table-bordered table-hover align-middle mb-0\">\r\n        <thead class=\"table-dark\">\r\n          <tr class=\"table-header\">\r\n            <th *ngFor=\"let header of tableHeadList; index as i\"  [ngClass]=\"getHeaderAlignment(header, i)\" [style.width]=\"getWidthById(header, i)\" [style.backgroundColor]=\"tableData.metaData.headerColor\"\r\n              [style.color]=\"tableData.metaData.headerTextColor\" (click)=\"sortByColumn(header)\" [ngStyle]=\"{ height: isRia ? '45px' : null , fontSize:isRia ? '14px' : null }\">\r\n              <span *ngIf=\"\r\n              (!tableData.metaData.isFirstColumnHeaderHidden && i == 0) || i > 0\r\n            \" [ngClass]=\"\r\n              !tableData.metaData.isHeaderSortHidden\r\n                ? 'cursor-pointer'\r\n                : 'cursor-default'\r\n            \">{{ header }}</span>\r\n              <i *ngIf=\"\r\n              (!isUserSort || checkIfColumnCurrentlyBeingSorted(header)) &&\r\n              !tableData.metaData.isHeaderSortHidden\r\n            \" class=\"sort-icons fa\" [ngClass]=\"\r\n              !isUserSort\r\n                ? 'fa-sort'\r\n                : sortDirection == 'asc'\r\n                ? 'fa-sort-asc'\r\n                : 'fa-sort-desc'\r\n            \"></i>\r\n            </th>\r\n          </tr>\r\n        </thead>\r\n\r\n        <tbody>\r\n          <tr *ngFor=\"let store of currentList\" [ngClass]=\"\r\n          tableData?.highlightedTexts?.includes(store[tableHeadList[0]])\r\n            ? 'font-weight-bold'\r\n            : ''\r\n        \">\r\n            <td (click)=\"handleClick(store)\" class=\"table-cell\" *ngFor=\"let header of tableHeadList; index as i\"\r\n              [style.width]=\"getWidthById(header, i)\" \r\n               [ngClass]=\"getCellAlignment(store[header], i)\"\r\n              [style.cursor]=\"\r\n            (tableData.metaData.hasDrillDown && !isRia) ? 'pointer' : 'default'\r\n          \">\r\n              <span>{{ store[header] }}</span>\r\n            </td>\r\n          </tr>\r\n          <tr *ngIf=\"!currentList || currentList.length === 0\"> <td [attr.colspan]=\"tableHeadList.length\" class=\"text-center\"> No data available </td> </tr>\r\n        </tbody>\r\n      </table>\r\n    </div>\r\n    <div class=\"pagination-bar mt-0\" [class.isria]=\"isRia\" *ngIf=\"shouldShowPagination()\">\r\n      <span>Go To</span>\r\n      <input type=\"number\" class=\"page-input\" min=\"1\" [max]=\"totalPages\" (keyup.enter)=\"goToSpecificPage()\" [(ngModel)]=\"goToPageNumber\"\r\n        (keypress)=\"preventNegative($event)\"\r\n      >\r\n\r\n      <span> {{ (currentList.length > 0 ? ((currentPage - 1) * pageSize + 1) : 0) }} -\r\n        {{ ((currentPage - 1) * pageSize + currentList.length) }} of\r\n        {{ totalItems | number }}</span>\r\n\r\n      <button [disabled]=\"currentPage === 1\" (click)=\"goToFirstPage()\" class=\"pagination-btn\" title=\"First Page\">\r\n        <i class=\"bi bi-chevron-double-left\"></i>\r\n      </button>\r\n      <button [disabled]=\"currentPage === 1\" (click)=\"goToPreviousPage()\" class=\"pagination-btn\" title=\"Previous Page\">\r\n        <i class=\"bi bi-chevron-left\"></i>\r\n      </button>\r\n      <button [disabled]=\"currentPage === totalPages\" (click)=\"goToNextPage()\" class=\"pagination-btn\" title=\"Next Page\">\r\n        <i class=\"bi bi-chevron-right\"></i>\r\n      </button>\r\n      <button [disabled]=\"currentPage === totalPages\" (click)=\"goToLastPage()\" class=\"pagination-btn\" title=\"Last Page\">\r\n        <i class=\"bi bi-chevron-double-right\"></i>\r\n      </button>\r\n    </div>\r\n  </div>\r\n</div>"]}
|
|
@@ -17,7 +17,6 @@ export class ChartHeaderV2Component {
|
|
|
17
17
|
this.clickEvent.emit(d);
|
|
18
18
|
}
|
|
19
19
|
isZoomOutSelected(isZoomOut, event) {
|
|
20
|
-
this.isZoomedOut = isZoomOut;
|
|
21
20
|
this.zoomInZoomOutClick.emit({ isZoomOut: isZoomOut, event: event });
|
|
22
21
|
}
|
|
23
22
|
handleGaugeChartVisibility() {
|
|
@@ -55,4 +54,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
55
54
|
}], compareByFilterSelection: [{
|
|
56
55
|
type: Output
|
|
57
56
|
}] } });
|
|
58
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart-header-v2.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/chart-header-v2/chart-header-v2.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/chart-header-v2/chart-header-v2.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;;AAOvE,MAAM,OAAO,sBAAsB;IALnC;QAQY,eAAU,GAAG,IAAI,YAAY,EAAO,CAAC;QACrC,uBAAkB,GAAG,IAAI,YAAY,EAAO,CAAC;QAC9C,6BAAwB,GAAG,IAAI,YAAY,EAAO,CAAC;QAG5D,cAAS,GAAY,KAAK,CAAC;QAC3B,cAAS,GAAY,KAAK,CAAC;QAC3B,gBAAW,GAAY,IAAI,CAAC;QA8B5B,cAAS,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YACnB,OAAO,CAAC,CAAC;QACX,CAAC,CAAC;KACH;IA9BC,WAAW,CAAC,CAAM;QAChB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;IACD,iBAAiB,CAAC,SAAS,EAAE,KAAK;QAChC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;IACvE,CAAC;IACD,0BAA0B;QACxB,IACE,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,EAAE,YAAY,CAAC,GAAG,CAAC;YACtD,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,KAAK,CAAC,GAAG,CAAC,EAC3C,CAAC;YACD,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IACA,cAAc;QACb,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IACD,cAAc;QACZ,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IACD,8BAA8B,CAAC,KAAK;QAClC,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5C,CAAC;+GAtCU,sBAAsB;mGAAtB,sBAAsB,gRCPnC,ouHAwFA;;4FDjFa,sBAAsB;kBALlC,SAAS;+BACE,qBAAqB;8BAKtB,SAAS;sBAAjB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACI,UAAU;sBAAnB,MAAM;gBACG,kBAAkB;sBAA3B,MAAM;gBACE,wBAAwB;sBAAjC,MAAM","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'lib-chart-header-v2',\r\n  templateUrl: './chart-header-v2.component.html',\r\n  styleUrl: './chart-header-v2.component.less',\r\n})\r\nexport class ChartHeaderV2Component {\r\n  @Input() chartData: any;\r\n  @Input() chartConfiguration: any;\r\n  @Output() clickEvent = new EventEmitter<any>();\r\n  @Output() zoomInZoomOutClick = new EventEmitter<any>();\r\n @Output() compareByFilterSelection = new EventEmitter<any>();\r\n\r\n\r\n  isDD1Open: boolean = false;\r\n  isDD2Open: boolean = false;\r\n  isZoomedOut: boolean = true;\r\n\r\n\r\n  handleClick(d: any) {\r\n    this.clickEvent.emit(d);\r\n  }\r\n  isZoomOutSelected(isZoomOut, event) {\r\n    this.zoomInZoomOutClick.emit({ isZoomOut: isZoomOut, event: event });\r\n  }\r\n  handleGaugeChartVisibility() {\r\n    if (\r\n      parseFloat(this.chartData?.metaData?.currentValue) > 0 ||\r\n      parseFloat(this.chartData?.data?.value) > 0\r\n    ) {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n   handleDD1Click() {\r\n    this.isDD1Open = true;\r\n    this.isDD2Open = false;\r\n  }\r\n  handleDD2Click() {\r\n    this.isDD2Open = true;\r\n    this.isDD1Open = false;\r\n  }\r\n  handleCompareByFilterSelection(event) {\r\n    this.compareByFilterSelection.emit(event);\r\n  }\r\n  \r\n  keepOrder = (a, b) => {\r\n    return a;\r\n  };\r\n}\r\n","<div\r\n  class=\"headerv2 lib-display-flex header-title-styles \"\r\n   [ngClass]=\"'lib-justify-content-end'\"\r\n>\r\n  <!-- <span [ngClass]=\"!chartConfiguration.isTitleHidden ? '' : 'hidden'\">\r\n    <lib-header-alt [title]=\"chartData.metaData.title\"></lib-header-alt>\r\n  </span> -->\r\n  <span\r\n    *ngIf=\"\r\n      (chartData.dropdownData1 &&\r\n        chartData.metaData.breadcrumbLength &&\r\n        chartData.metaData.breadcrumbLength == 1 &&\r\n        (chartConfiguration?.isToggleVisible ||\r\n          chartData.metaData.isToggleVisible)) ||\r\n      (chartData.metaData.breadcrumbLength > 1 &&\r\n        !chartData.dropdownData1 &&\r\n        (chartConfiguration?.isToggleVisible ||\r\n          chartData.metaData.isToggleVisible)) ||\r\n      (chartData.dropdownData2 &&\r\n        !chartData.dropdownData1 &&\r\n        chartData.metaData.breadcrumbLength == 1 &&\r\n        (chartConfiguration?.isToggleVisible ||\r\n          chartData.metaData.isToggleVisible)) ||\r\n      ((chartData.metaData.type == 'GAUGE' ||\r\n        chartData.metaData.type == 'NUMBERCHART') &&\r\n        chartConfiguration.isToggleVisible &&\r\n        handleGaugeChartVisibility())\r\n    \"\r\n    class=\"marginLeft-20 flex-inline marginRight-15\"\r\n  >\r\n    <span class=\"font-size-2\">Trending</span>\r\n    <span\r\n      class=\"switch\"\r\n      (click)=\"\r\n        handleClick(\r\n          chartData.metaData.type == 'NUMBERCHART'\r\n            ? { toggleFrom: 'plainTrend' }\r\n            : chartData.metaData.type == 'GAUGE'\r\n            ? { toggleFrom: 'gauge' }\r\n            : chartData.metaData.toggleVersion\r\n            ? { toggleFrom: 'groupchart-v1' }\r\n            : { toggleFrom: 'groupchart' }\r\n        )\r\n      \"\r\n    >\r\n      <input type=\"checkbox\" />\r\n      <span\r\n        [ngClass]=\"{\r\n          'slider1 round1': chartData && chartData.metaData.isToggled,\r\n          'slider round': chartData && !chartData.metaData.isToggled\r\n        }\"\r\n      ></span>\r\n    </span>\r\n    <span class=\"font-size-2\">Average</span>\r\n  </span>\r\n  <div class=\"lib-display-flex header-title-styles\">  \r\n  <span class=\"display-flex\">\r\n    <!-- <span *ngIf=\"\r\n        chartData.dropdownData1 &&\r\n        chartData.metaData.breadcrumbLength &&\r\n        chartData.metaData.breadcrumbLength == 1\r\n      \">\r\n      <lib-dropdown [dropdownData]=\"chartData.dropdownData1\" [isDropdownOpen]=\"this.isDD1Open\"\r\n        (ddClicked)=\"handleDD1Click()\" (selectedFromDropdown)=\"handleCompareByFilterSelection($event)\"></lib-dropdown>\r\n    </span>\r\n    <span *ngIf=\"\r\n        chartData.dropdownData2 &&\r\n        chartData.metaData.breadcrumbLength &&\r\n        chartData.metaData.breadcrumbLength == 1\r\n      \">\r\n      <lib-dropdown [dropdownData]=\"chartData.dropdownData2\" [isDropdownOpen]=\"this.isDD2Open\"\r\n        (ddClicked)=\"handleDD2Click()\" (selectedFromDropdown)=\"handleCompareByFilterSelection($event)\"\r\n        [isCheckboxVisible]=\"chartData.metaData.isCheckboxVisible\"\r\n        [dropdownHeaderName]=\"chartData.metaData.dropdownHeaderName\"></lib-dropdown>\r\n    </span> -->\r\n    <span class=\"zoomIcons-holder\" *ngIf=\"chartData.data && chartData.data.length > 8\">\r\n      <span class=\"zoomIcons\" title=\"Zoom In\" [ngClass]=\"!isZoomedOut ? 'zoom-active' : 'zoom-inactive'\"\r\n        (click)=\"isZoomOutSelected(false, $event)\">\r\n        <i class=\"fa fa-search-plus\"></i>\r\n      </span>\r\n      <span class=\"zoomIcons\" title=\"Zoom Out\" [ngClass]=\"isZoomedOut ? 'zoom-active' : 'zoom-inactive'\"\r\n        (click)=\"isZoomOutSelected(true, $event)\">\r\n        <i class=\"fa fa-search-minus\"></i>\r\n      </span>\r\n    </span>\r\n  </span>\r\n</div>\r\n</div>\r\n"]}
|
|
@@ -36,11 +36,11 @@ export class ChartHeaderV3Component {
|
|
|
36
36
|
this.zoomInZoomOutClick.emit({ isZoomOut: this.isZoomedOut, event: event });
|
|
37
37
|
}
|
|
38
38
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ChartHeaderV3Component, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
39
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ChartHeaderV3Component, selector: "lib-chart-header-v3", inputs: { chartData: "chartData", chartConfiguration: "chartConfiguration" }, outputs: { compareByFilterSelection: "compareByFilterSelection", zoomInZoomOutClick: "zoomInZoomOutClick" }, ngImport: i0, template: "<div class=\"lib-display-flex header-title-styles\" [ngClass]=\"\r\n !chartData.dropdownData2 &&\r\n !chartData.dropdownData1 &&\r\n chartData.data.length <= 8\r\n ? 'lib-justify-content-start'\r\n : 'lib-justify-content-space-between'\r\n \">\r\n <span class=\"legend-latest-holder\" *ngIf=\"\r\n chartData.data &&\r\n chartData.metaData.default_dept &&\r\n (chartConfiguration.isToggleVisible || chartData.metaData.isToggleVisible)\r\n \">\r\n <span *ngFor=\"let item of chartData.metaData.colors | keyvalue : keepOrder\"><span class=\"legends-latest\"\r\n *ngIf=\"chartData.metaData.default_dept == item.key\" [style.background-color]=\"item.value\"></span></span>\r\n <span class=\"marginRight-30 legend-style font-size-2\" *ngIf=\"chartData.metaData.default_dept\">\r\n Default Dept: {{ chartData.metaData.default_dept }}\r\n </span>\r\n <span *ngFor=\"let item of chartData.metaData.colors | keyvalue : keepOrder\"><span *ngIf=\"\r\n item.key != chartData.metaData.default_dept &&\r\n chartData.metaData.default_dept\r\n \" class=\"legends-latest\" [style.background-color]=\"item.value\"></span></span>\r\n <span class=\"legend-style font-size-2\" *ngIf=\"isLegendVisible() && chartData.metaData.default_dept\">Cross Train\r\n Dept</span>\r\n </span>\r\n <span class=\"legend-latest-holder legend-width\"\r\n [ngClass]=\"chartData.metaData.colorLegendVisibleOnTopLeft ? '' : 'invisible'\"\r\n *ngIf=\"chartData.data && !chartData.metaData.default_dept\">\r\n <span class=\"lib-display-flex lib-align-items-center\"\r\n *ngFor=\"let item of chartData.metaData.colors | keyvalue : keepOrder\"><span class=\"legends-latest\"\r\n [style.background-color]=\"item.value\"></span>\r\n <span class=\"marginRight-20 legend-style font-size-1 lib-white-space-nowrap\">\r\n {{ item.key }}\r\n </span>\r\n </span>\r\n </span>\r\n <!-- <span class=\"display-flex\"> -->\r\n <!-- <span *ngIf=\"\r\n chartData.dropdownData1 &&\r\n chartData.metaData.breadcrumbLength &&\r\n chartData.metaData.breadcrumbLength == 1\r\n \">\r\n <lib-dropdown [dropdownData]=\"chartData.dropdownData1\" [isDropdownOpen]=\"this.isDD1Open\"\r\n (ddClicked)=\"handleDD1Click()\" (selectedFromDropdown)=\"handleCompareByFilterSelection($event)\"></lib-dropdown>\r\n </span>\r\n <span *ngIf=\"\r\n chartData.dropdownData2 &&\r\n chartData.metaData.breadcrumbLength &&\r\n chartData.metaData.breadcrumbLength == 1\r\n \">\r\n <lib-dropdown [dropdownData]=\"chartData.dropdownData2\" [isDropdownOpen]=\"this.isDD2Open\"\r\n (ddClicked)=\"handleDD2Click()\" (selectedFromDropdown)=\"handleCompareByFilterSelection($event)\"\r\n [isCheckboxVisible]=\"chartData.metaData.isCheckboxVisible\"\r\n [dropdownHeaderName]=\"chartData.metaData.dropdownHeaderName\"></lib-dropdown>\r\n </span> -->\r\n <!-- <span class=\"zoomIcons-holder\" *ngIf=\"chartData.data && chartData.data.length > 8\">\r\n <span class=\"zoomIcons\" title=\"Zoom In\" [ngClass]=\"!isZoomedOut ? 'zoom-active' : 'zoom-inactive'\"\r\n (click)=\"isZoomOutSelected(false, $event)\">\r\n <i class=\"fa fa-search-plus\"></i>\r\n </span>\r\n <span class=\"zoomIcons\" title=\"Zoom Out\" [ngClass]=\"isZoomedOut ? 'zoom-active' : 'zoom-inactive'\"\r\n (click)=\"isZoomOutSelected(true, $event)\">\r\n <i class=\"fa fa-search-minus\"></i>\r\n </span>\r\n </span>\r\n </span> -->\r\n</div>", styles: [".invisible{visibility:hidden}.hidden{visibility:hidden!important}.content-hidden{visibility:hidden}.opacity-hidden{opacity:0;pointer-events:none}@media (min-height: 500px){.legend-width{max-width:550px;overflow:auto}}@media (min-height: 900px){.header-title-styles{margin-left:
|
|
39
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ChartHeaderV3Component, selector: "lib-chart-header-v3", inputs: { chartData: "chartData", chartConfiguration: "chartConfiguration" }, outputs: { compareByFilterSelection: "compareByFilterSelection", zoomInZoomOutClick: "zoomInZoomOutClick" }, ngImport: i0, template: "<div class=\"lib-display-flex header-title-styles\" [ngClass]=\"\r\n !chartData.dropdownData2 &&\r\n !chartData.dropdownData1 &&\r\n chartData.data.length <= 8\r\n ? 'lib-justify-content-start'\r\n : 'lib-justify-content-space-between'\r\n \">\r\n <span class=\"legend-latest-holder\" *ngIf=\"\r\n chartData.data &&\r\n chartData.metaData.default_dept &&\r\n (chartConfiguration.isToggleVisible || chartData.metaData.isToggleVisible)\r\n \">\r\n <span *ngFor=\"let item of chartData.metaData.colors | keyvalue : keepOrder\"><span class=\"legends-latest\"\r\n *ngIf=\"chartData.metaData.default_dept == item.key\" [style.background-color]=\"item.value\"></span></span>\r\n <span class=\"marginRight-30 legend-style font-size-2\" *ngIf=\"chartData.metaData.default_dept\">\r\n Default Dept: {{ chartData.metaData.default_dept }}\r\n </span>\r\n <span *ngFor=\"let item of chartData.metaData.colors | keyvalue : keepOrder\"><span *ngIf=\"\r\n item.key != chartData.metaData.default_dept &&\r\n chartData.metaData.default_dept\r\n \" class=\"legends-latest\" [style.background-color]=\"item.value\"></span></span>\r\n <span class=\"legend-style font-size-2\" *ngIf=\"isLegendVisible() && chartData.metaData.default_dept\">Cross Train\r\n Dept</span>\r\n </span>\r\n <span class=\"legend-latest-holder legend-width\"\r\n [ngClass]=\"chartData.metaData.colorLegendVisibleOnTopLeft ? '' : 'invisible'\"\r\n *ngIf=\"chartData.data && !chartData.metaData.default_dept\">\r\n <span class=\"lib-display-flex lib-align-items-center\"\r\n *ngFor=\"let item of chartData.metaData.colors | keyvalue : keepOrder\"><span class=\"legends-latest\"\r\n [style.background-color]=\"item.value\"></span>\r\n <span class=\"marginRight-20 legend-style font-size-1 lib-white-space-nowrap\">\r\n {{ item.key }}\r\n </span>\r\n </span>\r\n </span>\r\n <!-- <span class=\"display-flex\"> -->\r\n <!-- <span *ngIf=\"\r\n chartData.dropdownData1 &&\r\n chartData.metaData.breadcrumbLength &&\r\n chartData.metaData.breadcrumbLength == 1\r\n \">\r\n <lib-dropdown [dropdownData]=\"chartData.dropdownData1\" [isDropdownOpen]=\"this.isDD1Open\"\r\n (ddClicked)=\"handleDD1Click()\" (selectedFromDropdown)=\"handleCompareByFilterSelection($event)\"></lib-dropdown>\r\n </span>\r\n <span *ngIf=\"\r\n chartData.dropdownData2 &&\r\n chartData.metaData.breadcrumbLength &&\r\n chartData.metaData.breadcrumbLength == 1\r\n \">\r\n <lib-dropdown [dropdownData]=\"chartData.dropdownData2\" [isDropdownOpen]=\"this.isDD2Open\"\r\n (ddClicked)=\"handleDD2Click()\" (selectedFromDropdown)=\"handleCompareByFilterSelection($event)\"\r\n [isCheckboxVisible]=\"chartData.metaData.isCheckboxVisible\"\r\n [dropdownHeaderName]=\"chartData.metaData.dropdownHeaderName\"></lib-dropdown>\r\n </span> -->\r\n <!-- <span class=\"zoomIcons-holder\" *ngIf=\"chartData.data && chartData.data.length > 8\">\r\n <span class=\"zoomIcons\" title=\"Zoom In\" [ngClass]=\"!isZoomedOut ? 'zoom-active' : 'zoom-inactive'\"\r\n (click)=\"isZoomOutSelected(false, $event)\">\r\n <i class=\"fa fa-search-plus\"></i>\r\n </span>\r\n <span class=\"zoomIcons\" title=\"Zoom Out\" [ngClass]=\"isZoomedOut ? 'zoom-active' : 'zoom-inactive'\"\r\n (click)=\"isZoomOutSelected(true, $event)\">\r\n <i class=\"fa fa-search-minus\"></i>\r\n </span>\r\n </span>\r\n </span> -->\r\n</div>", styles: [".invisible{visibility:hidden}.hidden{visibility:hidden!important}.content-hidden{visibility:hidden}.opacity-hidden{opacity:0;pointer-events:none}@media (min-height: 500px){.legend-width{max-width:550px;overflow:auto}}@media (min-height: 900px){.header-title-styles{margin-left:35px;margin-top:12px;margin-bottom:25px}.legend-width{max-width:700px;overflow:auto}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.KeyValuePipe, name: "keyvalue" }] }); }
|
|
40
40
|
}
|
|
41
41
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ChartHeaderV3Component, decorators: [{
|
|
42
42
|
type: Component,
|
|
43
|
-
args: [{ selector: 'lib-chart-header-v3', template: "<div class=\"lib-display-flex header-title-styles\" [ngClass]=\"\r\n !chartData.dropdownData2 &&\r\n !chartData.dropdownData1 &&\r\n chartData.data.length <= 8\r\n ? 'lib-justify-content-start'\r\n : 'lib-justify-content-space-between'\r\n \">\r\n <span class=\"legend-latest-holder\" *ngIf=\"\r\n chartData.data &&\r\n chartData.metaData.default_dept &&\r\n (chartConfiguration.isToggleVisible || chartData.metaData.isToggleVisible)\r\n \">\r\n <span *ngFor=\"let item of chartData.metaData.colors | keyvalue : keepOrder\"><span class=\"legends-latest\"\r\n *ngIf=\"chartData.metaData.default_dept == item.key\" [style.background-color]=\"item.value\"></span></span>\r\n <span class=\"marginRight-30 legend-style font-size-2\" *ngIf=\"chartData.metaData.default_dept\">\r\n Default Dept: {{ chartData.metaData.default_dept }}\r\n </span>\r\n <span *ngFor=\"let item of chartData.metaData.colors | keyvalue : keepOrder\"><span *ngIf=\"\r\n item.key != chartData.metaData.default_dept &&\r\n chartData.metaData.default_dept\r\n \" class=\"legends-latest\" [style.background-color]=\"item.value\"></span></span>\r\n <span class=\"legend-style font-size-2\" *ngIf=\"isLegendVisible() && chartData.metaData.default_dept\">Cross Train\r\n Dept</span>\r\n </span>\r\n <span class=\"legend-latest-holder legend-width\"\r\n [ngClass]=\"chartData.metaData.colorLegendVisibleOnTopLeft ? '' : 'invisible'\"\r\n *ngIf=\"chartData.data && !chartData.metaData.default_dept\">\r\n <span class=\"lib-display-flex lib-align-items-center\"\r\n *ngFor=\"let item of chartData.metaData.colors | keyvalue : keepOrder\"><span class=\"legends-latest\"\r\n [style.background-color]=\"item.value\"></span>\r\n <span class=\"marginRight-20 legend-style font-size-1 lib-white-space-nowrap\">\r\n {{ item.key }}\r\n </span>\r\n </span>\r\n </span>\r\n <!-- <span class=\"display-flex\"> -->\r\n <!-- <span *ngIf=\"\r\n chartData.dropdownData1 &&\r\n chartData.metaData.breadcrumbLength &&\r\n chartData.metaData.breadcrumbLength == 1\r\n \">\r\n <lib-dropdown [dropdownData]=\"chartData.dropdownData1\" [isDropdownOpen]=\"this.isDD1Open\"\r\n (ddClicked)=\"handleDD1Click()\" (selectedFromDropdown)=\"handleCompareByFilterSelection($event)\"></lib-dropdown>\r\n </span>\r\n <span *ngIf=\"\r\n chartData.dropdownData2 &&\r\n chartData.metaData.breadcrumbLength &&\r\n chartData.metaData.breadcrumbLength == 1\r\n \">\r\n <lib-dropdown [dropdownData]=\"chartData.dropdownData2\" [isDropdownOpen]=\"this.isDD2Open\"\r\n (ddClicked)=\"handleDD2Click()\" (selectedFromDropdown)=\"handleCompareByFilterSelection($event)\"\r\n [isCheckboxVisible]=\"chartData.metaData.isCheckboxVisible\"\r\n [dropdownHeaderName]=\"chartData.metaData.dropdownHeaderName\"></lib-dropdown>\r\n </span> -->\r\n <!-- <span class=\"zoomIcons-holder\" *ngIf=\"chartData.data && chartData.data.length > 8\">\r\n <span class=\"zoomIcons\" title=\"Zoom In\" [ngClass]=\"!isZoomedOut ? 'zoom-active' : 'zoom-inactive'\"\r\n (click)=\"isZoomOutSelected(false, $event)\">\r\n <i class=\"fa fa-search-plus\"></i>\r\n </span>\r\n <span class=\"zoomIcons\" title=\"Zoom Out\" [ngClass]=\"isZoomedOut ? 'zoom-active' : 'zoom-inactive'\"\r\n (click)=\"isZoomOutSelected(true, $event)\">\r\n <i class=\"fa fa-search-minus\"></i>\r\n </span>\r\n </span>\r\n </span> -->\r\n</div>", styles: [".invisible{visibility:hidden}.hidden{visibility:hidden!important}.content-hidden{visibility:hidden}.opacity-hidden{opacity:0;pointer-events:none}@media (min-height: 500px){.legend-width{max-width:550px;overflow:auto}}@media (min-height: 900px){.header-title-styles{margin-left:
|
|
43
|
+
args: [{ selector: 'lib-chart-header-v3', template: "<div class=\"lib-display-flex header-title-styles\" [ngClass]=\"\r\n !chartData.dropdownData2 &&\r\n !chartData.dropdownData1 &&\r\n chartData.data.length <= 8\r\n ? 'lib-justify-content-start'\r\n : 'lib-justify-content-space-between'\r\n \">\r\n <span class=\"legend-latest-holder\" *ngIf=\"\r\n chartData.data &&\r\n chartData.metaData.default_dept &&\r\n (chartConfiguration.isToggleVisible || chartData.metaData.isToggleVisible)\r\n \">\r\n <span *ngFor=\"let item of chartData.metaData.colors | keyvalue : keepOrder\"><span class=\"legends-latest\"\r\n *ngIf=\"chartData.metaData.default_dept == item.key\" [style.background-color]=\"item.value\"></span></span>\r\n <span class=\"marginRight-30 legend-style font-size-2\" *ngIf=\"chartData.metaData.default_dept\">\r\n Default Dept: {{ chartData.metaData.default_dept }}\r\n </span>\r\n <span *ngFor=\"let item of chartData.metaData.colors | keyvalue : keepOrder\"><span *ngIf=\"\r\n item.key != chartData.metaData.default_dept &&\r\n chartData.metaData.default_dept\r\n \" class=\"legends-latest\" [style.background-color]=\"item.value\"></span></span>\r\n <span class=\"legend-style font-size-2\" *ngIf=\"isLegendVisible() && chartData.metaData.default_dept\">Cross Train\r\n Dept</span>\r\n </span>\r\n <span class=\"legend-latest-holder legend-width\"\r\n [ngClass]=\"chartData.metaData.colorLegendVisibleOnTopLeft ? '' : 'invisible'\"\r\n *ngIf=\"chartData.data && !chartData.metaData.default_dept\">\r\n <span class=\"lib-display-flex lib-align-items-center\"\r\n *ngFor=\"let item of chartData.metaData.colors | keyvalue : keepOrder\"><span class=\"legends-latest\"\r\n [style.background-color]=\"item.value\"></span>\r\n <span class=\"marginRight-20 legend-style font-size-1 lib-white-space-nowrap\">\r\n {{ item.key }}\r\n </span>\r\n </span>\r\n </span>\r\n <!-- <span class=\"display-flex\"> -->\r\n <!-- <span *ngIf=\"\r\n chartData.dropdownData1 &&\r\n chartData.metaData.breadcrumbLength &&\r\n chartData.metaData.breadcrumbLength == 1\r\n \">\r\n <lib-dropdown [dropdownData]=\"chartData.dropdownData1\" [isDropdownOpen]=\"this.isDD1Open\"\r\n (ddClicked)=\"handleDD1Click()\" (selectedFromDropdown)=\"handleCompareByFilterSelection($event)\"></lib-dropdown>\r\n </span>\r\n <span *ngIf=\"\r\n chartData.dropdownData2 &&\r\n chartData.metaData.breadcrumbLength &&\r\n chartData.metaData.breadcrumbLength == 1\r\n \">\r\n <lib-dropdown [dropdownData]=\"chartData.dropdownData2\" [isDropdownOpen]=\"this.isDD2Open\"\r\n (ddClicked)=\"handleDD2Click()\" (selectedFromDropdown)=\"handleCompareByFilterSelection($event)\"\r\n [isCheckboxVisible]=\"chartData.metaData.isCheckboxVisible\"\r\n [dropdownHeaderName]=\"chartData.metaData.dropdownHeaderName\"></lib-dropdown>\r\n </span> -->\r\n <!-- <span class=\"zoomIcons-holder\" *ngIf=\"chartData.data && chartData.data.length > 8\">\r\n <span class=\"zoomIcons\" title=\"Zoom In\" [ngClass]=\"!isZoomedOut ? 'zoom-active' : 'zoom-inactive'\"\r\n (click)=\"isZoomOutSelected(false, $event)\">\r\n <i class=\"fa fa-search-plus\"></i>\r\n </span>\r\n <span class=\"zoomIcons\" title=\"Zoom Out\" [ngClass]=\"isZoomedOut ? 'zoom-active' : 'zoom-inactive'\"\r\n (click)=\"isZoomOutSelected(true, $event)\">\r\n <i class=\"fa fa-search-minus\"></i>\r\n </span>\r\n </span>\r\n </span> -->\r\n</div>", styles: [".invisible{visibility:hidden}.hidden{visibility:hidden!important}.content-hidden{visibility:hidden}.opacity-hidden{opacity:0;pointer-events:none}@media (min-height: 500px){.legend-width{max-width:550px;overflow:auto}}@media (min-height: 900px){.header-title-styles{margin-left:35px;margin-top:12px;margin-bottom:25px}.legend-width{max-width:700px;overflow:auto}}\n"] }]
|
|
44
44
|
}], propDecorators: { chartData: [{
|
|
45
45
|
type: Input
|
|
46
46
|
}], chartConfiguration: [{
|