@junte/ui
Version:
Quality Angular UI components kit
270 lines • 23.3 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { Component, ContentChildren, HostBinding, Input, QueryList, ViewChild } from '@angular/core';
import { RouterLinkActive } from '@angular/router';
import { PropertyApi } from '../../core/decorators/api';
import { Context } from '../../core/enums/context';
import { Feature } from '../../core/enums/feature';
import { Outline } from '../../core/enums/outline';
import { Position } from '../../core/enums/position';
import { UI } from '../../core/enums/ui';
import { UrlMatching } from '../../core/enums/url';
import { BadgeComponent } from '../../elements/badge/badge.component';
import { LinkTarget } from './enums';
var LinkComponent = /** @class */ (function () {
function LinkComponent() {
this.host = 'jnt-link-host';
this.ui = UI;
this._target = LinkTarget.self;
this._matching = UrlMatching.fullMatch;
this.externalLink = true;
this._context = Context.text;
this._outline = Outline.transparent;
this.disabled = false;
this._orphan = false;
this.features = [];
}
Object.defineProperty(LinkComponent.prototype, "withTitle", {
get: function () {
return !!this.title;
},
enumerable: true,
configurable: true
});
Object.defineProperty(LinkComponent.prototype, "linkActive", {
// TODO: we must find better solution
get: function () {
return !!this.linkRef ? this.linkRef.isActive : false;
},
enumerable: true,
configurable: true
});
Object.defineProperty(LinkComponent.prototype, "outline", {
set: function (outline) {
this._outline = outline || Outline.transparent;
},
enumerable: true,
configurable: true
});
Object.defineProperty(LinkComponent.prototype, "__icon__", {
set: function (icon) {
this.icon = (typeof (icon) === 'string'
? { icon: icon, position: Position.left } : icon);
},
enumerable: true,
configurable: true
});
Object.defineProperty(LinkComponent.prototype, "position", {
get: function () {
return !!this.icon ? this.icon.position : null;
},
enumerable: true,
configurable: true
});
Object.defineProperty(LinkComponent.prototype, "source", {
get: function () {
return this._source;
},
set: function (source) {
if (!!source) {
this.externalLink = !Array.isArray(source);
this._source = source;
}
else {
this._orphan = true;
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(LinkComponent.prototype, "target", {
get: function () {
return this._target;
},
set: function (target) {
this._target = target || LinkTarget.self;
},
enumerable: true,
configurable: true
});
Object.defineProperty(LinkComponent.prototype, "matching", {
get: function () {
return this._matching;
},
set: function (matching) {
this._matching = matching || UrlMatching.fullMatch;
},
enumerable: true,
configurable: true
});
Object.defineProperty(LinkComponent.prototype, "context", {
set: function (context) {
this._context = context || Context.text;
},
enumerable: true,
configurable: true
});
__decorate([
HostBinding('attr.host'),
__metadata("design:type", Object)
], LinkComponent.prototype, "host", void 0);
__decorate([
HostBinding('attr.data-context'),
__metadata("design:type", String)
], LinkComponent.prototype, "_context", void 0);
__decorate([
HostBinding('attr.data-outline'),
__metadata("design:type", Object)
], LinkComponent.prototype, "_outline", void 0);
__decorate([
HostBinding('attr.data-with-title'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], LinkComponent.prototype, "withTitle", null);
__decorate([
Input(),
__metadata("design:type", Boolean)
], LinkComponent.prototype, "collapsed", void 0);
__decorate([
HostBinding('attr.data-active'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], LinkComponent.prototype, "linkActive", null);
__decorate([
PropertyApi({
description: 'Disable link',
type: 'boolean',
default: 'false'
}),
HostBinding('attr.data-disabled'),
Input(),
__metadata("design:type", Object)
], LinkComponent.prototype, "disabled", void 0);
__decorate([
PropertyApi({
description: 'Link outline',
path: 'ui.outline',
default: Outline.transparent,
options: [Outline.transparent,
Outline.ghost,
Outline.fill]
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], LinkComponent.prototype, "outline", null);
__decorate([
PropertyApi({
description: 'Icon for link',
type: 'string',
name: 'icon'
}),
Input('icon'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [Object])
], LinkComponent.prototype, "__icon__", null);
__decorate([
HostBinding('attr.data-position'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], LinkComponent.prototype, "position", null);
__decorate([
PropertyApi({
description: 'Link title',
type: 'string'
}),
Input(),
__metadata("design:type", String)
], LinkComponent.prototype, "title", void 0);
__decorate([
PropertyApi({
description: 'Link query params',
type: '{[k: string]: any}'
}),
Input(),
__metadata("design:type", Object)
], LinkComponent.prototype, "queryParams", void 0);
__decorate([
PropertyApi({
description: 'Link source',
type: 'string | string[]'
}),
Input(),
__metadata("design:type", Object),
__metadata("design:paramtypes", [Object])
], LinkComponent.prototype, "source", null);
__decorate([
HostBinding('attr.data-orphan'),
__metadata("design:type", Object)
], LinkComponent.prototype, "_orphan", void 0);
__decorate([
PropertyApi({
description: 'Link target',
path: 'ui.target',
default: LinkTarget.self,
options: [LinkTarget.blank,
LinkTarget.self,
LinkTarget.parent,
LinkTarget.top]
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], LinkComponent.prototype, "target", null);
__decorate([
PropertyApi({
description: 'Fragment for link #anchor',
default: 'null',
}),
Input(),
__metadata("design:type", String)
], LinkComponent.prototype, "fragment", void 0);
__decorate([
PropertyApi({
description: 'Matching to activate link',
path: 'ui.matching',
default: UrlMatching.fullMatch,
options: [UrlMatching.fullMatch, UrlMatching.wildcard]
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], LinkComponent.prototype, "matching", null);
__decorate([
PropertyApi({
description: 'Show chevron near link',
path: 'ui.feature',
options: [Feature.dropdown],
}),
HostBinding('attr.data-features'),
Input(),
__metadata("design:type", Array)
], LinkComponent.prototype, "features", void 0);
__decorate([
PropertyApi({
description: 'Link context',
path: 'ui.context',
default: Context.text,
options: [Context.text, Context.box]
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], LinkComponent.prototype, "context", null);
__decorate([
ViewChild(RouterLinkActive),
__metadata("design:type", RouterLinkActive)
], LinkComponent.prototype, "linkRef", void 0);
__decorate([
ContentChildren(BadgeComponent),
__metadata("design:type", QueryList)
], LinkComponent.prototype, "badges", void 0);
LinkComponent = __decorate([
Component({
selector: 'jnt-link',
template: "<ng-container *ngIf=\"externalLink; else internalLinkTemplate\">\n <ng-container *ngIf=\"!!source; else emptySourceTemplate\">\n <a child-of=\"jnt-link-host\" data-link [href]=\"source\" [target]=\"'_' + target\">\n <ng-container *ngTemplateOutlet=\"linkTemplate\"></ng-container>\n </a>\n </ng-container>\n <ng-template #emptySourceTemplate>\n <a child-of=\"jnt-link-host\" data-link>\n <ng-container *ngTemplateOutlet=\"linkTemplate\"></ng-container>\n </a>\n </ng-template>\n</ng-container>\n\n<ng-template #internalLinkTemplate>\n <a child-of=\"jnt-link-host\" data-link #link=\"routerLinkActive\" routerLinkActive [attr.data-active]=\"link.isActive\"\n [routerLink]=\"source\"\n [routerLinkActiveOptions]=\"{exact: matching === ui.matching.fullMatch}\"\n [queryParams]=\"queryParams\"\n [fragment]=\"fragment\">\n <ng-container *ngTemplateOutlet=\"linkTemplate\"></ng-container>\n </a>\n</ng-template>\n\n<ng-template #linkTemplate>\n <span child-of=\"jnt-link-host\" data-title *ngIf=\"!!icon || !!title\">\n <jnt-icon child-of=\"jnt-link-host\" *ngIf=\"!!icon && icon.position === ui.position.left\" [icon]=\"icon?.icon\"></jnt-icon>\n <span child-of=\"jnt-link-host\" *ngIf=\"!!title\" [innerHTML]=\"title | sanitizeHtml\"></span>\n <jnt-icon child-of=\"jnt-link-host\" *ngIf=\"!!icon && icon.position === ui.position.right\" [icon]=\"icon?.icon\"></jnt-icon>\n </span>\n <div child-of=\"jnt-link-host\" data-empty *ngIf=\"collapsed && !icon\"></div>\n <ng-container *ngIf=\"!!badges.length\">\n <jnt-badge child-of=\"jnt-link-host\" data-badge *ngFor=\"let badge of badges\"\n [color]=\"badge.color\"\n [value]=\"badge.value\"\n [text]=\"badge.text\"\n [position]=\"ui.position.inline\">\n </jnt-badge>\n </ng-container>\n <jnt-icon child-of=\"jnt-link-host\" *ngIf=\"features | includes : ui.feature.dropdown\"\n [icon]=\"ui.icons.selectClose\" data-toggle>\n </jnt-icon>\n</ng-template>"
})
], LinkComponent);
return LinkComponent;
}());
export { LinkComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link.component.js","sourceRoot":"ng://@junte/ui/","sources":["lib/navigation/link/link.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChildren, HostBinding, Input, QueryList, ViewChild } from '@angular/core';\nimport { RouterLinkActive } from '@angular/router';\nimport { PropertyApi } from '../../core/decorators/api';\nimport { Context } from '../../core/enums/context';\nimport { Feature } from '../../core/enums/feature';\nimport { Outline } from '../../core/enums/outline';\nimport { Position } from '../../core/enums/position';\nimport { UI } from '../../core/enums/ui';\nimport { UrlMatching } from '../../core/enums/url';\nimport { BadgeComponent } from '../../elements/badge/badge.component';\nimport { LinkTarget } from './enums';\n\ninterface Icon {\n  icon: string;\n  position: Position;\n}\n\n@Component({\n  selector: 'jnt-link',\n  templateUrl: './link.encapsulated.html'\n})\nexport class LinkComponent {\n\n  @HostBinding('attr.host') readonly host = 'jnt-link-host';\n\n  ui = UI;\n  icon: Icon;\n\n  private _source: string | any[];\n  private _target: LinkTarget = LinkTarget.self;\n  private _matching: UrlMatching = UrlMatching.fullMatch;\n\n  externalLink = true;\n\n  @HostBinding('attr.data-context')\n  _context: Context = Context.text;\n\n  @HostBinding('attr.data-outline')\n  _outline = Outline.transparent;\n\n  @HostBinding('attr.data-with-title')\n  get withTitle() {\n    return !!this.title;\n  }\n\n  @Input() collapsed: boolean;\n\n  // TODO: we must find better solution\n  @HostBinding('attr.data-active')\n  get linkActive(): boolean {\n    return !!this.linkRef ? this.linkRef.isActive : false;\n  }\n\n  @PropertyApi({\n    description: 'Disable link',\n    type: 'boolean',\n    default: 'false'\n  })\n  @HostBinding('attr.data-disabled')\n  @Input() disabled = false;\n\n  @PropertyApi({\n    description: 'Link outline',\n    path: 'ui.outline',\n    default: Outline.transparent,\n    options: [Outline.transparent,\n      Outline.ghost,\n      Outline.fill]\n  })\n  @Input() set outline(outline: Outline) {\n    this._outline = outline || Outline.transparent;\n  }\n\n  @PropertyApi({\n    description: 'Icon for link',\n    type: 'string',\n    name: 'icon'\n  })\n  @Input('icon')\n  set __icon__(icon: string | Icon) {\n    this.icon = (typeof (icon) === 'string'\n      ? {icon: icon, position: Position.left} : icon) as Icon;\n  }\n\n  @HostBinding('attr.data-position') get position() {\n    return !!this.icon ? this.icon.position : null;\n  }\n\n  @PropertyApi({\n    description: 'Link title',\n    type: 'string'\n  })\n  @Input() title: string;\n\n  @PropertyApi({\n    description: 'Link query params',\n    type: '{[k: string]: any}'\n  })\n  @Input()\n  queryParams: {[k: string]: any};\n\n  @PropertyApi({\n    description: 'Link source',\n    type: 'string | string[]'\n  })\n  @Input()\n  set source(source: string | string[]) {\n    if (!!source) {\n      this.externalLink = !Array.isArray(source);\n      this._source = source;\n    } else {\n      this._orphan = true;\n    }\n  }\n\n  get source() {\n    return this._source;\n  }\n\n  @HostBinding('attr.data-orphan')\n  _orphan = false;\n\n  @PropertyApi({\n    description: 'Link target',\n    path: 'ui.target',\n    default: LinkTarget.self,\n    options: [LinkTarget.blank,\n      LinkTarget.self,\n      LinkTarget.parent,\n      LinkTarget.top]\n  })\n  @Input()\n  set target(target: LinkTarget) {\n    this._target = target || LinkTarget.self;\n  }\n\n  get target() {\n    return this._target;\n  }\n\n  @PropertyApi({\n    description: 'Fragment for link #anchor',\n    default: 'null',\n  })\n  @Input()\n  fragment: string;\n\n  @PropertyApi({\n    description: 'Matching to activate link',\n    path: 'ui.matching',\n    default: UrlMatching.fullMatch,\n    options: [UrlMatching.fullMatch, UrlMatching.wildcard]\n  })\n  @Input()\n  set matching(matching: UrlMatching) {\n    this._matching = matching || UrlMatching.fullMatch;\n  }\n\n  get matching() {\n    return this._matching;\n  }\n\n  @PropertyApi({\n    description: 'Show chevron near link',\n    path: 'ui.feature',\n    options: [Feature.dropdown],\n  })\n  @HostBinding('attr.data-features')\n  @Input()\n  features: Feature[] = [];\n\n  @PropertyApi({\n    description: 'Link context',\n    path: 'ui.context',\n    default: Context.text,\n    options: [Context.text, Context.box]\n  })\n  @Input()\n  set context(context: Context) {\n    this._context = context || Context.text;\n  }\n\n  @ViewChild(RouterLinkActive)\n  linkRef: RouterLinkActive;\n\n  @ContentChildren(BadgeComponent)\n  badges: QueryList<BadgeComponent>;\n}\n"]}