@hestia-earth/ui-components 0.0.34 → 0.1.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/bundles/hestia-earth-ui-components.umd.js +481 -303
- package/bundles/hestia-earth-ui-components.umd.js.map +1 -1
- package/common/common.light.module.d.ts +15 -14
- package/common/common.module.d.ts +23 -22
- package/common/data-table/data-table.component.d.ts +21 -0
- package/common/index.d.ts +2 -0
- package/common/issue-confirm/issue-confirm.component.d.ts +14 -0
- package/common/utils.d.ts +11 -0
- package/cycles/cycles-emissions-chart/cycles-emissions-chart.component.d.ts +4 -1
- package/cycles/cycles-result/cycles-result.component.d.ts +3 -1
- package/esm2015/bibliographies/bibliographies-search-confirm/bibliographies-search-confirm.component.js +5 -4
- package/esm2015/common/blank-node-state/blank-node-state.component.js +5 -4
- package/esm2015/common/blank-node-state-notice/blank-node-state-notice.component.js +5 -4
- package/esm2015/common/blank-node-value-delta/blank-node-value-delta.component.js +5 -4
- package/esm2015/common/common.light.module.js +7 -3
- package/esm2015/common/common.module.js +28 -24
- package/esm2015/common/data-table/data-table.component.js +70 -0
- package/esm2015/common/index.js +3 -1
- package/esm2015/common/issue-confirm/issue-confirm.component.js +38 -0
- package/esm2015/common/link-key-value/link-key-value.component.js +5 -4
- package/esm2015/common/schema-version-link/schema-version-link.component.js +5 -4
- package/esm2015/common/social-tags/social-tags.component.js +5 -4
- package/esm2015/common/unit-converter/unit-converter.component.js +5 -4
- package/esm2015/common/utils.js +14 -1
- package/esm2015/cycles/cycles-activity/cycles-activity.component.js +15 -14
- package/esm2015/cycles/cycles-completeness/cycles-completeness.component.js +10 -8
- package/esm2015/cycles/cycles-emissions/cycles-emissions.component.js +16 -15
- package/esm2015/cycles/cycles-emissions-chart/cycles-emissions-chart.component.js +9 -5
- package/esm2015/cycles/cycles-functional-unit-measure/cycles-functional-unit-measure.component.js +5 -4
- package/esm2015/cycles/cycles-practices/cycles-practices.component.js +15 -14
- package/esm2015/cycles/cycles-result/cycles-result.component.js +10 -8
- package/esm2015/engine/engine-orchestrator-edit/engine-orchestrator-edit.component.js +4 -5
- package/esm2015/engine/engine-requirements-form/engine-requirements-form.component.js +5 -4
- package/esm2015/impact-assessments/impact-assessments-indicator-breakdown-chart/impact-assessments-indicator-breakdown-chart.component.js +9 -5
- package/esm2015/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.js +9 -5
- package/esm2015/impact-assessments/impact-assessments-products/impact-assessments-products.component.js +18 -17
- package/esm2015/node/node-csv-export-confirm/node-csv-export-confirm.component.js +5 -4
- package/esm2015/node/node-csv-select-headers/node-csv-select-headers.component.js +5 -4
- package/esm2015/node/node-diffs/node-diffs.component.js +5 -4
- package/esm2015/node/node-icon/node-icon.component.js +5 -4
- package/esm2015/node/node-link/node-link.component.js +5 -4
- package/esm2015/node/node-logs-file/node-logs-file.component.js +5 -4
- package/esm2015/node/node-logs-models/node-logs-models.component.js +17 -14
- package/esm2015/node/node-missing-lookup-factors/node-missing-lookup-factors.component.js +5 -4
- package/esm2015/node/node-value-details/node-value-details.component.js +5 -4
- package/esm2015/search/search.model.js +3 -3
- package/esm2015/sites/sites-maps/sites-maps.component.js +5 -4
- package/esm2015/sites/sites-measurements/sites-measurements.component.js +14 -13
- package/fesm2015/hestia-earth-ui-components.js +397 -242
- package/fesm2015/hestia-earth-ui-components.js.map +1 -1
- package/impact-assessments/impact-assessments-indicator-breakdown-chart/impact-assessments-indicator-breakdown-chart.component.d.ts +4 -2
- package/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.d.ts +4 -1
- package/node/node-logs-models/node-logs-models.component.d.ts +1 -0
- package/package.json +6 -6
- package/styles.scss +0 -83
|
@@ -1,19 +1,20 @@
|
|
|
1
1
|
import * as i0 from "@angular/core";
|
|
2
|
-
import * as i1 from "./
|
|
3
|
-
import * as i2 from "./
|
|
4
|
-
import * as i3 from "./
|
|
5
|
-
import * as i4 from "./
|
|
6
|
-
import * as i5 from "./
|
|
7
|
-
import * as i6 from "./
|
|
8
|
-
import * as i7 from "./
|
|
9
|
-
import * as i8 from "./
|
|
10
|
-
import * as i9 from "./
|
|
11
|
-
import * as i10 from "
|
|
12
|
-
import * as i11 from "@angular/
|
|
13
|
-
import * as i12 from "@angular/
|
|
14
|
-
import * as i13 from "
|
|
2
|
+
import * as i1 from "./issue-confirm/issue-confirm.component";
|
|
3
|
+
import * as i2 from "./social-tags/social-tags.component";
|
|
4
|
+
import * as i3 from "./toast/toast.component";
|
|
5
|
+
import * as i4 from "./bind-once.directive";
|
|
6
|
+
import * as i5 from "./default.pipe";
|
|
7
|
+
import * as i6 from "./ellipsis.pipe";
|
|
8
|
+
import * as i7 from "./keys.pipe";
|
|
9
|
+
import * as i8 from "./pluralize.pipe";
|
|
10
|
+
import * as i9 from "./key-to-label.pipe";
|
|
11
|
+
import * as i10 from "./precision.pipe";
|
|
12
|
+
import * as i11 from "@angular/common";
|
|
13
|
+
import * as i12 from "@angular/forms";
|
|
14
|
+
import * as i13 from "@angular/router";
|
|
15
|
+
import * as i14 from "../fontawesome/fontawesome.module";
|
|
15
16
|
export declare class HeCommonLightModule {
|
|
16
17
|
static ɵfac: i0.ɵɵFactoryDeclaration<HeCommonLightModule, never>;
|
|
17
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<HeCommonLightModule, [typeof i1.
|
|
18
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<HeCommonLightModule, [typeof i1.IssueConfirmComponent, typeof i2.SocialTagsComponent, typeof i3.ToastComponent, typeof i4.BindOnceDirective, typeof i5.DefaultPipe, typeof i6.EllipsisPipe, typeof i7.KeysPipe, typeof i8.PluralizePipe, typeof i9.KeyToLabelPipe, typeof i10.PrecisionPipe], [typeof i11.CommonModule, typeof i12.FormsModule, typeof i13.RouterModule, typeof i14.HeFontawesomeModule], [typeof i14.HeFontawesomeModule, typeof i1.IssueConfirmComponent, typeof i2.SocialTagsComponent, typeof i3.ToastComponent, typeof i4.BindOnceDirective, typeof i5.DefaultPipe, typeof i6.EllipsisPipe, typeof i7.KeysPipe, typeof i8.PluralizePipe, typeof i9.KeyToLabelPipe, typeof i10.PrecisionPipe]>;
|
|
18
19
|
static ɵinj: i0.ɵɵInjectorDeclaration<HeCommonLightModule>;
|
|
19
20
|
}
|
|
@@ -1,28 +1,29 @@
|
|
|
1
1
|
import * as i0 from "@angular/core";
|
|
2
|
-
import * as i1 from "./
|
|
3
|
-
import * as i2 from "./
|
|
4
|
-
import * as i3 from "./
|
|
5
|
-
import * as i4 from "./
|
|
6
|
-
import * as i5 from "./
|
|
7
|
-
import * as i6 from "./
|
|
8
|
-
import * as i7 from "./
|
|
9
|
-
import * as i8 from "./
|
|
10
|
-
import * as i9 from "./
|
|
2
|
+
import * as i1 from "./blank-node-state/blank-node-state.component";
|
|
3
|
+
import * as i2 from "./blank-node-state-notice/blank-node-state-notice.component";
|
|
4
|
+
import * as i3 from "./blank-node-value-delta/blank-node-value-delta.component";
|
|
5
|
+
import * as i4 from "./clipboard/clipboard.component";
|
|
6
|
+
import * as i5 from "./data-table/data-table.component";
|
|
7
|
+
import * as i6 from "./link-key-value/link-key-value.component";
|
|
8
|
+
import * as i7 from "./maps-drawing-confirm/maps-drawing-confirm.component";
|
|
9
|
+
import * as i8 from "./popover/popover.component";
|
|
10
|
+
import * as i9 from "./popover-confirm/popover-confirm.component";
|
|
11
11
|
import * as i10 from "./schema-version-link/schema-version-link.component";
|
|
12
|
-
import * as i11 from "./
|
|
13
|
-
import * as i12 from "./
|
|
14
|
-
import * as i13 from "./
|
|
15
|
-
import * as i14 from "./
|
|
16
|
-
import * as i15 from "./
|
|
17
|
-
import * as i16 from "./
|
|
18
|
-
import * as i17 from "
|
|
19
|
-
import * as i18 from "@angular/
|
|
20
|
-
import * as i19 from "@angular/
|
|
21
|
-
import * as i20 from "@
|
|
22
|
-
import * as i21 from "@
|
|
23
|
-
import * as i22 from "
|
|
12
|
+
import * as i11 from "./skeleton-text/skeleton-text.component";
|
|
13
|
+
import * as i12 from "./unit-converter/unit-converter.component";
|
|
14
|
+
import * as i13 from "./tags-input.directive";
|
|
15
|
+
import * as i14 from "./times.pipe";
|
|
16
|
+
import * as i15 from "./click-outside.directive";
|
|
17
|
+
import * as i16 from "./get.pipe";
|
|
18
|
+
import * as i17 from "./is-array.pipe";
|
|
19
|
+
import * as i18 from "@angular/common";
|
|
20
|
+
import * as i19 from "@angular/forms";
|
|
21
|
+
import * as i20 from "@angular/router";
|
|
22
|
+
import * as i21 from "@ng-bootstrap/ng-bootstrap";
|
|
23
|
+
import * as i22 from "@angular/google-maps";
|
|
24
|
+
import * as i23 from "./common.light.module";
|
|
24
25
|
export declare class HeCommonModule {
|
|
25
26
|
static ɵfac: i0.ɵɵFactoryDeclaration<HeCommonModule, never>;
|
|
26
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<HeCommonModule, [typeof i1.
|
|
27
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<HeCommonModule, [typeof i1.BlankNodeStateComponent, typeof i2.BlankNodeStateNoticeComponent, typeof i3.BlankNodeValueDeltaComponent, typeof i4.ClipboardComponent, typeof i5.DataTableComponent, typeof i6.LinkKeyValueComponent, typeof i7.MapsDrawingConfirmComponent, typeof i8.PopoverComponent, typeof i9.PopoverConfirmComponent, typeof i10.SchemaVersionLinkComponent, typeof i11.SkeletonTextComponent, typeof i12.UnitConverterComponent, typeof i13.TagsInputDirective, typeof i14.TimesPipe, typeof i15.ClickOutsideDirective, typeof i16.GetPipe, typeof i17.IsArrayPipe], [typeof i18.CommonModule, typeof i19.FormsModule, typeof i20.RouterModule, typeof i21.NgbTypeaheadModule, typeof i21.NgbTooltipModule, typeof i21.NgbPopoverModule, typeof i22.GoogleMapsModule, typeof i23.HeCommonLightModule], [typeof i21.NgbTypeaheadModule, typeof i21.NgbTooltipModule, typeof i21.NgbPopoverModule, typeof i22.GoogleMapsModule, typeof i23.HeCommonLightModule, typeof i1.BlankNodeStateComponent, typeof i2.BlankNodeStateNoticeComponent, typeof i3.BlankNodeValueDeltaComponent, typeof i4.ClipboardComponent, typeof i5.DataTableComponent, typeof i6.LinkKeyValueComponent, typeof i7.MapsDrawingConfirmComponent, typeof i8.PopoverComponent, typeof i9.PopoverConfirmComponent, typeof i10.SchemaVersionLinkComponent, typeof i11.SkeletonTextComponent, typeof i12.UnitConverterComponent, typeof i13.TagsInputDirective, typeof i14.TimesPipe, typeof i15.ClickOutsideDirective, typeof i16.GetPipe, typeof i17.IsArrayPipe]>;
|
|
27
28
|
static ɵinj: i0.ɵɵInjectorDeclaration<HeCommonModule>;
|
|
28
29
|
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { AfterViewInit, ElementRef, OnChanges, SimpleChanges } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class DataTableComponent implements AfterViewInit, OnChanges {
|
|
4
|
+
private el;
|
|
5
|
+
private minHeight;
|
|
6
|
+
private maxHeight?;
|
|
7
|
+
private nbRows?;
|
|
8
|
+
private small;
|
|
9
|
+
height: string;
|
|
10
|
+
width: string;
|
|
11
|
+
get isSmall(): boolean;
|
|
12
|
+
protected onResize(): void;
|
|
13
|
+
constructor(el: ElementRef);
|
|
14
|
+
ngAfterViewInit(): void;
|
|
15
|
+
ngOnChanges(changes: SimpleChanges): void;
|
|
16
|
+
get nbHeaders(): any;
|
|
17
|
+
get rowHeight(): 30 | 42;
|
|
18
|
+
private updateTableSize;
|
|
19
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DataTableComponent, never>;
|
|
20
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DataTableComponent, "he-data-table", never, { "minHeight": "minHeight"; "maxHeight": "maxHeight"; "nbRows": "nbRows"; "small": "small"; "height": "height"; "width": "width"; }, {}, never, ["*"]>;
|
|
21
|
+
}
|
package/common/index.d.ts
CHANGED
|
@@ -10,6 +10,8 @@ export { BlankNodeStateComponent } from './blank-node-state/blank-node-state.com
|
|
|
10
10
|
export { BlankNodeStateNoticeComponent } from './blank-node-state-notice/blank-node-state-notice.component';
|
|
11
11
|
export { BlankNodeValueDeltaComponent } from './blank-node-value-delta/blank-node-value-delta.component';
|
|
12
12
|
export { ClipboardComponent } from './clipboard/clipboard.component';
|
|
13
|
+
export { DataTableComponent } from './data-table/data-table.component';
|
|
14
|
+
export { IssueConfirmComponent } from './issue-confirm/issue-confirm.component';
|
|
13
15
|
export { LinkKeyValueComponent } from './link-key-value/link-key-value.component';
|
|
14
16
|
export { MapsDrawingConfirmComponent } from './maps-drawing-confirm/maps-drawing-confirm.component';
|
|
15
17
|
export { PopoverComponent } from './popover/popover.component';
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { EventEmitter } from '@angular/core';
|
|
2
|
+
import { Repository, Template } from '../utils';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class IssueConfirmComponent {
|
|
5
|
+
title: string;
|
|
6
|
+
repository?: Repository;
|
|
7
|
+
template?: Template;
|
|
8
|
+
closed: EventEmitter<boolean>;
|
|
9
|
+
Repository: typeof Repository;
|
|
10
|
+
Template: typeof Template;
|
|
11
|
+
get issueUrl(): string;
|
|
12
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<IssueConfirmComponent, never>;
|
|
13
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<IssueConfirmComponent, "he-issue-confirm", never, { "title": "title"; "repository": "repository"; "template": "template"; }, { "closed": "closed"; }, never, never>;
|
|
14
|
+
}
|
package/common/utils.d.ts
CHANGED
|
@@ -30,3 +30,14 @@ export declare const repeat: (times?: number) => number[];
|
|
|
30
30
|
export declare const filenameWithoutExt: (filename?: string) => string;
|
|
31
31
|
export declare const copyObject: (data?: any) => any;
|
|
32
32
|
export declare const isEqual: (a: any, b: any) => boolean;
|
|
33
|
+
export declare enum Repository {
|
|
34
|
+
glossary = "hestia-glossary",
|
|
35
|
+
models = "hestia-engine-models",
|
|
36
|
+
orchestrator = "hestia-engine-orchestrator",
|
|
37
|
+
community = "hestia-community-edition",
|
|
38
|
+
poorenemeck = "hestia-convert-poore-nemecek"
|
|
39
|
+
}
|
|
40
|
+
export declare enum Template {
|
|
41
|
+
bug = "bug",
|
|
42
|
+
feature = "feature"
|
|
43
|
+
}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import { OnChanges, SimpleChanges, AfterViewInit } from '@angular/core';
|
|
1
|
+
import { OnChanges, SimpleChanges, AfterViewInit, NgZone } from '@angular/core';
|
|
2
2
|
import { Emission, ITermJSONLD } from '@hestia-earth/schema';
|
|
3
3
|
import { IGroupedNodes } from '../../common/node-utils';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class CyclesEmissionsChartComponent implements AfterViewInit, OnChanges {
|
|
6
|
+
private ngZone;
|
|
6
7
|
private chartRef?;
|
|
7
8
|
private chart;
|
|
8
9
|
private cycles;
|
|
@@ -10,9 +11,11 @@ export declare class CyclesEmissionsChartComponent implements AfterViewInit, OnC
|
|
|
10
11
|
emissionPerCycle: IGroupedNodes<Emission>;
|
|
11
12
|
terms: ITermJSONLD[];
|
|
12
13
|
selectedTerm?: ITermJSONLD;
|
|
14
|
+
constructor(ngZone: NgZone);
|
|
13
15
|
ngAfterViewInit(): void;
|
|
14
16
|
ngOnChanges(changes: SimpleChanges): void;
|
|
15
17
|
private init;
|
|
18
|
+
private initChart;
|
|
16
19
|
updateChart(): void;
|
|
17
20
|
static ɵfac: i0.ɵɵFactoryDeclaration<CyclesEmissionsChartComponent, never>;
|
|
18
21
|
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesEmissionsChartComponent, "he-cycles-emissions-chart", never, { "cycles": "cycles"; "selected": "selected"; }, {}, never, never>;
|
|
@@ -1,10 +1,12 @@
|
|
|
1
|
-
import { AfterViewInit, OnChanges, SimpleChanges } from '@angular/core';
|
|
1
|
+
import { AfterViewInit, OnChanges, SimpleChanges, NgZone } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export declare class CyclesResultComponent implements AfterViewInit, OnChanges {
|
|
4
|
+
private ngZone;
|
|
4
5
|
private chartRef?;
|
|
5
6
|
private chart;
|
|
6
7
|
private cycles;
|
|
7
8
|
private selected;
|
|
9
|
+
constructor(ngZone: NgZone);
|
|
8
10
|
ngAfterViewInit(): void;
|
|
9
11
|
ngOnChanges(changes: SimpleChanges): void;
|
|
10
12
|
private isSelected;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ChangeDetectionStrategy } from '@angular/core';
|
|
2
2
|
import { Validators } from '@angular/forms';
|
|
3
3
|
import { catchError, debounceTime, distinctUntilChanged, map, switchMap, tap } from 'rxjs/operators';
|
|
4
4
|
import { of, zip } from 'rxjs';
|
|
@@ -78,13 +78,14 @@ export class BibliographiesSearchConfirmComponent {
|
|
|
78
78
|
}
|
|
79
79
|
}
|
|
80
80
|
BibliographiesSearchConfirmComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: BibliographiesSearchConfirmComponent, deps: [{ token: i1.FormBuilder }, { token: i2.HeMendeleyService }, { token: i3.HeSearchService }], target: i0.ɵɵFactoryTarget.Component });
|
|
81
|
-
BibliographiesSearchConfirmComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: BibliographiesSearchConfirmComponent, selector: "he-bibliographies-search-confirm", inputs: { search: "search", searchSources: "searchSources", searchBibliographies: "searchBibliographies", searchBy: "searchBy" }, outputs: { closed: "closed" }, ngImport: i0, template: "<div class=\"modal is-large is-active\">\n <div class=\"modal-background\"></div>\n <div class=\"modal-card\">\n <header class=\"modal-card-head\">\n <p class=\"modal-card-title\">Search Bibliographies</p>\n <button class=\"delete\" aria-label=\"close\" (click)=\"cancel()\"></button>\n </header>\n <section class=\"modal-card-body\">\n <form [formGroup]=\"formGroup\" novalidate>\n <div class=\"field has-addons\">\n <div class=\"control is-expanded has-icons-right\">\n <input class=\"input search-input\"\n [attr.placeholder]=\"'Search bibliography by ' + searchBy\"\n formControlName=\"search\" name=\"randomname\" autocomplete=\"off\"\n (focus)=\"searchFocus($event)\"\n >\n <a class=\"icon is-small is-right\" (click)=\"!loading && resetSearch()\" [ngSwitch]=\"loading\">\n <fa-icon *ngSwitchCase=\"true\" icon=\"spinner\" [pulse]=\"true\"></fa-icon>\n <fa-icon *ngSwitchCase=\"false\" icon=\"times\"></fa-icon>\n </a>\n </div>\n </div>\n </form>\n\n <div class=\"mt-2\">\n <span [class.is-hidden]=\"loading || !searchControl?.value || hasResults\">\n No bibliographies found matching query.\n </span>\n\n <ul>\n <li *ngFor=\"let result of results | async\">\n <a class=\"is-block p-1 search-result\" (click)=\"selectResult(result)\"\n [class.is-active]=\"selectedResult === result\"\n >\n <ngb-highlight\n [result]=\"result.bibliography ? result.bibliography.title : result.title\"\n [term]=\"searchControl?.value\"\n ></ngb-highlight>\n\n <span class=\"px-1\">-</span>\n\n <span class=\"px-1\"><i>{{result.name}}</i></span>\n\n <span class=\"px-1\"\n *ngIf=\"result.bibliography?.documentDOI || result.documentDOI\"\n >- <b>documentDOI:</b>\n </span>\n <ngb-highlight\n [result]=\"result.bibliography ? result.bibliography.documentDOI : result.documentDOI\"\n [term]=\"searchControl?.value\"\n ></ngb-highlight>\n\n <span class=\"px-1\"\n *ngIf=\"result.bibliography?.scopus || result.scopus\"\n >- <b>scopus:</b>\n </span>\n <ngb-highlight\n [result]=\"result.bibliography?.scopus || result.scopus\"\n [term]=\"searchControl?.value\"\n ></ngb-highlight>\n\n <span>\n <ng-container *ngTemplateOutlet=\"mendeleyLink; context: {$implicit: result.bibliography ? result.bibliography.mendeleyID : result.mendeleyID}\"></ng-container>\n </span>\n </a>\n </li>\n </ul>\n </div>\n </section>\n <footer class=\"modal-card-foot\">\n <button class=\"button is-primary\" (click)=\"confirm()\" [disabled]=\"!selectedResult\">\n <span>Confirm</span>\n </button>\n <button class=\"button\" (click)=\"cancel()\">\n <span>Close</span>\n </button>\n </footer>\n </div>\n</div>\n\n<ng-template #mendeleyLink let-id>\n <a *ngIf=\"id\" [href]=\"'https://www.mendeley.com/catalogue/' + id\" target=\"_blank\"\n (click)=\"$event.stopPropagation()\"\n >\n <fa-icon class=\"ml-2\" icon=\"external-link-alt\" size=\"sm\"></fa-icon>\n </a>\n</ng-template>\n", styles: ["ngb-highlight,span{vertical-align:middle;white-space:normal;width:auto}\n"], components: [{ type: i4.FaIconComponent, selector: "fa-icon", inputs: ["classes", "icon", "title", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }, { type: i5.NgbHighlight, selector: "ngb-highlight", inputs: ["highlightClass", "result", "term"] }], directives: [{ type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["disabled", "formControlName", "ngModel"], outputs: ["ngModelChange"] }, { type: i6.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i6.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i6.AsyncPipe } });
|
|
81
|
+
BibliographiesSearchConfirmComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: BibliographiesSearchConfirmComponent, selector: "he-bibliographies-search-confirm", inputs: { search: "search", searchSources: "searchSources", searchBibliographies: "searchBibliographies", searchBy: "searchBy" }, outputs: { closed: "closed" }, ngImport: i0, template: "<div class=\"modal is-large is-active\">\n <div class=\"modal-background\"></div>\n <div class=\"modal-card\">\n <header class=\"modal-card-head\">\n <p class=\"modal-card-title\">Search Bibliographies</p>\n <button class=\"delete\" aria-label=\"close\" (click)=\"cancel()\"></button>\n </header>\n <section class=\"modal-card-body\">\n <form [formGroup]=\"formGroup\" novalidate>\n <div class=\"field has-addons\">\n <div class=\"control is-expanded has-icons-right\">\n <input class=\"input search-input\"\n [attr.placeholder]=\"'Search bibliography by ' + searchBy\"\n formControlName=\"search\" name=\"randomname\" autocomplete=\"off\"\n (focus)=\"searchFocus($event)\"\n >\n <a class=\"icon is-small is-right\" (click)=\"!loading && resetSearch()\" [ngSwitch]=\"loading\">\n <fa-icon *ngSwitchCase=\"true\" icon=\"spinner\" [pulse]=\"true\"></fa-icon>\n <fa-icon *ngSwitchCase=\"false\" icon=\"times\"></fa-icon>\n </a>\n </div>\n </div>\n </form>\n\n <div class=\"mt-2\">\n <span [class.is-hidden]=\"loading || !searchControl?.value || hasResults\">\n No bibliographies found matching query.\n </span>\n\n <ul>\n <li *ngFor=\"let result of results | async\">\n <a class=\"is-block p-1 search-result\" (click)=\"selectResult(result)\"\n [class.is-active]=\"selectedResult === result\"\n >\n <ngb-highlight\n [result]=\"result.bibliography ? result.bibliography.title : result.title\"\n [term]=\"searchControl?.value\"\n ></ngb-highlight>\n\n <span class=\"px-1\">-</span>\n\n <span class=\"px-1\"><i>{{result.name}}</i></span>\n\n <span class=\"px-1\"\n *ngIf=\"result.bibliography?.documentDOI || result.documentDOI\"\n >- <b>documentDOI:</b>\n </span>\n <ngb-highlight\n [result]=\"result.bibliography ? result.bibliography.documentDOI : result.documentDOI\"\n [term]=\"searchControl?.value\"\n ></ngb-highlight>\n\n <span class=\"px-1\"\n *ngIf=\"result.bibliography?.scopus || result.scopus\"\n >- <b>scopus:</b>\n </span>\n <ngb-highlight\n [result]=\"result.bibliography?.scopus || result.scopus\"\n [term]=\"searchControl?.value\"\n ></ngb-highlight>\n\n <span>\n <ng-container *ngTemplateOutlet=\"mendeleyLink; context: {$implicit: result.bibliography ? result.bibliography.mendeleyID : result.mendeleyID}\"></ng-container>\n </span>\n </a>\n </li>\n </ul>\n </div>\n </section>\n <footer class=\"modal-card-foot\">\n <button class=\"button is-primary\" (click)=\"confirm()\" [disabled]=\"!selectedResult\">\n <span>Confirm</span>\n </button>\n <button class=\"button\" (click)=\"cancel()\">\n <span>Close</span>\n </button>\n </footer>\n </div>\n</div>\n\n<ng-template #mendeleyLink let-id>\n <a *ngIf=\"id\" [href]=\"'https://www.mendeley.com/catalogue/' + id\" target=\"_blank\"\n (click)=\"$event.stopPropagation()\"\n >\n <fa-icon class=\"ml-2\" icon=\"external-link-alt\" size=\"sm\"></fa-icon>\n </a>\n</ng-template>\n", styles: ["ngb-highlight,span{vertical-align:middle;white-space:normal;width:auto}\n"], components: [{ type: i4.FaIconComponent, selector: "fa-icon", inputs: ["classes", "icon", "title", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }, { type: i5.NgbHighlight, selector: "ngb-highlight", inputs: ["highlightClass", "result", "term"] }], directives: [{ type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["disabled", "formControlName", "ngModel"], outputs: ["ngModelChange"] }, { type: i6.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i6.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i6.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
82
82
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: BibliographiesSearchConfirmComponent, decorators: [{
|
|
83
83
|
type: Component,
|
|
84
84
|
args: [{
|
|
85
85
|
selector: 'he-bibliographies-search-confirm',
|
|
86
86
|
templateUrl: './bibliographies-search-confirm.component.html',
|
|
87
|
-
styleUrls: ['./bibliographies-search-confirm.component.scss']
|
|
87
|
+
styleUrls: ['./bibliographies-search-confirm.component.scss'],
|
|
88
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
88
89
|
}]
|
|
89
90
|
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.HeMendeleyService }, { type: i3.HeSearchService }]; }, propDecorators: { search: [{
|
|
90
91
|
type: Input
|
|
@@ -97,4 +98,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
97
98
|
}], closed: [{
|
|
98
99
|
type: Output
|
|
99
100
|
}] } });
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bibliographies-search-confirm.component.js","sourceRoot":"","sources":["../../../../src/bibliographies/bibliographies-search-confirm/bibliographies-search-confirm.component.ts","../../../../src/bibliographies/bibliographies-search-confirm/bibliographies-search-confirm.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, AfterViewInit, Output } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { catchError, debounceTime, distinctUntilChanged, map, switchMap, tap } from 'rxjs/operators';\nimport { Observable, of, Subscription, zip } from 'rxjs';\nimport { Bibliography, Source } from '@hestia-earth/schema';\n\nimport { HeMendeleyService } from '../../mendeley/mendeley.service';\nimport { HeSearchService } from '../../search/search.service';\n\ntype searchByFields = 'title' | 'documentDOI' | 'scopus';\ntype Result = Partial<Source> | Partial<Bibliography>;\n\n@Component({\n  selector: 'he-bibliographies-search-confirm',\n  templateUrl: './bibliographies-search-confirm.component.html',\n  styleUrls: ['./bibliographies-search-confirm.component.scss']\n})\nexport class BibliographiesSearchConfirmComponent implements AfterViewInit, OnDestroy {\n  private subscriptions: Subscription[] = [];\n\n  @Input()\n  private search?: string;\n  @Input()\n  private searchSources = true;\n  @Input()\n  private searchBibliographies = true;\n  @Input()\n  public searchBy: searchByFields = 'title';\n\n  @Output()\n  private closed = new EventEmitter<any>();\n\n  public formGroup: FormGroup;\n  public loading = true;\n\n  public results: Observable<Result[]>;\n  public selectedResult?: Result;\n  public hasResults = false;\n\n  constructor(\n    formBuilder: FormBuilder,\n    private mendeleyService: HeMendeleyService,\n    private searchService: HeSearchService\n  ) {\n    this.formGroup = formBuilder.group({\n      search: ['', Validators.required]\n    });\n    this.results = this.searchControl!.valueChanges.pipe(\n      debounceTime(300),\n      distinctUntilChanged(),\n      tap(() => {\n        this.loading = true;\n        this.selectedResult = undefined;\n      }),\n      switchMap(term => term.length > 1 ? this.runSearch(term) : of([] as any)),\n      tap(values => {\n        this.loading = false;\n        this.hasResults = values.length > 0;\n      })\n    );\n  }\n\n  ngAfterViewInit() {\n    this.searchControl!.setValue(this.search || '');\n  }\n\n  ngOnDestroy() {\n    this.subscriptions.forEach(subscription => subscription.unsubscribe());\n  }\n\n  private get searchLimit() {\n    return this.searchSources && this.searchBibliographies ? 5 : 10;\n  }\n\n  private runSearchSources(term: string) {\n    const fields = [`bibliography.${this.searchBy}`];\n    const includes = ['bibliography.title', 'bibliography.documentDOI', 'bibliography.scopus'];\n    return this.searchSources ? this.searchService.suggestSource(term, this.searchLimit, fields, includes) : of([]);\n  }\n\n  private runSearchBibliographies(term: string) {\n    // scopus\n    const params = this.searchBy === 'title' ? { title: term } : (\n      this.searchBy === 'documentDOI' ? { doi: term } : { scopus: term }\n    );\n    return this.searchBibliographies ? this.mendeleyService.find({ ...params, limit: this.searchLimit }).pipe(\n      map(({ results }: any) => results)\n    ) : of([]);\n  }\n\n  private runSearch(term: string) {\n    return zip(\n      this.runSearchSources(term),\n      this.runSearchBibliographies(term)\n    ).pipe(\n      catchError(() => of([])),\n      map(res => res.flat())\n    );\n  }\n\n  public searchFocus(e: Event) {\n    e.stopPropagation();\n    setTimeout(() => {\n      const inputEvent = new Event('input');\n      e.target?.dispatchEvent(inputEvent);\n    }, 0);\n  }\n\n  public get searchControl() {\n    return this.formGroup.get('search');\n  }\n\n  public resetSearch() {\n    this.searchControl!.setValue('');\n  }\n\n  public selectResult(result: Result) {\n    this.selectedResult = result;\n  }\n\n  public confirm() {\n    this.closed.next(this.selectedResult);\n  }\n\n  public cancel() {\n    this.closed.next(null);\n  }\n}\n","<div class=\"modal is-large is-active\">\n  <div class=\"modal-background\"></div>\n  <div class=\"modal-card\">\n    <header class=\"modal-card-head\">\n      <p class=\"modal-card-title\">Search Bibliographies</p>\n      <button class=\"delete\" aria-label=\"close\" (click)=\"cancel()\"></button>\n    </header>\n    <section class=\"modal-card-body\">\n      <form [formGroup]=\"formGroup\" novalidate>\n        <div class=\"field has-addons\">\n          <div class=\"control is-expanded has-icons-right\">\n            <input class=\"input search-input\"\n              [attr.placeholder]=\"'Search bibliography by ' + searchBy\"\n              formControlName=\"search\" name=\"randomname\" autocomplete=\"off\"\n              (focus)=\"searchFocus($event)\"\n            >\n            <a class=\"icon is-small is-right\" (click)=\"!loading && resetSearch()\" [ngSwitch]=\"loading\">\n              <fa-icon *ngSwitchCase=\"true\" icon=\"spinner\" [pulse]=\"true\"></fa-icon>\n              <fa-icon *ngSwitchCase=\"false\" icon=\"times\"></fa-icon>\n            </a>\n          </div>\n        </div>\n      </form>\n\n      <div class=\"mt-2\">\n        <span [class.is-hidden]=\"loading || !searchControl?.value || hasResults\">\n          No bibliographies found matching query.\n        </span>\n\n        <ul>\n          <li *ngFor=\"let result of results | async\">\n            <a class=\"is-block p-1 search-result\" (click)=\"selectResult(result)\"\n              [class.is-active]=\"selectedResult === result\"\n            >\n              <ngb-highlight\n                [result]=\"result.bibliography ? result.bibliography.title : result.title\"\n                [term]=\"searchControl?.value\"\n              ></ngb-highlight>\n\n              <span class=\"px-1\">-</span>\n\n              <span class=\"px-1\"><i>{{result.name}}</i></span>\n\n              <span class=\"px-1\"\n                *ngIf=\"result.bibliography?.documentDOI || result.documentDOI\"\n              >- <b>documentDOI:</b>\n              </span>\n              <ngb-highlight\n                [result]=\"result.bibliography ? result.bibliography.documentDOI : result.documentDOI\"\n                [term]=\"searchControl?.value\"\n              ></ngb-highlight>\n\n              <span class=\"px-1\"\n                *ngIf=\"result.bibliography?.scopus || result.scopus\"\n              >- <b>scopus:</b>\n              </span>\n              <ngb-highlight\n                [result]=\"result.bibliography?.scopus || result.scopus\"\n                [term]=\"searchControl?.value\"\n              ></ngb-highlight>\n\n              <span>\n                <ng-container *ngTemplateOutlet=\"mendeleyLink; context: {$implicit: result.bibliography ? result.bibliography.mendeleyID : result.mendeleyID}\"></ng-container>\n              </span>\n            </a>\n          </li>\n        </ul>\n      </div>\n    </section>\n    <footer class=\"modal-card-foot\">\n      <button class=\"button is-primary\" (click)=\"confirm()\" [disabled]=\"!selectedResult\">\n        <span>Confirm</span>\n      </button>\n      <button class=\"button\" (click)=\"cancel()\">\n        <span>Close</span>\n      </button>\n    </footer>\n  </div>\n</div>\n\n<ng-template #mendeleyLink let-id>\n  <a *ngIf=\"id\" [href]=\"'https://www.mendeley.com/catalogue/' + id\" target=\"_blank\"\n    (click)=\"$event.stopPropagation()\"\n  >\n    <fa-icon class=\"ml-2\" icon=\"external-link-alt\" size=\"sm\"></fa-icon>\n  </a>\n</ng-template>\n"]}
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bibliographies-search-confirm.component.js","sourceRoot":"","sources":["../../../../src/bibliographies/bibliographies-search-confirm/bibliographies-search-confirm.component.ts","../../../../src/bibliographies/bibliographies-search-confirm/bibliographies-search-confirm.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, AfterViewInit, Output, ChangeDetectionStrategy } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { catchError, debounceTime, distinctUntilChanged, map, switchMap, tap } from 'rxjs/operators';\nimport { Observable, of, Subscription, zip } from 'rxjs';\nimport { Bibliography, Source } from '@hestia-earth/schema';\n\nimport { HeMendeleyService } from '../../mendeley/mendeley.service';\nimport { HeSearchService } from '../../search/search.service';\n\ntype searchByFields = 'title' | 'documentDOI' | 'scopus';\ntype Result = Partial<Source> | Partial<Bibliography>;\n\n@Component({\n  selector: 'he-bibliographies-search-confirm',\n  templateUrl: './bibliographies-search-confirm.component.html',\n  styleUrls: ['./bibliographies-search-confirm.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BibliographiesSearchConfirmComponent implements AfterViewInit, OnDestroy {\n  private subscriptions: Subscription[] = [];\n\n  @Input()\n  private search?: string;\n  @Input()\n  private searchSources = true;\n  @Input()\n  private searchBibliographies = true;\n  @Input()\n  public searchBy: searchByFields = 'title';\n\n  @Output()\n  private closed = new EventEmitter<any>();\n\n  public formGroup: FormGroup;\n  public loading = true;\n\n  public results: Observable<Result[]>;\n  public selectedResult?: Result;\n  public hasResults = false;\n\n  constructor(\n    formBuilder: FormBuilder,\n    private mendeleyService: HeMendeleyService,\n    private searchService: HeSearchService\n  ) {\n    this.formGroup = formBuilder.group({\n      search: ['', Validators.required]\n    });\n    this.results = this.searchControl!.valueChanges.pipe(\n      debounceTime(300),\n      distinctUntilChanged(),\n      tap(() => {\n        this.loading = true;\n        this.selectedResult = undefined;\n      }),\n      switchMap(term => term.length > 1 ? this.runSearch(term) : of([] as any)),\n      tap(values => {\n        this.loading = false;\n        this.hasResults = values.length > 0;\n      })\n    );\n  }\n\n  ngAfterViewInit() {\n    this.searchControl!.setValue(this.search || '');\n  }\n\n  ngOnDestroy() {\n    this.subscriptions.forEach(subscription => subscription.unsubscribe());\n  }\n\n  private get searchLimit() {\n    return this.searchSources && this.searchBibliographies ? 5 : 10;\n  }\n\n  private runSearchSources(term: string) {\n    const fields = [`bibliography.${this.searchBy}`];\n    const includes = ['bibliography.title', 'bibliography.documentDOI', 'bibliography.scopus'];\n    return this.searchSources ? this.searchService.suggestSource(term, this.searchLimit, fields, includes) : of([]);\n  }\n\n  private runSearchBibliographies(term: string) {\n    // scopus\n    const params = this.searchBy === 'title' ? { title: term } : (\n      this.searchBy === 'documentDOI' ? { doi: term } : { scopus: term }\n    );\n    return this.searchBibliographies ? this.mendeleyService.find({ ...params, limit: this.searchLimit }).pipe(\n      map(({ results }: any) => results)\n    ) : of([]);\n  }\n\n  private runSearch(term: string) {\n    return zip(\n      this.runSearchSources(term),\n      this.runSearchBibliographies(term)\n    ).pipe(\n      catchError(() => of([])),\n      map(res => res.flat())\n    );\n  }\n\n  public searchFocus(e: Event) {\n    e.stopPropagation();\n    setTimeout(() => {\n      const inputEvent = new Event('input');\n      e.target?.dispatchEvent(inputEvent);\n    }, 0);\n  }\n\n  public get searchControl() {\n    return this.formGroup.get('search');\n  }\n\n  public resetSearch() {\n    this.searchControl!.setValue('');\n  }\n\n  public selectResult(result: Result) {\n    this.selectedResult = result;\n  }\n\n  public confirm() {\n    this.closed.next(this.selectedResult);\n  }\n\n  public cancel() {\n    this.closed.next(null);\n  }\n}\n","<div class=\"modal is-large is-active\">\n  <div class=\"modal-background\"></div>\n  <div class=\"modal-card\">\n    <header class=\"modal-card-head\">\n      <p class=\"modal-card-title\">Search Bibliographies</p>\n      <button class=\"delete\" aria-label=\"close\" (click)=\"cancel()\"></button>\n    </header>\n    <section class=\"modal-card-body\">\n      <form [formGroup]=\"formGroup\" novalidate>\n        <div class=\"field has-addons\">\n          <div class=\"control is-expanded has-icons-right\">\n            <input class=\"input search-input\"\n              [attr.placeholder]=\"'Search bibliography by ' + searchBy\"\n              formControlName=\"search\" name=\"randomname\" autocomplete=\"off\"\n              (focus)=\"searchFocus($event)\"\n            >\n            <a class=\"icon is-small is-right\" (click)=\"!loading && resetSearch()\" [ngSwitch]=\"loading\">\n              <fa-icon *ngSwitchCase=\"true\" icon=\"spinner\" [pulse]=\"true\"></fa-icon>\n              <fa-icon *ngSwitchCase=\"false\" icon=\"times\"></fa-icon>\n            </a>\n          </div>\n        </div>\n      </form>\n\n      <div class=\"mt-2\">\n        <span [class.is-hidden]=\"loading || !searchControl?.value || hasResults\">\n          No bibliographies found matching query.\n        </span>\n\n        <ul>\n          <li *ngFor=\"let result of results | async\">\n            <a class=\"is-block p-1 search-result\" (click)=\"selectResult(result)\"\n              [class.is-active]=\"selectedResult === result\"\n            >\n              <ngb-highlight\n                [result]=\"result.bibliography ? result.bibliography.title : result.title\"\n                [term]=\"searchControl?.value\"\n              ></ngb-highlight>\n\n              <span class=\"px-1\">-</span>\n\n              <span class=\"px-1\"><i>{{result.name}}</i></span>\n\n              <span class=\"px-1\"\n                *ngIf=\"result.bibliography?.documentDOI || result.documentDOI\"\n              >- <b>documentDOI:</b>\n              </span>\n              <ngb-highlight\n                [result]=\"result.bibliography ? result.bibliography.documentDOI : result.documentDOI\"\n                [term]=\"searchControl?.value\"\n              ></ngb-highlight>\n\n              <span class=\"px-1\"\n                *ngIf=\"result.bibliography?.scopus || result.scopus\"\n              >- <b>scopus:</b>\n              </span>\n              <ngb-highlight\n                [result]=\"result.bibliography?.scopus || result.scopus\"\n                [term]=\"searchControl?.value\"\n              ></ngb-highlight>\n\n              <span>\n                <ng-container *ngTemplateOutlet=\"mendeleyLink; context: {$implicit: result.bibliography ? result.bibliography.mendeleyID : result.mendeleyID}\"></ng-container>\n              </span>\n            </a>\n          </li>\n        </ul>\n      </div>\n    </section>\n    <footer class=\"modal-card-foot\">\n      <button class=\"button is-primary\" (click)=\"confirm()\" [disabled]=\"!selectedResult\">\n        <span>Confirm</span>\n      </button>\n      <button class=\"button\" (click)=\"cancel()\">\n        <span>Close</span>\n      </button>\n    </footer>\n  </div>\n</div>\n\n<ng-template #mendeleyLink let-id>\n  <a *ngIf=\"id\" [href]=\"'https://www.mendeley.com/catalogue/' + id\" target=\"_blank\"\n    (click)=\"$event.stopPropagation()\"\n  >\n    <fa-icon class=\"ml-2\" icon=\"external-link-alt\" size=\"sm\"></fa-icon>\n  </a>\n</ng-template>\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
2
|
import { of } from 'rxjs';
|
|
3
3
|
import { mergeMap } from 'rxjs/operators';
|
|
4
4
|
import { NodeKeyState, isState } from '../node-utils';
|
|
@@ -69,13 +69,14 @@ export class BlankNodeStateComponent {
|
|
|
69
69
|
}
|
|
70
70
|
}
|
|
71
71
|
BlankNodeStateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: BlankNodeStateComponent, deps: [{ token: i1.HeAggregationEngineService }, { token: i2.HeEngineService }], target: i0.ɵɵFactoryTarget.Component });
|
|
72
|
-
BlankNodeStateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: BlankNodeStateComponent, selector: "he-blank-node-state", inputs: { nodeType: "nodeType", dataKey: "dataKey", key: "key", node: "node", state: "state" }, ngImport: i0, template: "<ng-container *bindOnce=\"node\">\n <span *ngFor=\"let star of stars\">*</span>\n <span *ngIf=\"is(NodeKeyState.unchanged)\">\u2020</span>\n\n <ng-container *ngIf=\"showLink\">\n <!-- <span class=\"ml-2\" *ngIf=\"is(NodeKeyState.aggregated)\">\n <ng-container *ngIf=\"aggregatedModel$ | async as model\">\n <ng-container *ngTemplateOutlet=\"docsLink; context: {$implicit: model}\"></ng-container>\n </ng-container>\n </span> -->\n\n <span class=\"ml-2\" *ngIf=\"is(NodeKeyState.added); else showUpdated\">\n <ng-container *ngIf=\"engineModel$ | async as model\">\n <ng-container *ngTemplateOutlet=\"docsLink; context: {$implicit: model}\"></ng-container>\n </ng-container>\n </span>\n </ng-container>\n</ng-container>\n\n<ng-template #showUpdated>\n <span class=\"ml-2\" *ngIf=\"is(NodeKeyState.updated)\">\n <ng-container *ngIf=\"engineModel$ | async as model\">\n <ng-container *ngTemplateOutlet=\"docsLink; context: {$implicit: model}\"></ng-container>\n </ng-container>\n </span>\n</ng-template>\n\n<ng-template #docsLink let-model>\n <a [href]=\"model.apiDocsPath || model.docPath || model.path\" target=\"_blank\"\n (click)=\"$event.stopPropagation()\"\n >\n <span>Docs</span>\n <fa-icon class=\"ml-2\" icon=\"external-link-alt\" size=\"sm\"></fa-icon>\n </a>\n</ng-template>\n", styles: [":host{display:inline-block}\n"], components: [{ type: i3.FaIconComponent, selector: "fa-icon", inputs: ["classes", "icon", "title", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }], directives: [{ type: i4.BindOnceDirective, selector: "[bindOnce]", inputs: ["bindOnce"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i5.AsyncPipe } });
|
|
72
|
+
BlankNodeStateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: BlankNodeStateComponent, selector: "he-blank-node-state", inputs: { nodeType: "nodeType", dataKey: "dataKey", key: "key", node: "node", state: "state" }, ngImport: i0, template: "<ng-container *bindOnce=\"node\">\n <span *ngFor=\"let star of stars\">*</span>\n <span *ngIf=\"is(NodeKeyState.unchanged)\">\u2020</span>\n\n <ng-container *ngIf=\"showLink\">\n <!-- <span class=\"ml-2\" *ngIf=\"is(NodeKeyState.aggregated)\">\n <ng-container *ngIf=\"aggregatedModel$ | async as model\">\n <ng-container *ngTemplateOutlet=\"docsLink; context: {$implicit: model}\"></ng-container>\n </ng-container>\n </span> -->\n\n <span class=\"ml-2\" *ngIf=\"is(NodeKeyState.added); else showUpdated\">\n <ng-container *ngIf=\"engineModel$ | async as model\">\n <ng-container *ngTemplateOutlet=\"docsLink; context: {$implicit: model}\"></ng-container>\n </ng-container>\n </span>\n </ng-container>\n</ng-container>\n\n<ng-template #showUpdated>\n <span class=\"ml-2\" *ngIf=\"is(NodeKeyState.updated)\">\n <ng-container *ngIf=\"engineModel$ | async as model\">\n <ng-container *ngTemplateOutlet=\"docsLink; context: {$implicit: model}\"></ng-container>\n </ng-container>\n </span>\n</ng-template>\n\n<ng-template #docsLink let-model>\n <a [href]=\"model.apiDocsPath || model.docPath || model.path\" target=\"_blank\"\n (click)=\"$event.stopPropagation()\"\n >\n <span>Docs</span>\n <fa-icon class=\"ml-2\" icon=\"external-link-alt\" size=\"sm\"></fa-icon>\n </a>\n</ng-template>\n", styles: [":host{display:inline-block}\n"], components: [{ type: i3.FaIconComponent, selector: "fa-icon", inputs: ["classes", "icon", "title", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }], directives: [{ type: i4.BindOnceDirective, selector: "[bindOnce]", inputs: ["bindOnce"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i5.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
73
73
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: BlankNodeStateComponent, decorators: [{
|
|
74
74
|
type: Component,
|
|
75
75
|
args: [{
|
|
76
76
|
selector: 'he-blank-node-state',
|
|
77
77
|
templateUrl: './blank-node-state.component.html',
|
|
78
|
-
styleUrls: ['./blank-node-state.component.scss']
|
|
78
|
+
styleUrls: ['./blank-node-state.component.scss'],
|
|
79
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
79
80
|
}]
|
|
80
81
|
}], ctorParameters: function () { return [{ type: i1.HeAggregationEngineService }, { type: i2.HeEngineService }]; }, propDecorators: { nodeType: [{
|
|
81
82
|
type: Input
|
|
@@ -88,4 +89,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
88
89
|
}], state: [{
|
|
89
90
|
type: Input
|
|
90
91
|
}] } });
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"blank-node-state.component.js","sourceRoot":"","sources":["../../../../src/common/blank-node-state/blank-node-state.component.ts","../../../../src/common/blank-node-state/blank-node-state.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAE1E,OAAO,EAAE,EAAE,EAAE,MAAM,MAAM,CAAC;AAC1B,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAI1C,OAAO,EAAE,YAAY,EAAa,OAAO,EAAE,MAAM,eAAe,CAAC;AACjE,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;;;;;;;AAQxC,MAAM,OAAO,uBAAuB;IAiBlC,YACU,wBAAoD,EACpD,aAA8B;QAD9B,6BAAwB,GAAxB,wBAAwB,CAA4B;QACpD,kBAAa,GAAb,aAAa,CAAiB;QAJjC,iBAAY,GAAG,YAAY,CAAC;IAK/B,CAAC;IAEE,EAAE,CAAC,KAAmB;QAC3B,OAAO;QACL,gBAAgB;QAChB,CAAC,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,CACrC,IAAI,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IAC3C,CAAC;IAED,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC;YAClC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;YACd,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC;gBAC/B,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;gBACR,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC,gDAAgD;oBACnF,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;oBACX,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC;wBAC7B,CAAC,CAAC,CAAC,CAAC,CAAC;wBACL,CAAC,CAAC,EAAE,CACH;IACL,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAED,IAAY,qBAAqB;QAC/B,OAAO,YAAY,CAAC;YAClB,IAAI,EAAE,IAAI,CAAC,QAAQ;YACnB,QAAQ,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;SAC7D,CAAC,CAAC;IACL,CAAC;IAED,IAAW,gBAAgB;QACzB,OAAO,IAAI,CAAC,wBAAwB,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;IAC1E,CAAC;IAED,IAAY,WAAW;;QACrB,OAAO,YAAY,CAAC;YAClB,KAAK,EAAE,aAAa,IAAI,IAAI,CAAC,IAAK,CAAC,CAAC,CAAC,MAAA,IAAI,CAAC,IAAI,0CAAE,WAAW,CAAE,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS;YAC/E,IAAI,EAAE,MAAM,IAAI,IAAI,CAAC,IAAK,CAAC,CAAC,CAAC,MAAA,IAAI,CAAC,IAAI,0CAAE,IAAI,CAAE,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS;SACjE,CAAC,CAAC;IACL,CAAC;IAED,IAAY,cAAc;;QACxB,OAAO,YAAY,CAAC;YAClB,KAAK,EAAE,CAAC,IAAI,CAAC,IAAK,CAAC,OAAO,CAAC,KAAI,MAAA,IAAI,CAAC,IAAI,0CAAE,IAAI,CAAA,CAAC,CAAC,WAAW,EAAE;YAC7D,QAAQ,EAAE,IAAI,CAAC,GAAG;SACnB,CAAC,CAAC;IACL,CAAC;IAED,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI;QACrD,uBAAuB;QACvB,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QACrF,0BAA0B;QAC1B,QAAQ,CAAC,KAAK,CAAC,EAAE;;YAAC,OAAA,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CACpC,aAAa,IAAI,IAAI,CAAC,IAAK,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,MAAA,IAAI,CAAC,IAAI,0CAAE,WAAW,CAAE,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAC9G,CAAA;SAAA,CAAC,CACH,CAAC;IACJ,CAAC;;qHAhFU,uBAAuB;yGAAvB,uBAAuB,2JChBpC,g1CAmCA;4FDnBa,uBAAuB;kBANnC,SAAS;mBAAC;oBACT,QAAQ,EAAE,qBAAqB;oBAC/B,WAAW,EAAE,mCAAmC;oBAChD,SAAS,EAAE,CAAC,mCAAmC,CAAC;oBAChD,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD;+IAGS,QAAQ;sBADf,KAAK;gBAGE,OAAO;sBADd,KAAK;gBAGE,GAAG;sBADV,KAAK;gBAGC,IAAI;sBADV,KAAK;gBAMC,KAAK;sBADX,KAAK","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\nimport { NodeType } from '@hestia-earth/schema';\nimport { of } from 'rxjs';\nimport { mergeMap } from 'rxjs/operators';\n\nimport { HeAggregationEngineService } from '../../engine/aggregation-engine.service';\nimport { HeEngineService } from '../../engine/engine.service';\nimport { NodeKeyState, blankNode, isState } from '../node-utils';\nimport { filterParams } from '../utils';\n\n@Component({\n  selector: 'he-blank-node-state',\n  templateUrl: './blank-node-state.component.html',\n  styleUrls: ['./blank-node-state.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BlankNodeStateComponent {\n  @Input()\n  private nodeType?: NodeType;\n  @Input()\n  private dataKey?: string;\n  @Input()\n  private key?: string;\n  @Input()\n  public node?: blankNode;\n  /**\n   * Force override state.\n   */\n  @Input()\n  public state?: NodeKeyState;\n\n  public NodeKeyState = NodeKeyState;\n\n  constructor(\n    private aggregationEngineService: HeAggregationEngineService,\n    private engineService: HeEngineService\n  ) { }\n\n  public is(state: NodeKeyState) {\n    return (\n      // forcing state\n      !!this.state && this.state === state\n    ) || isState(this.node, this.key, state);\n  }\n\n  public get stars() {\n    return this.is(NodeKeyState.deleted)\n      ? [0, 1, 2, 3]\n      : this.is(NodeKeyState.updated)\n      ? [0, 1]\n      : this.is(NodeKeyState.aggregated) // handle here because aggregated can be updated\n      ? [0, 1, 2]\n      : this.is(NodeKeyState.added)\n      ? [0]\n      : []\n      ;\n  }\n\n  public get showLink() {\n    return !!this.dataKey;\n  }\n\n  private get aggregatedModelParams() {\n    return filterParams({\n      type: this.nodeType,\n      dataPath: [this.dataKey, this.key].filter(Boolean).join('.')\n    });\n  }\n\n  public get aggregatedModel$() {\n    return this.aggregationEngineService.model$(this.aggregatedModelParams);\n  }\n\n  private get modelParams() {\n    return filterParams({\n      model: 'methodModel' in this.node! ? this.node?.methodModel!['@id'] : undefined,\n      term: 'term' in this.node! ? this.node?.term!['@id'] : undefined\n    });\n  }\n\n  private get modelKeyParams() {\n    return filterParams({\n      model: (this.node!['@type'] || this.node?.type).toLowerCase(),\n      modelKey: this.key\n    });\n  }\n\n  public get engineModel$() {\n    return this.engineService.model$(this.modelParams).pipe(\n      // fallback to modelKey\n      mergeMap(value => value ? of(value) : this.engineService.model$(this.modelKeyParams)),\n      // defaults to methodModel\n      mergeMap(value => value ? of(value) : (\n        'methodModel' in this.node! ? this.engineService.model$({ model: this.node?.methodModel!['@id'] }) : of(null)\n      ))\n    );\n  }\n}\n","<ng-container *bindOnce=\"node\">\n  <span *ngFor=\"let star of stars\">*</span>\n  <span *ngIf=\"is(NodeKeyState.unchanged)\">†</span>\n\n  <ng-container *ngIf=\"showLink\">\n    <!-- <span class=\"ml-2\" *ngIf=\"is(NodeKeyState.aggregated)\">\n      <ng-container *ngIf=\"aggregatedModel$ | async as model\">\n        <ng-container *ngTemplateOutlet=\"docsLink; context: {$implicit: model}\"></ng-container>\n      </ng-container>\n    </span> -->\n\n    <span class=\"ml-2\" *ngIf=\"is(NodeKeyState.added); else showUpdated\">\n      <ng-container *ngIf=\"engineModel$ | async as model\">\n        <ng-container *ngTemplateOutlet=\"docsLink; context: {$implicit: model}\"></ng-container>\n      </ng-container>\n    </span>\n  </ng-container>\n</ng-container>\n\n<ng-template #showUpdated>\n  <span class=\"ml-2\" *ngIf=\"is(NodeKeyState.updated)\">\n    <ng-container *ngIf=\"engineModel$ | async as model\">\n      <ng-container *ngTemplateOutlet=\"docsLink; context: {$implicit: model}\"></ng-container>\n    </ng-container>\n  </span>\n</ng-template>\n\n<ng-template #docsLink let-model>\n  <a [href]=\"model.apiDocsPath || model.docPath || model.path\" target=\"_blank\"\n    (click)=\"$event.stopPropagation()\"\n  >\n    <span>Docs</span>\n    <fa-icon class=\"ml-2\" icon=\"external-link-alt\" size=\"sm\"></fa-icon>\n  </a>\n</ng-template>\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
2
|
import { DataState } from '@hestia-earth/api';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/common";
|
|
@@ -13,13 +13,14 @@ export class BlankNodeStateNoticeComponent {
|
|
|
13
13
|
}
|
|
14
14
|
}
|
|
15
15
|
BlankNodeStateNoticeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: BlankNodeStateNoticeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
16
|
-
BlankNodeStateNoticeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: BlankNodeStateNoticeComponent, selector: "he-blank-node-state-notice", inputs: { dataState: "dataState", showAggregated: "showAggregated", showDeleted: "showDeleted", showUnchanged: "showUnchanged" }, ngImport: i0, template: "<p class=\"is-size-7 is-italic\" *ngIf=\"show\">\n <span>Recalculations:</span>\n <span class=\"pl-1 notice-data-added\">* Data Added</span>\n <span class=\"pl-1 notice-data-updated\">** Data Updated</span>\n <span *ngIf=\"showAggregated\" class=\"pl-1 notice-data-aggregated\">*** Data Aggregated</span>\n <span *ngIf=\"showDeleted\" class=\"pl-1 notice-data-deleted\">**** Data Deleted</span>\n <span *ngIf=\"showUnchanged\" class=\"pl-1 notice-data-unchaged\">\u2020 Data Unchanged</span>\n</p>\n", styles: [""], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
16
|
+
BlankNodeStateNoticeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: BlankNodeStateNoticeComponent, selector: "he-blank-node-state-notice", inputs: { dataState: "dataState", showAggregated: "showAggregated", showDeleted: "showDeleted", showUnchanged: "showUnchanged" }, ngImport: i0, template: "<p class=\"is-size-7 is-italic\" *ngIf=\"show\">\n <span>Recalculations:</span>\n <span class=\"pl-1 notice-data-added\">* Data Added</span>\n <span class=\"pl-1 notice-data-updated\">** Data Updated</span>\n <span *ngIf=\"showAggregated\" class=\"pl-1 notice-data-aggregated\">*** Data Aggregated</span>\n <span *ngIf=\"showDeleted\" class=\"pl-1 notice-data-deleted\">**** Data Deleted</span>\n <span *ngIf=\"showUnchanged\" class=\"pl-1 notice-data-unchaged\">\u2020 Data Unchanged</span>\n</p>\n", styles: [""], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
17
17
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: BlankNodeStateNoticeComponent, decorators: [{
|
|
18
18
|
type: Component,
|
|
19
19
|
args: [{
|
|
20
20
|
selector: 'he-blank-node-state-notice',
|
|
21
21
|
templateUrl: './blank-node-state-notice.component.html',
|
|
22
|
-
styleUrls: ['./blank-node-state-notice.component.scss']
|
|
22
|
+
styleUrls: ['./blank-node-state-notice.component.scss'],
|
|
23
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
23
24
|
}]
|
|
24
25
|
}], propDecorators: { dataState: [{
|
|
25
26
|
type: Input
|
|
@@ -30,4 +31,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
30
31
|
}], showUnchanged: [{
|
|
31
32
|
type: Input
|
|
32
33
|
}] } });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxhbmstbm9kZS1zdGF0ZS1ub3RpY2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbW1vbi9ibGFuay1ub2RlLXN0YXRlLW5vdGljZS9ibGFuay1ub2RlLXN0YXRlLW5vdGljZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9zcmMvY29tbW9uL2JsYW5rLW5vZGUtc3RhdGUtbm90aWNlL2JsYW5rLW5vZGUtc3RhdGUtbm90aWNlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7O0FBUTlDLE1BQU0sT0FBTyw2QkFBNkI7SUFOMUM7UUFVUyxtQkFBYyxHQUFHLElBQUksQ0FBQztRQUV0QixnQkFBVyxHQUFHLEtBQUssQ0FBQztRQUVwQixrQkFBYSxHQUFHLEtBQUssQ0FBQztLQUs5QjtJQUhDLElBQVcsSUFBSTtRQUNiLE9BQU8sQ0FBQyxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxTQUFTLEtBQUssU0FBUyxDQUFDLFlBQVksQ0FBQztJQUN0RSxDQUFDOzsySEFaVSw2QkFBNkI7K0dBQTdCLDZCQUE2QixvTUNUMUMsMmZBUUE7NEZEQ2EsNkJBQTZCO2tCQU56QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSw0QkFBNEI7b0JBQ3RDLFdBQVcsRUFBRSwwQ0FBMEM7b0JBQ3ZELFNBQVMsRUFBRSxDQUFDLDBDQUEwQyxDQUFDO29CQUN2RCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQ7OEJBR1MsU0FBUztzQkFEaEIsS0FBSztnQkFHQyxjQUFjO3NCQURwQixLQUFLO2dCQUdDLFdBQVc7c0JBRGpCLEtBQUs7Z0JBR0MsYUFBYTtzQkFEbkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEYXRhU3RhdGUgfSBmcm9tICdAaGVzdGlhLWVhcnRoL2FwaSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2hlLWJsYW5rLW5vZGUtc3RhdGUtbm90aWNlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2JsYW5rLW5vZGUtc3RhdGUtbm90aWNlLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYmxhbmstbm9kZS1zdGF0ZS1ub3RpY2UuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgQmxhbmtOb2RlU3RhdGVOb3RpY2VDb21wb25lbnQge1xuICBASW5wdXQoKVxuICBwcml2YXRlIGRhdGFTdGF0ZT86IERhdGFTdGF0ZTtcbiAgQElucHV0KClcbiAgcHVibGljIHNob3dBZ2dyZWdhdGVkID0gdHJ1ZTtcbiAgQElucHV0KClcbiAgcHVibGljIHNob3dEZWxldGVkID0gZmFsc2U7XG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBzaG93VW5jaGFuZ2VkID0gZmFsc2U7XG5cbiAgcHVibGljIGdldCBzaG93KCkge1xuICAgIHJldHVybiAhdGhpcy5kYXRhU3RhdGUgfHwgdGhpcy5kYXRhU3RhdGUgPT09IERhdGFTdGF0ZS5yZWNhbGN1bGF0ZWQ7XG4gIH1cbn1cbiIsIjxwIGNsYXNzPVwiaXMtc2l6ZS03IGlzLWl0YWxpY1wiICpuZ0lmPVwic2hvd1wiPlxuICA8c3Bhbj5SZWNhbGN1bGF0aW9uczo8L3NwYW4+XG4gIDxzcGFuIGNsYXNzPVwicGwtMSBub3RpY2UtZGF0YS1hZGRlZFwiPiogRGF0YSBBZGRlZDwvc3Bhbj5cbiAgPHNwYW4gY2xhc3M9XCJwbC0xIG5vdGljZS1kYXRhLXVwZGF0ZWRcIj4qKiBEYXRhIFVwZGF0ZWQ8L3NwYW4+XG4gIDxzcGFuICpuZ0lmPVwic2hvd0FnZ3JlZ2F0ZWRcIiBjbGFzcz1cInBsLTEgbm90aWNlLWRhdGEtYWdncmVnYXRlZFwiPioqKiBEYXRhIEFnZ3JlZ2F0ZWQ8L3NwYW4+XG4gIDxzcGFuICpuZ0lmPVwic2hvd0RlbGV0ZWRcIiBjbGFzcz1cInBsLTEgbm90aWNlLWRhdGEtZGVsZXRlZFwiPioqKiogRGF0YSBEZWxldGVkPC9zcGFuPlxuICA8c3BhbiAqbmdJZj1cInNob3dVbmNoYW5nZWRcIiBjbGFzcz1cInBsLTEgbm90aWNlLWRhdGEtdW5jaGFnZWRcIj7igKAgRGF0YSBVbmNoYW5nZWQ8L3NwYW4+XG48L3A+XG4iXX0=
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
2
|
import { emptyValue } from '@hestia-earth/utils/dist/term';
|
|
3
3
|
import { DeltaDisplayType, delta, customDeltaFuncs } from '@hestia-earth/utils/dist/delta';
|
|
4
4
|
import { evaluateSuccess } from '../delta-utils';
|
|
@@ -22,13 +22,14 @@ export class BlankNodeValueDeltaComponent {
|
|
|
22
22
|
}
|
|
23
23
|
}
|
|
24
24
|
BlankNodeValueDeltaComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: BlankNodeValueDeltaComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
25
|
-
BlankNodeValueDeltaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: BlankNodeValueDeltaComponent, selector: "he-blank-node-value-delta", inputs: { value: "value", originalValue: "originalValue", displayType: "displayType" }, ngImport: i0, template: "<small [class.is-hidden]=\"hide\">\n <span class=\"has-text-{{color}}\">\n <span *ngIf=\"delta > 0\">+</span>\n <ng-container [ngSwitch]=\"displayType\">\n <ng-container *ngSwitchCase=\"DeltaDisplayType.absolute\">\n <span *bindOnce=\"delta\">{{delta | precision:3}}</span>\n </ng-container>\n <ng-container *ngSwitchCase=\"DeltaDisplayType.percent\">\n <span *bindOnce=\"delta\">{{delta | number:'1.0-2'}}</span>\n <span>%</span>\n </ng-container>\n </ng-container>\n </span>\n</small>\n", styles: [""], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i2.BindOnceDirective, selector: "[bindOnce]", inputs: ["bindOnce"] }], pipes: { "precision": i3.PrecisionPipe, "number": i1.DecimalPipe } });
|
|
25
|
+
BlankNodeValueDeltaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: BlankNodeValueDeltaComponent, selector: "he-blank-node-value-delta", inputs: { value: "value", originalValue: "originalValue", displayType: "displayType" }, ngImport: i0, template: "<small [class.is-hidden]=\"hide\">\n <span class=\"has-text-{{color}}\">\n <span *ngIf=\"delta > 0\">+</span>\n <ng-container [ngSwitch]=\"displayType\">\n <ng-container *ngSwitchCase=\"DeltaDisplayType.absolute\">\n <span *bindOnce=\"delta\">{{delta | precision:3}}</span>\n </ng-container>\n <ng-container *ngSwitchCase=\"DeltaDisplayType.percent\">\n <span *bindOnce=\"delta\">{{delta | number:'1.0-2'}}</span>\n <span>%</span>\n </ng-container>\n </ng-container>\n </span>\n</small>\n", styles: [""], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i2.BindOnceDirective, selector: "[bindOnce]", inputs: ["bindOnce"] }], pipes: { "precision": i3.PrecisionPipe, "number": i1.DecimalPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
26
26
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: BlankNodeValueDeltaComponent, decorators: [{
|
|
27
27
|
type: Component,
|
|
28
28
|
args: [{
|
|
29
29
|
selector: 'he-blank-node-value-delta',
|
|
30
30
|
templateUrl: './blank-node-value-delta.component.html',
|
|
31
|
-
styleUrls: ['./blank-node-value-delta.component.scss']
|
|
31
|
+
styleUrls: ['./blank-node-value-delta.component.scss'],
|
|
32
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
32
33
|
}]
|
|
33
34
|
}], propDecorators: { value: [{
|
|
34
35
|
type: Input
|
|
@@ -37,4 +38,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
37
38
|
}], displayType: [{
|
|
38
39
|
type: Input
|
|
39
40
|
}] } });
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxhbmstbm9kZS12YWx1ZS1kZWx0YS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tbW9uL2JsYW5rLW5vZGUtdmFsdWUtZGVsdGEvYmxhbmstbm9kZS12YWx1ZS1kZWx0YS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9zcmMvY29tbW9uL2JsYW5rLW5vZGUtdmFsdWUtZGVsdGEvYmxhbmstbm9kZS12YWx1ZS1kZWx0YS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGdCQUFnQixFQUFFLEtBQUssRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBRTNGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7QUFRakQsTUFBTSxPQUFPLDRCQUE0QjtJQU56QztRQVlTLGdCQUFXLEdBQUcsZ0JBQWdCLENBQUMsT0FBTyxDQUFDO1FBRXZDLHFCQUFnQixHQUFHLGdCQUFnQixDQUFDO0tBYTVDO0lBWEMsSUFBVyxJQUFJO1FBQ2IsT0FBTyxVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLFVBQVUsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDbEUsQ0FBQztJQUVELElBQVcsS0FBSztRQUNkLE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsV0FBVyxFQUFFLGdCQUFnQixDQUFDLENBQUM7SUFDbkYsQ0FBQztJQUVELElBQVcsS0FBSztRQUNkLE9BQU8sSUFBSSxDQUFDLFdBQVcsS0FBSyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztJQUMxRixDQUFDOzswSEFwQlUsNEJBQTRCOzhHQUE1Qiw0QkFBNEIseUpDWnpDLDhoQkFjQTs0RkRGYSw0QkFBNEI7a0JBTnhDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLDJCQUEyQjtvQkFDckMsV0FBVyxFQUFFLHlDQUF5QztvQkFDdEQsU0FBUyxFQUFFLENBQUMseUNBQXlDLENBQUM7b0JBQ3RELGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNoRDs4QkFHUyxLQUFLO3NCQURaLEtBQUs7Z0JBR0UsYUFBYTtzQkFEcEIsS0FBSztnQkFHQyxXQUFXO3NCQURqQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGVtcHR5VmFsdWUgfSBmcm9tICdAaGVzdGlhLWVhcnRoL3V0aWxzL2Rpc3QvdGVybSc7XG5pbXBvcnQgeyBEZWx0YURpc3BsYXlUeXBlLCBkZWx0YSwgY3VzdG9tRGVsdGFGdW5jcyB9IGZyb20gJ0BoZXN0aWEtZWFydGgvdXRpbHMvZGlzdC9kZWx0YSc7XG5cbmltcG9ydCB7IGV2YWx1YXRlU3VjY2VzcyB9IGZyb20gJy4uL2RlbHRhLXV0aWxzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnaGUtYmxhbmstbm9kZS12YWx1ZS1kZWx0YScsXG4gIHRlbXBsYXRlVXJsOiAnLi9ibGFuay1ub2RlLXZhbHVlLWRlbHRhLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYmxhbmstbm9kZS12YWx1ZS1kZWx0YS5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBCbGFua05vZGVWYWx1ZURlbHRhQ29tcG9uZW50IHtcbiAgQElucHV0KClcbiAgcHJpdmF0ZSB2YWx1ZTogYW55O1xuICBASW5wdXQoKVxuICBwcml2YXRlIG9yaWdpbmFsVmFsdWU6IGFueTtcbiAgQElucHV0KClcbiAgcHVibGljIGRpc3BsYXlUeXBlID0gRGVsdGFEaXNwbGF5VHlwZS5wZXJjZW50O1xuXG4gIHB1YmxpYyBEZWx0YURpc3BsYXlUeXBlID0gRGVsdGFEaXNwbGF5VHlwZTtcblxuICBwdWJsaWMgZ2V0IGhpZGUoKSB7XG4gICAgcmV0dXJuIGVtcHR5VmFsdWUodGhpcy52YWx1ZSkgfHwgZW1wdHlWYWx1ZSh0aGlzLm9yaWdpbmFsVmFsdWUpO1xuICB9XG5cbiAgcHVibGljIGdldCBkZWx0YSgpIHtcbiAgICByZXR1cm4gZGVsdGEodGhpcy52YWx1ZSwgdGhpcy5vcmlnaW5hbFZhbHVlLCB0aGlzLmRpc3BsYXlUeXBlLCBjdXN0b21EZWx0YUZ1bmNzKTtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgY29sb3IoKSB7XG4gICAgcmV0dXJuIHRoaXMuZGlzcGxheVR5cGUgPT09IERlbHRhRGlzcGxheVR5cGUucGVyY2VudCA/IGV2YWx1YXRlU3VjY2Vzcyh0aGlzLmRlbHRhKSA6ICcnO1xuICB9XG59XG4iLCI8c21hbGwgW2NsYXNzLmlzLWhpZGRlbl09XCJoaWRlXCI+XG4gIDxzcGFuIGNsYXNzPVwiaGFzLXRleHQte3tjb2xvcn19XCI+XG4gICAgPHNwYW4gKm5nSWY9XCJkZWx0YSA+IDBcIj4rPC9zcGFuPlxuICAgIDxuZy1jb250YWluZXIgW25nU3dpdGNoXT1cImRpc3BsYXlUeXBlXCI+XG4gICAgICA8bmctY29udGFpbmVyICpuZ1N3aXRjaENhc2U9XCJEZWx0YURpc3BsYXlUeXBlLmFic29sdXRlXCI+XG4gICAgICAgIDxzcGFuICpiaW5kT25jZT1cImRlbHRhXCI+e3tkZWx0YSB8IHByZWNpc2lvbjozfX08L3NwYW4+XG4gICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgIDxuZy1jb250YWluZXIgKm5nU3dpdGNoQ2FzZT1cIkRlbHRhRGlzcGxheVR5cGUucGVyY2VudFwiPlxuICAgICAgICA8c3BhbiAqYmluZE9uY2U9XCJkZWx0YVwiPnt7ZGVsdGEgfCBudW1iZXI6JzEuMC0yJ319PC9zcGFuPlxuICAgICAgICA8c3Bhbj4lPC9zcGFuPlxuICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgPC9uZy1jb250YWluZXI+XG4gIDwvc3Bhbj5cbjwvc21hbGw+XG4iXX0=
|
|
@@ -3,6 +3,7 @@ import { CommonModule } from '@angular/common';
|
|
|
3
3
|
import { FormsModule } from '@angular/forms';
|
|
4
4
|
import { RouterModule } from '@angular/router';
|
|
5
5
|
import { HeFontawesomeModule } from '../fontawesome/fontawesome.module';
|
|
6
|
+
import { IssueConfirmComponent } from './issue-confirm/issue-confirm.component';
|
|
6
7
|
import { SocialTagsComponent } from './social-tags/social-tags.component';
|
|
7
8
|
import { ToastComponent } from './toast/toast.component';
|
|
8
9
|
import { BindOnceDirective } from './bind-once.directive';
|
|
@@ -14,6 +15,7 @@ import { PluralizePipe } from './pluralize.pipe';
|
|
|
14
15
|
import { PrecisionPipe } from './precision.pipe';
|
|
15
16
|
import * as i0 from "@angular/core";
|
|
16
17
|
const components = [
|
|
18
|
+
IssueConfirmComponent,
|
|
17
19
|
SocialTagsComponent,
|
|
18
20
|
ToastComponent,
|
|
19
21
|
BindOnceDirective,
|
|
@@ -27,7 +29,8 @@ const components = [
|
|
|
27
29
|
export class HeCommonLightModule {
|
|
28
30
|
}
|
|
29
31
|
HeCommonLightModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: HeCommonLightModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
30
|
-
HeCommonLightModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: HeCommonLightModule, declarations: [
|
|
32
|
+
HeCommonLightModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: HeCommonLightModule, declarations: [IssueConfirmComponent,
|
|
33
|
+
SocialTagsComponent,
|
|
31
34
|
ToastComponent,
|
|
32
35
|
BindOnceDirective,
|
|
33
36
|
DefaultPipe,
|
|
@@ -36,7 +39,8 @@ HeCommonLightModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", ver
|
|
|
36
39
|
PluralizePipe,
|
|
37
40
|
KeyToLabelPipe,
|
|
38
41
|
PrecisionPipe], imports: [CommonModule, FormsModule, RouterModule,
|
|
39
|
-
HeFontawesomeModule], exports: [HeFontawesomeModule,
|
|
42
|
+
HeFontawesomeModule], exports: [HeFontawesomeModule, IssueConfirmComponent,
|
|
43
|
+
SocialTagsComponent,
|
|
40
44
|
ToastComponent,
|
|
41
45
|
BindOnceDirective,
|
|
42
46
|
DefaultPipe,
|
|
@@ -63,4 +67,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
63
67
|
]
|
|
64
68
|
}]
|
|
65
69
|
}] });
|
|
66
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmxpZ2h0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tb24vY29tbW9uLmxpZ2h0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRS9DLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBRXhFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQ2hGLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQzFFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNyRCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ3ZDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNqRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7O0FBRWpELE1BQU0sVUFBVSxHQUFHO0lBQ2pCLHFCQUFxQjtJQUNyQixtQkFBbUI7SUFDbkIsY0FBYztJQUNkLGlCQUFpQjtJQUNqQixXQUFXO0lBQ1gsWUFBWTtJQUNaLFFBQVE7SUFDUixhQUFhO0lBQ2IsY0FBYztJQUNkLGFBQWE7Q0FDZCxDQUFDO0FBYUYsTUFBTSxPQUFPLG1CQUFtQjs7aUhBQW5CLG1CQUFtQjtrSEFBbkIsbUJBQW1CLGlCQXZCOUIscUJBQXFCO1FBQ3JCLG1CQUFtQjtRQUNuQixjQUFjO1FBQ2QsaUJBQWlCO1FBQ2pCLFdBQVc7UUFDWCxZQUFZO1FBQ1osUUFBUTtRQUNSLGFBQWE7UUFDYixjQUFjO1FBQ2QsYUFBYSxhQVVYLFlBQVksRUFBRSxXQUFXLEVBQUUsWUFBWTtRQUN2QyxtQkFBbUIsYUFMbkIsbUJBQW1CLEVBZnJCLHFCQUFxQjtRQUNyQixtQkFBbUI7UUFDbkIsY0FBYztRQUNkLGlCQUFpQjtRQUNqQixXQUFXO1FBQ1gsWUFBWTtRQUNaLFFBQVE7UUFDUixhQUFhO1FBQ2IsY0FBYztRQUNkLGFBQWE7a0hBY0YsbUJBQW1CLFlBTHJCO1lBQ1AsWUFBWSxFQUFFLFdBQVcsRUFBRSxZQUFZO1lBQ3ZDLG1CQUFtQjtTQUNwQixFQU5DLG1CQUFtQjs0RkFRVixtQkFBbUI7a0JBWC9CLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLFVBQVU7b0JBQ3hCLE9BQU8sRUFBRTt3QkFDUCxtQkFBbUI7d0JBQ25CLEdBQUcsVUFBVTtxQkFDZDtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWSxFQUFFLFdBQVcsRUFBRSxZQUFZO3dCQUN2QyxtQkFBbUI7cUJBQ3BCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IFJvdXRlck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5cbmltcG9ydCB7IEhlRm9udGF3ZXNvbWVNb2R1bGUgfSBmcm9tICcuLi9mb250YXdlc29tZS9mb250YXdlc29tZS5tb2R1bGUnO1xuXG5pbXBvcnQgeyBJc3N1ZUNvbmZpcm1Db21wb25lbnQgfSBmcm9tICcuL2lzc3VlLWNvbmZpcm0vaXNzdWUtY29uZmlybS5jb21wb25lbnQnO1xuaW1wb3J0IHsgU29jaWFsVGFnc0NvbXBvbmVudCB9IGZyb20gJy4vc29jaWFsLXRhZ3Mvc29jaWFsLXRhZ3MuY29tcG9uZW50JztcbmltcG9ydCB7IFRvYXN0Q29tcG9uZW50IH0gZnJvbSAnLi90b2FzdC90b2FzdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQmluZE9uY2VEaXJlY3RpdmUgfSBmcm9tICcuL2JpbmQtb25jZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRGVmYXVsdFBpcGUgfSBmcm9tICcuL2RlZmF1bHQucGlwZSc7XG5pbXBvcnQgeyBFbGxpcHNpc1BpcGUgfSBmcm9tICcuL2VsbGlwc2lzLnBpcGUnO1xuaW1wb3J0IHsgS2V5VG9MYWJlbFBpcGUgfSBmcm9tICcuL2tleS10by1sYWJlbC5waXBlJztcbmltcG9ydCB7IEtleXNQaXBlIH0gZnJvbSAnLi9rZXlzLnBpcGUnO1xuaW1wb3J0IHsgUGx1cmFsaXplUGlwZSB9IGZyb20gJy4vcGx1cmFsaXplLnBpcGUnO1xuaW1wb3J0IHsgUHJlY2lzaW9uUGlwZSB9IGZyb20gJy4vcHJlY2lzaW9uLnBpcGUnO1xuXG5jb25zdCBjb21wb25lbnRzID0gW1xuICBJc3N1ZUNvbmZpcm1Db21wb25lbnQsXG4gIFNvY2lhbFRhZ3NDb21wb25lbnQsXG4gIFRvYXN0Q29tcG9uZW50LFxuICBCaW5kT25jZURpcmVjdGl2ZSxcbiAgRGVmYXVsdFBpcGUsXG4gIEVsbGlwc2lzUGlwZSxcbiAgS2V5c1BpcGUsXG4gIFBsdXJhbGl6ZVBpcGUsXG4gIEtleVRvTGFiZWxQaXBlLFxuICBQcmVjaXNpb25QaXBlXG5dO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IGNvbXBvbmVudHMsXG4gIGV4cG9ydHM6IFtcbiAgICBIZUZvbnRhd2Vzb21lTW9kdWxlLFxuICAgIC4uLmNvbXBvbmVudHNcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGUsIFJvdXRlck1vZHVsZSxcbiAgICBIZUZvbnRhd2Vzb21lTW9kdWxlXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgSGVDb21tb25MaWdodE1vZHVsZSB7IH1cbiJdfQ==
|