@inspark/inspark-components 14.0.57 → 14.0.58

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.
@@ -82,7 +82,7 @@ export class ButtonComponent extends PButton {
82
82
  else {
83
83
  this._target = this.linkTarget === 'self' ? '_self' : 'blank';
84
84
  }
85
- if (this.icon && this.icon.indexOf('fa-') === -1 && this.icon.indexOf('pi-') === -1) {
85
+ if (this.icon && this.icon.indexOf('in-') === -1 && this.icon.indexOf('fa-') === -1 && this.icon.indexOf('pi-') === -1) {
86
86
  this.isMaterialIcon = true;
87
87
  }
88
88
  else {
@@ -157,4 +157,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
157
157
  }], click: [{
158
158
  type: Output
159
159
  }] } });
160
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../../projects/inspark-components/src/components/button/button.component.ts","../../../../../../projects/inspark-components/src/components/button/button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, OnChanges, OnInit, Output, ViewChild, ViewEncapsulation, HostListener, HostBinding} from '@angular/core';\nimport {Button as PButton} from 'primeng/button';\nimport {InsparkMenuItem} from '../../interface';\nimport {Menu} from 'primeng/menu';\n\n\ntype ButtonSize = 'small' | 'normal' | 'large' | 'tiny';\ntype ButtonColor = 'normal' | 'danger' | 'primary' | 'secondary' | 'transparent';\ntype ButtonType = 'button' | 'submit';\ntype IconPos = 'left' | 'right';\ntype ButtonNotify = 'warning' | 'error';\n\n\n@Component({\n  selector: 'in-button',\n  templateUrl: './button.component.html',\n  styleUrls: ['./button.component.scss'],\n  encapsulation: ViewEncapsulation.Emulated,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ButtonComponent extends PButton implements OnInit, OnChanges {\n\n  @Input() size: ButtonSize = 'normal';\n  @Input() color: ButtonColor = 'normal';\n  @Input() type: ButtonType = 'button';\n  @Input() name = '';\n  @Input() testId = '';\n  @Input() label = '';\n  @Input() icon = '';\n  @Input() className = '';\n  @Input() notify: ButtonNotify = null;\n  @Input() svg = '';\n  @Input() width = 'auto';\n  @Input() link = '';\n  @Input() isLoading = false;\n  @Input() shadow = false;\n  @Input() isIconOnly = false;\n\n  /**\n   * external - ссылка на внешний источник\n   * internal - ссылка внутри приложения\n   * auto - определяется автоматически исходя из link\n   */\n  @Input() linkType: 'auto' | 'external' | 'internal' = 'auto';\n  /**\n   * self - открывается в этом же окне\n   * blank - открывается в новом окне\n   * auto - определяется автоматически исходя из linkType\n   */\n  @Input() linkTarget: 'auto' | 'self' | 'blank' = 'auto';\n\n\n  // Отображает кнопку нажатой\n  @Input() pressed = false;\n\n  @Input() disabled = false;\n\n  @Input() iconPos: IconPos = 'left';\n\n  @Input() selectedItem = null;\n  @Input() menuPlacement = 'bottom-left';\n  @Input() menuItems: InsparkMenuItem[] = [];\n\n  @ViewChild(Menu, {static: false}) _menu !: Menu;\n  @HostBinding('style.pointer-events')\n  get pointerEvents(): string {\n    return this.disabled ? 'none' : 'auto';\n  }\n\n  @Output() focus: EventEmitter<any> = new EventEmitter();\n  @Output() blur: EventEmitter<any> = new EventEmitter();\n  @Output() click: EventEmitter<any> = new EventEmitter();\n\n  _target = '_self';\n  _linkType: 'auto' | 'external' | 'internal' = 'auto';\n\n  isMaterialIcon = false;\n  constructor( private cdr: ChangeDetectorRef ) {\n    super();\n  }\n\n  ngOnInit() {\n\n\n    this.updateData();\n  }\n\n  ngOnChanges(changes) {\n    this.updateData();\n  }\n\n  updateData() {\n    this._linkType = this.linkType;\n\n    if (this._linkType === 'auto') {\n      if ((this.link.indexOf('://') !== -1 || this.link.indexOf('//') === 0)) {\n        this._linkType = 'external';\n      } else {\n        this._linkType = 'internal';\n      }\n    }\n\n    if (this.linkTarget === 'auto') {\n      if (this._linkType === 'external') {\n        this._target = '_blank';\n      } else {\n        this._target = '_self';\n      }\n    } else {\n      this._target = this.linkTarget === 'self' ? '_self' : 'blank';\n    }\n\n    if (this.icon && this.icon.indexOf('fa-') === -1 && this.icon.indexOf('pi-') === -1) {\n      this.isMaterialIcon = true;\n    } else {\n      this.isMaterialIcon = false;\n    }\n  }\n\n  _onClick($event) {\n   this.cdr.detectChanges();\n  }\n}\n","<a (blur)=\"blur.emit($event)\"\n   (click)=\"_onClick($event)\"\n   (focus)=\"focus.emit($event)\"\n   *ngIf=\"link && _linkType ==='external'\"\n   [attr.type]=\"type\"\n   [class]=\"className + ' ' + testId  + ' field_' + name\"\n   [href]=\"link\"\n   [ngClass]=\"{'p-button p-widget p-state-default p-corner-all':true,\n                        'p-button-icon-only': ((icon || svg) && !label),\n                        'p-button-text-icon-left': ((icon || svg) && label && iconPos === 'left'),\n                        'p-button-text-icon-right': ((icon || svg) && label && iconPos === 'right'),\n                        'p-button-text-only': (!(icon || svg) && label),\n                        'p-button-text-empty': (!(icon || svg) && !label),\n                        'p-button-svg': svg,\n                        'p-button-material': isMaterialIcon,\n                        'p-state-disabled': disabled,\n                        'p-button-tiny': size === 'tiny',\n                        'p-button-small': size === 'small',\n                        'p-button-large': size === 'large',\n                        'p-button-primary': color === 'primary',\n                        'p-button-secondary': color === 'secondary',\n                        'p-button-danger': color === 'danger',\n                        'p-button-transparency': color === 'transparent',\n                        'p-button-pressed' : pressed}\"\n   [ngStyle]=\"{width:width}\"\n   [style]=\"style\"\n   [target]=\"_target\" class=\"button-container\">\n  <ng-container *ngTemplateOutlet=\"content;\"></ng-container>\n</a>\n<a (blur)=\"blur.emit($event)\"\n   (click)=\"_onClick($event)\"\n   (focus)=\"focus.emit($event)\"\n   *ngIf=\"link && _linkType ==='internal'\"\n   [attr.type]=\"type\"\n   [class]=\"className + ' ' + testId  + ' field_' + name\"\n   [ngClass]=\"{'p-button p-widget p-state-default p-corner-all':true,\n                        'p-button-icon-only': ((icon || svg) && !label),\n                        'p-button-text-icon-left': ((icon || svg) && label && iconPos === 'left'),\n                        'p-button-text-icon-right': ((icon || svg) && label && iconPos === 'right'),\n                        'p-button-text-only': (!(icon || svg) && label),\n                        'p-button-text-empty': (!(icon || svg) && !label),\n                        'p-button-svg': svg,\n                        'p-button-material': isMaterialIcon,\n                        'p-state-disabled': disabled,\n                        'p-button-tiny': size === 'tiny',\n                        'p-button-small': size === 'small',\n                        'p-button-large': size === 'large',\n                        'p-button-primary': color === 'primary',\n                        'p-button-secondary': color === 'secondary',\n                        'p-button-danger': color === 'danger',\n                        'p-button-transparency': color === 'transparent',\n                        'p-button-pressed' : pressed}\"\n   [ngStyle]=\"{width:width}\"\n   [routerLink]=\"link\"\n   [style]=\"style\"\n   [target]=\"_target\" class=\"button-container\">\n  <ng-container *ngTemplateOutlet=\"content;\"></ng-container>\n</a>\n<span #dropdown=\"ngbDropdown\" *ngIf=\"!link && menuItems.length\" [ngStyle]=\"{width:width}\" class=\"button-container\" container=\"body\"\n      ngbDropdown>\n    <button\n      (blur)=\"blur.emit($event)\"\n      (click)=\"_onClick($event)\"\n      (focus)=\"focus.emit($event)\"\n      [attr.type]=\"type\"\n      [class]=\"className + ' ' + testId + ' field_' + name\"\n      [disabled]=\"disabled\"\n      [ngClass]=\" {'p-button p-widget p-state-default p-corner-all':true,\n                        'p-button-icon-only': ((icon || svg) && !label),\n                        'p-button-text-icon-left': ((icon || svg) && label && iconPos === 'left'),\n                        'p-button-text-icon-right': ((icon || svg) && label && iconPos === 'right'),\n                        'p-button-text-only': (!(icon || svg) && label),\n                        'p-button-text-empty': (!(icon || svg) && !label),\n                        'p-button-svg': svg,\n                        'p-button-material': isMaterialIcon,\n                        'p-state-disabled': disabled,\n                        'p-button-tiny': size === 'tiny',\n                        'p-button-small': size === 'small',\n                        'p-button-large': size === 'large',\n                        'p-button-primary': color === 'primary',\n                        'p-button-secondary': color === 'secondary',\n                        'p-button-danger': color === 'danger',\n                        'p-button-transparency': color === 'transparent',\n                        'p-button-shadowed': shadow === true,\n                        'p-button-pressed' : pressed}\"\n      [style]=\"style\" ngbDropdownToggle>\n        <ng-container *ngTemplateOutlet=\"content;\"></ng-container>\n    </button>\n    <div *ngIf=\"menuItems.length\" aria-labelledby=\"menu\"\n         class=\"in-dropdown-menu\"\n         ngbDropdownMenu>\n        <div *ngFor=\"let item of menuItems\" class=\"in-dropdown-menu-item\" role=\"menuitem\">\n            <in-button (click)=\"dropdown.close(); item.command();\"\n                       [color]=\"selectedItem && selectedItem == item.id?'primary':'transparent'\"\n                       [icon]=\"item.icon\"\n                       [label]=\"item.label\"\n                       [svg]=\"item.svg\"\n                       size=\"large\"\n                       width=\"100%\"></in-button>\n        </div>\n    </div>\n\n    <div *ngIf=\"notify\" [ngClass]=\"notify\" class=\"notify\"></div>\n</span>\n<span *ngIf=\"!link && !menuItems.length\" [ngStyle]=\"{width:width}\" class=\"button-container\">\n    <button\n      (blur)=\"blur.emit($event)\"\n      (click)=\"_onClick($event)\"\n      (focus)=\"focus.emit($event)\"\n      [attr.type]=\"type\"\n      [class]=\"className + ' ' + testId  + ' field_' + name\"\n      [disabled]=\"disabled\"\n      [ngClass]=\" {'p-button p-widget p-state-default p-corner-all':true,\n                        'p-button-icon-only': ((icon || svg) && !label) || isIconOnly,\n                        'p-button-text-icon-left': ((icon || svg) && label && iconPos === 'left'),\n                        'p-button-text-icon-right': ((icon || svg) && label && iconPos === 'right'),\n                        'p-button-text-only': (!(icon || svg) && label),\n                        'p-button-text-empty': (!(icon || svg) && !label),\n                        'p-button-svg': svg,\n                        'p-button-material': isMaterialIcon,\n                        'p-state-disabled': disabled,\n                        'p-button-tiny': size === 'tiny',\n                        'p-button-small': size === 'small',\n                        'p-button-large': size === 'large',\n                        'p-button-primary': color === 'primary',\n                        'p-button-secondary': color === 'secondary',\n                        'p-button-danger': color === 'danger',\n                        'p-button-transparency': color === 'transparent',\n                        'p-button-shadowed': shadow === true,\n                        'p-button-pressed' : pressed}\" [style]=\"style\">\n        <ng-container *ngTemplateOutlet=\"content;\"></ng-container>\n    </button>\n    <div *ngIf=\"notify\" [ngClass]=\"notify\" class=\"notify\"></div>\n</span>\n\n<ng-template #content>\n    <span *ngIf=\"!isMaterialIcon && icon && !isLoading\" [class]=\"icon\"\n          [ngClass]=\"{'p-clickable': true,\n                        'p-button-icon-left': (iconPos === 'left'),\n                        'p-button-icon-right': (iconPos === 'right')}\"></span>\n  <span *ngIf=\"isMaterialIcon && icon && !isLoading\" [ngClass]=\"{'p-clickable': true,\n                        'p-button-icon-left': (iconPos === 'left'),\n                        'p-button-icon-right': (iconPos === 'right')}\"\n  ><i class=\"material-icons\">{{icon}}</i></span>\n  <in-preloader *ngIf=\"isLoading\" size=\"small\"></in-preloader>\n  <span class=\"p-button-text p-clickable\">{{label}}</span>\n  <span *ngIf=\"svg && !isLoading\" [ngClass]=\"{'p-clickable': true,\n                        'p-button-icon-left': (iconPos === 'left'),\n                        'p-button-icon-right': (iconPos === 'right')}\">\n        <in-svg *ngIf=\"size === 'normal'\" [src]=\"svg\" height=\"20px\" width=\"20px\"></in-svg>\n        <in-svg *ngIf=\"size === 'large'\" [src]=\"svg\" height=\"20px\" width=\"20px\"></in-svg>\n        <in-svg *ngIf=\"size === 'small'\" [src]=\"svg\" height=\"20px\" width=\"20px\"></in-svg>\n        <in-svg *ngIf=\"size === 'tiny'\" [src]=\"svg\" height=\"10px\" width=\"10px\"></in-svg>\n    </span>\n</ng-template>\n"]}
160
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../../projects/inspark-components/src/components/button/button.component.ts","../../../../../../projects/inspark-components/src/components/button/button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, OnChanges, OnInit, Output, ViewChild, ViewEncapsulation, HostListener, HostBinding} from '@angular/core';\nimport {Button as PButton} from 'primeng/button';\nimport {InsparkMenuItem} from '../../interface';\nimport {Menu} from 'primeng/menu';\n\n\ntype ButtonSize = 'small' | 'normal' | 'large' | 'tiny';\ntype ButtonColor = 'normal' | 'danger' | 'primary' | 'secondary' | 'transparent';\ntype ButtonType = 'button' | 'submit';\ntype IconPos = 'left' | 'right';\ntype ButtonNotify = 'warning' | 'error';\n\n\n@Component({\n  selector: 'in-button',\n  templateUrl: './button.component.html',\n  styleUrls: ['./button.component.scss'],\n  encapsulation: ViewEncapsulation.Emulated,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ButtonComponent extends PButton implements OnInit, OnChanges {\n\n  @Input() size: ButtonSize = 'normal';\n  @Input() color: ButtonColor = 'normal';\n  @Input() type: ButtonType = 'button';\n  @Input() name = '';\n  @Input() testId = '';\n  @Input() label = '';\n  @Input() icon = '';\n  @Input() className = '';\n  @Input() notify: ButtonNotify = null;\n  @Input() svg = '';\n  @Input() width = 'auto';\n  @Input() link = '';\n  @Input() isLoading = false;\n  @Input() shadow = false;\n  @Input() isIconOnly = false;\n\n  /**\n   * external - ссылка на внешний источник\n   * internal - ссылка внутри приложения\n   * auto - определяется автоматически исходя из link\n   */\n  @Input() linkType: 'auto' | 'external' | 'internal' = 'auto';\n  /**\n   * self - открывается в этом же окне\n   * blank - открывается в новом окне\n   * auto - определяется автоматически исходя из linkType\n   */\n  @Input() linkTarget: 'auto' | 'self' | 'blank' = 'auto';\n\n\n  // Отображает кнопку нажатой\n  @Input() pressed = false;\n\n  @Input() disabled = false;\n\n  @Input() iconPos: IconPos = 'left';\n\n  @Input() selectedItem = null;\n  @Input() menuPlacement = 'bottom-left';\n  @Input() menuItems: InsparkMenuItem[] = [];\n\n  @ViewChild(Menu, {static: false}) _menu !: Menu;\n  @HostBinding('style.pointer-events')\n  get pointerEvents(): string {\n    return this.disabled ? 'none' : 'auto';\n  }\n\n  @Output() focus: EventEmitter<any> = new EventEmitter();\n  @Output() blur: EventEmitter<any> = new EventEmitter();\n  @Output() click: EventEmitter<any> = new EventEmitter();\n\n  _target = '_self';\n  _linkType: 'auto' | 'external' | 'internal' = 'auto';\n\n  isMaterialIcon = false;\n  constructor( private cdr: ChangeDetectorRef ) {\n    super();\n  }\n\n  ngOnInit() {\n\n\n    this.updateData();\n  }\n\n  ngOnChanges(changes) {\n    this.updateData();\n  }\n\n  updateData() {\n    this._linkType = this.linkType;\n\n    if (this._linkType === 'auto') {\n      if ((this.link.indexOf('://') !== -1 || this.link.indexOf('//') === 0)) {\n        this._linkType = 'external';\n      } else {\n        this._linkType = 'internal';\n      }\n    }\n\n    if (this.linkTarget === 'auto') {\n      if (this._linkType === 'external') {\n        this._target = '_blank';\n      } else {\n        this._target = '_self';\n      }\n    } else {\n      this._target = this.linkTarget === 'self' ? '_self' : 'blank';\n    }\n\n    if (this.icon && this.icon.indexOf('in-') === -1 && this.icon.indexOf('fa-') === -1 && this.icon.indexOf('pi-') === -1) {\n      this.isMaterialIcon = true;\n    } else {\n      this.isMaterialIcon = false;\n    }\n  }\n\n  _onClick($event) {\n   this.cdr.detectChanges();\n  }\n}\n","<a (blur)=\"blur.emit($event)\"\n   (click)=\"_onClick($event)\"\n   (focus)=\"focus.emit($event)\"\n   *ngIf=\"link && _linkType ==='external'\"\n   [attr.type]=\"type\"\n   [class]=\"className + ' ' + testId  + ' field_' + name\"\n   [href]=\"link\"\n   [ngClass]=\"{'p-button p-widget p-state-default p-corner-all':true,\n                        'p-button-icon-only': ((icon || svg) && !label),\n                        'p-button-text-icon-left': ((icon || svg) && label && iconPos === 'left'),\n                        'p-button-text-icon-right': ((icon || svg) && label && iconPos === 'right'),\n                        'p-button-text-only': (!(icon || svg) && label),\n                        'p-button-text-empty': (!(icon || svg) && !label),\n                        'p-button-svg': svg,\n                        'p-button-material': isMaterialIcon,\n                        'p-state-disabled': disabled,\n                        'p-button-tiny': size === 'tiny',\n                        'p-button-small': size === 'small',\n                        'p-button-large': size === 'large',\n                        'p-button-primary': color === 'primary',\n                        'p-button-secondary': color === 'secondary',\n                        'p-button-danger': color === 'danger',\n                        'p-button-transparency': color === 'transparent',\n                        'p-button-pressed' : pressed}\"\n   [ngStyle]=\"{width:width}\"\n   [style]=\"style\"\n   [target]=\"_target\" class=\"button-container\">\n  <ng-container *ngTemplateOutlet=\"content;\"></ng-container>\n</a>\n<a (blur)=\"blur.emit($event)\"\n   (click)=\"_onClick($event)\"\n   (focus)=\"focus.emit($event)\"\n   *ngIf=\"link && _linkType ==='internal'\"\n   [attr.type]=\"type\"\n   [class]=\"className + ' ' + testId  + ' field_' + name\"\n   [ngClass]=\"{'p-button p-widget p-state-default p-corner-all':true,\n                        'p-button-icon-only': ((icon || svg) && !label),\n                        'p-button-text-icon-left': ((icon || svg) && label && iconPos === 'left'),\n                        'p-button-text-icon-right': ((icon || svg) && label && iconPos === 'right'),\n                        'p-button-text-only': (!(icon || svg) && label),\n                        'p-button-text-empty': (!(icon || svg) && !label),\n                        'p-button-svg': svg,\n                        'p-button-material': isMaterialIcon,\n                        'p-state-disabled': disabled,\n                        'p-button-tiny': size === 'tiny',\n                        'p-button-small': size === 'small',\n                        'p-button-large': size === 'large',\n                        'p-button-primary': color === 'primary',\n                        'p-button-secondary': color === 'secondary',\n                        'p-button-danger': color === 'danger',\n                        'p-button-transparency': color === 'transparent',\n                        'p-button-pressed' : pressed}\"\n   [ngStyle]=\"{width:width}\"\n   [routerLink]=\"link\"\n   [style]=\"style\"\n   [target]=\"_target\" class=\"button-container\">\n  <ng-container *ngTemplateOutlet=\"content;\"></ng-container>\n</a>\n<span #dropdown=\"ngbDropdown\" *ngIf=\"!link && menuItems.length\" [ngStyle]=\"{width:width}\" class=\"button-container\" container=\"body\"\n      ngbDropdown>\n    <button\n      (blur)=\"blur.emit($event)\"\n      (click)=\"_onClick($event)\"\n      (focus)=\"focus.emit($event)\"\n      [attr.type]=\"type\"\n      [class]=\"className + ' ' + testId + ' field_' + name\"\n      [disabled]=\"disabled\"\n      [ngClass]=\" {'p-button p-widget p-state-default p-corner-all':true,\n                        'p-button-icon-only': ((icon || svg) && !label),\n                        'p-button-text-icon-left': ((icon || svg) && label && iconPos === 'left'),\n                        'p-button-text-icon-right': ((icon || svg) && label && iconPos === 'right'),\n                        'p-button-text-only': (!(icon || svg) && label),\n                        'p-button-text-empty': (!(icon || svg) && !label),\n                        'p-button-svg': svg,\n                        'p-button-material': isMaterialIcon,\n                        'p-state-disabled': disabled,\n                        'p-button-tiny': size === 'tiny',\n                        'p-button-small': size === 'small',\n                        'p-button-large': size === 'large',\n                        'p-button-primary': color === 'primary',\n                        'p-button-secondary': color === 'secondary',\n                        'p-button-danger': color === 'danger',\n                        'p-button-transparency': color === 'transparent',\n                        'p-button-shadowed': shadow === true,\n                        'p-button-pressed' : pressed}\"\n      [style]=\"style\" ngbDropdownToggle>\n        <ng-container *ngTemplateOutlet=\"content;\"></ng-container>\n    </button>\n    <div *ngIf=\"menuItems.length\" aria-labelledby=\"menu\"\n         class=\"in-dropdown-menu\"\n         ngbDropdownMenu>\n        <div *ngFor=\"let item of menuItems\" class=\"in-dropdown-menu-item\" role=\"menuitem\">\n            <in-button (click)=\"dropdown.close(); item.command();\"\n                       [color]=\"selectedItem && selectedItem == item.id?'primary':'transparent'\"\n                       [icon]=\"item.icon\"\n                       [label]=\"item.label\"\n                       [svg]=\"item.svg\"\n                       size=\"large\"\n                       width=\"100%\"></in-button>\n        </div>\n    </div>\n\n    <div *ngIf=\"notify\" [ngClass]=\"notify\" class=\"notify\"></div>\n</span>\n<span *ngIf=\"!link && !menuItems.length\" [ngStyle]=\"{width:width}\" class=\"button-container\">\n    <button\n      (blur)=\"blur.emit($event)\"\n      (click)=\"_onClick($event)\"\n      (focus)=\"focus.emit($event)\"\n      [attr.type]=\"type\"\n      [class]=\"className + ' ' + testId  + ' field_' + name\"\n      [disabled]=\"disabled\"\n      [ngClass]=\" {'p-button p-widget p-state-default p-corner-all':true,\n                        'p-button-icon-only': ((icon || svg) && !label) || isIconOnly,\n                        'p-button-text-icon-left': ((icon || svg) && label && iconPos === 'left'),\n                        'p-button-text-icon-right': ((icon || svg) && label && iconPos === 'right'),\n                        'p-button-text-only': (!(icon || svg) && label),\n                        'p-button-text-empty': (!(icon || svg) && !label),\n                        'p-button-svg': svg,\n                        'p-button-material': isMaterialIcon,\n                        'p-state-disabled': disabled,\n                        'p-button-tiny': size === 'tiny',\n                        'p-button-small': size === 'small',\n                        'p-button-large': size === 'large',\n                        'p-button-primary': color === 'primary',\n                        'p-button-secondary': color === 'secondary',\n                        'p-button-danger': color === 'danger',\n                        'p-button-transparency': color === 'transparent',\n                        'p-button-shadowed': shadow === true,\n                        'p-button-pressed' : pressed}\" [style]=\"style\">\n        <ng-container *ngTemplateOutlet=\"content;\"></ng-container>\n    </button>\n    <div *ngIf=\"notify\" [ngClass]=\"notify\" class=\"notify\"></div>\n</span>\n\n<ng-template #content>\n    <span *ngIf=\"!isMaterialIcon && icon && !isLoading\" [class]=\"icon\"\n          [ngClass]=\"{'p-clickable': true,\n                        'p-button-icon-left': (iconPos === 'left'),\n                        'p-button-icon-right': (iconPos === 'right')}\"></span>\n  <span *ngIf=\"isMaterialIcon && icon && !isLoading\" [ngClass]=\"{'p-clickable': true,\n                        'p-button-icon-left': (iconPos === 'left'),\n                        'p-button-icon-right': (iconPos === 'right')}\"\n  ><i class=\"material-icons\">{{icon}}</i></span>\n  <in-preloader *ngIf=\"isLoading\" size=\"small\"></in-preloader>\n  <span class=\"p-button-text p-clickable\">{{label}}</span>\n  <span *ngIf=\"svg && !isLoading\" [ngClass]=\"{'p-clickable': true,\n                        'p-button-icon-left': (iconPos === 'left'),\n                        'p-button-icon-right': (iconPos === 'right')}\">\n        <in-svg *ngIf=\"size === 'normal'\" [src]=\"svg\" height=\"20px\" width=\"20px\"></in-svg>\n        <in-svg *ngIf=\"size === 'large'\" [src]=\"svg\" height=\"20px\" width=\"20px\"></in-svg>\n        <in-svg *ngIf=\"size === 'small'\" [src]=\"svg\" height=\"20px\" width=\"20px\"></in-svg>\n        <in-svg *ngIf=\"size === 'tiny'\" [src]=\"svg\" height=\"10px\" width=\"10px\"></in-svg>\n    </span>\n</ng-template>\n"]}
@@ -67,7 +67,7 @@ export class LinkComponent {
67
67
  else {
68
68
  this._target = this.linkTarget === 'self' ? '_self' : 'blank';
69
69
  }
70
- if (this.icon && this.icon.indexOf('fa-') === -1) {
70
+ if (this.icon && this.icon.indexOf('in-') === -1 && this.icon.indexOf('fa-') === -1) {
71
71
  this.isMaterialIcon = true;
72
72
  }
73
73
  else {
@@ -128,4 +128,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
128
128
  }], click: [{
129
129
  type: Output
130
130
  }] } });
131
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link.component.js","sourceRoot":"","sources":["../../../../../../projects/inspark-components/src/components/link/link.component.ts","../../../../../../projects/inspark-components/src/components/link/link.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnChanges, OnInit, Output, ViewChild} from '@angular/core';\nimport {MenuItem} from 'primeng/api';\nimport {Menu} from 'primeng/menu';\n\n\ntype LinkColor = 'normal' | 'secondary' | 'danger' | 'primary'  | 'transparent';\ntype IconPos = 'left' | 'right';\n\n@Component({\n  selector: 'in-link',\n  templateUrl: './link.component.html',\n  styleUrls: ['./link.component.scss'],\n})\nexport class LinkComponent implements OnInit, OnChanges {\n\n  @Input() color: LinkColor = 'normal';\n  @Input() name = '';\n  @Input() testId = '';\n  @Input() label = '';\n  @Input() icon = '';\n  @Input() className = '';\n  @Input() svg = '';\n  @Input() link = '';\n  /**\n   * external - ссылка на внешний источник\n   * internal - ссылка внутри приложения\n   * auto - определяется автоматически исходя из link\n   */\n  @Input() linkType: 'auto' | 'external' | 'internal' = 'auto';\n  /**\n   * self - открывается в этом же окне\n   * blank - открывается в новом окне\n   * auto - определяется автоматически исходя из linkType\n   */\n  @Input() linkTarget: 'auto' | 'self' | 'blank' = 'auto';\n\n\n  // Отображает кнопку нажатой\n  @Input() pressed = false;\n\n  @Input() disabled = false;\n\n  @Input() iconPos: IconPos = 'left';\n  @Input() menuItems: MenuItem[] = [];\n\n  @ViewChild(Menu, {static: false}) _menu !: Menu;\n\n  @Output() focus: EventEmitter<any> = new EventEmitter();\n  @Output() blur: EventEmitter<any> = new EventEmitter();\n  @Output() click: EventEmitter<any> = new EventEmitter();\n\n  style={}\n\n  _target = '_self';\n  _linkType: 'auto' | 'external' | 'internal' = 'auto';\n\n   isMaterialIcon = false;\n\n  ngOnInit() {\n\n\n    this.updateData();\n  }\n\n  ngOnChanges(changes) {\n    this.updateData();\n  }\n\n  updateData() {\n    this._linkType = this.linkType;\n\n    if (this._linkType === 'auto') {\n      if ((this.link.indexOf('://') !== -1 || this.link.indexOf('//') === 0)) {\n        this._linkType = 'external';\n      } else {\n        this._linkType = 'internal';\n      }\n    }\n\n    if (this.linkTarget === 'auto') {\n      if (this._linkType === 'external') {\n        this._target = '_blank';\n      } else {\n        this._target = '_self';\n      }\n    } else {\n      this._target = this.linkTarget === 'self' ? '_self' : 'blank';\n    }\n\n    if (this.icon && this.icon.indexOf('fa-') === -1) {\n      this.isMaterialIcon = true;\n    } else {\n      this.isMaterialIcon = false;\n    }\n  }\n\n   _onClick($event: Event) {\n    // if (!this.link) {\n    //   $event.stopPropagation();\n    //   $event.preventDefault();\n    //   this.click.emit($event);\n    // }\n    if (this.menuItems.length) {\n      this._menu.toggle($event);\n    }\n  }\n}\n","<a (blur)=\"blur.emit($event)\"\n   (focus)=\"focus.emit($event)\"\n   *ngIf=\"link &&_linkType ==='external'\"\n   [class]=\"className\"\n   [href]=\"link\"\n   [ngClass]=\"{'p-link p-state-default p-corner-all p-link-transparency':true,\n                        'p-link-text-icon-left': ((icon || svg) && label && iconPos === 'left'),\n                        'p-link-text-icon-right': ((icon || svg) && label && iconPos === 'right'),\n                        'p-link-text-only': (!(icon || svg) && label),\n                        'p-link-text-empty': (!(icon || svg) && !label),\n                        'p-link-svg': svg,\n                        'p-link-material': isMaterialIcon,\n                        'p-state-disabled': disabled,\n                        'p-link-primary': color === 'primary',\n                        'p-link-secondary': color === 'secondary',\n                        'p-link-danger': color === 'danger'}\"\n   [style]=\"style\" [target]=\"_target\">\n  <ng-container *ngTemplateOutlet=\"content;\"></ng-container>\n</a>\n<a (blur)=\"blur.emit($event)\"\n   (focus)=\"focus.emit($event)\"\n   *ngIf=\"link && _linkType ==='internal'\"\n   [class]=\"className\"\n   [ngClass]=\"{'p-link p-state-default p-corner-all p-link-transparency':true,\n                        'p-link-text-icon-left': ((icon || svg) && label && iconPos === 'left'),\n                        'p-link-text-icon-right': ((icon || svg) && label && iconPos === 'right'),\n                        'p-link-text-only': (!(icon || svg) && label),\n                        'p-link-text-empty': (!(icon || svg) && !label),\n                        'p-link-svg': svg,\n                        'p-link-material': isMaterialIcon,\n                        'p-state-disabled': disabled,\n                        'p-link-primary': color === 'primary',\n                        'p-link-secondary': color === 'secondary',\n                        'p-link-danger': color === 'danger'}\"\n   [routerLink]=\"link\"\n   [style]=\"style\" [target]=\"_target\">\n  <ng-container *ngTemplateOutlet=\"content;\"></ng-container>\n</a>\n<span (blur)=\"blur.emit($event)\"\n      (click)=\"_onClick($event)\"\n      (focus)=\"focus.emit($event)\"\n      *ngIf=\"!link\"\n      [class]=\"className\"\n      [ngClass]=\"{'p-link p-state-default p-corner-all p-link-transparency':true,\n                        'p-link-text-icon-left': ((icon || svg) && label && iconPos === 'left'),\n                        'p-link-text-icon-right': ((icon || svg) && label && iconPos === 'right'),\n                        'p-link-text-only': (!(icon || svg) && label),\n                        'p-link-text-empty': (!(icon || svg) && !label),\n                        'p-link-svg': svg,\n                        'p-link-material': isMaterialIcon,\n                        'p-state-disabled': disabled,\n                        'p-link-primary': color === 'primary',\n                        'p-link-secondary': color === 'secondary',\n                        'p-link-danger': color === 'danger'}\" [style]=\"style\">\n    <ng-container *ngTemplateOutlet=\"content;\"></ng-container>\n</span>\n<p-menu *ngIf=\"menuItems.length\" [model]=\"menuItems\" [popup]=\"true\" appendTo=\"body\" styleClass=\"button-menu\"></p-menu>\n\n<ng-template #content>\n    <span *ngIf=\"!isMaterialIcon && icon\" [class]=\"icon\"\n          [ngClass]=\"{'p-clickable': true,\n                        'p-link-icon-left': (iconPos === 'left'),\n                        'p-link-icon-right': (iconPos === 'right')}\"></span>\n  <span *ngIf=\"isMaterialIcon && icon\" [ngClass]=\"{'p-clickable': true,\n                        'p-link-icon-left': (iconPos === 'left'),\n                        'p-link-icon-right': (iconPos === 'right')}\"\n  ><i class=\"material-icons\">{{icon}}</i></span>\n  <span *ngIf=\"svg\" [ngClass]=\"{'p-clickable': true,\n                        'p-link-icon-left': (iconPos === 'left'),\n                        'p-link-icon-right': (iconPos === 'right')}\">\n        <in-svg [src]=\"svg\" height=\"20px\" width=\"20px\"></in-svg>\n    </span>\n  <span class=\"p-link-text p-clickable\">{{label}}</span>\n\n</ng-template>\n"]}
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link.component.js","sourceRoot":"","sources":["../../../../../../projects/inspark-components/src/components/link/link.component.ts","../../../../../../projects/inspark-components/src/components/link/link.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnChanges, OnInit, Output, ViewChild} from '@angular/core';\nimport {MenuItem} from 'primeng/api';\nimport {Menu} from 'primeng/menu';\n\n\ntype LinkColor = 'normal' | 'secondary' | 'danger' | 'primary'  | 'transparent';\ntype IconPos = 'left' | 'right';\n\n@Component({\n  selector: 'in-link',\n  templateUrl: './link.component.html',\n  styleUrls: ['./link.component.scss'],\n})\nexport class LinkComponent implements OnInit, OnChanges {\n\n  @Input() color: LinkColor = 'normal';\n  @Input() name = '';\n  @Input() testId = '';\n  @Input() label = '';\n  @Input() icon = '';\n  @Input() className = '';\n  @Input() svg = '';\n  @Input() link = '';\n  /**\n   * external - ссылка на внешний источник\n   * internal - ссылка внутри приложения\n   * auto - определяется автоматически исходя из link\n   */\n  @Input() linkType: 'auto' | 'external' | 'internal' = 'auto';\n  /**\n   * self - открывается в этом же окне\n   * blank - открывается в новом окне\n   * auto - определяется автоматически исходя из linkType\n   */\n  @Input() linkTarget: 'auto' | 'self' | 'blank' = 'auto';\n\n\n  // Отображает кнопку нажатой\n  @Input() pressed = false;\n\n  @Input() disabled = false;\n\n  @Input() iconPos: IconPos = 'left';\n  @Input() menuItems: MenuItem[] = [];\n\n  @ViewChild(Menu, {static: false}) _menu !: Menu;\n\n  @Output() focus: EventEmitter<any> = new EventEmitter();\n  @Output() blur: EventEmitter<any> = new EventEmitter();\n  @Output() click: EventEmitter<any> = new EventEmitter();\n\n  style={}\n\n  _target = '_self';\n  _linkType: 'auto' | 'external' | 'internal' = 'auto';\n\n   isMaterialIcon = false;\n\n  ngOnInit() {\n\n\n    this.updateData();\n  }\n\n  ngOnChanges(changes) {\n    this.updateData();\n  }\n\n  updateData() {\n    this._linkType = this.linkType;\n\n    if (this._linkType === 'auto') {\n      if ((this.link.indexOf('://') !== -1 || this.link.indexOf('//') === 0)) {\n        this._linkType = 'external';\n      } else {\n        this._linkType = 'internal';\n      }\n    }\n\n    if (this.linkTarget === 'auto') {\n      if (this._linkType === 'external') {\n        this._target = '_blank';\n      } else {\n        this._target = '_self';\n      }\n    } else {\n      this._target = this.linkTarget === 'self' ? '_self' : 'blank';\n    }\n\n    if (this.icon && this.icon.indexOf('in-') === -1 && this.icon.indexOf('fa-') === -1) {\n      this.isMaterialIcon = true;\n    } else {\n      this.isMaterialIcon = false;\n    }\n  }\n\n   _onClick($event: Event) {\n    // if (!this.link) {\n    //   $event.stopPropagation();\n    //   $event.preventDefault();\n    //   this.click.emit($event);\n    // }\n    if (this.menuItems.length) {\n      this._menu.toggle($event);\n    }\n  }\n}\n","<a (blur)=\"blur.emit($event)\"\n   (focus)=\"focus.emit($event)\"\n   *ngIf=\"link &&_linkType ==='external'\"\n   [class]=\"className\"\n   [href]=\"link\"\n   [ngClass]=\"{'p-link p-state-default p-corner-all p-link-transparency':true,\n                        'p-link-text-icon-left': ((icon || svg) && label && iconPos === 'left'),\n                        'p-link-text-icon-right': ((icon || svg) && label && iconPos === 'right'),\n                        'p-link-text-only': (!(icon || svg) && label),\n                        'p-link-text-empty': (!(icon || svg) && !label),\n                        'p-link-svg': svg,\n                        'p-link-material': isMaterialIcon,\n                        'p-state-disabled': disabled,\n                        'p-link-primary': color === 'primary',\n                        'p-link-secondary': color === 'secondary',\n                        'p-link-danger': color === 'danger'}\"\n   [style]=\"style\" [target]=\"_target\">\n  <ng-container *ngTemplateOutlet=\"content;\"></ng-container>\n</a>\n<a (blur)=\"blur.emit($event)\"\n   (focus)=\"focus.emit($event)\"\n   *ngIf=\"link && _linkType ==='internal'\"\n   [class]=\"className\"\n   [ngClass]=\"{'p-link p-state-default p-corner-all p-link-transparency':true,\n                        'p-link-text-icon-left': ((icon || svg) && label && iconPos === 'left'),\n                        'p-link-text-icon-right': ((icon || svg) && label && iconPos === 'right'),\n                        'p-link-text-only': (!(icon || svg) && label),\n                        'p-link-text-empty': (!(icon || svg) && !label),\n                        'p-link-svg': svg,\n                        'p-link-material': isMaterialIcon,\n                        'p-state-disabled': disabled,\n                        'p-link-primary': color === 'primary',\n                        'p-link-secondary': color === 'secondary',\n                        'p-link-danger': color === 'danger'}\"\n   [routerLink]=\"link\"\n   [style]=\"style\" [target]=\"_target\">\n  <ng-container *ngTemplateOutlet=\"content;\"></ng-container>\n</a>\n<span (blur)=\"blur.emit($event)\"\n      (click)=\"_onClick($event)\"\n      (focus)=\"focus.emit($event)\"\n      *ngIf=\"!link\"\n      [class]=\"className\"\n      [ngClass]=\"{'p-link p-state-default p-corner-all p-link-transparency':true,\n                        'p-link-text-icon-left': ((icon || svg) && label && iconPos === 'left'),\n                        'p-link-text-icon-right': ((icon || svg) && label && iconPos === 'right'),\n                        'p-link-text-only': (!(icon || svg) && label),\n                        'p-link-text-empty': (!(icon || svg) && !label),\n                        'p-link-svg': svg,\n                        'p-link-material': isMaterialIcon,\n                        'p-state-disabled': disabled,\n                        'p-link-primary': color === 'primary',\n                        'p-link-secondary': color === 'secondary',\n                        'p-link-danger': color === 'danger'}\" [style]=\"style\">\n    <ng-container *ngTemplateOutlet=\"content;\"></ng-container>\n</span>\n<p-menu *ngIf=\"menuItems.length\" [model]=\"menuItems\" [popup]=\"true\" appendTo=\"body\" styleClass=\"button-menu\"></p-menu>\n\n<ng-template #content>\n    <span *ngIf=\"!isMaterialIcon && icon\" [class]=\"icon\"\n          [ngClass]=\"{'p-clickable': true,\n                        'p-link-icon-left': (iconPos === 'left'),\n                        'p-link-icon-right': (iconPos === 'right')}\"></span>\n  <span *ngIf=\"isMaterialIcon && icon\" [ngClass]=\"{'p-clickable': true,\n                        'p-link-icon-left': (iconPos === 'left'),\n                        'p-link-icon-right': (iconPos === 'right')}\"\n  ><i class=\"material-icons\">{{icon}}</i></span>\n  <span *ngIf=\"svg\" [ngClass]=\"{'p-clickable': true,\n                        'p-link-icon-left': (iconPos === 'left'),\n                        'p-link-icon-right': (iconPos === 'right')}\">\n        <in-svg [src]=\"svg\" height=\"20px\" width=\"20px\"></in-svg>\n    </span>\n  <span class=\"p-link-text p-clickable\">{{label}}</span>\n\n</ng-template>\n"]}
@@ -628,7 +628,7 @@ class ButtonComponent extends Button {
628
628
  else {
629
629
  this._target = this.linkTarget === 'self' ? '_self' : 'blank';
630
630
  }
631
- if (this.icon && this.icon.indexOf('fa-') === -1 && this.icon.indexOf('pi-') === -1) {
631
+ if (this.icon && this.icon.indexOf('in-') === -1 && this.icon.indexOf('fa-') === -1 && this.icon.indexOf('pi-') === -1) {
632
632
  this.isMaterialIcon = true;
633
633
  }
634
634
  else {
@@ -2456,7 +2456,7 @@ class LinkComponent {
2456
2456
  else {
2457
2457
  this._target = this.linkTarget === 'self' ? '_self' : 'blank';
2458
2458
  }
2459
- if (this.icon && this.icon.indexOf('fa-') === -1) {
2459
+ if (this.icon && this.icon.indexOf('in-') === -1 && this.icon.indexOf('fa-') === -1) {
2460
2460
  this.isMaterialIcon = true;
2461
2461
  }
2462
2462
  else {