@hestia-earth/ui-components 0.28.1 → 0.28.2
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/common/collapsible-box/collapsible-box.component.d.ts +9 -0
- package/common/index.d.ts +1 -0
- package/common/resized.directive.d.ts +1 -1
- package/esm2022/common/collapsible-box/collapsible-box.component.mjs +22 -0
- package/esm2022/common/index.mjs +2 -1
- package/esm2022/common/resized.directive.mjs +1 -1
- package/esm2022/files/files-error-summary/files-error-summary-item/files-error-summary-item.component.mjs +16 -6
- package/esm2022/files/files-error-summary/files-error-summary.component.mjs +23 -13
- package/esm2022/files/files-error.model.mjs +5 -3
- package/esm2022/schema/schema-validation.model.mjs +9 -2
- package/fesm2022/hestia-earth-ui-components.mjs +65 -18
- package/fesm2022/hestia-earth-ui-components.mjs.map +1 -1
- package/files/files-error-summary/files-error-summary-item/files-error-summary-item.component.d.ts +8 -1
- package/files/files-error-summary/files-error-summary.component.d.ts +8 -1
- package/package.json +1 -1
- package/schema/schema-validation.model.d.ts +1 -0
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class CollapsibleBoxComponent {
|
|
3
|
+
protected readonly faAngleUp: import("@fortawesome/fontawesome-common-types").IconDefinition;
|
|
4
|
+
protected readonly faAngleDown: import("@fortawesome/fontawesome-common-types").IconDefinition;
|
|
5
|
+
protected readonly hostClass = "box";
|
|
6
|
+
readonly open: import("@angular/core").ModelSignal<boolean>;
|
|
7
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CollapsibleBoxComponent, never>;
|
|
8
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CollapsibleBoxComponent, "he-collapsible-box", never, { "open": { "alias": "open"; "required": false; "isSignal": true; }; }, { "open": "openChange"; }, never, ["[box-title]", "[box-content]"], true, never>;
|
|
9
|
+
}
|
package/common/index.d.ts
CHANGED
|
@@ -15,6 +15,7 @@ export { BlankNodeStateComponent } from './blank-node-state/blank-node-state.com
|
|
|
15
15
|
export { BlankNodeStateNoticeComponent } from './blank-node-state-notice/blank-node-state-notice.component';
|
|
16
16
|
export { BlankNodeValueDeltaComponent } from './blank-node-value-delta/blank-node-value-delta.component';
|
|
17
17
|
export { ClipboardComponent } from './clipboard/clipboard.component';
|
|
18
|
+
export { CollapsibleBoxComponent } from './collapsible-box/collapsible-box.component';
|
|
18
19
|
export { DataTableComponent } from './data-table/data-table.component';
|
|
19
20
|
export { DrawerContainerComponent } from './drawer-container/drawer-container.component';
|
|
20
21
|
export { IssueConfirmComponent } from './issue-confirm/issue-confirm.component';
|
|
@@ -11,7 +11,7 @@ export declare class ResizedDirective implements OnInit, OnDestroy {
|
|
|
11
11
|
private readonly zone;
|
|
12
12
|
private observer;
|
|
13
13
|
private oldRect?;
|
|
14
|
-
protected resized: import("@angular/core").OutputEmitterRef<ResizedEvent>;
|
|
14
|
+
protected readonly resized: import("@angular/core").OutputEmitterRef<ResizedEvent>;
|
|
15
15
|
constructor();
|
|
16
16
|
ngOnInit(): void;
|
|
17
17
|
ngOnDestroy(): void;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Component, HostBinding, model } from '@angular/core';
|
|
2
|
+
import { FaIconComponent } from '@fortawesome/angular-fontawesome';
|
|
3
|
+
import { faAngleDown, faAngleUp } from '@fortawesome/free-solid-svg-icons';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class CollapsibleBoxComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.faAngleUp = faAngleUp;
|
|
8
|
+
this.faAngleDown = faAngleDown;
|
|
9
|
+
this.hostClass = 'box';
|
|
10
|
+
this.open = model(true);
|
|
11
|
+
}
|
|
12
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: CollapsibleBoxComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
13
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: CollapsibleBoxComponent, isStandalone: true, selector: "he-collapsible-box", inputs: { open: { classPropertyName: "open", publicName: "open", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { open: "openChange" }, host: { properties: { "class": "this.hostClass" } }, ngImport: i0, template: "<div class=\"is-flex is-flex-direction-column is-gap-24\">\n <div>\n <div class=\"columns is-mobile is-vcentered has-text-secondary is-my-0\">\n <div class=\"column is-py-0\">\n <h2 class=\"has-text-weight-bold\">\n <ng-content select=\"[box-title]\"></ng-content>\n </h2>\n </div>\n <div class=\"column is-py-0 is-narrow\" (click)=\"open.set(!open())\" pointer>\n <fa-icon [icon]=\"open() ? faAngleUp : faAngleDown\"></fa-icon>\n </div>\n </div>\n\n <hr class=\"section-divider w-100 is-mt-2 is-mb-0\" />\n </div>\n\n @if (open()) {\n <ng-content select=\"[box-content]\"></ng-content>\n }\n</div>\n", styles: [""], dependencies: [{ kind: "component", type: FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "animation", "mask", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }] }); }
|
|
14
|
+
}
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: CollapsibleBoxComponent, decorators: [{
|
|
16
|
+
type: Component,
|
|
17
|
+
args: [{ selector: 'he-collapsible-box', standalone: true, imports: [FaIconComponent], template: "<div class=\"is-flex is-flex-direction-column is-gap-24\">\n <div>\n <div class=\"columns is-mobile is-vcentered has-text-secondary is-my-0\">\n <div class=\"column is-py-0\">\n <h2 class=\"has-text-weight-bold\">\n <ng-content select=\"[box-title]\"></ng-content>\n </h2>\n </div>\n <div class=\"column is-py-0 is-narrow\" (click)=\"open.set(!open())\" pointer>\n <fa-icon [icon]=\"open() ? faAngleUp : faAngleDown\"></fa-icon>\n </div>\n </div>\n\n <hr class=\"section-divider w-100 is-mt-2 is-mb-0\" />\n </div>\n\n @if (open()) {\n <ng-content select=\"[box-content]\"></ng-content>\n }\n</div>\n" }]
|
|
18
|
+
}], propDecorators: { hostClass: [{
|
|
19
|
+
type: HostBinding,
|
|
20
|
+
args: ['class']
|
|
21
|
+
}] } });
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGFwc2libGUtYm94LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21tb24vY29sbGFwc2libGUtYm94L2NvbGxhcHNpYmxlLWJveC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9zcmMvY29tbW9uL2NvbGxhcHNpYmxlLWJveC9jb2xsYXBzaWJsZS1ib3guY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNuRSxPQUFPLEVBQUUsV0FBVyxFQUFFLFNBQVMsRUFBRSxNQUFNLG1DQUFtQyxDQUFDOztBQVMzRSxNQUFNLE9BQU8sdUJBQXVCO0lBUHBDO1FBUXFCLGNBQVMsR0FBRyxTQUFTLENBQUM7UUFDdEIsZ0JBQVcsR0FBRyxXQUFXLENBQUM7UUFHMUIsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUVyQixTQUFJLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO0tBQ3BDOytHQVJZLHVCQUF1QjttR0FBdkIsdUJBQXVCLHFTQ1hwQyw0cEJBb0JBLDBERGJZLGVBQWU7OzRGQUlkLHVCQUF1QjtrQkFQbkMsU0FBUzsrQkFDRSxvQkFBb0IsY0FDbEIsSUFBSSxXQUNQLENBQUMsZUFBZSxDQUFDOzhCQVNQLFNBQVM7c0JBRDNCLFdBQVc7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIG1vZGVsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGYUljb25Db21wb25lbnQgfSBmcm9tICdAZm9ydGF3ZXNvbWUvYW5ndWxhci1mb250YXdlc29tZSc7XG5pbXBvcnQgeyBmYUFuZ2xlRG93biwgZmFBbmdsZVVwIH0gZnJvbSAnQGZvcnRhd2Vzb21lL2ZyZWUtc29saWQtc3ZnLWljb25zJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnaGUtY29sbGFwc2libGUtYm94JyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0ZhSWNvbkNvbXBvbmVudF0sXG4gIHRlbXBsYXRlVXJsOiAnLi9jb2xsYXBzaWJsZS1ib3guY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vY29sbGFwc2libGUtYm94LmNvbXBvbmVudC5zY3NzJ1xufSlcbmV4cG9ydCBjbGFzcyBDb2xsYXBzaWJsZUJveENvbXBvbmVudCB7XG4gIHByb3RlY3RlZCByZWFkb25seSBmYUFuZ2xlVXAgPSBmYUFuZ2xlVXA7XG4gIHByb3RlY3RlZCByZWFkb25seSBmYUFuZ2xlRG93biA9IGZhQW5nbGVEb3duO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MnKVxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgaG9zdENsYXNzID0gJ2JveCc7XG5cbiAgcHVibGljIHJlYWRvbmx5IG9wZW4gPSBtb2RlbCh0cnVlKTtcbn1cbiIsIjxkaXYgY2xhc3M9XCJpcy1mbGV4IGlzLWZsZXgtZGlyZWN0aW9uLWNvbHVtbiBpcy1nYXAtMjRcIj5cbiAgPGRpdj5cbiAgICA8ZGl2IGNsYXNzPVwiY29sdW1ucyBpcy1tb2JpbGUgaXMtdmNlbnRlcmVkIGhhcy10ZXh0LXNlY29uZGFyeSBpcy1teS0wXCI+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sdW1uIGlzLXB5LTBcIj5cbiAgICAgICAgPGgyIGNsYXNzPVwiaGFzLXRleHQtd2VpZ2h0LWJvbGRcIj5cbiAgICAgICAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbYm94LXRpdGxlXVwiPjwvbmctY29udGVudD5cbiAgICAgICAgPC9oMj5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cImNvbHVtbiBpcy1weS0wIGlzLW5hcnJvd1wiIChjbGljayk9XCJvcGVuLnNldCghb3BlbigpKVwiIHBvaW50ZXI+XG4gICAgICAgIDxmYS1pY29uIFtpY29uXT1cIm9wZW4oKSA/IGZhQW5nbGVVcCA6IGZhQW5nbGVEb3duXCI+PC9mYS1pY29uPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG5cbiAgICA8aHIgY2xhc3M9XCJzZWN0aW9uLWRpdmlkZXIgdy0xMDAgaXMtbXQtMiBpcy1tYi0wXCIgLz5cbiAgPC9kaXY+XG5cbiAgQGlmIChvcGVuKCkpIHtcbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbYm94LWNvbnRlbnRdXCI+PC9uZy1jb250ZW50PlxuICB9XG48L2Rpdj5cbiJdfQ==
|
package/esm2022/common/index.mjs
CHANGED
|
@@ -15,6 +15,7 @@ export { BlankNodeStateComponent } from './blank-node-state/blank-node-state.com
|
|
|
15
15
|
export { BlankNodeStateNoticeComponent } from './blank-node-state-notice/blank-node-state-notice.component';
|
|
16
16
|
export { BlankNodeValueDeltaComponent } from './blank-node-value-delta/blank-node-value-delta.component';
|
|
17
17
|
export { ClipboardComponent } from './clipboard/clipboard.component';
|
|
18
|
+
export { CollapsibleBoxComponent } from './collapsible-box/collapsible-box.component';
|
|
18
19
|
export { DataTableComponent } from './data-table/data-table.component';
|
|
19
20
|
export { DrawerContainerComponent } from './drawer-container/drawer-container.component';
|
|
20
21
|
export { IssueConfirmComponent } from './issue-confirm/issue-confirm.component';
|
|
@@ -60,4 +61,4 @@ export { SortByPipe } from './sort-by.pipe';
|
|
|
60
61
|
export * from './sort-select/sort-select.component';
|
|
61
62
|
export { ShelfDialogComponent } from './shelf-dialog/shelf-dialog.component';
|
|
62
63
|
export { NavigationMenuComponent } from './navigation-menu/navigation-menu.component';
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/index.ts"],"names":[],"mappings":"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","sourcesContent":["export * from './color';\nexport * from './common.service';\nexport * from './compound';\nexport * from './toast.service';\nexport * from './d3-utils';\nexport * from './delta-utils';\nexport * from './logs-utils';\nexport * from './maps-utils';\nexport * from './node-utils';\nexport * from './pluralize';\nexport * from './rxjs-utils';\nexport * from './thousands';\nexport * from './utils';\n\nexport { BlankNodeStateComponent } from './blank-node-state/blank-node-state.component';\nexport { BlankNodeStateNoticeComponent } from './blank-node-state-notice/blank-node-state-notice.component';\nexport { BlankNodeValueDeltaComponent } from './blank-node-value-delta/blank-node-value-delta.component';\nexport { ClipboardComponent } from './clipboard/clipboard.component';\nexport { CollapsibleBoxComponent } from './collapsible-box/collapsible-box.component';\nexport { DataTableComponent } from './data-table/data-table.component';\nexport { DrawerContainerComponent } from './drawer-container/drawer-container.component';\nexport { IssueConfirmComponent } from './issue-confirm/issue-confirm.component';\nexport { LinkKeyValueComponent } from './link-key-value/link-key-value.component';\nexport { MapsDrawingComponent } from './maps-drawing/maps-drawing.component';\nexport { MapsDrawingConfirmComponent } from './maps-drawing-confirm/maps-drawing-confirm.component';\nexport * from './mobile-shell/mobile-shell.component';\nexport * from './navigation-menu/navigation-menu.component';\nexport { PopoverComponent } from './popover/popover.component';\nexport { PopoverConfirmComponent } from './popover-confirm/popover-confirm.component';\nexport { SchemaVersionLinkComponent } from './schema-version-link/schema-version-link.component';\nexport { SearchExtendComponent } from './search-extend/search-extend.component';\nexport * from './shell/shell.component';\nexport { SkeletonTextComponent } from './skeleton-text/skeleton-text.component';\nexport { SocialTagsComponent } from './social-tags/social-tags.component';\nexport { ToastComponent } from './toast/toast.component';\nexport { UnitConverterComponent } from './unit-converter/unit-converter.component';\nexport { ApplyPurePipe } from './apply-pure.pipe';\nexport { BindOnceDirective } from './bind-once.directive';\nexport { CapitalizePipe } from './capitalize.pipe';\nexport { ClickOutsideDirective } from './click-outside.directive';\nexport { CompoundDirective } from './compound.directive';\nexport { CompoundPipe } from './compound.pipe';\nexport { DefaultPipe } from './default.pipe';\nexport { EllipsisPipe } from './ellipsis.pipe';\nexport { FileSizePipe } from './file-size.pipe';\nexport { GetPipe } from './get.pipe';\nexport { IsArrayPipe } from './is-array.pipe';\nexport { IsObjectPipe } from './is-object.pipe';\nexport { KeyToLabelPipe } from './key-to-label.pipe';\nexport { KeysPipe } from './keys.pipe';\nexport { NoExtPipe } from './no-ext.pipe';\nexport { PluralizePipe } from './pluralize.pipe';\nexport { PrecisionPipe } from './precision.pipe';\nexport { RemoveMarkdownPipe } from './remove-markdown.pipe';\nexport * from './resized.directive';\nexport { ResponsiveService } from './responsive.service';\nexport { TagsInputDirective } from './tags-input.directive';\nexport { ThousandSuffixesPipe } from './thousand-suffixes.pipe';\nexport { TimesPipe } from './times.pipe';\nexport { UncapitalizePipe } from './uncapitalize.pipe';\nexport { SortByPipe } from './sort-by.pipe';\nexport * from './sort-select/sort-select.component';\nexport { ShelfDialogComponent } from './shelf-dialog/shelf-dialog.component';\nexport { NavigationMenuComponent, INavigationMenuLink } from './navigation-menu/navigation-menu.component';\n"]}
|
|
@@ -36,4 +36,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImpo
|
|
|
36
36
|
standalone: true
|
|
37
37
|
}]
|
|
38
38
|
}], ctorParameters: () => [] });
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzaXplZC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tbW9uL3Jlc2l6ZWQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBcUIsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFakcsTUFBTSxPQUFPLFlBQVk7SUFLdkIsWUFBWSxPQUF3QixFQUFFLE9BQW9DO1FBQ3hFLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxJQUFJLElBQUksQ0FBQztJQUNqQyxDQUFDO0NBQ0Y7QUFNRCxNQUFNLE9BQU8sZ0JBQWdCO0lBUzNCO1FBUmlCLFlBQU8sR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDN0IsU0FBSSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUtwQixZQUFPLEdBQUcsTUFBTSxFQUFnQixDQUFDO1FBR2xELElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxjQUFjLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM1RixDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDcEQsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsUUFBUSxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQzdCLENBQUM7SUFFTyxPQUFPLENBQUMsT0FBOEI7UUFDNUMsTUFBTSxPQUFPLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzNCLE1BQU0sWUFBWSxHQUFHLElBQUksWUFBWSxDQUFDLE9BQU8sQ0FBQyxXQUFXLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3pFLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDLFdBQVcsQ0FBQztRQUNuQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUNsQyxDQUFDOytHQTFCVSxnQkFBZ0I7bUdBQWhCLGdCQUFnQjs7NEZBQWhCLGdCQUFnQjtrQkFKNUIsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsV0FBVztvQkFDckIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBOZ1pvbmUsIE9uRGVzdHJveSwgT25Jbml0LCBpbmplY3QsIG91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY2xhc3MgUmVzaXplZEV2ZW50IHtcbiAgcHVibGljIG5ld1JlY3Q6IERPTVJlY3RSZWFkT25seTtcbiAgcHVibGljIG9sZFJlY3Q/OiBET01SZWN0UmVhZE9ubHk7XG4gIHB1YmxpYyBpc0ZpcnN0OiBib29sZWFuO1xuXG4gIGNvbnN0cnVjdG9yKG5ld1JlY3Q6IERPTVJlY3RSZWFkT25seSwgb2xkUmVjdDogRE9NUmVjdFJlYWRPbmx5IHwgdW5kZWZpbmVkKSB7XG4gICAgdGhpcy5uZXdSZWN0ID0gbmV3UmVjdDtcbiAgICB0aGlzLm9sZFJlY3QgPSBvbGRSZWN0O1xuICAgIHRoaXMuaXNGaXJzdCA9IG9sZFJlY3QgPT0gbnVsbDtcbiAgfVxufVxuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbcmVzaXplZF0nLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIFJlc2l6ZWREaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgZWxlbWVudCA9IGluamVjdChFbGVtZW50UmVmKTtcbiAgcHJpdmF0ZSByZWFkb25seSB6b25lID0gaW5qZWN0KE5nWm9uZSk7XG5cbiAgcHJpdmF0ZSBvYnNlcnZlcjogUmVzaXplT2JzZXJ2ZXI7XG4gIHByaXZhdGUgb2xkUmVjdD86IERPTVJlY3RSZWFkT25seTtcblxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgcmVzaXplZCA9IG91dHB1dDxSZXNpemVkRXZlbnQ+KCk7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5vYnNlcnZlciA9IG5ldyBSZXNpemVPYnNlcnZlcihlbnRyaWVzID0+IHRoaXMuem9uZS5ydW4oKCkgPT4gdGhpcy5vYnNlcnZlKGVudHJpZXMpKSk7XG4gIH1cblxuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLm9ic2VydmVyLm9ic2VydmUodGhpcy5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQpO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy5vYnNlcnZlci5kaXNjb25uZWN0KCk7XG4gIH1cblxuICBwcml2YXRlIG9ic2VydmUoZW50cmllczogUmVzaXplT2JzZXJ2ZXJFbnRyeVtdKSB7XG4gICAgY29uc3QgZG9tU2l6ZSA9IGVudHJpZXNbMF07XG4gICAgY29uc3QgcmVzaXplZEV2ZW50ID0gbmV3IFJlc2l6ZWRFdmVudChkb21TaXplLmNvbnRlbnRSZWN0LCB0aGlzLm9sZFJlY3QpO1xuICAgIHRoaXMub2xkUmVjdCA9IGRvbVNpemUuY29udGVudFJlY3Q7XG4gICAgdGhpcy5yZXNpemVkLmVtaXQocmVzaXplZEV2ZW50KTtcbiAgfVxufVxuIl19
|
|
@@ -2,25 +2,35 @@ import { ChangeDetectionStrategy, Component, computed, input, model, signal } fr
|
|
|
2
2
|
import { FaIconComponent } from '@fortawesome/angular-fontawesome';
|
|
3
3
|
import { faCheckCircle, faTimesCircle } from '@fortawesome/free-solid-svg-icons';
|
|
4
4
|
import { EllipsisPipe } from '../../../common/ellipsis.pipe';
|
|
5
|
+
import { PluralizePipe } from '../../../common/pluralize.pipe';
|
|
6
|
+
import { ResizedDirective } from '../../../common/resized.directive';
|
|
5
7
|
import * as i0 from "@angular/core";
|
|
6
|
-
const
|
|
8
|
+
const minimumMaxLength = 150;
|
|
7
9
|
export class FilesErrorSummaryItemComponent {
|
|
8
10
|
constructor() {
|
|
9
11
|
this.faCheckCircle = faCheckCircle;
|
|
10
12
|
this.faTimesCircle = faTimesCircle;
|
|
11
13
|
this.summary = input.required();
|
|
14
|
+
/**
|
|
15
|
+
* Error is resolved and should not be displayed anymore.
|
|
16
|
+
*/
|
|
12
17
|
this.resolved = model(false);
|
|
13
|
-
this.maxLength =
|
|
18
|
+
this.maxLength = signal(minimumMaxLength);
|
|
19
|
+
this.textMaxLength = computed(() => (this.showMore() ? Number.MAX_SAFE_INTEGER : this.maxLength()));
|
|
14
20
|
this.showMore = signal(false);
|
|
15
|
-
this.showMoreButton = computed(() => this.summary().formattedMessage.length >= maxLength);
|
|
21
|
+
this.showMoreButton = computed(() => this.summary().formattedMessage.length >= this.maxLength());
|
|
16
22
|
this.message = computed(() => this.summary().formattedMessage);
|
|
23
|
+
this.errorColor = computed(() => (this.summary().level === 'warning' ? 'warning' : 'danger'));
|
|
17
24
|
this.hasAutoGeneratedNodes = computed(() => this.summary().errors.some(({ node }) => node?.autoGenerated));
|
|
18
25
|
}
|
|
26
|
+
onResized({ newRect: { width } }) {
|
|
27
|
+
this.maxLength.set(Math.max(minimumMaxLength, width / 3));
|
|
28
|
+
}
|
|
19
29
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: FilesErrorSummaryItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
20
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: FilesErrorSummaryItemComponent, isStandalone: true, selector: "he-files-error-summary-item", inputs: { summary: { classPropertyName: "summary", publicName: "summary", isSignal: true, isRequired: true, transformFunction: null }, resolved: { classPropertyName: "resolved", publicName: "resolved", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { resolved: "resolvedChange" }, ngImport: i0, template: "<div class=\"
|
|
30
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: FilesErrorSummaryItemComponent, isStandalone: true, selector: "he-files-error-summary-item", inputs: { summary: { classPropertyName: "summary", publicName: "summary", isSignal: true, isRequired: true, transformFunction: null }, resolved: { classPropertyName: "resolved", publicName: "resolved", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { resolved: "resolvedChange" }, ngImport: i0, template: "<div class=\"is-flex is-justify-content-center is-align-items-center is-align-self-stretch is-gap-8 is-mb-2\">\n <div class=\"is-flex is-flex-grow-1 | errors-path border-right\">\n <span class=\"has-text-weight-bold\">{{ summary().path || '-' }}</span>\n </div>\n\n <div class=\"is-flex is-align-items-center is-gap-4 | errors-count\">\n <div\n class=\"is-flex is-justify-content-center is-align-items-center has-background-{{\n errorColor()\n }} | errors-count--number\">\n <span class=\"has-text-weight-bold has-text-white\">{{ summary().count }}</span>\n </div>\n <span class=\"has-text-{{ errorColor() }} is-capitalized\">\n {{ summary().level | pluralize: summary().count }}\n </span>\n </div>\n</div>\n\n<div class=\"py-2 w-100 border-y\">\n @if (summary().terms) {\n <p class=\"is-size-7\">\n <span class=\"is-pr-1 has-text-weight-bold\">Terms:</span>\n <span [innerHtml]=\"summary().terms\"></span>\n </p>\n }\n\n @if (hasAutoGeneratedNodes()) {\n <p class=\"is-size-7 has-text-info\">\n <span>Some nodes are auto-generated and the {{ summary().level }} might come from other nodes</span>\n </p>\n }\n\n <p class=\"is-italic has-text-weight-semilight has-text-grey-dark\" (resized)=\"onResized($event)\">\n <span [innerHTML]=\"message() | ellipsis: textMaxLength()\"></span>\n @if (showMoreButton()) {\n <a class=\"has-text-weight-semibold\" (click)=\"$event.stopPropagation(); showMore.set(!showMore())\">\n @if (showMore()) {\n less\n } @else {\n more\n }\n </a>\n }\n </p>\n</div>\n<div class=\"px-1 py-3 w-100\">\n <div class=\"is-flex is-align-items-center is-gap-8 | resolved-actions\">\n <p class=\"has-text-weight-bold is-size-7\">Resolved?</p>\n\n <a\n (click)=\"$event.stopPropagation(); resolved.set(false)\"\n class=\"resolved-actions--unresolve\"\n [class.is-resolved]=\"resolved()\">\n <fa-icon [icon]=\"faTimesCircle\" />\n </a>\n\n <a\n (click)=\"$event.stopPropagation(); resolved.set(true)\"\n class=\"resolved-actions--resolve\"\n [class.is-resolved]=\"resolved()\">\n <fa-icon [icon]=\"faCheckCircle\" />\n </a>\n </div>\n</div>\n", styles: [":host{--summary-files-border-edge: 1px solid #f5f5f5}:host .border-top{border-top:var(--summary-files-border-edge)}:host .border-bottom{border-bottom:var(--summary-files-border-edge)}:host .border-right{border-right:var(--summary-files-border-edge)}:host .border-x{border-left:var(--summary-files-border-edge);border-right:var(--summary-files-border-edge)}:host .border-y{border-bottom:var(--summary-files-border-edge);border-top:var(--summary-files-border-edge)}p,span{word-break:break-word}.summary-content{max-height:400px;overflow-y:auto}.errors-path{color:#4c7194}.errors-count{width:110px}.errors-count--number{line-height:1.3;border-radius:1px;padding:1px 5px}.resolved-actions--resolve{color:#b5b5b5}.resolved-actions--resolve.is-resolved,.resolved-actions--resolve:hover{color:#48c78e}.resolved-actions--unresolve{color:#b5b5b5}.resolved-actions--unresolve:not(.is-resolved),.resolved-actions--unresolve:hover{color:#f14668}\n"], dependencies: [{ kind: "component", type: FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "animation", "mask", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }, { kind: "pipe", type: EllipsisPipe, name: "ellipsis" }, { kind: "pipe", type: PluralizePipe, name: "pluralize" }, { kind: "directive", type: ResizedDirective, selector: "[resized]", outputs: ["resized"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
21
31
|
}
|
|
22
32
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: FilesErrorSummaryItemComponent, decorators: [{
|
|
23
33
|
type: Component,
|
|
24
|
-
args: [{ selector: 'he-files-error-summary-item', standalone: true, imports: [FaIconComponent, EllipsisPipe], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"
|
|
34
|
+
args: [{ selector: 'he-files-error-summary-item', standalone: true, imports: [FaIconComponent, EllipsisPipe, PluralizePipe, ResizedDirective], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"is-flex is-justify-content-center is-align-items-center is-align-self-stretch is-gap-8 is-mb-2\">\n <div class=\"is-flex is-flex-grow-1 | errors-path border-right\">\n <span class=\"has-text-weight-bold\">{{ summary().path || '-' }}</span>\n </div>\n\n <div class=\"is-flex is-align-items-center is-gap-4 | errors-count\">\n <div\n class=\"is-flex is-justify-content-center is-align-items-center has-background-{{\n errorColor()\n }} | errors-count--number\">\n <span class=\"has-text-weight-bold has-text-white\">{{ summary().count }}</span>\n </div>\n <span class=\"has-text-{{ errorColor() }} is-capitalized\">\n {{ summary().level | pluralize: summary().count }}\n </span>\n </div>\n</div>\n\n<div class=\"py-2 w-100 border-y\">\n @if (summary().terms) {\n <p class=\"is-size-7\">\n <span class=\"is-pr-1 has-text-weight-bold\">Terms:</span>\n <span [innerHtml]=\"summary().terms\"></span>\n </p>\n }\n\n @if (hasAutoGeneratedNodes()) {\n <p class=\"is-size-7 has-text-info\">\n <span>Some nodes are auto-generated and the {{ summary().level }} might come from other nodes</span>\n </p>\n }\n\n <p class=\"is-italic has-text-weight-semilight has-text-grey-dark\" (resized)=\"onResized($event)\">\n <span [innerHTML]=\"message() | ellipsis: textMaxLength()\"></span>\n @if (showMoreButton()) {\n <a class=\"has-text-weight-semibold\" (click)=\"$event.stopPropagation(); showMore.set(!showMore())\">\n @if (showMore()) {\n less\n } @else {\n more\n }\n </a>\n }\n </p>\n</div>\n<div class=\"px-1 py-3 w-100\">\n <div class=\"is-flex is-align-items-center is-gap-8 | resolved-actions\">\n <p class=\"has-text-weight-bold is-size-7\">Resolved?</p>\n\n <a\n (click)=\"$event.stopPropagation(); resolved.set(false)\"\n class=\"resolved-actions--unresolve\"\n [class.is-resolved]=\"resolved()\">\n <fa-icon [icon]=\"faTimesCircle\" />\n </a>\n\n <a\n (click)=\"$event.stopPropagation(); resolved.set(true)\"\n class=\"resolved-actions--resolve\"\n [class.is-resolved]=\"resolved()\">\n <fa-icon [icon]=\"faCheckCircle\" />\n </a>\n </div>\n</div>\n", styles: [":host{--summary-files-border-edge: 1px solid #f5f5f5}:host .border-top{border-top:var(--summary-files-border-edge)}:host .border-bottom{border-bottom:var(--summary-files-border-edge)}:host .border-right{border-right:var(--summary-files-border-edge)}:host .border-x{border-left:var(--summary-files-border-edge);border-right:var(--summary-files-border-edge)}:host .border-y{border-bottom:var(--summary-files-border-edge);border-top:var(--summary-files-border-edge)}p,span{word-break:break-word}.summary-content{max-height:400px;overflow-y:auto}.errors-path{color:#4c7194}.errors-count{width:110px}.errors-count--number{line-height:1.3;border-radius:1px;padding:1px 5px}.resolved-actions--resolve{color:#b5b5b5}.resolved-actions--resolve.is-resolved,.resolved-actions--resolve:hover{color:#48c78e}.resolved-actions--unresolve{color:#b5b5b5}.resolved-actions--unresolve:not(.is-resolved),.resolved-actions--unresolve:hover{color:#f14668}\n"] }]
|
|
25
35
|
}] });
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"files-error-summary-item.component.js","sourceRoot":"","sources":["../../../../../src/files/files-error-summary/files-error-summary-item/files-error-summary-item.component.ts","../../../../../src/files/files-error-summary/files-error-summary-item/files-error-summary-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACnG,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAEjF,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,gBAAgB,EAAgB,MAAM,mCAAmC,CAAC;;AAGnF,MAAM,gBAAgB,GAAG,GAAG,CAAC;AAU7B,MAAM,OAAO,8BAA8B;IAR3C;QASqB,kBAAa,GAAG,aAAa,CAAC;QAC9B,kBAAa,GAAG,aAAa,CAAC;QAEjC,YAAO,GAAG,KAAK,CAAC,QAAQ,EAAY,CAAC;QACrD;;WAEG;QACa,aAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QAEvB,cAAS,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;QACnC,kBAAa,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;QAC/F,aAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QACzB,mBAAc,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,gBAAgB,CAAC,MAAM,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QAC5F,YAAO,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,gBAAgB,CAAC,CAAC;QAC1D,eAAU,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;QAEzF,0BAAqB,GAAG,QAAQ,CAAC,GAAG,EAAE,CACvD,IAAI,CAAC,OAAO,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAE,IAAY,EAAE,aAAa,CAAC,CACvE,CAAC;KAKH;IAHW,SAAS,CAAC,EAAE,OAAO,EAAE,EAAE,KAAK,EAAE,EAAgB;QACtD,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,gBAAgB,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;IAC5D,CAAC;+GAvBU,8BAA8B;mGAA9B,8BAA8B,0YCnB3C,8sEAgEA,i+BDlDY,eAAe,uMAAE,YAAY,4CAAE,aAAa,kDAAE,gBAAgB;;4FAK7D,8BAA8B;kBAR1C,SAAS;+BACE,6BAA6B,cAC3B,IAAI,WACP,CAAC,eAAe,EAAE,YAAY,EAAE,aAAa,EAAE,gBAAgB,CAAC,mBACxD,uBAAuB,CAAC,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, model, signal } from '@angular/core';\nimport { FaIconComponent } from '@fortawesome/angular-fontawesome';\nimport { faCheckCircle, faTimesCircle } from '@fortawesome/free-solid-svg-icons';\n\nimport { EllipsisPipe } from '../../../common/ellipsis.pipe';\nimport { PluralizePipe } from '../../../common/pluralize.pipe';\nimport { ResizedDirective, ResizedEvent } from '../../../common/resized.directive';\nimport { ISummary } from '../files-error-summary.model';\n\nconst minimumMaxLength = 150;\n\n@Component({\n  selector: 'he-files-error-summary-item',\n  standalone: true,\n  imports: [FaIconComponent, EllipsisPipe, PluralizePipe, ResizedDirective],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  templateUrl: './files-error-summary-item.component.html',\n  styleUrl: './files-error-summary-item.component.scss'\n})\nexport class FilesErrorSummaryItemComponent {\n  protected readonly faCheckCircle = faCheckCircle;\n  protected readonly faTimesCircle = faTimesCircle;\n\n  public readonly summary = input.required<ISummary>();\n  /**\n   * Error is resolved and should not be displayed anymore.\n   */\n  public readonly resolved = model(false);\n\n  private readonly maxLength = signal(minimumMaxLength);\n  protected readonly textMaxLength = computed(() => (this.showMore() ? Number.MAX_SAFE_INTEGER : this.maxLength()));\n  protected readonly showMore = signal(false);\n  protected readonly showMoreButton = computed(() => this.summary().formattedMessage.length >= this.maxLength());\n  protected readonly message = computed(() => this.summary().formattedMessage);\n  protected readonly errorColor = computed(() => (this.summary().level === 'warning' ? 'warning' : 'danger'));\n\n  protected readonly hasAutoGeneratedNodes = computed(() =>\n    this.summary().errors.some(({ node }) => (node as any)?.autoGenerated)\n  );\n\n  protected onResized({ newRect: { width } }: ResizedEvent) {\n    this.maxLength.set(Math.max(minimumMaxLength, width / 3));\n  }\n}\n","<div class=\"is-flex is-justify-content-center is-align-items-center is-align-self-stretch is-gap-8 is-mb-2\">\n  <div class=\"is-flex is-flex-grow-1 | errors-path border-right\">\n    <span class=\"has-text-weight-bold\">{{ summary().path || '-' }}</span>\n  </div>\n\n  <div class=\"is-flex is-align-items-center is-gap-4 | errors-count\">\n    <div\n      class=\"is-flex is-justify-content-center is-align-items-center has-background-{{\n        errorColor()\n      }} | errors-count--number\">\n      <span class=\"has-text-weight-bold has-text-white\">{{ summary().count }}</span>\n    </div>\n    <span class=\"has-text-{{ errorColor() }} is-capitalized\">\n      {{ summary().level | pluralize: summary().count }}\n    </span>\n  </div>\n</div>\n\n<div class=\"py-2 w-100 border-y\">\n  @if (summary().terms) {\n    <p class=\"is-size-7\">\n      <span class=\"is-pr-1 has-text-weight-bold\">Terms:</span>\n      <span [innerHtml]=\"summary().terms\"></span>\n    </p>\n  }\n\n  @if (hasAutoGeneratedNodes()) {\n    <p class=\"is-size-7 has-text-info\">\n      <span>Some nodes are auto-generated and the {{ summary().level }} might come from other nodes</span>\n    </p>\n  }\n\n  <p class=\"is-italic has-text-weight-semilight has-text-grey-dark\" (resized)=\"onResized($event)\">\n    <span [innerHTML]=\"message() | ellipsis: textMaxLength()\"></span>\n    @if (showMoreButton()) {\n      <a class=\"has-text-weight-semibold\" (click)=\"$event.stopPropagation(); showMore.set(!showMore())\">\n        @if (showMore()) {\n          less\n        } @else {\n          more\n        }\n      </a>\n    }\n  </p>\n</div>\n<div class=\"px-1 py-3 w-100\">\n  <div class=\"is-flex is-align-items-center is-gap-8 | resolved-actions\">\n    <p class=\"has-text-weight-bold is-size-7\">Resolved?</p>\n\n    <a\n      (click)=\"$event.stopPropagation(); resolved.set(false)\"\n      class=\"resolved-actions--unresolve\"\n      [class.is-resolved]=\"resolved()\">\n      <fa-icon [icon]=\"faTimesCircle\" />\n    </a>\n\n    <a\n      (click)=\"$event.stopPropagation(); resolved.set(true)\"\n      class=\"resolved-actions--resolve\"\n      [class.is-resolved]=\"resolved()\">\n      <fa-icon [icon]=\"faCheckCircle\" />\n    </a>\n  </div>\n</div>\n"]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, input, computed, viewChildren, output, effect } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, input, computed, viewChildren, output, effect, signal } from '@angular/core';
|
|
2
2
|
import { toObservable, toSignal } from '@angular/core/rxjs-interop';
|
|
3
3
|
import { unique } from '@hestia-earth/utils';
|
|
4
|
-
import { mergeMap, startWith } from 'rxjs/operators';
|
|
4
|
+
import { filter, map, mergeMap, startWith } from 'rxjs/operators';
|
|
5
5
|
import { combineLatest } from 'rxjs';
|
|
6
6
|
import { distinctUntilChangedDeep } from '../../common/rxjs-utils';
|
|
7
7
|
import { buildSummary } from './files-error-summary.model';
|
|
@@ -14,6 +14,8 @@ const sortSummaries = (summaries, resolved) => summaries.sort((a, b) => summaryS
|
|
|
14
14
|
export class FilesErrorSummaryComponent {
|
|
15
15
|
constructor() {
|
|
16
16
|
this.items = viewChildren(FilesErrorSummaryItemComponent);
|
|
17
|
+
this.itemData = computed(() => this.items().map(item => ({ resolved: item.resolved(), summary: item.summary() })));
|
|
18
|
+
this.itemData$ = toObservable(this.itemData);
|
|
17
19
|
this.nodes = input.required();
|
|
18
20
|
this.errors = input.required();
|
|
19
21
|
/**
|
|
@@ -24,29 +26,37 @@ export class FilesErrorSummaryComponent {
|
|
|
24
26
|
this.summaryData = toSignal(combineLatest([toObservable(this.nodes), toObservable(this.filteredErrors)]).pipe(distinctUntilChangedDeep(), mergeMap(([nodes, errors]) => buildSummary(nodes, errors, this.summaryData())), startWith([])));
|
|
25
27
|
this.resolvedByIndex = computed(() => (this.items() ?? []).reduce((p, c) => ({ ...p, [c.summary().index]: c.resolved() }), {}));
|
|
26
28
|
this.summaries = computed(() => sortSummaries(this.summaryData(), this.resolvedByIndex()));
|
|
29
|
+
this.selectedIndex = signal(undefined);
|
|
30
|
+
this.selectedIndex$ = toObservable(this.selectedIndex);
|
|
31
|
+
this.resolvedErrors = toSignal(combineLatest([this.itemData$, this.selectedIndex$]).pipe(distinctUntilChangedDeep(), filter(([items]) => items?.length > 0), map(([items, selectedIndex]) => items
|
|
32
|
+
.filter(item => (typeof selectedIndex === 'undefined' ? item.resolved : selectedIndex !== item.summary.index))
|
|
33
|
+
.flatMap(item => item.summary.errors)), startWith([])));
|
|
27
34
|
/**
|
|
28
35
|
* Returns the list of errors that have been resolved.
|
|
29
36
|
*/
|
|
30
37
|
this.resolvedErrorsChange = output();
|
|
38
|
+
this.unresolvedIndexes = toSignal(combineLatest([this.itemData$, this.selectedIndex$]).pipe(distinctUntilChangedDeep(), filter(([items]) => items?.length > 0), map(([items, selectedIndex]) => unique(items
|
|
39
|
+
.filter(item => typeof selectedIndex === 'undefined' ? !item.resolved : selectedIndex === item.summary.index)
|
|
40
|
+
.flatMap(item => item.summary.nodeIndexes) ?? [])), startWith([])));
|
|
31
41
|
/**
|
|
32
42
|
* Returns the list of indexes for nodes that match unresolved items.
|
|
33
43
|
*/
|
|
34
44
|
this.unresolvedIndexesChange = output();
|
|
35
|
-
effect(() => this.resolvedErrorsChange.emit(this.
|
|
36
|
-
|
|
37
|
-
?.flatMap(item => item.summary().errors)), { allowSignalWrites: true });
|
|
38
|
-
effect(() => this.unresolvedIndexesChange.emit(unique(this.items()
|
|
39
|
-
?.filter(item => !item.resolved())
|
|
40
|
-
?.flatMap(item => item.summary().nodeIndexes) ?? [])), { allowSignalWrites: true });
|
|
45
|
+
effect(() => this.resolvedErrorsChange.emit(this.resolvedErrors()), { allowSignalWrites: true });
|
|
46
|
+
effect(() => this.unresolvedIndexesChange.emit(this.unresolvedIndexes()), { allowSignalWrites: true });
|
|
41
47
|
}
|
|
42
|
-
|
|
43
|
-
|
|
48
|
+
toggleSummary(summary) {
|
|
49
|
+
const index = this.isSelected(summary) ? undefined : summary.index;
|
|
50
|
+
this.selectedIndex.set(index);
|
|
51
|
+
}
|
|
52
|
+
isSelected({ index }) {
|
|
53
|
+
return this.selectedIndex() === index;
|
|
44
54
|
}
|
|
45
55
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: FilesErrorSummaryComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
46
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: FilesErrorSummaryComponent, isStandalone: true, selector: "he-files-error-summary", inputs: { nodes: { classPropertyName: "nodes", publicName: "nodes", isSignal: true, isRequired: true, transformFunction: null }, errors: { classPropertyName: "errors", publicName: "errors", isSignal: true, isRequired: true, transformFunction: null }, showErrorsOnAutogenerated: { classPropertyName: "showErrorsOnAutogenerated", publicName: "showErrorsOnAutogenerated", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { resolvedErrorsChange: "resolvedErrorsChange", unresolvedIndexesChange: "unresolvedIndexesChange" }, viewQueries: [{ propertyName: "items", predicate: FilesErrorSummaryItemComponent, descendants: true, isSignal: true }], ngImport: i0, template: "@if (summaries().length) {\n <div class=\"table-container\">\n <table class=\"table is-fullwidth is-striped\">\n <tbody>\n @for (summary of summaries(); track
|
|
56
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: FilesErrorSummaryComponent, isStandalone: true, selector: "he-files-error-summary", inputs: { nodes: { classPropertyName: "nodes", publicName: "nodes", isSignal: true, isRequired: true, transformFunction: null }, errors: { classPropertyName: "errors", publicName: "errors", isSignal: true, isRequired: true, transformFunction: null }, showErrorsOnAutogenerated: { classPropertyName: "showErrorsOnAutogenerated", publicName: "showErrorsOnAutogenerated", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { resolvedErrorsChange: "resolvedErrorsChange", unresolvedIndexesChange: "unresolvedIndexesChange" }, viewQueries: [{ propertyName: "items", predicate: FilesErrorSummaryItemComponent, descendants: true, isSignal: true }], ngImport: i0, template: "@if (summaries().length) {\n <div class=\"table-container\">\n <table class=\"table is-fullwidth is-striped\">\n <tbody>\n @for (summary of summaries(); track summary.index) {\n <tr>\n <he-files-error-summary-item\n class=\"is-block is-p-2 pointer\"\n [summary]=\"summary\"\n [class.is-selected]=\"isSelected(summary)\"\n (click)=\"toggleSummary(summary)\" />\n </tr>\n }\n </tbody>\n </table>\n </div>\n}\n", styles: [".table.is-striped tbody tr:nth-child(2n){background-color:#fff}.table.is-striped tbody tr:nth-child(odd){background-color:#fefaf0!important}.table tbody tr:last-child td{border-bottom-width:thin}he-files-error-summary-item{border:2px solid transparent;border-radius:3px}he-files-error-summary-item.is-selected{border-color:#ffce38;background:#fefcf7}\n"], dependencies: [{ kind: "component", type: FilesErrorSummaryItemComponent, selector: "he-files-error-summary-item", inputs: ["summary", "resolved"], outputs: ["resolvedChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
47
57
|
}
|
|
48
58
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: FilesErrorSummaryComponent, decorators: [{
|
|
49
59
|
type: Component,
|
|
50
|
-
args: [{ selector: 'he-files-error-summary', standalone: true, imports: [FilesErrorSummaryItemComponent], changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (summaries().length) {\n <div class=\"table-container\">\n <table class=\"table is-fullwidth is-striped\">\n <tbody>\n @for (summary of summaries(); track
|
|
60
|
+
args: [{ selector: 'he-files-error-summary', standalone: true, imports: [FilesErrorSummaryItemComponent], changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (summaries().length) {\n <div class=\"table-container\">\n <table class=\"table is-fullwidth is-striped\">\n <tbody>\n @for (summary of summaries(); track summary.index) {\n <tr>\n <he-files-error-summary-item\n class=\"is-block is-p-2 pointer\"\n [summary]=\"summary\"\n [class.is-selected]=\"isSelected(summary)\"\n (click)=\"toggleSummary(summary)\" />\n </tr>\n }\n </tbody>\n </table>\n </div>\n}\n", styles: [".table.is-striped tbody tr:nth-child(2n){background-color:#fff}.table.is-striped tbody tr:nth-child(odd){background-color:#fefaf0!important}.table tbody tr:last-child td{border-bottom-width:thin}he-files-error-summary-item{border:2px solid transparent;border-radius:3px}he-files-error-summary-item.is-selected{border-color:#ffce38;background:#fefcf7}\n"] }]
|
|
51
61
|
}], ctorParameters: () => [] });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"files-error-summary.component.js","sourceRoot":"","sources":["../../../../src/files/files-error-summary/files-error-summary.component.ts","../../../../src/files/files-error-summary/files-error-summary.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, input, computed, viewChildren, output, effect } from '@angular/core';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { JSON as HestiaJson, SchemaType } from '@hestia-earth/schema';\nimport { unique } from '@hestia-earth/utils';\nimport { mergeMap, startWith } from 'rxjs/operators';\nimport { combineLatest } from 'rxjs';\n\nimport { distinctUntilChangedDeep } from '../../common/rxjs-utils';\nimport { IValidationErrorWithIndex } from '../files-error.model';\nimport { buildSummary, ISummary, ISummaryError } from './files-error-summary.model';\nimport { FilesErrorSummaryItemComponent } from './files-error-summary-item/files-error-summary-item.component';\n\ninterface IResolvedByIndex {\n  [index: number]: boolean;\n}\n\nconst filterErrors = (\n  showErrorsOnAutogenerated: boolean,\n  nodes: HestiaJson<SchemaType>[] = [],\n  errors: IValidationErrorWithIndex[] = []\n) => errors.filter(({ index }) => showErrorsOnAutogenerated || !(nodes?.[index] as any)?.autoGenerated);\n\n// sort by: unresolved errors - unresolved warnings - resolved errors - resolved warnings\nconst summaryScore = ({ level }: ISummary, resolved: boolean) => (resolved ? 1 : 10) + (level === 'error' ? 1 : 0);\n\nconst sortSummaries = (summaries: ISummary[], resolved: IResolvedByIndex) =>\n  summaries.sort((a, b) => summaryScore(b, resolved[b.index]) - summaryScore(a, resolved[a.index]));\n\n@Component({\n  selector: 'he-files-error-summary',\n  standalone: true,\n  imports: [FilesErrorSummaryItemComponent],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  templateUrl: './files-error-summary.component.html',\n  styleUrl: './files-error-summary.component.scss'\n})\nexport class FilesErrorSummaryComponent {\n  protected readonly items = viewChildren(FilesErrorSummaryItemComponent);\n\n  protected readonly nodes = input.required<HestiaJson<SchemaType>[]>();\n  protected readonly errors = input.required<IValidationErrorWithIndex[]>();\n  /**\n   * Some nodes are autogenerated, and errors should not be shown on them (unless user is Admin).\n   */\n  protected readonly showErrorsOnAutogenerated = input(false);\n\n  private readonly filteredErrors = computed(() =>\n    filterErrors(this.showErrorsOnAutogenerated(), this.nodes(), this.errors())\n  );\n  private readonly summaryData: any = toSignal(\n    combineLatest([toObservable(this.nodes), toObservable(this.filteredErrors)]).pipe(\n      distinctUntilChangedDeep(),\n      mergeMap(([nodes, errors]) => buildSummary(nodes, errors, this.summaryData())),\n      startWith([] as ISummary[])\n    )\n  );\n  private readonly resolvedByIndex = computed(() =>\n    (this.items() ?? []).reduce((p, c) => ({ ...p, [c.summary().index]: c.resolved() }), {} as IResolvedByIndex)\n  );\n\n  protected readonly summaries = computed(() => sortSummaries(this.summaryData(), this.resolvedByIndex()));\n\n  /**\n   * Returns the list of errors that have been resolved.\n   */\n  protected readonly resolvedErrorsChange = output<ISummaryError[]>();\n  /**\n   * Returns the list of indexes for nodes that match unresolved items.\n   */\n  protected readonly unresolvedIndexesChange = output<number[]>();\n\n  constructor() {\n    effect(\n      () =>\n        this.resolvedErrorsChange.emit(\n          this.items()\n            ?.filter(item => item.resolved())\n            ?.flatMap(item => item.summary().errors)\n        ),\n      { allowSignalWrites: true }\n    );\n\n    effect(\n      () =>\n        this.unresolvedIndexesChange.emit(\n          unique(\n            this.items()\n              ?.filter(item => !item.resolved())\n              ?.flatMap(item => item.summary().nodeIndexes) ?? []\n          )\n        ),\n      { allowSignalWrites: true }\n    );\n  }\n\n  protected trackSummary(summary: ISummary) {\n    return [summary.path, summary.level, summary.message, summary.count].join('-');\n  }\n}\n","@if (summaries().length) {\n  <div class=\"table-container\">\n    <table class=\"table is-fullwidth is-striped\">\n      <tbody>\n        @for (summary of summaries(); track trackSummary(summary)) {\n          <tr>\n            <he-files-error-summary-item class=\"is-block is-p-2\" [summary]=\"summary\" />\n          </tr>\n        }\n      </tbody>\n    </table>\n  </div>\n}\n"]}
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"files-error-summary.component.js","sourceRoot":"","sources":["../../../../src/files/files-error-summary/files-error-summary.component.ts","../../../../src/files/files-error-summary/files-error-summary.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  input,\n  computed,\n  viewChildren,\n  output,\n  effect,\n  signal\n} from '@angular/core';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { JSON as HestiaJson, SchemaType } from '@hestia-earth/schema';\nimport { unique } from '@hestia-earth/utils';\nimport { filter, map, mergeMap, startWith } from 'rxjs/operators';\nimport { combineLatest } from 'rxjs';\n\nimport { distinctUntilChangedDeep } from '../../common/rxjs-utils';\nimport { IValidationErrorWithIndex } from '../files-error.model';\nimport { buildSummary, ISummary, ISummaryError } from './files-error-summary.model';\nimport { FilesErrorSummaryItemComponent } from './files-error-summary-item/files-error-summary-item.component';\n\ninterface IResolvedByIndex {\n  [index: number]: boolean;\n}\n\nconst filterErrors = (\n  showErrorsOnAutogenerated: boolean,\n  nodes: HestiaJson<SchemaType>[] = [],\n  errors: IValidationErrorWithIndex[] = []\n) => errors.filter(({ index }) => showErrorsOnAutogenerated || !(nodes?.[index] as any)?.autoGenerated);\n\n// sort by: unresolved errors - unresolved warnings - resolved errors - resolved warnings\nconst summaryScore = ({ level }: ISummary, resolved: boolean) => (resolved ? 1 : 10) + (level === 'error' ? 1 : 0);\n\nconst sortSummaries = (summaries: ISummary[], resolved: IResolvedByIndex) =>\n  summaries.sort((a, b) => summaryScore(b, resolved[b.index]) - summaryScore(a, resolved[a.index]));\n\n@Component({\n  selector: 'he-files-error-summary',\n  standalone: true,\n  imports: [FilesErrorSummaryItemComponent],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  templateUrl: './files-error-summary.component.html',\n  styleUrl: './files-error-summary.component.scss'\n})\nexport class FilesErrorSummaryComponent {\n  protected readonly items = viewChildren(FilesErrorSummaryItemComponent);\n  private readonly itemData = computed(() =>\n    this.items().map(item => ({ resolved: item.resolved(), summary: item.summary() }))\n  );\n  private readonly itemData$ = toObservable(this.itemData);\n\n  protected readonly nodes = input.required<HestiaJson<SchemaType>[]>();\n  protected readonly errors = input.required<IValidationErrorWithIndex[]>();\n  /**\n   * Some nodes are autogenerated, and errors should not be shown on them (unless user is Admin).\n   */\n  protected readonly showErrorsOnAutogenerated = input(false);\n\n  private readonly filteredErrors = computed(() =>\n    filterErrors(this.showErrorsOnAutogenerated(), this.nodes(), this.errors())\n  );\n  private readonly summaryData: any = toSignal(\n    combineLatest([toObservable(this.nodes), toObservable(this.filteredErrors)]).pipe(\n      distinctUntilChangedDeep(),\n      mergeMap(([nodes, errors]) => buildSummary(nodes, errors, this.summaryData())),\n      startWith([] as ISummary[])\n    )\n  );\n  private readonly resolvedByIndex = computed(() =>\n    (this.items() ?? []).reduce((p, c) => ({ ...p, [c.summary().index]: c.resolved() }), {} as IResolvedByIndex)\n  );\n\n  protected readonly summaries = computed(() => sortSummaries(this.summaryData(), this.resolvedByIndex()));\n\n  private readonly selectedIndex = signal<number>(undefined);\n  private readonly selectedIndex$ = toObservable(this.selectedIndex);\n\n  private readonly resolvedErrors = toSignal(\n    combineLatest([this.itemData$, this.selectedIndex$]).pipe(\n      distinctUntilChangedDeep(),\n      filter(([items]) => items?.length > 0),\n      map(([items, selectedIndex]) =>\n        items\n          .filter(item => (typeof selectedIndex === 'undefined' ? item.resolved : selectedIndex !== item.summary.index))\n          .flatMap(item => item.summary.errors)\n      ),\n      startWith([] as ISummaryError[])\n    )\n  );\n  /**\n   * Returns the list of errors that have been resolved.\n   */\n  protected readonly resolvedErrorsChange = output<ISummaryError[]>();\n\n  private readonly unresolvedIndexes = toSignal(\n    combineLatest([this.itemData$, this.selectedIndex$]).pipe(\n      distinctUntilChangedDeep(),\n      filter(([items]) => items?.length > 0),\n      map(([items, selectedIndex]) =>\n        unique(\n          items\n            .filter(item =>\n              typeof selectedIndex === 'undefined' ? !item.resolved : selectedIndex === item.summary.index\n            )\n            .flatMap(item => item.summary.nodeIndexes) ?? []\n        )\n      ),\n      startWith([] as number[])\n    )\n  );\n  /**\n   * Returns the list of indexes for nodes that match unresolved items.\n   */\n  protected readonly unresolvedIndexesChange = output<number[]>();\n\n  constructor() {\n    effect(() => this.resolvedErrorsChange.emit(this.resolvedErrors()), { allowSignalWrites: true });\n    effect(() => this.unresolvedIndexesChange.emit(this.unresolvedIndexes()), { allowSignalWrites: true });\n  }\n\n  protected toggleSummary(summary: ISummary) {\n    const index = this.isSelected(summary) ? undefined : summary.index;\n    this.selectedIndex.set(index);\n  }\n\n  protected isSelected({ index }: ISummary) {\n    return this.selectedIndex() === index;\n  }\n}\n","@if (summaries().length) {\n  <div class=\"table-container\">\n    <table class=\"table is-fullwidth is-striped\">\n      <tbody>\n        @for (summary of summaries(); track summary.index) {\n          <tr>\n            <he-files-error-summary-item\n              class=\"is-block is-p-2 pointer\"\n              [summary]=\"summary\"\n              [class.is-selected]=\"isSelected(summary)\"\n              (click)=\"toggleSummary(summary)\" />\n          </tr>\n        }\n      </tbody>\n    </table>\n  </div>\n}\n"]}
|