@dso-design-system/ui 0.0.2 → 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/alert/alert.component.mjs +54 -0
- package/esm2022/lib/badge/badge.component.mjs +22 -0
- package/esm2022/lib/breadcrumb/breadcrumb.component.mjs +29 -0
- package/esm2022/lib/checkbox/checkbox.component.mjs +82 -0
- package/esm2022/lib/datepicker/datepicker.component.mjs +161 -0
- package/esm2022/lib/dialog/dialog.component.mjs +25 -0
- package/esm2022/lib/directives/truncate.directive.mjs +71 -0
- package/esm2022/lib/dropdown-list/dropdown-list.component.mjs +89 -0
- package/esm2022/lib/file-upload-items/file-upload-items.component.mjs +65 -0
- package/esm2022/lib/file-upload-multiple/file-upload-multiple.component.mjs +232 -0
- package/esm2022/lib/file-upload-multiple/upload-item.model.mjs +2 -0
- package/esm2022/lib/file-upload-multiple/upload-simulator.service.mjs +76 -0
- package/esm2022/lib/file-upload-single/file-upload-single.component.mjs +100 -0
- package/esm2022/lib/input-text/input-text.component.mjs +93 -0
- package/esm2022/lib/pagination/pagination.component.mjs +115 -0
- package/esm2022/lib/progress-bar/progress-bar.component.mjs +25 -0
- package/esm2022/lib/radio/radio.component.mjs +41 -0
- package/esm2022/lib/select-dropdown/select-dropdown.component.mjs +228 -0
- package/esm2022/lib/service/toast.service.mjs +20 -0
- package/esm2022/lib/side-navigation-bar/side-navigation-bar.component.mjs +113 -0
- package/esm2022/lib/spinner/spinner.component.mjs +60 -0
- package/esm2022/lib/table/table.component.mjs +136 -0
- package/esm2022/lib/tabs/tab.component.mjs +20 -0
- package/esm2022/lib/tabs/tabs.component.mjs +40 -0
- package/esm2022/lib/tag/tag.component.mjs +27 -0
- package/esm2022/lib/text-area/text-area.component.mjs +74 -0
- package/esm2022/lib/toast/toast.component.mjs +36 -0
- package/esm2022/lib/tooltip/tooltip.component.mjs +38 -0
- package/esm2022/lib/tooltip/tooltip.directive.mjs +105 -0
- package/esm2022/lib/top-navigation-bar/top-navigation-bar.component.mjs +24 -0
- package/esm2022/public-api.mjs +27 -2
- package/fesm2022/dso-design-system-ui.mjs +2056 -3
- package/fesm2022/dso-design-system-ui.mjs.map +1 -1
- package/lib/alert/alert.component.d.ts +20 -0
- package/lib/badge/badge.component.d.ts +8 -0
- package/lib/breadcrumb/breadcrumb.component.d.ts +15 -0
- package/lib/checkbox/checkbox.component.d.ts +42 -0
- package/lib/datepicker/datepicker.component.d.ts +48 -0
- package/lib/dialog/dialog.component.d.ts +10 -0
- package/lib/directives/truncate.directive.d.ts +23 -0
- package/lib/dropdown-list/dropdown-list.component.d.ts +33 -0
- package/lib/file-upload-items/file-upload-items.component.d.ts +27 -0
- package/lib/file-upload-multiple/file-upload-multiple.component.d.ts +44 -0
- package/lib/file-upload-multiple/upload-item.model.d.ts +7 -0
- package/lib/file-upload-multiple/upload-simulator.service.d.ts +34 -0
- package/lib/file-upload-single/file-upload-single.component.d.ts +28 -0
- package/lib/input-text/input-text.component.d.ts +24 -0
- package/lib/pagination/pagination.component.d.ts +31 -0
- package/lib/progress-bar/progress-bar.component.d.ts +11 -0
- package/lib/radio/radio.component.d.ts +14 -0
- package/lib/select-dropdown/select-dropdown.component.d.ts +78 -0
- package/lib/service/toast.service.d.ts +16 -0
- package/lib/side-navigation-bar/side-navigation-bar.component.d.ts +74 -0
- package/lib/spinner/spinner.component.d.ts +23 -0
- package/lib/table/table.component.d.ts +43 -0
- package/lib/tabs/tab.component.d.ts +9 -0
- package/lib/tabs/tabs.component.d.ts +15 -0
- package/lib/tag/tag.component.d.ts +10 -0
- package/lib/text-area/text-area.component.d.ts +21 -0
- package/lib/toast/toast.component.d.ts +13 -0
- package/lib/tooltip/tooltip.component.d.ts +15 -0
- package/lib/tooltip/tooltip.directive.d.ts +19 -0
- package/lib/top-navigation-bar/top-navigation-bar.component.d.ts +16 -0
- package/package.json +1 -1
- package/public-api.d.ts +25 -0
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { Directive, Input, HostListener } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class TooltipDirective {
|
|
4
|
+
el;
|
|
5
|
+
renderer;
|
|
6
|
+
tooltipElement = null;
|
|
7
|
+
// Make input reactive so it updates dynamically
|
|
8
|
+
_tooltipText = '';
|
|
9
|
+
set dsoDirectiveTooltip(value) {
|
|
10
|
+
this._tooltipText = value;
|
|
11
|
+
if (this.tooltipElement) {
|
|
12
|
+
this.tooltipElement.textContent = value;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
get dsoDirectiveTooltip() {
|
|
16
|
+
return this._tooltipText;
|
|
17
|
+
}
|
|
18
|
+
position = 'top';
|
|
19
|
+
tooltipWidth = 'auto';
|
|
20
|
+
gap = 4; // distance from the element
|
|
21
|
+
constructor(el, renderer) {
|
|
22
|
+
this.el = el;
|
|
23
|
+
this.renderer = renderer;
|
|
24
|
+
}
|
|
25
|
+
onMouseEnter() {
|
|
26
|
+
if (!this.dsoDirectiveTooltip)
|
|
27
|
+
return;
|
|
28
|
+
// Create tooltip element if not exists
|
|
29
|
+
if (!this.tooltipElement) {
|
|
30
|
+
this.tooltipElement = this.renderer.createElement('div');
|
|
31
|
+
this.renderer.addClass(this.tooltipElement, 'tooltip-directive');
|
|
32
|
+
// Style
|
|
33
|
+
this.renderer.setStyle(this.tooltipElement, 'position', 'fixed'); // fixed so it won't be clipped
|
|
34
|
+
this.renderer.setStyle(this.tooltipElement, 'background', '#333');
|
|
35
|
+
this.renderer.setStyle(this.tooltipElement, 'color', '#fff');
|
|
36
|
+
this.renderer.setStyle(this.tooltipElement, 'padding', '4px 8px');
|
|
37
|
+
this.renderer.setStyle(this.tooltipElement, 'border-radius', '4px');
|
|
38
|
+
this.renderer.setStyle(this.tooltipElement, 'font-size', '12px');
|
|
39
|
+
this.renderer.setStyle(this.tooltipElement, 'z-index', '1000');
|
|
40
|
+
this.renderer.setStyle(this.tooltipElement, 'max-width', this.tooltipWidth);
|
|
41
|
+
this.renderer.setStyle(this.tooltipElement, 'white-space', 'normal'); // allow wrapping
|
|
42
|
+
this.renderer.setStyle(this.tooltipElement, 'word-break', 'break-word'); // break long words
|
|
43
|
+
this.renderer.appendChild(document.body, this.tooltipElement);
|
|
44
|
+
}
|
|
45
|
+
// Step 3: set tooltip text
|
|
46
|
+
if (this.tooltipElement) {
|
|
47
|
+
this.tooltipElement.textContent = this.dsoDirectiveTooltip;
|
|
48
|
+
const rect = this.el.nativeElement.getBoundingClientRect();
|
|
49
|
+
const tooltipHeight = this.tooltipElement.offsetHeight;
|
|
50
|
+
const tooltipWidth = this.tooltipElement.offsetWidth;
|
|
51
|
+
// Step 4: position tooltip based on input
|
|
52
|
+
switch (this.position) {
|
|
53
|
+
case 'top':
|
|
54
|
+
this.renderer.setStyle(this.tooltipElement, 'top', `${rect.top - tooltipHeight - this.gap}px`);
|
|
55
|
+
this.renderer.setStyle(this.tooltipElement, 'left', `${rect.left + (rect.width - tooltipWidth) / 2}px`);
|
|
56
|
+
break;
|
|
57
|
+
case 'bottom':
|
|
58
|
+
this.renderer.setStyle(this.tooltipElement, 'top', `${rect.bottom + this.gap}px`);
|
|
59
|
+
this.renderer.setStyle(this.tooltipElement, 'left', `${rect.left + (rect.width - tooltipWidth) / 2}px`);
|
|
60
|
+
break;
|
|
61
|
+
case 'left':
|
|
62
|
+
this.renderer.setStyle(this.tooltipElement, 'top', `${rect.top + (rect.height - tooltipHeight) / 2}px`);
|
|
63
|
+
this.renderer.setStyle(this.tooltipElement, 'left', `${rect.left - tooltipWidth - this.gap}px`);
|
|
64
|
+
break;
|
|
65
|
+
case 'right':
|
|
66
|
+
this.renderer.setStyle(this.tooltipElement, 'top', `${rect.top + (rect.height - tooltipHeight) / 2}px`);
|
|
67
|
+
this.renderer.setStyle(this.tooltipElement, 'left', `${rect.right + this.gap}px`);
|
|
68
|
+
break;
|
|
69
|
+
}
|
|
70
|
+
this.renderer.setStyle(this.tooltipElement, 'visibility', 'visible');
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
onMouseLeave() {
|
|
74
|
+
if (this.tooltipElement) {
|
|
75
|
+
this.renderer.setStyle(this.tooltipElement, 'visibility', 'hidden');
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
ngOnDestroy() {
|
|
79
|
+
if (this.tooltipElement) {
|
|
80
|
+
this.renderer.removeChild(document.body, this.tooltipElement);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
|
|
84
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: TooltipDirective, isStandalone: true, selector: "[dsoDirectiveTooltip]", inputs: { dsoDirectiveTooltip: "dsoDirectiveTooltip", position: "position", tooltipWidth: "tooltipWidth" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()" } }, ngImport: i0 });
|
|
85
|
+
}
|
|
86
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TooltipDirective, decorators: [{
|
|
87
|
+
type: Directive,
|
|
88
|
+
args: [{
|
|
89
|
+
selector: '[dsoDirectiveTooltip]', // This directive will be used with the attribute dsoTooltip
|
|
90
|
+
standalone: true
|
|
91
|
+
}]
|
|
92
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { dsoDirectiveTooltip: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], position: [{
|
|
95
|
+
type: Input
|
|
96
|
+
}], tooltipWidth: [{
|
|
97
|
+
type: Input
|
|
98
|
+
}], onMouseEnter: [{
|
|
99
|
+
type: HostListener,
|
|
100
|
+
args: ['mouseenter']
|
|
101
|
+
}], onMouseLeave: [{
|
|
102
|
+
type: HostListener,
|
|
103
|
+
args: ['mouseleave']
|
|
104
|
+
}] } });
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, Renderer2, HostListener, OnDestroy } from '@angular/core';\r\n\r\n@Directive({\r\n  selector: '[dsoDirectiveTooltip]', // This directive will be used with the attribute dsoTooltip\r\n  standalone: true\r\n})\r\n\r\nexport class TooltipDirective implements OnDestroy {\r\n\r\n  private tooltipElement: HTMLElement | null = null;\r\n\r\n  // Make input reactive so it updates dynamically\r\n  private _tooltipText = '';\r\n  @Input() set dsoDirectiveTooltip(value: string) {\r\n    this._tooltipText = value;\r\n    if (this.tooltipElement) {\r\n      this.tooltipElement.textContent = value;\r\n    }\r\n  }\r\n  get dsoDirectiveTooltip(): string {\r\n    return this._tooltipText;\r\n  }\r\n\r\n  @Input() position: 'top' | 'bottom' | 'left' | 'right' = 'top';\r\n  @Input() tooltipWidth: string = 'auto';\r\n\r\n  private readonly gap = 4; // distance from the element\r\n\r\n  constructor(private el: ElementRef, private renderer: Renderer2) {}\r\n\r\n  @HostListener('mouseenter')\r\n  onMouseEnter() {\r\n    if (!this.dsoDirectiveTooltip) return;\r\n\r\n    // Create tooltip element if not exists\r\n    if (!this.tooltipElement) {\r\n      this.tooltipElement = this.renderer.createElement('div');\r\n      this.renderer.addClass(this.tooltipElement, 'tooltip-directive');\r\n\r\n      // Style\r\n      this.renderer.setStyle(this.tooltipElement, 'position', 'fixed'); // fixed so it won't be clipped\r\n      this.renderer.setStyle(this.tooltipElement, 'background', '#333');\r\n      this.renderer.setStyle(this.tooltipElement, 'color', '#fff');\r\n      this.renderer.setStyle(this.tooltipElement, 'padding', '4px 8px');\r\n      this.renderer.setStyle(this.tooltipElement, 'border-radius', '4px');\r\n      this.renderer.setStyle(this.tooltipElement, 'font-size', '12px');\r\n      this.renderer.setStyle(this.tooltipElement, 'z-index', '1000');\r\n      this.renderer.setStyle(this.tooltipElement, 'max-width', this.tooltipWidth);\r\n      this.renderer.setStyle(this.tooltipElement, 'white-space', 'normal'); // allow wrapping\r\n      this.renderer.setStyle(this.tooltipElement, 'word-break', 'break-word'); // break long words\r\n\r\n\r\n      this.renderer.appendChild(document.body, this.tooltipElement);\r\n    }\r\n\r\n    // Step 3: set tooltip text\r\n    if (this.tooltipElement) {\r\n      this.tooltipElement.textContent = this.dsoDirectiveTooltip;\r\n\r\n      const rect = this.el.nativeElement.getBoundingClientRect();\r\n      const tooltipHeight = this.tooltipElement.offsetHeight;\r\n      const tooltipWidth = this.tooltipElement.offsetWidth;\r\n\r\n      // Step 4: position tooltip based on input\r\n      switch (this.position) {\r\n        case 'top':\r\n          this.renderer.setStyle(this.tooltipElement, 'top', `${rect.top - tooltipHeight - this.gap}px`);\r\n          this.renderer.setStyle(this.tooltipElement, 'left', `${rect.left + (rect.width - tooltipWidth)/2}px`);\r\n          break;\r\n        case 'bottom':\r\n          this.renderer.setStyle(this.tooltipElement, 'top', `${rect.bottom + this.gap}px`);\r\n          this.renderer.setStyle(this.tooltipElement, 'left', `${rect.left + (rect.width - tooltipWidth)/2}px`);\r\n          break;\r\n        case 'left':\r\n          this.renderer.setStyle(this.tooltipElement, 'top', `${rect.top + (rect.height - tooltipHeight)/2}px`);\r\n          this.renderer.setStyle(this.tooltipElement, 'left', `${rect.left - tooltipWidth - this.gap}px`);\r\n          break;\r\n        case 'right':\r\n          this.renderer.setStyle(this.tooltipElement, 'top', `${rect.top + (rect.height - tooltipHeight)/2}px`);\r\n          this.renderer.setStyle(this.tooltipElement, 'left', `${rect.right + this.gap}px`);\r\n          break;\r\n      }\r\n\r\n      this.renderer.setStyle(this.tooltipElement, 'visibility', 'visible');\r\n    }\r\n  }\r\n\r\n  @HostListener('mouseleave')\r\n  onMouseLeave() {\r\n    if (this.tooltipElement) {\r\n      this.renderer.setStyle(this.tooltipElement, 'visibility', 'hidden');\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (this.tooltipElement) {\r\n      this.renderer.removeChild(document.body, this.tooltipElement);\r\n    }\r\n  }\r\n}"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { RouterModule } from '@angular/router';
|
|
4
|
+
import { IconComponent } from '../icon/icon.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
import * as i2 from "@angular/router";
|
|
8
|
+
export class TopNavComponent {
|
|
9
|
+
/** App name displayed next to logo */
|
|
10
|
+
appName = '';
|
|
11
|
+
/** Dynamic menu items */
|
|
12
|
+
menuItems = [];
|
|
13
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TopNavComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
14
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: TopNavComponent, isStandalone: true, selector: "dso-top-nav", inputs: { appName: "appName", menuItems: "menuItems" }, ngImport: i0, template: "<nav class=\"dso-top-nav\">\r\n\r\n <!-- Left section: menu+logo -->\r\n <div class=\"nav-left\">\r\n <div class=\"nav-left-group menu-logo\">\r\n <ng-content select=\"[dso-menu-logo]\"></ng-content>\r\n <span class=\"top-nav-app-name\" *ngIf=\"appName\">{{ appName }}</span>\r\n </div>\r\n\r\n <div class=\"nav-left-group menu-buttons\">\r\n <ng-container *ngFor=\"let item of menuItems\">\r\n <!-- Router link item -->\r\n <a \r\n *ngIf=\"item.route; else clickItem\" \r\n [routerLink]=\"item.route\" \r\n class=\"top-nav-item\"\r\n >\r\n <dso-icon *ngIf=\"item.iconName\" [iconName]=\"item.iconName\" size=\"small\"></dso-icon>\r\n <span>{{ item.label }}</span>\r\n </a>\r\n\r\n <!-- Click handler item -->\r\n <ng-template #clickItem>\r\n <button class=\"top-nav-item\" (click)=\"item.click?.()\">\r\n <dso-icon *ngIf=\"item.iconName\" [iconName]=\"item.iconName\" size=\"small\"></dso-icon>\r\n <span>{{ item.label }}</span>\r\n </button>\r\n </ng-template>\r\n </ng-container>\r\n </div>\r\n </div>\r\n\r\n <!-- Right section -->\r\n <div class=\"nav-right\">\r\n <!-- \u2705 Project each element individually with dso-nav-right -->\r\n <ng-content select=\"[dso-nav-right]\"></ng-content>\r\n </div>\r\n\r\n</nav>\r\n", styles: ["@charset \"UTF-8\";.dso-top-nav{display:flex;align-items:center;justify-content:space-between;height:52px;padding:0 1rem;background-color:#fff;border:1px solid #e5e5e5}.dso-top-nav .nav-left{display:flex;align-items:center;gap:2rem}.dso-top-nav .nav-left .nav-left-group{display:flex;align-items:center}.dso-top-nav .nav-left .menu-logo{gap:.5rem}.dso-top-nav .nav-left .menu-buttons{gap:1rem}.dso-top-nav .nav-right{display:flex;align-items:center;gap:1rem;flex-direction:row;justify-content:flex-end}.dso-top-nav .nav-right dso-button{margin:0}.dso-top-nav .nav-right p{margin:0;font-weight:500}.top-nav-item{display:flex;align-items:center;gap:.5rem;padding:.25rem .5rem;background:none;border:none;cursor:pointer;font:inherit;color:inherit;text-decoration:none}.top-nav-item:hover{background-color:#f2f2f2;border-radius:4px}.top-nav-app-name{font-weight:700;font-size:1rem;margin-left:.5rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: RouterModule }, { kind: "directive", type: i2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: IconComponent, selector: "dso-icon", inputs: ["iconName", "size"] }] });
|
|
15
|
+
}
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TopNavComponent, decorators: [{
|
|
17
|
+
type: Component,
|
|
18
|
+
args: [{ selector: 'dso-top-nav', standalone: true, imports: [CommonModule, RouterModule, IconComponent], template: "<nav class=\"dso-top-nav\">\r\n\r\n <!-- Left section: menu+logo -->\r\n <div class=\"nav-left\">\r\n <div class=\"nav-left-group menu-logo\">\r\n <ng-content select=\"[dso-menu-logo]\"></ng-content>\r\n <span class=\"top-nav-app-name\" *ngIf=\"appName\">{{ appName }}</span>\r\n </div>\r\n\r\n <div class=\"nav-left-group menu-buttons\">\r\n <ng-container *ngFor=\"let item of menuItems\">\r\n <!-- Router link item -->\r\n <a \r\n *ngIf=\"item.route; else clickItem\" \r\n [routerLink]=\"item.route\" \r\n class=\"top-nav-item\"\r\n >\r\n <dso-icon *ngIf=\"item.iconName\" [iconName]=\"item.iconName\" size=\"small\"></dso-icon>\r\n <span>{{ item.label }}</span>\r\n </a>\r\n\r\n <!-- Click handler item -->\r\n <ng-template #clickItem>\r\n <button class=\"top-nav-item\" (click)=\"item.click?.()\">\r\n <dso-icon *ngIf=\"item.iconName\" [iconName]=\"item.iconName\" size=\"small\"></dso-icon>\r\n <span>{{ item.label }}</span>\r\n </button>\r\n </ng-template>\r\n </ng-container>\r\n </div>\r\n </div>\r\n\r\n <!-- Right section -->\r\n <div class=\"nav-right\">\r\n <!-- \u2705 Project each element individually with dso-nav-right -->\r\n <ng-content select=\"[dso-nav-right]\"></ng-content>\r\n </div>\r\n\r\n</nav>\r\n", styles: ["@charset \"UTF-8\";.dso-top-nav{display:flex;align-items:center;justify-content:space-between;height:52px;padding:0 1rem;background-color:#fff;border:1px solid #e5e5e5}.dso-top-nav .nav-left{display:flex;align-items:center;gap:2rem}.dso-top-nav .nav-left .nav-left-group{display:flex;align-items:center}.dso-top-nav .nav-left .menu-logo{gap:.5rem}.dso-top-nav .nav-left .menu-buttons{gap:1rem}.dso-top-nav .nav-right{display:flex;align-items:center;gap:1rem;flex-direction:row;justify-content:flex-end}.dso-top-nav .nav-right dso-button{margin:0}.dso-top-nav .nav-right p{margin:0;font-weight:500}.top-nav-item{display:flex;align-items:center;gap:.5rem;padding:.25rem .5rem;background:none;border:none;cursor:pointer;font:inherit;color:inherit;text-decoration:none}.top-nav-item:hover{background-color:#f2f2f2;border-radius:4px}.top-nav-app-name{font-weight:700;font-size:1rem;margin-left:.5rem}\n"] }]
|
|
19
|
+
}], propDecorators: { appName: [{
|
|
20
|
+
type: Input
|
|
21
|
+
}], menuItems: [{
|
|
22
|
+
type: Input
|
|
23
|
+
}] } });
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9wLW5hdmlnYXRpb24tYmFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvdG9wLW5hdmlnYXRpb24tYmFyL3RvcC1uYXZpZ2F0aW9uLWJhci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL3RvcC1uYXZpZ2F0aW9uLWJhci90b3AtbmF2aWdhdGlvbi1iYXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7Ozs7QUFpQnZELE1BQU0sT0FBTyxlQUFlO0lBQzFCLHNDQUFzQztJQUM3QixPQUFPLEdBQVcsRUFBRSxDQUFDO0lBRTlCLHlCQUF5QjtJQUNoQixTQUFTLEdBQWlCLEVBQUUsQ0FBQzt3R0FMM0IsZUFBZTs0RkFBZixlQUFlLCtIQ3BCNUIsNDNDQXVDQSwwN0JEdkJZLFlBQVksK1BBQUUsWUFBWSxnUkFBRSxhQUFhOzs0RkFJeEMsZUFBZTtrQkFQM0IsU0FBUzsrQkFDRSxhQUFhLGNBQ1gsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLFlBQVksRUFBRSxhQUFhLENBQUM7OEJBTTNDLE9BQU87c0JBQWYsS0FBSztnQkFHRyxTQUFTO3NCQUFqQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBSb3V0ZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xyXG5pbXBvcnQgeyBJY29uQ29tcG9uZW50IH0gZnJvbSAnLi4vaWNvbi9pY29uLmNvbXBvbmVudCc7XHJcblxyXG4vKiogSW50ZXJmYWNlIGRlZmluaW5nIGEgc2luZ2xlIHRvcCBuYXYgbWVudSBpdGVtICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgVG9wTmF2SXRlbSB7XHJcbiAgbGFiZWw6IHN0cmluZzsgICAgICAgICAgIC8vIFRleHQgZm9yIHRoZSBtZW51IGl0ZW1cclxuICBpY29uTmFtZT86IHN0cmluZzsgICAgICAgLy8gT3B0aW9uYWwgaWNvblxyXG4gIHJvdXRlPzogc3RyaW5nOyAgICAgICAgICAvLyBPcHRpb25hbCByb3V0ZXIgbGlua1xyXG4gIGNsaWNrPzogKCkgPT4gdm9pZDsgICAgICAvLyBPcHRpb25hbCBjbGljayBoYW5kbGVyXHJcbn1cclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnZHNvLXRvcC1uYXYnLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgUm91dGVyTW9kdWxlLCBJY29uQ29tcG9uZW50XSxcclxuICB0ZW1wbGF0ZVVybDogJy4vdG9wLW5hdmlnYXRpb24tYmFyLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi90b3AtbmF2aWdhdGlvbi1iYXIuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVG9wTmF2Q29tcG9uZW50IHtcclxuICAvKiogQXBwIG5hbWUgZGlzcGxheWVkIG5leHQgdG8gbG9nbyAqL1xyXG4gIEBJbnB1dCgpIGFwcE5hbWU6IHN0cmluZyA9ICcnO1xyXG5cclxuICAvKiogRHluYW1pYyBtZW51IGl0ZW1zICovXHJcbiAgQElucHV0KCkgbWVudUl0ZW1zOiBUb3BOYXZJdGVtW10gPSBbXTtcclxufVxyXG4iLCI8bmF2IGNsYXNzPVwiZHNvLXRvcC1uYXZcIj5cclxuXHJcbiAgPCEtLSBMZWZ0IHNlY3Rpb246IG1lbnUrbG9nbyAtLT5cclxuICA8ZGl2IGNsYXNzPVwibmF2LWxlZnRcIj5cclxuICAgIDxkaXYgY2xhc3M9XCJuYXYtbGVmdC1ncm91cCBtZW51LWxvZ29cIj5cclxuICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiW2Rzby1tZW51LWxvZ29dXCI+PC9uZy1jb250ZW50PlxyXG4gICAgICA8c3BhbiBjbGFzcz1cInRvcC1uYXYtYXBwLW5hbWVcIiAqbmdJZj1cImFwcE5hbWVcIj57eyBhcHBOYW1lIH19PC9zcGFuPlxyXG4gICAgPC9kaXY+XHJcblxyXG4gICAgPGRpdiBjbGFzcz1cIm5hdi1sZWZ0LWdyb3VwIG1lbnUtYnV0dG9uc1wiPlxyXG4gICAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBpdGVtIG9mIG1lbnVJdGVtc1wiPlxyXG4gICAgICAgIDwhLS0gUm91dGVyIGxpbmsgaXRlbSAtLT5cclxuICAgICAgICA8YSBcclxuICAgICAgICAgICpuZ0lmPVwiaXRlbS5yb3V0ZTsgZWxzZSBjbGlja0l0ZW1cIiBcclxuICAgICAgICAgIFtyb3V0ZXJMaW5rXT1cIml0ZW0ucm91dGVcIiBcclxuICAgICAgICAgIGNsYXNzPVwidG9wLW5hdi1pdGVtXCJcclxuICAgICAgICA+XHJcbiAgICAgICAgICA8ZHNvLWljb24gKm5nSWY9XCJpdGVtLmljb25OYW1lXCIgW2ljb25OYW1lXT1cIml0ZW0uaWNvbk5hbWVcIiBzaXplPVwic21hbGxcIj48L2Rzby1pY29uPlxyXG4gICAgICAgICAgPHNwYW4+e3sgaXRlbS5sYWJlbCB9fTwvc3Bhbj5cclxuICAgICAgICA8L2E+XHJcblxyXG4gICAgICAgIDwhLS0gQ2xpY2sgaGFuZGxlciBpdGVtIC0tPlxyXG4gICAgICAgIDxuZy10ZW1wbGF0ZSAjY2xpY2tJdGVtPlxyXG4gICAgICAgICAgPGJ1dHRvbiBjbGFzcz1cInRvcC1uYXYtaXRlbVwiIChjbGljayk9XCJpdGVtLmNsaWNrPy4oKVwiPlxyXG4gICAgICAgICAgICA8ZHNvLWljb24gKm5nSWY9XCJpdGVtLmljb25OYW1lXCIgW2ljb25OYW1lXT1cIml0ZW0uaWNvbk5hbWVcIiBzaXplPVwic21hbGxcIj48L2Rzby1pY29uPlxyXG4gICAgICAgICAgICA8c3Bhbj57eyBpdGVtLmxhYmVsIH19PC9zcGFuPlxyXG4gICAgICAgICAgPC9idXR0b24+XHJcbiAgICAgICAgPC9uZy10ZW1wbGF0ZT5cclxuICAgICAgPC9uZy1jb250YWluZXI+XHJcbiAgICA8L2Rpdj5cclxuICA8L2Rpdj5cclxuXHJcbiAgPCEtLSBSaWdodCBzZWN0aW9uIC0tPlxyXG4gIDxkaXYgY2xhc3M9XCJuYXYtcmlnaHRcIj5cclxuICAgIDwhLS0g4pyFIFByb2plY3QgZWFjaCBlbGVtZW50IGluZGl2aWR1YWxseSB3aXRoIGRzby1uYXYtcmlnaHQgLS0+XHJcbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbZHNvLW5hdi1yaWdodF1cIj48L25nLWNvbnRlbnQ+XHJcbiAgPC9kaXY+XHJcblxyXG48L25hdj5cclxuIl19
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -1,3 +1,28 @@
|
|
|
1
|
+
export * from './lib/alert/alert.component';
|
|
2
|
+
export * from './lib/badge/badge.component';
|
|
3
|
+
export * from './lib/breadcrumb/breadcrumb.component';
|
|
1
4
|
export * from './lib/button/button.component';
|
|
2
|
-
export * from './lib/
|
|
3
|
-
|
|
5
|
+
export * from './lib/checkbox/checkbox.component';
|
|
6
|
+
export * from './lib/datepicker/datepicker.component';
|
|
7
|
+
export * from './lib/dialog/dialog.component';
|
|
8
|
+
export * from './lib/directives/truncate.directive';
|
|
9
|
+
export * from './lib/dropdown-list/dropdown-list.component';
|
|
10
|
+
export * from './lib/file-upload-items/file-upload-items.component';
|
|
11
|
+
export * from './lib/file-upload-multiple/file-upload-multiple.component';
|
|
12
|
+
export * from './lib/file-upload-single/file-upload-single.component';
|
|
13
|
+
export * from './lib/icon/icon.component';
|
|
14
|
+
export * from './lib/input-text/input-text.component';
|
|
15
|
+
export * from './lib/pagination/pagination.component';
|
|
16
|
+
export * from './lib/progress-bar/progress-bar.component';
|
|
17
|
+
export * from './lib/radio/radio.component';
|
|
18
|
+
export * from './lib/select-dropdown/select-dropdown.component';
|
|
19
|
+
export * from './lib/side-navigation-bar/side-navigation-bar.component';
|
|
20
|
+
export * from './lib/spinner/spinner.component';
|
|
21
|
+
export * from './lib/table/table.component';
|
|
22
|
+
export * from './lib/tabs/tabs.component';
|
|
23
|
+
export * from './lib/tag/tag.component';
|
|
24
|
+
export * from './lib/text-area/text-area.component';
|
|
25
|
+
export * from './lib/toast/toast.component';
|
|
26
|
+
export * from './lib/tooltip/tooltip.component';
|
|
27
|
+
export * from './lib/top-navigation-bar/top-navigation-bar.component';
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYywyREFBMkQsQ0FBQztBQUMxRSxjQUFjLHVEQUF1RCxDQUFDO0FBQ3RFLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMseURBQXlELENBQUM7QUFDeEUsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLHVEQUF1RCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvYWxlcnQvYWxlcnQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYmFkZ2UvYmFkZ2UuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYnJlYWRjcnVtYi9icmVhZGNydW1iLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0ZXBpY2tlci9kYXRlcGlja2VyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpYWxvZy9kaWFsb2cuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlyZWN0aXZlcy90cnVuY2F0ZS5kaXJlY3RpdmUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcm9wZG93bi1saXN0L2Ryb3Bkb3duLWxpc3QuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZmlsZS11cGxvYWQtaXRlbXMvZmlsZS11cGxvYWQtaXRlbXMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZmlsZS11cGxvYWQtbXVsdGlwbGUvZmlsZS11cGxvYWQtbXVsdGlwbGUuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZmlsZS11cGxvYWQtc2luZ2xlL2ZpbGUtdXBsb2FkLXNpbmdsZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9pY29uL2ljb24uY29tcG9uZW50JzsgXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2lucHV0LXRleHQvaW5wdXQtdGV4dC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wYWdpbmF0aW9uL3BhZ2luYXRpb24uY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvcHJvZ3Jlc3MtYmFyL3Byb2dyZXNzLWJhci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yYWRpby9yYWRpby5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZWxlY3QtZHJvcGRvd24vc2VsZWN0LWRyb3Bkb3duLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NpZGUtbmF2aWdhdGlvbi1iYXIvc2lkZS1uYXZpZ2F0aW9uLWJhci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zcGlubmVyL3NwaW5uZXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdGFibGUvdGFibGUuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdGFicy90YWJzLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RhZy90YWcuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdGV4dC1hcmVhL3RleHQtYXJlYS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi90b2FzdC90b2FzdC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi90b29sdGlwL3Rvb2x0aXAuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdG9wLW5hdmlnYXRpb24tYmFyL3RvcC1uYXZpZ2F0aW9uLWJhci5jb21wb25lbnQnO1xyXG4iXX0=
|