@progressio_resources/gravity-design-system 2.4.3 → 2.4.4

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.
@@ -53,37 +53,43 @@ export class GravityTableComponent {
53
53
  let tableBodyRows = document.querySelectorAll('table[table-id="' + this.tableId + '"] tbody tr');
54
54
  let closeButtons = document.querySelectorAll('gravity-button[id-reference="close-button"]');
55
55
  tableBodyRows.forEach((tr, index) => {
56
- let mobileMenuTrigger = document.createElement('div');
57
- this.renderer.addClass(mobileMenuTrigger, 'mobile-menu-trigger');
58
- this.renderer.setAttribute(mobileMenuTrigger, 'cloned-node', 'true');
59
- let menuToggle = document.createElement('div');
60
- this.renderer.addClass(menuToggle, 'menu-toggle');
61
- menuToggle.appendChild(document.createElement('span'));
62
- menuToggle.appendChild(document.createElement('span'));
63
- menuToggle.appendChild(document.createElement('span'));
64
- menuToggle.addEventListener("click", () => {
65
- if (menuToggle.classList.contains('open')) {
56
+ let actionColum = null;
57
+ if (tr.firstChild) {
58
+ actionColum = tr.firstChild.parentElement.querySelectorAll('td.actions-column');
59
+ }
60
+ if (actionColum?.length > 0) {
61
+ let mobileMenuTrigger = document.createElement('div');
62
+ this.renderer.addClass(mobileMenuTrigger, 'mobile-menu-trigger');
63
+ this.renderer.setAttribute(mobileMenuTrigger, 'cloned-node', 'true');
64
+ let menuToggle = document.createElement('div');
65
+ this.renderer.addClass(menuToggle, 'menu-toggle');
66
+ menuToggle.appendChild(document.createElement('span'));
67
+ menuToggle.appendChild(document.createElement('span'));
68
+ menuToggle.appendChild(document.createElement('span'));
69
+ menuToggle.addEventListener("click", () => {
70
+ if (menuToggle.classList.contains('open')) {
71
+ this.renderer.removeClass(menuToggle, 'open');
72
+ this.renderer.removeClass(menuToggle.parentElement.lastElementChild, 'open');
73
+ }
74
+ else {
75
+ this.renderer.addClass(menuToggle, 'open');
76
+ this.renderer.addClass(menuToggle.parentElement.lastElementChild, 'open');
77
+ }
78
+ });
79
+ mobileMenuTrigger.appendChild(menuToggle);
80
+ let panel = document.createElement('div');
81
+ this.renderer.addClass(panel, 'panel');
82
+ let closeButtonFromNodeList = closeButtons.item(index);
83
+ let closeButtonRemoved = closeButtonFromNodeList.parentNode.removeChild(closeButtonFromNodeList);
84
+ this.renderer.setAttribute(closeButtonRemoved, 'cloned-button', 'true');
85
+ closeButtonRemoved.addEventListener("click", () => {
66
86
  this.renderer.removeClass(menuToggle, 'open');
67
87
  this.renderer.removeClass(menuToggle.parentElement.lastElementChild, 'open');
68
- }
69
- else {
70
- this.renderer.addClass(menuToggle, 'open');
71
- this.renderer.addClass(menuToggle.parentElement.lastElementChild, 'open');
72
- }
73
- });
74
- mobileMenuTrigger.appendChild(menuToggle);
75
- let panel = document.createElement('div');
76
- this.renderer.addClass(panel, 'panel');
77
- let closeButtonFromNodeList = closeButtons.item(index);
78
- let closeButtonRemoved = closeButtonFromNodeList.parentNode.removeChild(closeButtonFromNodeList);
79
- this.renderer.setAttribute(closeButtonRemoved, 'cloned-button', 'true');
80
- closeButtonRemoved.addEventListener("click", () => {
81
- this.renderer.removeClass(menuToggle, 'open');
82
- this.renderer.removeClass(menuToggle.parentElement.lastElementChild, 'open');
83
- });
84
- panel.append(closeButtonRemoved);
85
- mobileMenuTrigger.appendChild(panel);
86
- tr.insertBefore(mobileMenuTrigger, tr.firstChild);
88
+ });
89
+ panel.append(closeButtonRemoved);
90
+ mobileMenuTrigger.appendChild(panel);
91
+ tr.insertBefore(mobileMenuTrigger, tr.firstChild);
92
+ }
87
93
  });
88
94
  }
89
95
  adjustTableDensity(densityValue) {
@@ -136,23 +142,28 @@ export class GravityTableComponent {
136
142
  adjustTable() {
137
143
  if (this.tableSize == 'md' || this.tableSize == 'sm') {
138
144
  let tableBodyRows = document.querySelectorAll('table[table-id="' + this.tableId + '"] tbody tr');
139
- let tableBodyRowsActions = document.querySelectorAll('table[table-id="' + this.tableId + '"] tbody tr td.actions-column');
140
- let tableBodyRowsMenuTrigger = document.querySelectorAll('table[table-id="' + this.tableId + '"] tbody tr .mobile-menu-trigger[cloned-node="true"]');
141
- tableBodyRows.forEach((tr, index) => {
142
- let mobileMenuTrigger = tableBodyRowsMenuTrigger.item(index);
143
- let mobileMenuTriggerPanel = mobileMenuTrigger.lastChild;
144
- if (tableBodyRowsActions.item(index) && mobileMenuTriggerPanel) {
145
- this.appendNodesList(mobileMenuTriggerPanel, tableBodyRowsActions.item(index).childNodes);
145
+ tableBodyRows.forEach((tr) => {
146
+ if (tr.firstChild) {
147
+ let trActionsColum = tr.firstChild.parentElement.querySelectorAll('td.actions-column')[0];
148
+ let mobileMenuTrigger = tr.firstChild.parentElement.querySelectorAll('.mobile-menu-trigger[cloned-node="true"]')[0];
149
+ if (mobileMenuTrigger) {
150
+ let mobileMenuTriggerPanel = mobileMenuTrigger.lastChild;
151
+ if (trActionsColum && mobileMenuTriggerPanel) {
152
+ this.appendNodesList(mobileMenuTriggerPanel, trActionsColum.childNodes);
153
+ }
154
+ }
146
155
  }
147
156
  });
148
157
  }
149
158
  if (this.tableSize == 'lg' || this.tableSize == 'xl') {
150
159
  let tableBodyRows = document.querySelectorAll('table[table-id="' + this.tableId + '"] tbody tr');
151
- let tableBodyRowsActions = document.querySelectorAll('table[table-id="' + this.tableId + '"] tbody tr td.actions-column');
152
- let tableBodyRowsMenuTrigger = document.querySelectorAll('table[table-id="' + this.tableId + '"] tbody tr .mobile-menu-trigger[cloned-node="true"]');
153
- tableBodyRows.forEach((tr, index) => {
154
- if (tableBodyRowsActions.item(index)) {
155
- this.appendNodesList(tableBodyRowsActions.item(index), tableBodyRowsMenuTrigger.item(index).lastChild.childNodes);
160
+ tableBodyRows.forEach((tr) => {
161
+ if (tr.firstChild) {
162
+ let trActionsColum = tr.firstChild.parentElement.querySelectorAll('td.actions-column')[0];
163
+ let mobileMenuTrigger = tr.firstChild.parentElement.querySelectorAll('.mobile-menu-trigger[cloned-node="true"]')[0];
164
+ if (trActionsColum && mobileMenuTrigger) {
165
+ this.appendNodesList(trActionsColum, mobileMenuTrigger.lastChild.childNodes);
166
+ }
156
167
  }
157
168
  });
158
169
  }
@@ -198,4 +209,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
198
209
  type: HostListener,
199
210
  args: ['window:resize', ['$event']]
200
211
  }] } });
201
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gravity-table.component.js","sourceRoot":"","sources":["../../../../../../projects/gravity-design-system/src/lib/components/gravity-table/gravity-table.component.ts","../../../../../../projects/gravity-design-system/src/lib/components/gravity-table/gravity-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  HostListener,\n  Input,\n  OnChanges,\n  Renderer2,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\n\n@Component({\n  selector: 'gravity-table',\n  templateUrl: './gravity-table.component.html',\n  styleUrls: ['./gravity-table.component.scss']\n})\nexport class GravityTableComponent implements AfterViewInit, OnChanges {\n  @Input() public tableDensity: 'standard' | 'compressed' = \"standard\";\n  @Input() public tableSizeInput: 'xl' | 'lg' | 'md' | 'sm' | 'auto' = \"auto\";\n  @ViewChild('tableContainer') public readonly tableContainer: ElementRef;\n\n  private tableElement: ElementRef = null;\n  public tableId: string;\n  public tableSize: 'xl' | 'lg' | 'md' | 'sm' = 'xl';\n\n  constructor(private readonly renderer: Renderer2) {\n    let milliseconds: number = new Date().getTime();\n    let randomNumber: number = Math.random() * 10;\n\n    this.tableId = '' + (milliseconds * randomNumber / 2);\n  }\n\n  ngAfterViewInit(): void {\n    this.tableElement = this.tableContainer?.nativeElement?.childNodes[0];\n    this.renderer.setAttribute(this.tableElement, 'table-id', this.tableId);\n    this.initializeComponent();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.tableElement) {\n      if (changes['tableDensity']) {\n        this.adjustTableDensity(changes['tableDensity'].currentValue);\n      }\n\n      if (changes['tableSizeInput']) {\n        this.tableSizeInput = changes['tableSizeInput'].currentValue;\n        this.onResize();\n      }\n    }\n  }\n\n  private getTableHeaders(): string[] {\n    let tableHeaderItems: NodeList = document.querySelectorAll('thead tr th');\n    let tableHeaders: string[] = [];\n\n    tableHeaderItems.forEach((tableHeaderItem: Node) => {\n      tableHeaders.push(tableHeaderItem.childNodes[0].nodeValue);\n    });\n\n    return tableHeaders;\n  }\n\n  public initializeComponent(): void {\n    let tableHeaders: string[] = this.getTableHeaders();\n    this.initializeTable(tableHeaders);\n    this.adjustTableDensity(this.tableDensity);\n    this.adjustButtonsSize();\n    this.onResize();\n  }\n\n  private initializeTable(tableHeaders: string[]): void {\n    //Set corresponding tableHeader as an attribute of each td\n    let tableBody: NodeList = document.querySelectorAll('table[table-id=\"' + this.tableId + '\"] tbody tr td');\n    tableBody.forEach((tableBodyRow: Node, index: number) => {\n      this.renderer.setAttribute(tableBodyRow, 'header-name', tableHeaders[index % tableHeaders.length]);\n    });\n\n    //Creates a copy of mobile-menu-trigger element for each tr\n    let tableBodyRows: NodeList = document.querySelectorAll('table[table-id=\"' + this.tableId + '\"] tbody tr');\n    let closeButtons: NodeList = document.querySelectorAll('gravity-button[id-reference=\"close-button\"]');\n\n    tableBodyRows.forEach((tr: Node, index: number) => {\n      let mobileMenuTrigger: HTMLDivElement = document.createElement('div');\n      this.renderer.addClass(mobileMenuTrigger, 'mobile-menu-trigger');\n      this.renderer.setAttribute(mobileMenuTrigger, 'cloned-node', 'true');\n\n      let menuToggle: HTMLDivElement = document.createElement('div');\n      this.renderer.addClass(menuToggle, 'menu-toggle');\n      menuToggle.appendChild(document.createElement('span'));\n      menuToggle.appendChild(document.createElement('span'));\n      menuToggle.appendChild(document.createElement('span'));\n      menuToggle.addEventListener(\"click\", () => {\n        if (menuToggle.classList.contains('open')) {\n          this.renderer.removeClass(menuToggle, 'open');\n          this.renderer.removeClass(menuToggle.parentElement.lastElementChild, 'open');\n        } else {\n          this.renderer.addClass(menuToggle, 'open');\n          this.renderer.addClass(menuToggle.parentElement.lastElementChild, 'open');\n        }\n      });\n      mobileMenuTrigger.appendChild(menuToggle);\n\n      let panel: HTMLDivElement = document.createElement('div');\n      this.renderer.addClass(panel, 'panel');\n\n      let closeButtonFromNodeList: Node = closeButtons.item(index);\n      let closeButtonRemoved: Node = closeButtonFromNodeList.parentNode.removeChild(closeButtonFromNodeList);\n      this.renderer.setAttribute(closeButtonRemoved, 'cloned-button', 'true');\n      closeButtonRemoved.addEventListener(\"click\", () => {\n        this.renderer.removeClass(menuToggle, 'open');\n        this.renderer.removeClass(menuToggle.parentElement.lastElementChild, 'open');\n      });\n\n      panel.append(closeButtonRemoved);\n\n      mobileMenuTrigger.appendChild(panel);\n\n      tr.insertBefore(mobileMenuTrigger, tr.firstChild);\n    });\n  }\n\n  private adjustTableDensity(densityValue: 'standard' | 'compressed'): void {\n    this.renderer.removeClass(this.tableElement, 'standard-table');\n    this.renderer.removeClass(this.tableElement, 'compressed-table');\n\n    this.renderer.addClass(this.tableElement, densityValue + '-table');\n  }\n\n  private adjustButtonsSize(): void {\n    let actionsColumns: NodeList = document.querySelectorAll('table[table-id=\"' + this.tableId + '\"] .actions-column');\n    actionsColumns.forEach((actionsColumn: Node) => {\n      actionsColumn.childNodes.forEach((gravityButton: Node) => {\n        let button: Node = gravityButton.childNodes[0];\n\n        this.renderer.removeClass(button, 'gravity-size-lg');\n        this.renderer.removeClass(button, 'gravity-size-md');\n        this.renderer.removeClass(button, 'gravity-size-sm');\n        this.renderer.removeClass(button, 'lg-bold');\n        this.renderer.removeClass(button, 'md-bold');\n        this.renderer.removeClass(button, 'sm-bold');\n\n        this.renderer.addClass(button, 'gravity-size-sm');\n        this.renderer.addClass(button, 'sm-bold');\n      });\n    });\n  }\n\n  @HostListener('window:resize', ['$event'])\n  private onResize(): void {\n    if (window.innerWidth <= 576) {\n      this.tableSize = 'sm';\n    } else if (window.innerWidth <= 992) {\n      this.tableSize = 'md';\n    } else if (window.innerWidth <= 1440) {\n      this.tableSize = 'lg';\n    } else {\n      this.tableSize = 'xl';\n    }\n\n    this.adjustTableSize();\n  }\n\n  private adjustTableSize(): void {\n    this.renderer.removeClass(this.tableElement, 'sm-table');\n    this.renderer.removeClass(this.tableElement, 'md-table');\n    this.renderer.removeClass(this.tableElement, 'lg-table');\n    this.renderer.removeClass(this.tableElement, 'xl-table');\n\n    if (this.tableSizeInput != 'auto') {\n      this.tableSize = this.tableSizeInput;\n    }\n\n    this.renderer.addClass(this.tableElement, this.tableSize + '-table');\n    this.adjustTable();\n  }\n\n  private adjustTable(): void {\n    if (this.tableSize == 'md' || this.tableSize == 'sm') {\n      let tableBodyRows: NodeList = document.querySelectorAll('table[table-id=\"' + this.tableId + '\"] tbody tr');\n      let tableBodyRowsActions: NodeList = document.querySelectorAll('table[table-id=\"' + this.tableId + '\"] tbody tr td.actions-column');\n      let tableBodyRowsMenuTrigger: NodeList = document.querySelectorAll('table[table-id=\"' + this.tableId + '\"] tbody tr .mobile-menu-trigger[cloned-node=\"true\"]');\n\n      tableBodyRows.forEach((tr: Node, index: number) => {\n        let mobileMenuTrigger: Node = tableBodyRowsMenuTrigger.item(index);\n        let mobileMenuTriggerPanel: Node = mobileMenuTrigger.lastChild;\n\n        if (tableBodyRowsActions.item(index) && mobileMenuTriggerPanel) {\n          this.appendNodesList(mobileMenuTriggerPanel, tableBodyRowsActions.item(index).childNodes);\n        }\n      });\n    }\n\n    if (this.tableSize == 'lg' || this.tableSize == 'xl') {\n      let tableBodyRows: NodeList = document.querySelectorAll('table[table-id=\"' + this.tableId + '\"] tbody tr');\n      let tableBodyRowsActions: NodeList = document.querySelectorAll('table[table-id=\"' + this.tableId + '\"] tbody tr td.actions-column');\n      let tableBodyRowsMenuTrigger: NodeList = document.querySelectorAll('table[table-id=\"' + this.tableId + '\"] tbody tr .mobile-menu-trigger[cloned-node=\"true\"]');\n\n      tableBodyRows.forEach((tr: Node, index: number) => {\n        if (tableBodyRowsActions.item(index)) {\n          this.appendNodesList(tableBodyRowsActions.item(index), tableBodyRowsMenuTrigger.item(index).lastChild.childNodes);\n        }\n      });\n    }\n  }\n\n  private appendNodesList(elementToAppend: Node, nodesList: NodeListOf<ChildNode>): Node {\n    if (this.tableSize == 'md' || this.tableSize == 'sm') {\n      let nodeListIndex: number = nodesList.length - 1;\n\n      while (nodesList.length != 0) {\n        let removedNode: Node = nodesList.item(nodeListIndex).parentNode.removeChild(nodesList.item(nodeListIndex));\n        elementToAppend.insertBefore(removedNode, elementToAppend.firstChild);\n        nodeListIndex--;\n      }\n\n      return elementToAppend;\n    }\n\n    if (this.tableSize == 'lg' || this.tableSize == 'xl') {\n      let nodeListIndex: number = nodesList.length - 1;\n\n      while (nodesList.length > 1) {\n        let item: Node = nodesList.item(nodeListIndex);\n        let closeButtonNode: Node = item.parentNode.querySelectorAll('gravity-button[id-reference=\"close-button\"]').item(0);\n\n        if (item != closeButtonNode) {\n          let removedNode: Node = item.parentNode.removeChild(item);\n          elementToAppend.insertBefore(removedNode, elementToAppend.firstChild);\n        }\n\n        nodeListIndex--;\n      }\n\n      return elementToAppend;\n    }\n  }\n}\n","<div class=\"table-container {{tableSize}}\" #tableContainer>\n  <ng-content></ng-content>\n</div>\n\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n"]}
212
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gravity-table.component.js","sourceRoot":"","sources":["../../../../../../projects/gravity-design-system/src/lib/components/gravity-table/gravity-table.component.ts","../../../../../../projects/gravity-design-system/src/lib/components/gravity-table/gravity-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  HostListener,\n  Input,\n  OnChanges,\n  Renderer2,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\n\n@Component({\n  selector: 'gravity-table',\n  templateUrl: './gravity-table.component.html',\n  styleUrls: ['./gravity-table.component.scss']\n})\nexport class GravityTableComponent implements AfterViewInit, OnChanges {\n  @Input() public tableDensity: 'standard' | 'compressed' = \"standard\";\n  @Input() public tableSizeInput: 'xl' | 'lg' | 'md' | 'sm' | 'auto' = \"auto\";\n  @ViewChild('tableContainer') public readonly tableContainer: ElementRef;\n\n  private tableElement: ElementRef = null;\n  public tableId: string;\n  public tableSize: 'xl' | 'lg' | 'md' | 'sm' = 'xl';\n\n  constructor(private readonly renderer: Renderer2) {\n    let milliseconds: number = new Date().getTime();\n    let randomNumber: number = Math.random() * 10;\n\n    this.tableId = '' + (milliseconds * randomNumber / 2);\n  }\n\n  ngAfterViewInit(): void {\n    this.tableElement = this.tableContainer?.nativeElement?.childNodes[0];\n    this.renderer.setAttribute(this.tableElement, 'table-id', this.tableId);\n    this.initializeComponent();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.tableElement) {\n      if (changes['tableDensity']) {\n        this.adjustTableDensity(changes['tableDensity'].currentValue);\n      }\n\n      if (changes['tableSizeInput']) {\n        this.tableSizeInput = changes['tableSizeInput'].currentValue;\n        this.onResize();\n      }\n    }\n  }\n\n  private getTableHeaders(): string[] {\n    let tableHeaderItems: NodeList = document.querySelectorAll('thead tr th');\n    let tableHeaders: string[] = [];\n\n    tableHeaderItems.forEach((tableHeaderItem: Node) => {\n      tableHeaders.push(tableHeaderItem.childNodes[0].nodeValue);\n    });\n\n    return tableHeaders;\n  }\n\n  public initializeComponent(): void {\n    let tableHeaders: string[] = this.getTableHeaders();\n    this.initializeTable(tableHeaders);\n    this.adjustTableDensity(this.tableDensity);\n    this.adjustButtonsSize();\n    this.onResize();\n  }\n\n  private initializeTable(tableHeaders: string[]): void {\n    //Set corresponding tableHeader as an attribute of each td\n    let tableBody: NodeList = document.querySelectorAll('table[table-id=\"' + this.tableId + '\"] tbody tr td');\n    tableBody.forEach((tableBodyRow: Node, index: number) => {\n      this.renderer.setAttribute(tableBodyRow, 'header-name', tableHeaders[index % tableHeaders.length]);\n    });\n\n    //Creates a copy of mobile-menu-trigger element for each tr\n    let tableBodyRows: NodeList = document.querySelectorAll('table[table-id=\"' + this.tableId + '\"] tbody tr');\n    let closeButtons: NodeList = document.querySelectorAll('gravity-button[id-reference=\"close-button\"]');\n\n    tableBodyRows.forEach((tr: Node, index: number) => {\n      let actionColum: NodeList = null;\n\n      if (tr.firstChild) {\n        actionColum = tr.firstChild.parentElement.querySelectorAll('td.actions-column');\n      }\n\n      if (actionColum?.length > 0) {\n        let mobileMenuTrigger: HTMLDivElement = document.createElement('div');\n        this.renderer.addClass(mobileMenuTrigger, 'mobile-menu-trigger');\n        this.renderer.setAttribute(mobileMenuTrigger, 'cloned-node', 'true');\n\n        let menuToggle: HTMLDivElement = document.createElement('div');\n        this.renderer.addClass(menuToggle, 'menu-toggle');\n        menuToggle.appendChild(document.createElement('span'));\n        menuToggle.appendChild(document.createElement('span'));\n        menuToggle.appendChild(document.createElement('span'));\n        menuToggle.addEventListener(\"click\", () => {\n          if (menuToggle.classList.contains('open')) {\n            this.renderer.removeClass(menuToggle, 'open');\n            this.renderer.removeClass(menuToggle.parentElement.lastElementChild, 'open');\n          } else {\n            this.renderer.addClass(menuToggle, 'open');\n            this.renderer.addClass(menuToggle.parentElement.lastElementChild, 'open');\n          }\n        });\n        mobileMenuTrigger.appendChild(menuToggle);\n\n        let panel: HTMLDivElement = document.createElement('div');\n        this.renderer.addClass(panel, 'panel');\n\n        let closeButtonFromNodeList: Node = closeButtons.item(index);\n        let closeButtonRemoved: Node = closeButtonFromNodeList.parentNode.removeChild(closeButtonFromNodeList);\n        this.renderer.setAttribute(closeButtonRemoved, 'cloned-button', 'true');\n        closeButtonRemoved.addEventListener(\"click\", () => {\n          this.renderer.removeClass(menuToggle, 'open');\n          this.renderer.removeClass(menuToggle.parentElement.lastElementChild, 'open');\n        });\n\n        panel.append(closeButtonRemoved);\n\n        mobileMenuTrigger.appendChild(panel);\n\n        tr.insertBefore(mobileMenuTrigger, tr.firstChild);\n      }\n    });\n  }\n\n  private adjustTableDensity(densityValue: 'standard' | 'compressed'): void {\n    this.renderer.removeClass(this.tableElement, 'standard-table');\n    this.renderer.removeClass(this.tableElement, 'compressed-table');\n\n    this.renderer.addClass(this.tableElement, densityValue + '-table');\n  }\n\n  private adjustButtonsSize(): void {\n    let actionsColumns: NodeList = document.querySelectorAll('table[table-id=\"' + this.tableId + '\"] .actions-column');\n    actionsColumns.forEach((actionsColumn: Node) => {\n      actionsColumn.childNodes.forEach((gravityButton: Node) => {\n        let button: Node = gravityButton.childNodes[0];\n\n        this.renderer.removeClass(button, 'gravity-size-lg');\n        this.renderer.removeClass(button, 'gravity-size-md');\n        this.renderer.removeClass(button, 'gravity-size-sm');\n        this.renderer.removeClass(button, 'lg-bold');\n        this.renderer.removeClass(button, 'md-bold');\n        this.renderer.removeClass(button, 'sm-bold');\n\n        this.renderer.addClass(button, 'gravity-size-sm');\n        this.renderer.addClass(button, 'sm-bold');\n      });\n    });\n  }\n\n  @HostListener('window:resize', ['$event'])\n  private onResize(): void {\n    if (window.innerWidth <= 576) {\n      this.tableSize = 'sm';\n    } else if (window.innerWidth <= 992) {\n      this.tableSize = 'md';\n    } else if (window.innerWidth <= 1440) {\n      this.tableSize = 'lg';\n    } else {\n      this.tableSize = 'xl';\n    }\n\n    this.adjustTableSize();\n  }\n\n  private adjustTableSize(): void {\n    this.renderer.removeClass(this.tableElement, 'sm-table');\n    this.renderer.removeClass(this.tableElement, 'md-table');\n    this.renderer.removeClass(this.tableElement, 'lg-table');\n    this.renderer.removeClass(this.tableElement, 'xl-table');\n\n    if (this.tableSizeInput != 'auto') {\n      this.tableSize = this.tableSizeInput;\n    }\n\n    this.renderer.addClass(this.tableElement, this.tableSize + '-table');\n    this.adjustTable();\n  }\n\n  private adjustTable(): void {\n    if (this.tableSize == 'md' || this.tableSize == 'sm') {\n      let tableBodyRows: NodeList = document.querySelectorAll('table[table-id=\"' + this.tableId + '\"] tbody tr');\n\n      tableBodyRows.forEach((tr: Node) => {\n        if (tr.firstChild) {\n          let trActionsColum: Node = tr.firstChild.parentElement.querySelectorAll('td.actions-column')[0];\n          let mobileMenuTrigger: Node = tr.firstChild.parentElement.querySelectorAll('.mobile-menu-trigger[cloned-node=\"true\"]')[0];\n\n          if (mobileMenuTrigger) {\n            let mobileMenuTriggerPanel: Node = mobileMenuTrigger.lastChild;\n\n            if (trActionsColum && mobileMenuTriggerPanel) {\n              this.appendNodesList(mobileMenuTriggerPanel, trActionsColum.childNodes);\n            }\n          }\n        }\n      });\n    }\n\n    if (this.tableSize == 'lg' || this.tableSize == 'xl') {\n      let tableBodyRows: NodeList = document.querySelectorAll('table[table-id=\"' + this.tableId + '\"] tbody tr');\n\n      tableBodyRows.forEach((tr: Node) => {\n        if (tr.firstChild) {\n          let trActionsColum: Node = tr.firstChild.parentElement.querySelectorAll('td.actions-column')[0];\n          let mobileMenuTrigger: Node = tr.firstChild.parentElement.querySelectorAll('.mobile-menu-trigger[cloned-node=\"true\"]')[0];\n\n          if (trActionsColum && mobileMenuTrigger) {\n            this.appendNodesList(trActionsColum, mobileMenuTrigger.lastChild.childNodes);\n          }\n        }\n      });\n    }\n  }\n\n  private appendNodesList(elementToAppend: Node, nodesList: NodeListOf<ChildNode>): Node {\n    if (this.tableSize == 'md' || this.tableSize == 'sm') {\n      let nodeListIndex: number = nodesList.length - 1;\n\n      while (nodesList.length != 0) {\n        let removedNode: Node = nodesList.item(nodeListIndex).parentNode.removeChild(nodesList.item(nodeListIndex));\n        elementToAppend.insertBefore(removedNode, elementToAppend.firstChild);\n        nodeListIndex--;\n      }\n\n      return elementToAppend;\n    }\n\n    if (this.tableSize == 'lg' || this.tableSize == 'xl') {\n      let nodeListIndex: number = nodesList.length - 1;\n\n      while (nodesList.length > 1) {\n        let item: Node = nodesList.item(nodeListIndex);\n        let closeButtonNode: Node = item.parentNode.querySelectorAll('gravity-button[id-reference=\"close-button\"]').item(0);\n\n        if (item != closeButtonNode) {\n          let removedNode: Node = item.parentNode.removeChild(item);\n          elementToAppend.insertBefore(removedNode, elementToAppend.firstChild);\n        }\n\n        nodeListIndex--;\n      }\n\n      return elementToAppend;\n    }\n  }\n}\n","<div class=\"table-container {{tableSize}}\" #tableContainer>\n  <ng-content></ng-content>\n</div>\n\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n<gravity-button id-reference=\"close-button\" [iconName]=\"'unsuccess'\" [type]=\"'tertiary'\" [size]=\"'sm'\">Close menu</gravity-button>\n"]}
@@ -83,11 +83,11 @@ export class GravityTextFieldComponent {
83
83
  }
84
84
  }
85
85
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GravityTextFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
86
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: GravityTextFieldComponent, selector: "gravity-text-field", inputs: { autocomplete: "autocomplete", clickOnIconName: "clickOnIconName", currentLang: "currentLang", customPlaceholder: "customPlaceholder", customInputValue: "customInputValue", cypressTag: "cypressTag", iconColor: "iconColor", iconNames: "iconNames", iconsSizes: "iconsSizes", iconPlacement: "iconPlacement", inputContentType: "inputContentType", label: "label", placeholderType: "placeholderType", prefix: "prefix", required: "required", state: "state", supportTextContent: "supportTextContent", supportTextType: "supportTextType", textFieldType: "textFieldType", validations: "validations" }, outputs: { iconResponse: "clickIcon", textFieldValueResponse: "response" }, viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["inputElement"], descendants: true }, { propertyName: "textAreaElement", first: true, predicate: ["textAreaElement"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<label class=\"hr-body-text sm-regular {{state}}\" [class.empty]=\"inputValue == '' && !focusInput\"\n [class.focused]=\"focusInput\" [class.full-input]=\"inputValue != '' && !focusInput\" *ngIf=\"label\">\n {{label}}\n <ng-container *ngIf=\"required\">\n <ng-container *ngIf=\"currentLang == 'es'\">- Requerido <span class=\"text-negative\">*</span></ng-container>\n <ng-container *ngIf=\"currentLang == 'en'\">- Required <span class=\"text-negative\">*</span></ng-container>\n </ng-container>\n <ng-container *ngIf=\"state == 'readonly'\">\n <ng-container *ngIf=\"currentLang == 'es'\">- S\u00F3lo lectura</ng-container>\n <ng-container *ngIf=\"currentLang == 'en'\">- Readonly</ng-container>\n </ng-container>\n <ng-container *ngIf=\"state == 'disabled'\">\n <ng-container *ngIf=\"currentLang == 'es'\">- Deshabilitado</ng-container>\n <ng-container *ngIf=\"currentLang == 'en'\">- Disabled</ng-container>\n </ng-container>\n</label>\n<div class=\"gravity-input-field {{textFieldType}} {{state}}\" [class.empty]=\"inputValue == '' && !focusInput\"\n [class.focused]=\"focusInput\" [class.full-input]=\"inputValue != '' && !focusInput\">\n <ng-container *ngIf=\"iconPlacement == 'left'\">\n <ng-container *ngTemplateOutlet=\"icons\"></ng-container>\n </ng-container>\n <span class=\"hr-label md-regular prefix\">{{prefix}}</span>\n <input [attr.data-cy]=\"cypressTag\"\n [attr.disabled]=\"state == 'disabled' ? true : null\"\n [attr.readonly]=\"state == 'readonly' ? true : null\"\n [autocomplete]=\"autocomplete\"\n [maxLength]=\"validations?.maxLength ? validations?.maxLength : 100\"\n [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n [placeholder]=\"getPlaceholder()\"\n [type]=\"inputContentType\"\n [value]=\"inputValue\"\n\n (blur)=\"focusInput = false\"\n (change)=\"changeInputValue()\"\n (focus)=\"focusInput = true\"\n (keyup)=\"changeInputValue()\"\n\n class=\"hr-label md-regular\"\n\n #inputElement\n\n *ngIf=\"textFieldType == 'input'\">\n <textarea [attr.data-cy]=\"cypressTag\"\n [attr.disabled]=\"state == 'disabled' ? true : null\"\n [attr.readonly]=\"state == 'readonly' ? true : null\"\n [maxLength]=\"validations?.maxLength ? validations?.maxLength : 200\"\n [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n [placeholder]=\"getPlaceholder()\"\n [value]=\"inputValue\"\n\n (blur)=\"focusInput = false\"\n (change)=\"changeInputValue()\"\n (focus)=\"focusInput = true\"\n (keyup)=\"changeInputValue()\"\n\n class=\"hr-label md-regular\"\n rows=\"3\"\n\n #textAreaElement\n\n *ngIf=\"textFieldType == 'textarea'\"></textarea>\n <ng-container *ngIf=\"iconPlacement == 'right'\">\n <ng-container *ngTemplateOutlet=\"icons\"></ng-container>\n </ng-container>\n</div>\n<p class=\"hr-body-text sm-regular support-text text-{{supportTextType}}\" *ngIf=\"supportTextContent\">\n {{supportTextContent}}\n</p>\n\n<ng-template #icons>\n <gravity-icon (click)=\"$event.stopPropagation(); handleIconClick(name)\" class=\"placement-{{iconPlacement}}\"\n [class.pointer]=\"!!clickOnIconName\" [customIconColorVariable]=\"getIconColor(i)\"\n [hoverIcon]=\"!!clickOnIconName\" [iconName]=\"name\" *ngFor=\"let name of iconNames; let i = index\"\n [size]=\"iconsSizes[i]\"></gravity-icon>\n</ng-template>\n", styles: [".border-radius-none{border-radius:0}.border-radius-xs{border-radius:.0625rem}.border-radius-sm{border-radius:.3125rem}.border-radius-md{border-radius:.625rem}.border-radius-lg{border-radius:.9375rem}.border-radius-xl{border-radius:1.25rem}.border-radius-xxl{border-radius:2rem}.border-radius-rounded{border-radius:6.25rem}.text-negative{color:var(--negative-primary)}.text-neutro{color:var(--text-primary)}.text-positive{color:var(--positive-primary)}.support-text{margin-left:0;margin-top:.3125rem;padding-inline:1rem}:host{display:block}label{color:var(--text-field-label-color);margin-inline:1rem}label.empty.enabled{--text-field-label-color: var(--label-text-empty-enabled-primary)}label.empty.disabled{--text-field-label-color: var(--label-text-empty-disabled-primary)}label.full-input.enabled{--text-field-label-color: var(--label-text-full-enabled-primary)}label.full-input.disabled{--text-field-label-color: var(--label-text-full-disabled-primary)}label.full-input.readonly{--text-field-label-color: var(--label-text-full-read-only-primary)}label.focused{--text-field-label-color: var(--label-text-full-enabled-pressed-primary)}.gravity-input-field{align-items:center;background-color:var(--text-field-input-field-background-color);border:1px solid var(--text-field-input-field-border-color);border-radius:.625rem;display:flex;padding:.75rem 1rem}.gravity-input-field .prefix{color:var(--text-field-input-field-input-color)}.gravity-input-field.input{height:3rem;max-height:3rem;min-height:1.5rem}.gravity-input-field.textarea{min-height:3rem}.gravity-input-field gravity-icon.pointer{cursor:pointer}.gravity-input-field gravity-icon ::ng-deep svg-icon{pointer-events:none}.gravity-input-field gravity-icon.placement-left{margin-right:.5rem}.gravity-input-field gravity-icon.placement-right{margin-left:.5rem}.gravity-input-field input{background-color:transparent;border:none;box-shadow:none;color:var(--text-field-input-field-input-color);line-height:0;outline:none;padding:0;width:100%}.gravity-input-field input:-webkit-autofill{-webkit-box-shadow:0 0 0 30px var(--text-field-input-field-background-color) inset!important;-webkit-text-fill-color:var(--text-field-input-field-input-color)!important}.gravity-input-field input::placeholder{color:var(--text-field-input-field-placeholder-color)}.gravity-input-field textarea{background-color:transparent;border:none;box-shadow:none;color:var(--text-field-input-field-input-color);font-family:var(--font-family);line-height:1;max-height:5rem;max-width:100%;min-height:1rem;outline:none;padding:0;resize:none;width:100%}.gravity-input-field textarea::placeholder{color:var(--text-field-input-field-placeholder-color)}.gravity-input-field.empty.enabled{--text-field-input-field-background-color: var(--bg-field-empty-enabled-primary);--text-field-input-field-border-color: var(--outline-field-empty-enabled-primary);--text-field-input-field-input-color: var(--placeholder-empty-enabled-primary);--text-field-input-field-placeholder-color: var(--placeholder-empty-enabled-primary)}.gravity-input-field.empty.enabled:hover{--text-field-input-field-background-color: var(--bg-field-empty-enabled-hover-primary)}.gravity-input-field.empty.disabled{--text-field-input-field-background-color: var(--bg-field-empty-disabled-primary);--text-field-input-field-border-color: var(--bg-field-empty-disabled-primary);--text-field-input-field-input-color: var(--placeholder-empty-disabled-primary);--text-field-input-field-placeholder-color: var(--placeholder-empty-disabled-primary)}.gravity-input-field.empty.disabled gravity-icon{--icon-color: var(--placeholder-empty-disabled-primary)}.gravity-input-field.full-input.enabled{--text-field-input-field-background-color: var(--bg-field-full-enabled-primary);--text-field-input-field-border-color: var(--outline-field-full-enabled-primary);--text-field-input-field-input-color: var(--input-text-full-enabled-primary)}.gravity-input-field.full-input.enabled:hover{--text-field-input-field-background-color: var(--bg-field-full-enabled-hover-primary)}.gravity-input-field.full-input.disabled{--text-field-input-field-background-color: var(--bg-field-full-disabled-primary);--text-field-input-field-border-color: var(--bg-field-full-disabled-primary);--text-field-input-field-input-color: var(--input-text-full-disabled-primary)}.gravity-input-field.full-input.disabled gravity-icon{--icon-color: var(--input-text-full-disabled-primary)}.gravity-input-field.readonly{--text-field-input-field-background-color: var(--bg-field-full-read-only-primary);--text-field-input-field-border-color: var(--bg-field-full-read-only-primary);--text-field-input-field-input-color: var(--input-text-full-read-only-primary)}.gravity-input-field.readonly gravity-icon{--icon-color: var(--input-text-full-read-only-primary)}.gravity-input-field.focused:not(.readonly){--text-field-input-field-background-color: var(--bg-field-full-enabled-pressed-primary);--text-field-input-field-border-color: var(--outline-field-full-enabled-pressed-primary);--text-field-input-field-input-color: var(--placeholder-full-enabled-pressed-primary)}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.GravityIconComponent, selector: "gravity-icon", inputs: ["customIconColorVariable", "iconName", "hoverIcon", "size"] }] }); }
86
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: GravityTextFieldComponent, selector: "gravity-text-field", inputs: { autocomplete: "autocomplete", clickOnIconName: "clickOnIconName", currentLang: "currentLang", customPlaceholder: "customPlaceholder", customInputValue: "customInputValue", cypressTag: "cypressTag", iconColor: "iconColor", iconNames: "iconNames", iconsSizes: "iconsSizes", iconPlacement: "iconPlacement", inputContentType: "inputContentType", label: "label", placeholderType: "placeholderType", prefix: "prefix", required: "required", state: "state", supportTextContent: "supportTextContent", supportTextType: "supportTextType", textFieldType: "textFieldType", validations: "validations" }, outputs: { iconResponse: "clickIcon", textFieldValueResponse: "response" }, viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["inputElement"], descendants: true }, { propertyName: "textAreaElement", first: true, predicate: ["textAreaElement"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<label class=\"hr-body-text sm-regular {{state}}\" [class.empty]=\"inputValue == '' && !focusInput\"\n [class.focused]=\"focusInput\" [class.full-input]=\"inputValue != '' && !focusInput\" *ngIf=\"label\">\n {{label}}\n <ng-container *ngIf=\"required\">\n <ng-container *ngIf=\"currentLang == 'es'\">- Requerido <span class=\"text-negative\">*</span></ng-container>\n <ng-container *ngIf=\"currentLang == 'en'\">- Required <span class=\"text-negative\">*</span></ng-container>\n </ng-container>\n <ng-container *ngIf=\"state == 'readonly'\">\n <ng-container *ngIf=\"currentLang == 'es'\">- S\u00F3lo lectura</ng-container>\n <ng-container *ngIf=\"currentLang == 'en'\">- Readonly</ng-container>\n </ng-container>\n <ng-container *ngIf=\"state == 'disabled'\">\n <ng-container *ngIf=\"currentLang == 'es'\">- Deshabilitado</ng-container>\n <ng-container *ngIf=\"currentLang == 'en'\">- Disabled</ng-container>\n </ng-container>\n</label>\n<div class=\"gravity-input-field {{textFieldType}} {{state}}\" [class.empty]=\"inputValue == '' && !focusInput\"\n [class.focused]=\"focusInput\" [class.full-input]=\"inputValue != '' && !focusInput\">\n <ng-container *ngIf=\"iconPlacement == 'left'\">\n <ng-container *ngTemplateOutlet=\"icons\"></ng-container>\n </ng-container>\n <span class=\"hr-label md-regular prefix\">{{prefix}}</span>\n <input [attr.data-cy]=\"cypressTag\"\n [attr.disabled]=\"state == 'disabled' ? true : null\"\n [attr.readonly]=\"state == 'readonly' ? true : null\"\n [autocomplete]=\"autocomplete\"\n [maxLength]=\"validations?.maxLength ? validations?.maxLength : 100\"\n [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n [placeholder]=\"getPlaceholder()\"\n [type]=\"inputContentType\"\n [value]=\"inputValue\"\n\n (blur)=\"focusInput = false\"\n (change)=\"changeInputValue()\"\n (focus)=\"focusInput = true\"\n (keyup)=\"changeInputValue()\"\n\n class=\"hr-label md-regular\"\n\n #inputElement\n\n *ngIf=\"textFieldType == 'input'\">\n <textarea [attr.data-cy]=\"cypressTag\"\n [attr.disabled]=\"state == 'disabled' ? true : null\"\n [attr.readonly]=\"state == 'readonly' ? true : null\"\n [maxLength]=\"validations?.maxLength ? validations?.maxLength : 200\"\n [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n [placeholder]=\"getPlaceholder()\"\n [value]=\"inputValue\"\n\n (blur)=\"focusInput = false\"\n (change)=\"changeInputValue()\"\n (focus)=\"focusInput = true\"\n (keyup)=\"changeInputValue()\"\n\n class=\"hr-label md-regular\"\n rows=\"3\"\n\n #textAreaElement\n\n *ngIf=\"textFieldType == 'textarea'\"></textarea>\n <ng-container *ngIf=\"iconPlacement == 'right'\">\n <ng-container *ngTemplateOutlet=\"icons\"></ng-container>\n </ng-container>\n</div>\n<p class=\"hr-body-text sm-regular support-text text-{{supportTextType}}\" *ngIf=\"supportTextContent\">\n {{supportTextContent}}\n</p>\n\n<ng-template #icons>\n <gravity-icon (click)=\"$event.stopPropagation(); handleIconClick(name)\" class=\"placement-{{iconPlacement}}\"\n [class.pointer]=\"!!clickOnIconName\" [customIconColorVariable]=\"getIconColor(i)\"\n [hoverIcon]=\"!!clickOnIconName\" [iconName]=\"name\" *ngFor=\"let name of iconNames; let i = index\"\n [size]=\"iconsSizes[i % iconsSizes.length]\"></gravity-icon>\n</ng-template>\n", styles: [".border-radius-none{border-radius:0}.border-radius-xs{border-radius:.0625rem}.border-radius-sm{border-radius:.3125rem}.border-radius-md{border-radius:.625rem}.border-radius-lg{border-radius:.9375rem}.border-radius-xl{border-radius:1.25rem}.border-radius-xxl{border-radius:2rem}.border-radius-rounded{border-radius:6.25rem}.text-negative{color:var(--negative-primary)}.text-neutro{color:var(--text-primary)}.text-positive{color:var(--positive-primary)}.support-text{margin-left:0;margin-top:.3125rem;padding-inline:1rem}:host{display:block}label{color:var(--text-field-label-color);margin-inline:1rem}label.empty.enabled{--text-field-label-color: var(--label-text-empty-enabled-primary)}label.empty.disabled{--text-field-label-color: var(--label-text-empty-disabled-primary)}label.full-input.enabled{--text-field-label-color: var(--label-text-full-enabled-primary)}label.full-input.disabled{--text-field-label-color: var(--label-text-full-disabled-primary)}label.full-input.readonly{--text-field-label-color: var(--label-text-full-read-only-primary)}label.focused{--text-field-label-color: var(--label-text-full-enabled-pressed-primary)}.gravity-input-field{align-items:center;background-color:var(--text-field-input-field-background-color);border:1px solid var(--text-field-input-field-border-color);border-radius:.625rem;display:flex;padding:.75rem 1rem}.gravity-input-field .prefix{color:var(--text-field-input-field-input-color)}.gravity-input-field.input{height:3rem;max-height:3rem;min-height:1.5rem}.gravity-input-field.textarea{min-height:3rem}.gravity-input-field gravity-icon.pointer{cursor:pointer}.gravity-input-field gravity-icon ::ng-deep svg-icon{pointer-events:none}.gravity-input-field gravity-icon.placement-left{margin-right:.5rem}.gravity-input-field gravity-icon.placement-right{margin-left:.5rem}.gravity-input-field input{background-color:transparent;border:none;box-shadow:none;color:var(--text-field-input-field-input-color);line-height:0;outline:none;padding:0;width:100%}.gravity-input-field input:-webkit-autofill{-webkit-box-shadow:0 0 0 30px var(--text-field-input-field-background-color) inset!important;-webkit-text-fill-color:var(--text-field-input-field-input-color)!important}.gravity-input-field input::placeholder{color:var(--text-field-input-field-placeholder-color)}.gravity-input-field textarea{background-color:transparent;border:none;box-shadow:none;color:var(--text-field-input-field-input-color);font-family:var(--font-family);line-height:1;max-height:5rem;max-width:100%;min-height:1rem;outline:none;padding:0;resize:none;width:100%}.gravity-input-field textarea::placeholder{color:var(--text-field-input-field-placeholder-color)}.gravity-input-field.empty.enabled{--text-field-input-field-background-color: var(--bg-field-empty-enabled-primary);--text-field-input-field-border-color: var(--outline-field-empty-enabled-primary);--text-field-input-field-input-color: var(--placeholder-empty-enabled-primary);--text-field-input-field-placeholder-color: var(--placeholder-empty-enabled-primary)}.gravity-input-field.empty.enabled:hover{--text-field-input-field-background-color: var(--bg-field-empty-enabled-hover-primary)}.gravity-input-field.empty.disabled{--text-field-input-field-background-color: var(--bg-field-empty-disabled-primary);--text-field-input-field-border-color: var(--bg-field-empty-disabled-primary);--text-field-input-field-input-color: var(--placeholder-empty-disabled-primary);--text-field-input-field-placeholder-color: var(--placeholder-empty-disabled-primary)}.gravity-input-field.empty.disabled gravity-icon{--icon-color: var(--placeholder-empty-disabled-primary)}.gravity-input-field.full-input.enabled{--text-field-input-field-background-color: var(--bg-field-full-enabled-primary);--text-field-input-field-border-color: var(--outline-field-full-enabled-primary);--text-field-input-field-input-color: var(--input-text-full-enabled-primary)}.gravity-input-field.full-input.enabled:hover{--text-field-input-field-background-color: var(--bg-field-full-enabled-hover-primary)}.gravity-input-field.full-input.disabled{--text-field-input-field-background-color: var(--bg-field-full-disabled-primary);--text-field-input-field-border-color: var(--bg-field-full-disabled-primary);--text-field-input-field-input-color: var(--input-text-full-disabled-primary)}.gravity-input-field.full-input.disabled gravity-icon{--icon-color: var(--input-text-full-disabled-primary)}.gravity-input-field.readonly{--text-field-input-field-background-color: var(--bg-field-full-read-only-primary);--text-field-input-field-border-color: var(--bg-field-full-read-only-primary);--text-field-input-field-input-color: var(--input-text-full-read-only-primary)}.gravity-input-field.readonly gravity-icon{--icon-color: var(--input-text-full-read-only-primary)}.gravity-input-field.focused:not(.readonly){--text-field-input-field-background-color: var(--bg-field-full-enabled-pressed-primary);--text-field-input-field-border-color: var(--outline-field-full-enabled-pressed-primary);--text-field-input-field-input-color: var(--placeholder-full-enabled-pressed-primary)}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.GravityIconComponent, selector: "gravity-icon", inputs: ["customIconColorVariable", "iconName", "hoverIcon", "size"] }] }); }
87
87
  }
88
88
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GravityTextFieldComponent, decorators: [{
89
89
  type: Component,
90
- args: [{ selector: 'gravity-text-field', template: "<label class=\"hr-body-text sm-regular {{state}}\" [class.empty]=\"inputValue == '' && !focusInput\"\n [class.focused]=\"focusInput\" [class.full-input]=\"inputValue != '' && !focusInput\" *ngIf=\"label\">\n {{label}}\n <ng-container *ngIf=\"required\">\n <ng-container *ngIf=\"currentLang == 'es'\">- Requerido <span class=\"text-negative\">*</span></ng-container>\n <ng-container *ngIf=\"currentLang == 'en'\">- Required <span class=\"text-negative\">*</span></ng-container>\n </ng-container>\n <ng-container *ngIf=\"state == 'readonly'\">\n <ng-container *ngIf=\"currentLang == 'es'\">- S\u00F3lo lectura</ng-container>\n <ng-container *ngIf=\"currentLang == 'en'\">- Readonly</ng-container>\n </ng-container>\n <ng-container *ngIf=\"state == 'disabled'\">\n <ng-container *ngIf=\"currentLang == 'es'\">- Deshabilitado</ng-container>\n <ng-container *ngIf=\"currentLang == 'en'\">- Disabled</ng-container>\n </ng-container>\n</label>\n<div class=\"gravity-input-field {{textFieldType}} {{state}}\" [class.empty]=\"inputValue == '' && !focusInput\"\n [class.focused]=\"focusInput\" [class.full-input]=\"inputValue != '' && !focusInput\">\n <ng-container *ngIf=\"iconPlacement == 'left'\">\n <ng-container *ngTemplateOutlet=\"icons\"></ng-container>\n </ng-container>\n <span class=\"hr-label md-regular prefix\">{{prefix}}</span>\n <input [attr.data-cy]=\"cypressTag\"\n [attr.disabled]=\"state == 'disabled' ? true : null\"\n [attr.readonly]=\"state == 'readonly' ? true : null\"\n [autocomplete]=\"autocomplete\"\n [maxLength]=\"validations?.maxLength ? validations?.maxLength : 100\"\n [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n [placeholder]=\"getPlaceholder()\"\n [type]=\"inputContentType\"\n [value]=\"inputValue\"\n\n (blur)=\"focusInput = false\"\n (change)=\"changeInputValue()\"\n (focus)=\"focusInput = true\"\n (keyup)=\"changeInputValue()\"\n\n class=\"hr-label md-regular\"\n\n #inputElement\n\n *ngIf=\"textFieldType == 'input'\">\n <textarea [attr.data-cy]=\"cypressTag\"\n [attr.disabled]=\"state == 'disabled' ? true : null\"\n [attr.readonly]=\"state == 'readonly' ? true : null\"\n [maxLength]=\"validations?.maxLength ? validations?.maxLength : 200\"\n [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n [placeholder]=\"getPlaceholder()\"\n [value]=\"inputValue\"\n\n (blur)=\"focusInput = false\"\n (change)=\"changeInputValue()\"\n (focus)=\"focusInput = true\"\n (keyup)=\"changeInputValue()\"\n\n class=\"hr-label md-regular\"\n rows=\"3\"\n\n #textAreaElement\n\n *ngIf=\"textFieldType == 'textarea'\"></textarea>\n <ng-container *ngIf=\"iconPlacement == 'right'\">\n <ng-container *ngTemplateOutlet=\"icons\"></ng-container>\n </ng-container>\n</div>\n<p class=\"hr-body-text sm-regular support-text text-{{supportTextType}}\" *ngIf=\"supportTextContent\">\n {{supportTextContent}}\n</p>\n\n<ng-template #icons>\n <gravity-icon (click)=\"$event.stopPropagation(); handleIconClick(name)\" class=\"placement-{{iconPlacement}}\"\n [class.pointer]=\"!!clickOnIconName\" [customIconColorVariable]=\"getIconColor(i)\"\n [hoverIcon]=\"!!clickOnIconName\" [iconName]=\"name\" *ngFor=\"let name of iconNames; let i = index\"\n [size]=\"iconsSizes[i]\"></gravity-icon>\n</ng-template>\n", styles: [".border-radius-none{border-radius:0}.border-radius-xs{border-radius:.0625rem}.border-radius-sm{border-radius:.3125rem}.border-radius-md{border-radius:.625rem}.border-radius-lg{border-radius:.9375rem}.border-radius-xl{border-radius:1.25rem}.border-radius-xxl{border-radius:2rem}.border-radius-rounded{border-radius:6.25rem}.text-negative{color:var(--negative-primary)}.text-neutro{color:var(--text-primary)}.text-positive{color:var(--positive-primary)}.support-text{margin-left:0;margin-top:.3125rem;padding-inline:1rem}:host{display:block}label{color:var(--text-field-label-color);margin-inline:1rem}label.empty.enabled{--text-field-label-color: var(--label-text-empty-enabled-primary)}label.empty.disabled{--text-field-label-color: var(--label-text-empty-disabled-primary)}label.full-input.enabled{--text-field-label-color: var(--label-text-full-enabled-primary)}label.full-input.disabled{--text-field-label-color: var(--label-text-full-disabled-primary)}label.full-input.readonly{--text-field-label-color: var(--label-text-full-read-only-primary)}label.focused{--text-field-label-color: var(--label-text-full-enabled-pressed-primary)}.gravity-input-field{align-items:center;background-color:var(--text-field-input-field-background-color);border:1px solid var(--text-field-input-field-border-color);border-radius:.625rem;display:flex;padding:.75rem 1rem}.gravity-input-field .prefix{color:var(--text-field-input-field-input-color)}.gravity-input-field.input{height:3rem;max-height:3rem;min-height:1.5rem}.gravity-input-field.textarea{min-height:3rem}.gravity-input-field gravity-icon.pointer{cursor:pointer}.gravity-input-field gravity-icon ::ng-deep svg-icon{pointer-events:none}.gravity-input-field gravity-icon.placement-left{margin-right:.5rem}.gravity-input-field gravity-icon.placement-right{margin-left:.5rem}.gravity-input-field input{background-color:transparent;border:none;box-shadow:none;color:var(--text-field-input-field-input-color);line-height:0;outline:none;padding:0;width:100%}.gravity-input-field input:-webkit-autofill{-webkit-box-shadow:0 0 0 30px var(--text-field-input-field-background-color) inset!important;-webkit-text-fill-color:var(--text-field-input-field-input-color)!important}.gravity-input-field input::placeholder{color:var(--text-field-input-field-placeholder-color)}.gravity-input-field textarea{background-color:transparent;border:none;box-shadow:none;color:var(--text-field-input-field-input-color);font-family:var(--font-family);line-height:1;max-height:5rem;max-width:100%;min-height:1rem;outline:none;padding:0;resize:none;width:100%}.gravity-input-field textarea::placeholder{color:var(--text-field-input-field-placeholder-color)}.gravity-input-field.empty.enabled{--text-field-input-field-background-color: var(--bg-field-empty-enabled-primary);--text-field-input-field-border-color: var(--outline-field-empty-enabled-primary);--text-field-input-field-input-color: var(--placeholder-empty-enabled-primary);--text-field-input-field-placeholder-color: var(--placeholder-empty-enabled-primary)}.gravity-input-field.empty.enabled:hover{--text-field-input-field-background-color: var(--bg-field-empty-enabled-hover-primary)}.gravity-input-field.empty.disabled{--text-field-input-field-background-color: var(--bg-field-empty-disabled-primary);--text-field-input-field-border-color: var(--bg-field-empty-disabled-primary);--text-field-input-field-input-color: var(--placeholder-empty-disabled-primary);--text-field-input-field-placeholder-color: var(--placeholder-empty-disabled-primary)}.gravity-input-field.empty.disabled gravity-icon{--icon-color: var(--placeholder-empty-disabled-primary)}.gravity-input-field.full-input.enabled{--text-field-input-field-background-color: var(--bg-field-full-enabled-primary);--text-field-input-field-border-color: var(--outline-field-full-enabled-primary);--text-field-input-field-input-color: var(--input-text-full-enabled-primary)}.gravity-input-field.full-input.enabled:hover{--text-field-input-field-background-color: var(--bg-field-full-enabled-hover-primary)}.gravity-input-field.full-input.disabled{--text-field-input-field-background-color: var(--bg-field-full-disabled-primary);--text-field-input-field-border-color: var(--bg-field-full-disabled-primary);--text-field-input-field-input-color: var(--input-text-full-disabled-primary)}.gravity-input-field.full-input.disabled gravity-icon{--icon-color: var(--input-text-full-disabled-primary)}.gravity-input-field.readonly{--text-field-input-field-background-color: var(--bg-field-full-read-only-primary);--text-field-input-field-border-color: var(--bg-field-full-read-only-primary);--text-field-input-field-input-color: var(--input-text-full-read-only-primary)}.gravity-input-field.readonly gravity-icon{--icon-color: var(--input-text-full-read-only-primary)}.gravity-input-field.focused:not(.readonly){--text-field-input-field-background-color: var(--bg-field-full-enabled-pressed-primary);--text-field-input-field-border-color: var(--outline-field-full-enabled-pressed-primary);--text-field-input-field-input-color: var(--placeholder-full-enabled-pressed-primary)}\n"] }]
90
+ args: [{ selector: 'gravity-text-field', template: "<label class=\"hr-body-text sm-regular {{state}}\" [class.empty]=\"inputValue == '' && !focusInput\"\n [class.focused]=\"focusInput\" [class.full-input]=\"inputValue != '' && !focusInput\" *ngIf=\"label\">\n {{label}}\n <ng-container *ngIf=\"required\">\n <ng-container *ngIf=\"currentLang == 'es'\">- Requerido <span class=\"text-negative\">*</span></ng-container>\n <ng-container *ngIf=\"currentLang == 'en'\">- Required <span class=\"text-negative\">*</span></ng-container>\n </ng-container>\n <ng-container *ngIf=\"state == 'readonly'\">\n <ng-container *ngIf=\"currentLang == 'es'\">- S\u00F3lo lectura</ng-container>\n <ng-container *ngIf=\"currentLang == 'en'\">- Readonly</ng-container>\n </ng-container>\n <ng-container *ngIf=\"state == 'disabled'\">\n <ng-container *ngIf=\"currentLang == 'es'\">- Deshabilitado</ng-container>\n <ng-container *ngIf=\"currentLang == 'en'\">- Disabled</ng-container>\n </ng-container>\n</label>\n<div class=\"gravity-input-field {{textFieldType}} {{state}}\" [class.empty]=\"inputValue == '' && !focusInput\"\n [class.focused]=\"focusInput\" [class.full-input]=\"inputValue != '' && !focusInput\">\n <ng-container *ngIf=\"iconPlacement == 'left'\">\n <ng-container *ngTemplateOutlet=\"icons\"></ng-container>\n </ng-container>\n <span class=\"hr-label md-regular prefix\">{{prefix}}</span>\n <input [attr.data-cy]=\"cypressTag\"\n [attr.disabled]=\"state == 'disabled' ? true : null\"\n [attr.readonly]=\"state == 'readonly' ? true : null\"\n [autocomplete]=\"autocomplete\"\n [maxLength]=\"validations?.maxLength ? validations?.maxLength : 100\"\n [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n [placeholder]=\"getPlaceholder()\"\n [type]=\"inputContentType\"\n [value]=\"inputValue\"\n\n (blur)=\"focusInput = false\"\n (change)=\"changeInputValue()\"\n (focus)=\"focusInput = true\"\n (keyup)=\"changeInputValue()\"\n\n class=\"hr-label md-regular\"\n\n #inputElement\n\n *ngIf=\"textFieldType == 'input'\">\n <textarea [attr.data-cy]=\"cypressTag\"\n [attr.disabled]=\"state == 'disabled' ? true : null\"\n [attr.readonly]=\"state == 'readonly' ? true : null\"\n [maxLength]=\"validations?.maxLength ? validations?.maxLength : 200\"\n [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n [placeholder]=\"getPlaceholder()\"\n [value]=\"inputValue\"\n\n (blur)=\"focusInput = false\"\n (change)=\"changeInputValue()\"\n (focus)=\"focusInput = true\"\n (keyup)=\"changeInputValue()\"\n\n class=\"hr-label md-regular\"\n rows=\"3\"\n\n #textAreaElement\n\n *ngIf=\"textFieldType == 'textarea'\"></textarea>\n <ng-container *ngIf=\"iconPlacement == 'right'\">\n <ng-container *ngTemplateOutlet=\"icons\"></ng-container>\n </ng-container>\n</div>\n<p class=\"hr-body-text sm-regular support-text text-{{supportTextType}}\" *ngIf=\"supportTextContent\">\n {{supportTextContent}}\n</p>\n\n<ng-template #icons>\n <gravity-icon (click)=\"$event.stopPropagation(); handleIconClick(name)\" class=\"placement-{{iconPlacement}}\"\n [class.pointer]=\"!!clickOnIconName\" [customIconColorVariable]=\"getIconColor(i)\"\n [hoverIcon]=\"!!clickOnIconName\" [iconName]=\"name\" *ngFor=\"let name of iconNames; let i = index\"\n [size]=\"iconsSizes[i % iconsSizes.length]\"></gravity-icon>\n</ng-template>\n", styles: [".border-radius-none{border-radius:0}.border-radius-xs{border-radius:.0625rem}.border-radius-sm{border-radius:.3125rem}.border-radius-md{border-radius:.625rem}.border-radius-lg{border-radius:.9375rem}.border-radius-xl{border-radius:1.25rem}.border-radius-xxl{border-radius:2rem}.border-radius-rounded{border-radius:6.25rem}.text-negative{color:var(--negative-primary)}.text-neutro{color:var(--text-primary)}.text-positive{color:var(--positive-primary)}.support-text{margin-left:0;margin-top:.3125rem;padding-inline:1rem}:host{display:block}label{color:var(--text-field-label-color);margin-inline:1rem}label.empty.enabled{--text-field-label-color: var(--label-text-empty-enabled-primary)}label.empty.disabled{--text-field-label-color: var(--label-text-empty-disabled-primary)}label.full-input.enabled{--text-field-label-color: var(--label-text-full-enabled-primary)}label.full-input.disabled{--text-field-label-color: var(--label-text-full-disabled-primary)}label.full-input.readonly{--text-field-label-color: var(--label-text-full-read-only-primary)}label.focused{--text-field-label-color: var(--label-text-full-enabled-pressed-primary)}.gravity-input-field{align-items:center;background-color:var(--text-field-input-field-background-color);border:1px solid var(--text-field-input-field-border-color);border-radius:.625rem;display:flex;padding:.75rem 1rem}.gravity-input-field .prefix{color:var(--text-field-input-field-input-color)}.gravity-input-field.input{height:3rem;max-height:3rem;min-height:1.5rem}.gravity-input-field.textarea{min-height:3rem}.gravity-input-field gravity-icon.pointer{cursor:pointer}.gravity-input-field gravity-icon ::ng-deep svg-icon{pointer-events:none}.gravity-input-field gravity-icon.placement-left{margin-right:.5rem}.gravity-input-field gravity-icon.placement-right{margin-left:.5rem}.gravity-input-field input{background-color:transparent;border:none;box-shadow:none;color:var(--text-field-input-field-input-color);line-height:0;outline:none;padding:0;width:100%}.gravity-input-field input:-webkit-autofill{-webkit-box-shadow:0 0 0 30px var(--text-field-input-field-background-color) inset!important;-webkit-text-fill-color:var(--text-field-input-field-input-color)!important}.gravity-input-field input::placeholder{color:var(--text-field-input-field-placeholder-color)}.gravity-input-field textarea{background-color:transparent;border:none;box-shadow:none;color:var(--text-field-input-field-input-color);font-family:var(--font-family);line-height:1;max-height:5rem;max-width:100%;min-height:1rem;outline:none;padding:0;resize:none;width:100%}.gravity-input-field textarea::placeholder{color:var(--text-field-input-field-placeholder-color)}.gravity-input-field.empty.enabled{--text-field-input-field-background-color: var(--bg-field-empty-enabled-primary);--text-field-input-field-border-color: var(--outline-field-empty-enabled-primary);--text-field-input-field-input-color: var(--placeholder-empty-enabled-primary);--text-field-input-field-placeholder-color: var(--placeholder-empty-enabled-primary)}.gravity-input-field.empty.enabled:hover{--text-field-input-field-background-color: var(--bg-field-empty-enabled-hover-primary)}.gravity-input-field.empty.disabled{--text-field-input-field-background-color: var(--bg-field-empty-disabled-primary);--text-field-input-field-border-color: var(--bg-field-empty-disabled-primary);--text-field-input-field-input-color: var(--placeholder-empty-disabled-primary);--text-field-input-field-placeholder-color: var(--placeholder-empty-disabled-primary)}.gravity-input-field.empty.disabled gravity-icon{--icon-color: var(--placeholder-empty-disabled-primary)}.gravity-input-field.full-input.enabled{--text-field-input-field-background-color: var(--bg-field-full-enabled-primary);--text-field-input-field-border-color: var(--outline-field-full-enabled-primary);--text-field-input-field-input-color: var(--input-text-full-enabled-primary)}.gravity-input-field.full-input.enabled:hover{--text-field-input-field-background-color: var(--bg-field-full-enabled-hover-primary)}.gravity-input-field.full-input.disabled{--text-field-input-field-background-color: var(--bg-field-full-disabled-primary);--text-field-input-field-border-color: var(--bg-field-full-disabled-primary);--text-field-input-field-input-color: var(--input-text-full-disabled-primary)}.gravity-input-field.full-input.disabled gravity-icon{--icon-color: var(--input-text-full-disabled-primary)}.gravity-input-field.readonly{--text-field-input-field-background-color: var(--bg-field-full-read-only-primary);--text-field-input-field-border-color: var(--bg-field-full-read-only-primary);--text-field-input-field-input-color: var(--input-text-full-read-only-primary)}.gravity-input-field.readonly gravity-icon{--icon-color: var(--input-text-full-read-only-primary)}.gravity-input-field.focused:not(.readonly){--text-field-input-field-background-color: var(--bg-field-full-enabled-pressed-primary);--text-field-input-field-border-color: var(--outline-field-full-enabled-pressed-primary);--text-field-input-field-input-color: var(--placeholder-full-enabled-pressed-primary)}\n"] }]
91
91
  }], propDecorators: { iconResponse: [{
92
92
  type: Output,
93
93
  args: ['clickIcon']
@@ -141,4 +141,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
141
141
  type: ViewChild,
142
142
  args: ['textAreaElement', { static: false }]
143
143
  }] } });
144
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gravity-text-field.component.js","sourceRoot":"","sources":["../../../../../../projects/gravity-design-system/src/lib/components/gravity-text-field/gravity-text-field.component.ts","../../../../../../projects/gravity-design-system/src/lib/components/gravity-text-field/gravity-text-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, ViewChild} from '@angular/core';\n\n@Component({\n  selector: 'gravity-text-field',\n  templateUrl: './gravity-text-field.component.html',\n  styleUrls: ['./gravity-text-field.component.scss']\n})\nexport class GravityTextFieldComponent implements OnInit, OnChanges {\n  @Output('clickIcon') public iconResponse: EventEmitter<boolean> = new EventEmitter();\n  @Output('response') public textFieldValueResponse: EventEmitter<string> = new EventEmitter();\n\n  @Input() public autocomplete: string = 'off';\n  @Input() public clickOnIconName: string | boolean = false;\n  @Input() public currentLang: string = 'en';\n  @Input() public customPlaceholder: string;\n  @Input() public customInputValue: string;\n  @Input() public cypressTag: string;\n  @Input() public iconColor?: string | string[];\n  @Input() public iconNames: string[];\n  @Input() public iconsSizes: ('sm' | 'md' | 'lg')[] = ['sm'];\n  @Input() public iconPlacement: 'left' | 'right' = \"left\";\n  @Input() public inputContentType: 'email' | 'number' | 'password' | 'tel' | 'text' = \"text\";\n  @Input() public label: string;\n  @Input() public placeholderType: 'default' | 'email' | 'url' = \"default\";\n  @Input() public prefix: string = \"\";\n  @Input() public required: boolean;\n  @Input() public state: 'readonly' | 'disabled' | 'enabled' = \"enabled\";\n  @Input() public supportTextContent: string;\n  @Input() public supportTextType: 'neutro' | 'negative' | 'positive' = \"neutro\";\n  @Input() public textFieldType: 'input' | 'textarea' = \"input\";\n  @Input() public validations: { maxLength?: number; minLength?: number };\n\n  @ViewChild('inputElement', {static: false}) private inputElement: any;\n  @ViewChild('textAreaElement', {static: false}) private textAreaElement: any;\n\n  public focusInput: boolean = false;\n  public inputValue: string = '';\n\n  private readonly placeholders = {\n    'email': 'test@email.com',\n    'url': 'https://www.test.com'\n  }\n\n  ngOnInit(): void {\n    this.inputValue = this.customInputValue ? this.customInputValue : '';\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['customInputValue']) {\n      this.inputValue = changes['customInputValue'].currentValue ? changes['customInputValue'].currentValue : '';\n    }\n  }\n\n  public getPlaceholder(): string {\n    if (this.customPlaceholder && this.customPlaceholder != '') {\n      return this.customPlaceholder;\n    } else if (this.placeholderType == 'default') {\n      return this.label;\n    } else {\n      return this.placeholders[this.placeholderType];\n    }\n  }\n\n  public clearInput(): void {\n    this.changeInputValue(true);\n  }\n\n  public changeInputValue(clearInput: boolean = false): void {\n    if (clearInput) {\n      this.inputValue = '';\n    } else if (this.textFieldType == 'input') {\n      this.inputValue = this.inputElement.nativeElement.value;\n    } else {\n      this.inputValue = this.textAreaElement.nativeElement.value;\n    }\n\n    if (this.inputValue == '') {\n      this.textFieldValueResponse.emit('');\n    } else {\n      this.textFieldValueResponse.emit(this.prefix + this.inputValue);\n    }\n  }\n\n  public handleIconClick(iconName: string): void {\n    if (this.iconNames.length == 1) {\n      this.iconResponse.emit(true);\n    } else if (this.clickOnIconName == iconName) {\n      this.iconResponse.emit(true);\n    }\n  }\n\n  public getIconColor(iconIndex: number): string | null {\n    if (typeof (this.iconColor) == 'string') {\n      return this.iconColor;\n    } else if (typeof (this.iconColor) == \"undefined\") {\n      return null;\n    } else {\n      return this.iconColor[iconIndex];\n    }\n  }\n}\n","<label class=\"hr-body-text sm-regular {{state}}\" [class.empty]=\"inputValue == '' && !focusInput\"\n       [class.focused]=\"focusInput\" [class.full-input]=\"inputValue != '' && !focusInput\" *ngIf=\"label\">\n  {{label}}\n  <ng-container *ngIf=\"required\">\n    <ng-container *ngIf=\"currentLang == 'es'\">- Requerido <span class=\"text-negative\">*</span></ng-container>\n    <ng-container *ngIf=\"currentLang == 'en'\">- Required <span class=\"text-negative\">*</span></ng-container>\n  </ng-container>\n  <ng-container *ngIf=\"state == 'readonly'\">\n    <ng-container *ngIf=\"currentLang == 'es'\">- Sólo lectura</ng-container>\n    <ng-container *ngIf=\"currentLang == 'en'\">- Readonly</ng-container>\n  </ng-container>\n  <ng-container *ngIf=\"state == 'disabled'\">\n    <ng-container *ngIf=\"currentLang == 'es'\">- Deshabilitado</ng-container>\n    <ng-container *ngIf=\"currentLang == 'en'\">- Disabled</ng-container>\n  </ng-container>\n</label>\n<div class=\"gravity-input-field {{textFieldType}} {{state}}\" [class.empty]=\"inputValue == '' && !focusInput\"\n     [class.focused]=\"focusInput\" [class.full-input]=\"inputValue != '' && !focusInput\">\n  <ng-container *ngIf=\"iconPlacement == 'left'\">\n    <ng-container *ngTemplateOutlet=\"icons\"></ng-container>\n  </ng-container>\n  <span class=\"hr-label md-regular prefix\">{{prefix}}</span>\n  <input [attr.data-cy]=\"cypressTag\"\n         [attr.disabled]=\"state == 'disabled' ? true : null\"\n         [attr.readonly]=\"state == 'readonly' ? true : null\"\n         [autocomplete]=\"autocomplete\"\n         [maxLength]=\"validations?.maxLength ? validations?.maxLength : 100\"\n         [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n         [placeholder]=\"getPlaceholder()\"\n         [type]=\"inputContentType\"\n         [value]=\"inputValue\"\n\n         (blur)=\"focusInput = false\"\n         (change)=\"changeInputValue()\"\n         (focus)=\"focusInput = true\"\n         (keyup)=\"changeInputValue()\"\n\n         class=\"hr-label md-regular\"\n\n         #inputElement\n\n         *ngIf=\"textFieldType == 'input'\">\n  <textarea [attr.data-cy]=\"cypressTag\"\n            [attr.disabled]=\"state == 'disabled' ? true : null\"\n            [attr.readonly]=\"state == 'readonly' ? true : null\"\n            [maxLength]=\"validations?.maxLength ? validations?.maxLength : 200\"\n            [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n            [placeholder]=\"getPlaceholder()\"\n            [value]=\"inputValue\"\n\n            (blur)=\"focusInput = false\"\n            (change)=\"changeInputValue()\"\n            (focus)=\"focusInput = true\"\n            (keyup)=\"changeInputValue()\"\n\n            class=\"hr-label md-regular\"\n            rows=\"3\"\n\n            #textAreaElement\n\n            *ngIf=\"textFieldType == 'textarea'\"></textarea>\n  <ng-container *ngIf=\"iconPlacement == 'right'\">\n    <ng-container *ngTemplateOutlet=\"icons\"></ng-container>\n  </ng-container>\n</div>\n<p class=\"hr-body-text sm-regular support-text text-{{supportTextType}}\" *ngIf=\"supportTextContent\">\n  {{supportTextContent}}\n</p>\n\n<ng-template #icons>\n  <gravity-icon (click)=\"$event.stopPropagation(); handleIconClick(name)\" class=\"placement-{{iconPlacement}}\"\n                [class.pointer]=\"!!clickOnIconName\" [customIconColorVariable]=\"getIconColor(i)\"\n                [hoverIcon]=\"!!clickOnIconName\" [iconName]=\"name\" *ngFor=\"let name of iconNames; let i = index\"\n                [size]=\"iconsSizes[i]\"></gravity-icon>\n</ng-template>\n"]}
144
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gravity-text-field.component.js","sourceRoot":"","sources":["../../../../../../projects/gravity-design-system/src/lib/components/gravity-text-field/gravity-text-field.component.ts","../../../../../../projects/gravity-design-system/src/lib/components/gravity-text-field/gravity-text-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, ViewChild} from '@angular/core';\n\n@Component({\n  selector: 'gravity-text-field',\n  templateUrl: './gravity-text-field.component.html',\n  styleUrls: ['./gravity-text-field.component.scss']\n})\nexport class GravityTextFieldComponent implements OnInit, OnChanges {\n  @Output('clickIcon') public iconResponse: EventEmitter<boolean> = new EventEmitter();\n  @Output('response') public textFieldValueResponse: EventEmitter<string> = new EventEmitter();\n\n  @Input() public autocomplete: string = 'off';\n  @Input() public clickOnIconName: string | boolean = false;\n  @Input() public currentLang: string = 'en';\n  @Input() public customPlaceholder: string;\n  @Input() public customInputValue: string;\n  @Input() public cypressTag: string;\n  @Input() public iconColor?: string | string[];\n  @Input() public iconNames: string[];\n  @Input() public iconsSizes: ('sm' | 'md' | 'lg')[] = ['sm'];\n  @Input() public iconPlacement: 'left' | 'right' = \"left\";\n  @Input() public inputContentType: 'email' | 'number' | 'password' | 'tel' | 'text' = \"text\";\n  @Input() public label: string;\n  @Input() public placeholderType: 'default' | 'email' | 'url' = \"default\";\n  @Input() public prefix: string = \"\";\n  @Input() public required: boolean;\n  @Input() public state: 'readonly' | 'disabled' | 'enabled' = \"enabled\";\n  @Input() public supportTextContent: string;\n  @Input() public supportTextType: 'neutro' | 'negative' | 'positive' = \"neutro\";\n  @Input() public textFieldType: 'input' | 'textarea' = \"input\";\n  @Input() public validations: { maxLength?: number; minLength?: number };\n\n  @ViewChild('inputElement', {static: false}) private inputElement: any;\n  @ViewChild('textAreaElement', {static: false}) private textAreaElement: any;\n\n  public focusInput: boolean = false;\n  public inputValue: string = '';\n\n  private readonly placeholders = {\n    'email': 'test@email.com',\n    'url': 'https://www.test.com'\n  }\n\n  ngOnInit(): void {\n    this.inputValue = this.customInputValue ? this.customInputValue : '';\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['customInputValue']) {\n      this.inputValue = changes['customInputValue'].currentValue ? changes['customInputValue'].currentValue : '';\n    }\n  }\n\n  public getPlaceholder(): string {\n    if (this.customPlaceholder && this.customPlaceholder != '') {\n      return this.customPlaceholder;\n    } else if (this.placeholderType == 'default') {\n      return this.label;\n    } else {\n      return this.placeholders[this.placeholderType];\n    }\n  }\n\n  public clearInput(): void {\n    this.changeInputValue(true);\n  }\n\n  public changeInputValue(clearInput: boolean = false): void {\n    if (clearInput) {\n      this.inputValue = '';\n    } else if (this.textFieldType == 'input') {\n      this.inputValue = this.inputElement.nativeElement.value;\n    } else {\n      this.inputValue = this.textAreaElement.nativeElement.value;\n    }\n\n    if (this.inputValue == '') {\n      this.textFieldValueResponse.emit('');\n    } else {\n      this.textFieldValueResponse.emit(this.prefix + this.inputValue);\n    }\n  }\n\n  public handleIconClick(iconName: string): void {\n    if (this.iconNames.length == 1) {\n      this.iconResponse.emit(true);\n    } else if (this.clickOnIconName == iconName) {\n      this.iconResponse.emit(true);\n    }\n  }\n\n  public getIconColor(iconIndex: number): string | null {\n    if (typeof (this.iconColor) == 'string') {\n      return this.iconColor;\n    } else if (typeof (this.iconColor) == \"undefined\") {\n      return null;\n    } else {\n      return this.iconColor[iconIndex];\n    }\n  }\n}\n","<label class=\"hr-body-text sm-regular {{state}}\" [class.empty]=\"inputValue == '' && !focusInput\"\n       [class.focused]=\"focusInput\" [class.full-input]=\"inputValue != '' && !focusInput\" *ngIf=\"label\">\n  {{label}}\n  <ng-container *ngIf=\"required\">\n    <ng-container *ngIf=\"currentLang == 'es'\">- Requerido <span class=\"text-negative\">*</span></ng-container>\n    <ng-container *ngIf=\"currentLang == 'en'\">- Required <span class=\"text-negative\">*</span></ng-container>\n  </ng-container>\n  <ng-container *ngIf=\"state == 'readonly'\">\n    <ng-container *ngIf=\"currentLang == 'es'\">- Sólo lectura</ng-container>\n    <ng-container *ngIf=\"currentLang == 'en'\">- Readonly</ng-container>\n  </ng-container>\n  <ng-container *ngIf=\"state == 'disabled'\">\n    <ng-container *ngIf=\"currentLang == 'es'\">- Deshabilitado</ng-container>\n    <ng-container *ngIf=\"currentLang == 'en'\">- Disabled</ng-container>\n  </ng-container>\n</label>\n<div class=\"gravity-input-field {{textFieldType}} {{state}}\" [class.empty]=\"inputValue == '' && !focusInput\"\n     [class.focused]=\"focusInput\" [class.full-input]=\"inputValue != '' && !focusInput\">\n  <ng-container *ngIf=\"iconPlacement == 'left'\">\n    <ng-container *ngTemplateOutlet=\"icons\"></ng-container>\n  </ng-container>\n  <span class=\"hr-label md-regular prefix\">{{prefix}}</span>\n  <input [attr.data-cy]=\"cypressTag\"\n         [attr.disabled]=\"state == 'disabled' ? true : null\"\n         [attr.readonly]=\"state == 'readonly' ? true : null\"\n         [autocomplete]=\"autocomplete\"\n         [maxLength]=\"validations?.maxLength ? validations?.maxLength : 100\"\n         [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n         [placeholder]=\"getPlaceholder()\"\n         [type]=\"inputContentType\"\n         [value]=\"inputValue\"\n\n         (blur)=\"focusInput = false\"\n         (change)=\"changeInputValue()\"\n         (focus)=\"focusInput = true\"\n         (keyup)=\"changeInputValue()\"\n\n         class=\"hr-label md-regular\"\n\n         #inputElement\n\n         *ngIf=\"textFieldType == 'input'\">\n  <textarea [attr.data-cy]=\"cypressTag\"\n            [attr.disabled]=\"state == 'disabled' ? true : null\"\n            [attr.readonly]=\"state == 'readonly' ? true : null\"\n            [maxLength]=\"validations?.maxLength ? validations?.maxLength : 200\"\n            [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n            [placeholder]=\"getPlaceholder()\"\n            [value]=\"inputValue\"\n\n            (blur)=\"focusInput = false\"\n            (change)=\"changeInputValue()\"\n            (focus)=\"focusInput = true\"\n            (keyup)=\"changeInputValue()\"\n\n            class=\"hr-label md-regular\"\n            rows=\"3\"\n\n            #textAreaElement\n\n            *ngIf=\"textFieldType == 'textarea'\"></textarea>\n  <ng-container *ngIf=\"iconPlacement == 'right'\">\n    <ng-container *ngTemplateOutlet=\"icons\"></ng-container>\n  </ng-container>\n</div>\n<p class=\"hr-body-text sm-regular support-text text-{{supportTextType}}\" *ngIf=\"supportTextContent\">\n  {{supportTextContent}}\n</p>\n\n<ng-template #icons>\n  <gravity-icon (click)=\"$event.stopPropagation(); handleIconClick(name)\" class=\"placement-{{iconPlacement}}\"\n                [class.pointer]=\"!!clickOnIconName\" [customIconColorVariable]=\"getIconColor(i)\"\n                [hoverIcon]=\"!!clickOnIconName\" [iconName]=\"name\" *ngFor=\"let name of iconNames; let i = index\"\n                [size]=\"iconsSizes[i % iconsSizes.length]\"></gravity-icon>\n</ng-template>\n"]}