@ngageoint/mage.web-core-lib 6.6.1 → 6.6.3
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/angular-cli/builders/fesm-amd.js +64 -36
- package/angular-cli/builders/fesm-amd.js.map +1 -1
- package/angular-cli/schematics/plugin-library/index.js.map +1 -1
- package/common/xhr-img.component.d.ts +1 -1
- package/{esm2020 → esm2022}/common/mage-common.module.mjs +5 -5
- package/esm2022/common/xhr-img.component.mjs +105 -0
- package/esm2022/feed/feed.service.mjs +105 -0
- package/{esm2020 → esm2022}/mage-core-lib.module.mjs +5 -5
- package/esm2022/paging/paging.cdk-data-source.adapter.mjs +52 -0
- package/esm2022/paging/paging.model.mjs +25 -0
- package/esm2022/static-icon/static-icon-form-field/static-icon-form-field.component.mjs +146 -0
- package/esm2022/static-icon/static-icon-img/static-icon-img.component.mjs +36 -0
- package/{esm2020 → esm2022}/static-icon/static-icon-select/static-icon-select.component.mjs +16 -15
- package/esm2022/static-icon/static-icon.model.mjs +10 -0
- package/esm2022/static-icon/static-icon.module.mjs +54 -0
- package/esm2022/static-icon/static-icon.service.mjs +82 -0
- package/esm2022/user/user-read.service.mjs +34 -0
- package/esm2022/user/user-select/user-select.component.mjs +159 -0
- package/esm2022/user/user.module.mjs +64 -0
- package/feed/feed.model.d.ts +3 -3
- package/feed/feed.model.d.ts.map +1 -1
- package/{fesm2020 → fesm2022}/ngageoint-mage.web-core-lib-common.mjs +21 -20
- package/{fesm2020 → fesm2022}/ngageoint-mage.web-core-lib-common.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/ngageoint-mage.web-core-lib-feed.mjs +4 -4
- package/{fesm2015 → fesm2022}/ngageoint-mage.web-core-lib-feed.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/ngageoint-mage.web-core-lib-paging.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/ngageoint-mage.web-core-lib-static-icon.mjs +61 -58
- package/fesm2022/ngageoint-mage.web-core-lib-static-icon.mjs.map +1 -0
- package/{fesm2020 → fesm2022}/ngageoint-mage.web-core-lib-user.mjs +45 -45
- package/fesm2022/ngageoint-mage.web-core-lib-user.mjs.map +1 -0
- package/{fesm2020 → fesm2022}/ngageoint-mage.web-core-lib.mjs +4 -4
- package/{fesm2015 → fesm2022}/ngageoint-mage.web-core-lib.mjs.map +1 -1
- package/package.json +26 -46
- package/static-icon/static-icon-form-field/static-icon-form-field.component.d.ts +1 -1
- package/static-icon/static-icon-img/static-icon-img.component.d.ts +1 -1
- package/static-icon/static-icon-select/static-icon-select.component.d.ts +1 -1
- package/static-icon/static-icon.model.d.ts +1 -1
- package/static-icon/static-icon.model.d.ts.map +1 -1
- package/user/user-read.service.d.ts +1 -1
- package/user/user-read.service.d.ts.map +1 -1
- package/user/user-select/user-select.component.d.ts +1 -1
- package/angular-cli/README.md +0 -30
- package/esm2020/common/xhr-img.component.mjs +0 -104
- package/esm2020/feed/feed.service.mjs +0 -105
- package/esm2020/paging/paging.cdk-data-source.adapter.mjs +0 -52
- package/esm2020/paging/paging.model.mjs +0 -25
- package/esm2020/static-icon/static-icon-form-field/static-icon-form-field.component.mjs +0 -145
- package/esm2020/static-icon/static-icon-img/static-icon-img.component.mjs +0 -35
- package/esm2020/static-icon/static-icon.model.mjs +0 -10
- package/esm2020/static-icon/static-icon.module.mjs +0 -54
- package/esm2020/static-icon/static-icon.service.mjs +0 -82
- package/esm2020/user/user-read.service.mjs +0 -34
- package/esm2020/user/user-select/user-select.component.mjs +0 -159
- package/esm2020/user/user.module.mjs +0 -64
- package/fesm2015/ngageoint-mage.web-core-lib-common.mjs +0 -142
- package/fesm2015/ngageoint-mage.web-core-lib-common.mjs.map +0 -1
- package/fesm2015/ngageoint-mage.web-core-lib-feed.mjs +0 -114
- package/fesm2015/ngageoint-mage.web-core-lib-paging.mjs.map +0 -1
- package/fesm2015/ngageoint-mage.web-core-lib-static-icon.mjs +0 -392
- package/fesm2015/ngageoint-mage.web-core-lib-static-icon.mjs.map +0 -1
- package/fesm2015/ngageoint-mage.web-core-lib-user.mjs +0 -273
- package/fesm2015/ngageoint-mage.web-core-lib-user.mjs.map +0 -1
- package/fesm2015/ngageoint-mage.web-core-lib.mjs +0 -32
- package/fesm2020/ngageoint-mage.web-core-lib-event.mjs +0 -10
- package/fesm2020/ngageoint-mage.web-core-lib-event.mjs.map +0 -1
- package/fesm2020/ngageoint-mage.web-core-lib-feed.mjs.map +0 -1
- package/fesm2020/ngageoint-mage.web-core-lib-paging.mjs +0 -83
- package/fesm2020/ngageoint-mage.web-core-lib-plugin.mjs +0 -4
- package/fesm2020/ngageoint-mage.web-core-lib-plugin.mjs.map +0 -1
- package/fesm2020/ngageoint-mage.web-core-lib-static-icon.mjs.map +0 -1
- package/fesm2020/ngageoint-mage.web-core-lib-user.mjs.map +0 -1
- package/fesm2020/ngageoint-mage.web-core-lib.mjs.map +0 -1
- /package/{esm2020 → esm2022}/common/ngageoint-mage.web-core-lib-common.mjs +0 -0
- /package/{esm2020 → esm2022}/common/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/event/event-read.service.mjs +0 -0
- /package/{esm2020 → esm2022}/event/event.model.mjs +0 -0
- /package/{esm2020 → esm2022}/event/ngageoint-mage.web-core-lib-event.mjs +0 -0
- /package/{esm2020 → esm2022}/event/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/feed/feed.model.mjs +0 -0
- /package/{esm2020 → esm2022}/feed/ngageoint-mage.web-core-lib-feed.mjs +0 -0
- /package/{esm2020 → esm2022}/feed/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/ngageoint-mage.web-core-lib.mjs +0 -0
- /package/{esm2020 → esm2022}/paging/ngageoint-mage.web-core-lib-paging.mjs +0 -0
- /package/{esm2020 → esm2022}/paging/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/plugin/ngageoint-mage.web-core-lib-plugin.mjs +0 -0
- /package/{esm2020 → esm2022}/plugin/plugin.model.mjs +0 -0
- /package/{esm2020 → esm2022}/plugin/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/static-icon/ngageoint-mage.web-core-lib-static-icon.mjs +0 -0
- /package/{esm2020 → esm2022}/static-icon/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/user/ngageoint-mage.web-core-lib-user.mjs +0 -0
- /package/{esm2020 → esm2022}/user/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/user/user.model.mjs +0 -0
- /package/{fesm2015 → fesm2022}/ngageoint-mage.web-core-lib-event.mjs +0 -0
- /package/{fesm2015 → fesm2022}/ngageoint-mage.web-core-lib-event.mjs.map +0 -0
- /package/{fesm2015 → fesm2022}/ngageoint-mage.web-core-lib-paging.mjs +0 -0
- /package/{fesm2015 → fesm2022}/ngageoint-mage.web-core-lib-plugin.mjs +0 -0
- /package/{fesm2015 → fesm2022}/ngageoint-mage.web-core-lib-plugin.mjs.map +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"static-icon.model.d.ts","sourceRoot":"","sources":["../../../projects/core-lib/static-icon/static-icon.model.ts"],"names":[],"mappings":"AACA,MAAM,WAAW,UAAU;IACzB,EAAE,EAAE,MAAM,CAAA;IACV,SAAS,EAAE,MAAM,CAAA;IACjB,WAAW,EAAE,MAAM,CAAA;IACnB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;CAChB;AAED,MAAM,WAAW,6BAA6B;IAC5C,EAAE,EAAE,MAAM,CAAA;IACV,SAAS,CAAC,EAAE,KAAK,CAAA;CAClB;AAED,MAAM,WAAW,4BAA4B;IAC3C,SAAS,EAAE,MAAM,CAAA;IACjB,EAAE,CAAC,EAAE,KAAK,CAAA;CACX;AAED,eAAO,MAAM,iBAAiB,UAAW,UAAU,GAAG,6BAA6B,GAAG,MAAM,GAAG,IAAI,GAAG,SAAS,KAAG,MAAM,GAAG,SAQ1H,CAAA;AAED,
|
|
1
|
+
{"version":3,"file":"static-icon.model.d.ts","sourceRoot":"","sources":["../../../projects/core-lib/static-icon/static-icon.model.ts"],"names":[],"mappings":"AACA,MAAM,WAAW,UAAU;IACzB,EAAE,EAAE,MAAM,CAAA;IACV,SAAS,EAAE,MAAM,CAAA;IACjB,WAAW,EAAE,MAAM,CAAA;IACnB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;CAChB;AAED,MAAM,WAAW,6BAA6B;IAC5C,EAAE,EAAE,MAAM,CAAA;IACV,SAAS,CAAC,EAAE,KAAK,CAAA;CAClB;AAED,MAAM,WAAW,4BAA4B;IAC3C,SAAS,EAAE,MAAM,CAAA;IACjB,EAAE,CAAC,EAAE,KAAK,CAAA;CACX;AAED,eAAO,MAAM,iBAAiB,UAAW,UAAU,GAAG,6BAA6B,GAAG,MAAM,GAAG,IAAI,GAAG,SAAS,KAAG,MAAM,GAAG,SAQ1H,CAAA;AAED,MAAM,MAAM,mBAAmB,GAAG,6BAA6B,GAAG,4BAA4B,CAAA"}
|
|
@@ -15,7 +15,7 @@ export declare class UserReadService {
|
|
|
15
15
|
export interface UserSearchParams extends PagingParameters {
|
|
16
16
|
term?: string | null | undefined;
|
|
17
17
|
}
|
|
18
|
-
export
|
|
18
|
+
export type UserSearchResult = Pick<User, 'id' | 'username' | 'displayName' | 'email' | 'active' | 'enabled'> & {
|
|
19
19
|
/**
|
|
20
20
|
* A reduction of all the phone numbers to a single string
|
|
21
21
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"user-read.service.d.ts","sourceRoot":"","sources":["../../../projects/core-lib/user/user-read.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AACjD,OAAO,EAAE,cAAc,EAAc,MAAM,eAAe,CAAA;AAC1D,OAAO,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAA;AAC9E,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAA;AACjC,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAA;;AAEnC,eAAO,MAAM,kBAAkB,oBAAoB,CAAA;AAUnD,qBAGa,eAAe;IAEd,OAAO,CAAC,SAAS;gBAAT,SAAS,EAAE,UAAU;IAEzC,MAAM,CAAC,KAAK,EAAE,gBAAgB,GAAG,UAAU,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;yCAJ1D,eAAe;6CAAf,eAAe;CAmB3B;AAED,MAAM,WAAW,gBAAiB,SAAQ,gBAAgB;IACxD,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAA;CACjC;AAED,
|
|
1
|
+
{"version":3,"file":"user-read.service.d.ts","sourceRoot":"","sources":["../../../projects/core-lib/user/user-read.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AACjD,OAAO,EAAE,cAAc,EAAc,MAAM,eAAe,CAAA;AAC1D,OAAO,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAA;AAC9E,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAA;AACjC,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAA;;AAEnC,eAAO,MAAM,kBAAkB,oBAAoB,CAAA;AAUnD,qBAGa,eAAe;IAEd,OAAO,CAAC,SAAS;gBAAT,SAAS,EAAE,UAAU;IAEzC,MAAM,CAAC,KAAK,EAAE,gBAAgB,GAAG,UAAU,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;yCAJ1D,eAAe;6CAAf,eAAe;CAmB3B;AAED,MAAM,WAAW,gBAAiB,SAAQ,gBAAgB;IACxD,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAA;CACjC;AAED,MAAM,MAAM,gBAAgB,GAAG,IAAI,CAAC,IAAI,EAAE,IAAI,GAAG,UAAU,GAAG,aAAa,GAAG,OAAO,GAAG,QAAQ,GAAG,SAAS,CAAC,GAAG;IAC9G;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAA;CACtC,CAAA;AAED,eAAO,MAAM,iBAAiB,iCAAyD,CAAA"}
|
|
@@ -34,6 +34,6 @@ export declare class UserSelectComponent implements OnInit, OnChanges, AfterView
|
|
|
34
34
|
onScrollToEnd(): void;
|
|
35
35
|
fetchNextPage(): void;
|
|
36
36
|
static ɵfac: i0.ɵɵFactoryDeclaration<UserSelectComponent, never>;
|
|
37
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<UserSelectComponent, "mage-user-select", never, {}, {}, never, never, false>;
|
|
37
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<UserSelectComponent, "mage-user-select", never, {}, {}, never, never, false, never>;
|
|
38
38
|
}
|
|
39
39
|
//# sourceMappingURL=user-select.component.d.ts.map
|
package/angular-cli/README.md
DELETED
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
# Angular CLI Integration
|
|
2
|
-
|
|
3
|
-
This subfolder of modules contains Angular CLI integrations, including a [schematic]() and
|
|
4
|
-
[builder](), that facilitates creating Mage web plugin bundles.
|
|
5
|
-
|
|
6
|
-
## Background
|
|
7
|
-
Before Angular 13, the Angular [Library](https://angular.dev/tools/libraries/creating-libraries) CLI tools and
|
|
8
|
-
[Angular Package Format](https://docs.google.com/document/d/1CZC2rcpxffTDfRDs6p1cfbmKNLA6x5O-NtkJglDaBVs/preview#heading=h.k0mh3o8u5hx)
|
|
9
|
-
produced a [UMD](https://github.com/umdjs/umd) bundle by default. The UMD bundle was suitable to include in a plugin's
|
|
10
|
-
NPM package and for the core web app to download directly and load with [SystemJS](https://github.com/systemjs/systemjs)
|
|
11
|
-
at runtime to hook the plugin module into the web app. Angular 13, however, eliminated the UMD bundle output from the
|
|
12
|
-
[Angular Package Format](https://angular.dev/tools/libraries/angular-package-format) leaving only ECMAScript Module
|
|
13
|
-
(ESM) outputs, as opposed to a concatenated, resolved bundle. Angular's intention is that libraries are strictly a
|
|
14
|
-
development time construct, with the hosting application left to resolving, bundling, and tree-shaking the library's
|
|
15
|
-
`import` statements. Mage, however, is using Angular libraries differently, creating a bundle that excludes shared
|
|
16
|
-
dependencies the host web app provides, but including dependencies specific to the library, such that the host web app
|
|
17
|
-
can load the library as one chunk dynamically at runtime. While native ESM could be a possibility for Mage in the
|
|
18
|
-
future, a significant amount of evaluation and testing is necessary, and at minimum Mage would require all instances to
|
|
19
|
-
run on HTTP/2 to maximize performance. The major issue would be all the transactions required to load the large number
|
|
20
|
-
of module entry points that Mage, Angular, Angular Material, and others comprise. Whereas a conventional web app can
|
|
21
|
-
provide all the shared entry points by bare module specifier to SystemJS's named registry from a single bundle
|
|
22
|
-
downloaded initially, an ESM app must download each module separately on-demand as the JS engine processes `import`
|
|
23
|
-
statements. Even with HTTP/2 multiplexing, this could be a serious performance hit.
|
|
24
|
-
|
|
25
|
-
## Plugin Library Schematic
|
|
26
|
-
|
|
27
|
-
## AMD Builder
|
|
28
|
-
|
|
29
|
-
## TODO
|
|
30
|
-
|
|
@@ -1,104 +0,0 @@
|
|
|
1
|
-
import { Component, Inject, InjectionToken, Input } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "@angular/common/http";
|
|
4
|
-
import * as i2 from "@angular/platform-browser";
|
|
5
|
-
const selector = 'mage-xhr-img';
|
|
6
|
-
export const OBJECT_URL_SERVICE = new InjectionToken(`${selector}.objectUrlService`);
|
|
7
|
-
/**
|
|
8
|
-
* This component allows fetching images by `XMLHttpRequest` rather than the
|
|
9
|
-
* browser's native mechanism. These image requests are subject to HTTP
|
|
10
|
-
* interceptors that can add authorization headers to the request instead of
|
|
11
|
-
* using cache-defeating URL query parameters to set an auth token. Applying
|
|
12
|
-
* headers to the browser's native `img` requests is impossible, so a query
|
|
13
|
-
* parameter is necessary for authorization, but adding the parameter to the
|
|
14
|
-
* URL effectively bypasses the browser's caching mechanism when the auth token
|
|
15
|
-
* changes for images that
|
|
16
|
-
* should otherwise be subject to caching.
|
|
17
|
-
*
|
|
18
|
-
* The catch to fetching images by XHR is the response must be fetched as a
|
|
19
|
-
* `Blob`. The user then gets a browser-specific URL for the blob by
|
|
20
|
-
* `URL.createObjectURL(blob)`, which can then be assigned to the `src`
|
|
21
|
-
* attribute of an `img` tag. These blob URLs must then be "revoked" by
|
|
22
|
-
* `URL.revokeObjectURL(url)` in order to reclaim object URL's associated
|
|
23
|
-
* resources. See [Mozilla's docs](https://developer.mozilla.org/en-US/docs/Web/API/File/Using_files_from_web_applications#example_using_object_urls_to_display_images)
|
|
24
|
-
* on the subject.
|
|
25
|
-
*
|
|
26
|
-
* To use the component, simply add the tag to a template and bind the `src`
|
|
27
|
-
* attribute to the source URL of the desired image.
|
|
28
|
-
* ```
|
|
29
|
-
* <mage-xhr-img [src]="someComponent.imageUrlRequiresAuth"></mage-xhr-img>
|
|
30
|
-
* ```
|
|
31
|
-
* The component encapsulates the logic of creating and releasing the object
|
|
32
|
-
* URLs for the image data, preventing memory leaks.
|
|
33
|
-
*/
|
|
34
|
-
export class XhrImgComponent {
|
|
35
|
-
constructor(objectUrlService, webClient, sanitizer) {
|
|
36
|
-
this.objectUrlService = objectUrlService;
|
|
37
|
-
this.webClient = webClient;
|
|
38
|
-
this.sanitizer = sanitizer;
|
|
39
|
-
this.sourceUrl = null;
|
|
40
|
-
this.safeBlobUrl = null;
|
|
41
|
-
}
|
|
42
|
-
ngOnChanges(changes) {
|
|
43
|
-
if (!changes.sourceUrl) {
|
|
44
|
-
return;
|
|
45
|
-
}
|
|
46
|
-
if (changes.sourceUrl.isFirstChange() && !this.sourceUrl) {
|
|
47
|
-
return;
|
|
48
|
-
}
|
|
49
|
-
this.disposeCurrent();
|
|
50
|
-
if (!this.sourceUrl) {
|
|
51
|
-
return;
|
|
52
|
-
}
|
|
53
|
-
this.subscription = this.webClient.get(this.sourceUrl, { responseType: 'blob' })
|
|
54
|
-
.subscribe(x => {
|
|
55
|
-
this.objectUrlService.revokeObjectURL(this.blobUrl);
|
|
56
|
-
this.blobUrl = this.objectUrlService.createObjectURL(x);
|
|
57
|
-
this.safeBlobUrl = this.sanitizer.bypassSecurityTrustUrl(this.blobUrl);
|
|
58
|
-
});
|
|
59
|
-
}
|
|
60
|
-
ngOnDestroy() {
|
|
61
|
-
this.disposeCurrent();
|
|
62
|
-
}
|
|
63
|
-
onImgLoad() {
|
|
64
|
-
this.disposeCurrent();
|
|
65
|
-
}
|
|
66
|
-
disposeCurrent() {
|
|
67
|
-
if (this.blobUrl) {
|
|
68
|
-
this.objectUrlService.revokeObjectURL(this.blobUrl);
|
|
69
|
-
}
|
|
70
|
-
if (this.subscription) {
|
|
71
|
-
this.subscription.unsubscribe();
|
|
72
|
-
}
|
|
73
|
-
this.blobUrl = null;
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
XhrImgComponent.ɵfac = function XhrImgComponent_Factory(t) { return new (t || XhrImgComponent)(i0.ɵɵdirectiveInject(OBJECT_URL_SERVICE), i0.ɵɵdirectiveInject(i1.HttpClient), i0.ɵɵdirectiveInject(i2.DomSanitizer)); };
|
|
77
|
-
XhrImgComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: XhrImgComponent, selectors: [["mage-xhr-img"]], inputs: { sourceUrl: ["src", "sourceUrl"] }, features: [i0.ɵɵProvidersFeature([
|
|
78
|
-
{
|
|
79
|
-
provide: OBJECT_URL_SERVICE,
|
|
80
|
-
useValue: URL
|
|
81
|
-
}
|
|
82
|
-
]), i0.ɵɵNgOnChangesFeature], decls: 1, vars: 1, consts: [[3, "load"]], template: function XhrImgComponent_Template(rf, ctx) { if (rf & 1) {
|
|
83
|
-
i0.ɵɵelementStart(0, "img", 0);
|
|
84
|
-
i0.ɵɵlistener("load", function XhrImgComponent_Template_img_load_0_listener() { return ctx.onImgLoad(); });
|
|
85
|
-
i0.ɵɵelementEnd();
|
|
86
|
-
} if (rf & 2) {
|
|
87
|
-
i0.ɵɵattribute("src", ctx.safeBlobUrl, i0.ɵɵsanitizeUrl);
|
|
88
|
-
} }, styles: ["img[_ngcontent-%COMP%]{height:100%;width:100%}"] });
|
|
89
|
-
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(XhrImgComponent, [{
|
|
90
|
-
type: Component,
|
|
91
|
-
args: [{ selector: `${selector}`, template: `<img [attr.src]="safeBlobUrl" (load)="onImgLoad()"/>`, providers: [
|
|
92
|
-
{
|
|
93
|
-
provide: OBJECT_URL_SERVICE,
|
|
94
|
-
useValue: URL
|
|
95
|
-
}
|
|
96
|
-
], styles: ["img{height:100%;width:100%}\n"] }]
|
|
97
|
-
}], function () { return [{ type: undefined, decorators: [{
|
|
98
|
-
type: Inject,
|
|
99
|
-
args: [OBJECT_URL_SERVICE]
|
|
100
|
-
}] }, { type: i1.HttpClient }, { type: i2.DomSanitizer }]; }, { sourceUrl: [{
|
|
101
|
-
type: Input,
|
|
102
|
-
args: ['src']
|
|
103
|
-
}] }); })();
|
|
104
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoieGhyLWltZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlLWxpYi9jb21tb24veGhyLWltZy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsY0FBYyxFQUFFLEtBQUssRUFBdUMsTUFBTSxlQUFlLENBQUE7Ozs7QUFLN0csTUFBTSxRQUFRLEdBQUcsY0FBYyxDQUFBO0FBWS9CLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksY0FBYyxDQUFtQixHQUFHLFFBQVEsbUJBQW1CLENBQUMsQ0FBQTtBQUV0Rzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0EwQkc7QUFZSCxNQUFNLE9BQU8sZUFBZTtJQVMxQixZQUFnRCxnQkFBa0MsRUFBVSxTQUFxQixFQUFVLFNBQXVCO1FBQWxHLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7UUFBVSxjQUFTLEdBQVQsU0FBUyxDQUFZO1FBQVUsY0FBUyxHQUFULFNBQVMsQ0FBYztRQU5sSixjQUFTLEdBQWtCLElBQUksQ0FBQTtRQUMvQixnQkFBVyxHQUFtQixJQUFJLENBQUE7SUFLbUgsQ0FBQztJQUV0SixXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLEVBQUU7WUFDdEIsT0FBTTtTQUNQO1FBQ0QsSUFBSSxPQUFPLENBQUMsU0FBUyxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRTtZQUN4RCxPQUFNO1NBQ1A7UUFDRCxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUE7UUFDckIsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDbkIsT0FBTTtTQUNQO1FBQ0QsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBRSxDQUFDO2FBQzdFLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUNiLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFBO1lBQ25ELElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUMsQ0FBQTtZQUN2RCxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsc0JBQXNCLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFBO1FBQ3hFLENBQUMsQ0FBQyxDQUFBO0lBQ04sQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUE7SUFDdkIsQ0FBQztJQUVELFNBQVM7UUFDUCxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUE7SUFDdkIsQ0FBQztJQUVPLGNBQWM7UUFDcEIsSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ2hCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFBO1NBQ3BEO1FBQ0QsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFO1lBQ3JCLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLENBQUE7U0FDaEM7UUFDRCxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQTtJQUNyQixDQUFDOzs4RUE5Q1UsZUFBZSx1QkFTTixrQkFBa0I7a0VBVDNCLGVBQWUsK0dBUGY7WUFDVDtnQkFDRSxPQUFPLEVBQUUsa0JBQWtCO2dCQUMzQixRQUFRLEVBQUUsR0FBRzthQUNkO1NBQ0Y7UUFQVSw4QkFBb0Q7UUFBdEIsdUZBQVEsZUFBVyxJQUFDO1FBQWxELGlCQUFvRDs7UUFBL0Msd0RBQXdCOzt1RkFTN0IsZUFBZTtjQVgzQixTQUFTOzJCQUNFLEdBQUcsUUFBUSxFQUFFLFlBQ2Isc0RBQXNELGFBRXJEO29CQUNUO3dCQUNFLE9BQU8sRUFBRSxrQkFBa0I7d0JBQzNCLFFBQVEsRUFBRSxHQUFHO3FCQUNkO2lCQUNGOztzQkFXWSxNQUFNO3VCQUFDLGtCQUFrQjs0RUFOdEMsU0FBUztrQkFEUixLQUFLO21CQUFDLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEluamVjdCwgSW5qZWN0aW9uVG9rZW4sIElucHV0LCBPbkNoYW5nZXMsIE9uRGVzdHJveSwgU2ltcGxlQ2hhbmdlcyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnXG5pbXBvcnQgeyBEb21TYW5pdGl6ZXIsIFNhZmVVcmwgfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJ1xuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcydcblxuY29uc3Qgc2VsZWN0b3IgPSAnbWFnZS14aHItaW1nJ1xuXG4vKipcbiAqIFRoaXMgaXMgYSBzaW1wbGUgaW50ZXJmYWNlIHRoYXQgaW5jbHVkZXMgdGhlIFttZXRob2RzXShodHRwczovL3d3dy53My5vcmcvVFIvRmlsZUFQSS8jY3JlYXRpbmctcmV2b2tpbmcpXG4gKiBmcm9tIHRoZSBbVVJMIEFQSV0oaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQVBJL1VSTCkgZm9yXG4gKiBtYW5hZ2luZyBibG9iIFVSTHMuICBUaGlzIGFsbG93cyBhIHNlcnZpY2UgdG8gYmUgaW5qZWN0ZWQgaW50b1xuICogYFhockltZ0NvbXBvbmVudGAgYW5kIG92ZXJyaWRkZW4gZm9yIHRlc3RpbmcuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgT2JqZWN0VXJsU2VydmljZSB7XG4gIGNyZWF0ZU9iamVjdFVSTDogKHR5cGVvZiBVUkwpWydjcmVhdGVPYmplY3RVUkwnXVxuICByZXZva2VPYmplY3RVUkw6ICh0eXBlb2YgVVJMKVsncmV2b2tlT2JqZWN0VVJMJ11cbn1cbmV4cG9ydCBjb25zdCBPQkpFQ1RfVVJMX1NFUlZJQ0UgPSBuZXcgSW5qZWN0aW9uVG9rZW48T2JqZWN0VXJsU2VydmljZT4oYCR7c2VsZWN0b3J9Lm9iamVjdFVybFNlcnZpY2VgKVxuXG4vKipcbiAqIFRoaXMgY29tcG9uZW50IGFsbG93cyBmZXRjaGluZyBpbWFnZXMgYnkgYFhNTEh0dHBSZXF1ZXN0YCByYXRoZXIgdGhhbiB0aGVcbiAqIGJyb3dzZXIncyBuYXRpdmUgbWVjaGFuaXNtLiAgVGhlc2UgaW1hZ2UgcmVxdWVzdHMgYXJlIHN1YmplY3QgdG8gSFRUUFxuICogaW50ZXJjZXB0b3JzIHRoYXQgY2FuIGFkZCBhdXRob3JpemF0aW9uIGhlYWRlcnMgdG8gdGhlIHJlcXVlc3QgaW5zdGVhZCBvZlxuICogdXNpbmcgY2FjaGUtZGVmZWF0aW5nIFVSTCBxdWVyeSBwYXJhbWV0ZXJzIHRvIHNldCBhbiBhdXRoIHRva2VuLiAgQXBwbHlpbmdcbiAqIGhlYWRlcnMgdG8gdGhlIGJyb3dzZXIncyBuYXRpdmUgYGltZ2AgcmVxdWVzdHMgaXMgaW1wb3NzaWJsZSwgc28gYSBxdWVyeVxuICogcGFyYW1ldGVyIGlzIG5lY2Vzc2FyeSBmb3IgYXV0aG9yaXphdGlvbiwgYnV0IGFkZGluZyB0aGUgcGFyYW1ldGVyIHRvIHRoZVxuICogVVJMIGVmZmVjdGl2ZWx5IGJ5cGFzc2VzIHRoZSBicm93c2VyJ3MgY2FjaGluZyBtZWNoYW5pc20gd2hlbiB0aGUgYXV0aCB0b2tlblxuICogY2hhbmdlcyBmb3IgaW1hZ2VzIHRoYXRcbiAqIHNob3VsZCBvdGhlcndpc2UgYmUgc3ViamVjdCB0byBjYWNoaW5nLlxuICpcbiAqIFRoZSBjYXRjaCB0byBmZXRjaGluZyBpbWFnZXMgYnkgWEhSIGlzIHRoZSByZXNwb25zZSBtdXN0IGJlIGZldGNoZWQgYXMgYVxuICogYEJsb2JgLiAgVGhlIHVzZXIgdGhlbiBnZXRzIGEgYnJvd3Nlci1zcGVjaWZpYyBVUkwgZm9yIHRoZSBibG9iIGJ5XG4gKiBgVVJMLmNyZWF0ZU9iamVjdFVSTChibG9iKWAsIHdoaWNoIGNhbiB0aGVuIGJlIGFzc2lnbmVkIHRvIHRoZSBgc3JjYFxuICogYXR0cmlidXRlIG9mIGFuIGBpbWdgIHRhZy4gIFRoZXNlIGJsb2IgVVJMcyBtdXN0IHRoZW4gYmUgXCJyZXZva2VkXCIgYnlcbiAqIGBVUkwucmV2b2tlT2JqZWN0VVJMKHVybClgIGluIG9yZGVyIHRvIHJlY2xhaW0gb2JqZWN0IFVSTCdzIGFzc29jaWF0ZWRcbiAqIHJlc291cmNlcy4gIFNlZSBbTW96aWxsYSdzIGRvY3NdKGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0FQSS9GaWxlL1VzaW5nX2ZpbGVzX2Zyb21fd2ViX2FwcGxpY2F0aW9ucyNleGFtcGxlX3VzaW5nX29iamVjdF91cmxzX3RvX2Rpc3BsYXlfaW1hZ2VzKVxuICogb24gdGhlIHN1YmplY3QuXG4gKlxuICogVG8gdXNlIHRoZSBjb21wb25lbnQsIHNpbXBseSBhZGQgdGhlIHRhZyB0byBhIHRlbXBsYXRlIGFuZCBiaW5kIHRoZSBgc3JjYFxuICogYXR0cmlidXRlIHRvIHRoZSBzb3VyY2UgVVJMIG9mIHRoZSBkZXNpcmVkIGltYWdlLlxuICogYGBgXG4gKiA8bWFnZS14aHItaW1nIFtzcmNdPVwic29tZUNvbXBvbmVudC5pbWFnZVVybFJlcXVpcmVzQXV0aFwiPjwvbWFnZS14aHItaW1nPlxuICogYGBgXG4gKiBUaGUgY29tcG9uZW50IGVuY2Fwc3VsYXRlcyB0aGUgbG9naWMgb2YgY3JlYXRpbmcgYW5kIHJlbGVhc2luZyB0aGUgb2JqZWN0XG4gKiBVUkxzIGZvciB0aGUgaW1hZ2UgZGF0YSwgcHJldmVudGluZyBtZW1vcnkgbGVha3MuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogYCR7c2VsZWN0b3J9YCxcbiAgdGVtcGxhdGU6IGA8aW1nIFthdHRyLnNyY109XCJzYWZlQmxvYlVybFwiIChsb2FkKT1cIm9uSW1nTG9hZCgpXCIvPmAsXG4gIHN0eWxlczogWyBgaW1nIHsgaGVpZ2h0OiAxMDAlOyB3aWR0aDogMTAwJSB9YCBdLFxuICBwcm92aWRlcnM6IFtcbiAgICB7XG4gICAgICBwcm92aWRlOiBPQkpFQ1RfVVJMX1NFUlZJQ0UsXG4gICAgICB1c2VWYWx1ZTogVVJMXG4gICAgfVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFhockltZ0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcywgT25EZXN0cm95IHtcblxuICBASW5wdXQoJ3NyYycpXG4gIHNvdXJjZVVybDogc3RyaW5nIHwgbnVsbCA9IG51bGxcbiAgc2FmZUJsb2JVcmw6IFNhZmVVcmwgfCBudWxsID0gbnVsbFxuXG4gIHByaXZhdGUgYmxvYlVybDogc3RyaW5nXG4gIHByaXZhdGUgc3Vic2NyaXB0aW9uOiBTdWJzY3JpcHRpb25cblxuICBjb25zdHJ1Y3RvcihASW5qZWN0KE9CSkVDVF9VUkxfU0VSVklDRSkgcHJpdmF0ZSBvYmplY3RVcmxTZXJ2aWNlOiBPYmplY3RVcmxTZXJ2aWNlLCBwcml2YXRlIHdlYkNsaWVudDogSHR0cENsaWVudCwgcHJpdmF0ZSBzYW5pdGl6ZXI6IERvbVNhbml0aXplcikge31cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgaWYgKCFjaGFuZ2VzLnNvdXJjZVVybCkge1xuICAgICAgcmV0dXJuXG4gICAgfVxuICAgIGlmIChjaGFuZ2VzLnNvdXJjZVVybC5pc0ZpcnN0Q2hhbmdlKCkgJiYgIXRoaXMuc291cmNlVXJsKSB7XG4gICAgICByZXR1cm5cbiAgICB9XG4gICAgdGhpcy5kaXNwb3NlQ3VycmVudCgpXG4gICAgaWYgKCF0aGlzLnNvdXJjZVVybCkge1xuICAgICAgcmV0dXJuXG4gICAgfVxuICAgIHRoaXMuc3Vic2NyaXB0aW9uID0gdGhpcy53ZWJDbGllbnQuZ2V0KHRoaXMuc291cmNlVXJsLCB7IHJlc3BvbnNlVHlwZTogJ2Jsb2InIH0pXG4gICAgICAuc3Vic2NyaWJlKHggPT4ge1xuICAgICAgICB0aGlzLm9iamVjdFVybFNlcnZpY2UucmV2b2tlT2JqZWN0VVJMKHRoaXMuYmxvYlVybClcbiAgICAgICAgdGhpcy5ibG9iVXJsID0gdGhpcy5vYmplY3RVcmxTZXJ2aWNlLmNyZWF0ZU9iamVjdFVSTCh4KVxuICAgICAgICB0aGlzLnNhZmVCbG9iVXJsID0gdGhpcy5zYW5pdGl6ZXIuYnlwYXNzU2VjdXJpdHlUcnVzdFVybCh0aGlzLmJsb2JVcmwpXG4gICAgICB9KVxuICB9XG5cbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy5kaXNwb3NlQ3VycmVudCgpXG4gIH1cblxuICBvbkltZ0xvYWQoKTogdm9pZCB7XG4gICAgdGhpcy5kaXNwb3NlQ3VycmVudCgpXG4gIH1cblxuICBwcml2YXRlIGRpc3Bvc2VDdXJyZW50KCk6IHZvaWQge1xuICAgIGlmICh0aGlzLmJsb2JVcmwpIHtcbiAgICAgIHRoaXMub2JqZWN0VXJsU2VydmljZS5yZXZva2VPYmplY3RVUkwodGhpcy5ibG9iVXJsKVxuICAgIH1cbiAgICBpZiAodGhpcy5zdWJzY3JpcHRpb24pIHtcbiAgICAgIHRoaXMuc3Vic2NyaXB0aW9uLnVuc3Vic2NyaWJlKClcbiAgICB9XG4gICAgdGhpcy5ibG9iVXJsID0gbnVsbFxuICB9XG59Il19
|
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import { BehaviorSubject, Subject } from 'rxjs';
|
|
3
|
-
import { map } from 'rxjs/operators';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "@angular/common/http";
|
|
6
|
-
export class FeedService {
|
|
7
|
-
constructor(webClient) {
|
|
8
|
-
this.webClient = webClient;
|
|
9
|
-
// TODO: there is probably a better solution than maintaining this map here
|
|
10
|
-
this._feeds = new BehaviorSubject([]);
|
|
11
|
-
this.feeds$ = this._feeds.asObservable();
|
|
12
|
-
this._feedItems = new Map();
|
|
13
|
-
}
|
|
14
|
-
feedItems(feedId) {
|
|
15
|
-
return this._feedItems.get(feedId).asObservable();
|
|
16
|
-
}
|
|
17
|
-
fetchAllFeeds() {
|
|
18
|
-
return this.webClient.get('/api/feeds/');
|
|
19
|
-
}
|
|
20
|
-
fetchFeed(feedId) {
|
|
21
|
-
return this.webClient.get(`/api/feeds/${feedId}`);
|
|
22
|
-
}
|
|
23
|
-
fetchService(serviceId) {
|
|
24
|
-
return this.webClient.get(`/api/feeds/services/${serviceId}`);
|
|
25
|
-
}
|
|
26
|
-
createService(service) {
|
|
27
|
-
return this.webClient.post(`/api/feeds/services`, service);
|
|
28
|
-
}
|
|
29
|
-
fetchServices() {
|
|
30
|
-
return this.webClient.get(`/api/feeds/services`);
|
|
31
|
-
}
|
|
32
|
-
fetchServiceFeeds(serviceId) {
|
|
33
|
-
return this.webClient.get(`/api/feeds/services/${serviceId}/feeds`);
|
|
34
|
-
}
|
|
35
|
-
fetchServiceType(serviceTypeId) {
|
|
36
|
-
return this.webClient.get(`/api/feeds/service_types/${serviceTypeId}`);
|
|
37
|
-
}
|
|
38
|
-
fetchTopics(serviceId) {
|
|
39
|
-
return this.webClient.get(`/api/feeds/services/${serviceId}/topics`);
|
|
40
|
-
}
|
|
41
|
-
previewFeed(serviceId, topicId, feedSpec, opts) {
|
|
42
|
-
opts = opts || {};
|
|
43
|
-
const skipContentFetch = opts.skipContentFetch === true;
|
|
44
|
-
return this.webClient.post(`/api/feeds/services/${serviceId}/topics/${topicId}/feed_preview?skip_content_fetch=${skipContentFetch}`, { feed: feedSpec });
|
|
45
|
-
}
|
|
46
|
-
fetchTopic(serviceId, topicId) {
|
|
47
|
-
return this.webClient.get(`/api/feeds/services/${serviceId}/topics/${topicId}`);
|
|
48
|
-
}
|
|
49
|
-
fetchServiceTypes() {
|
|
50
|
-
return this.webClient.get(`/api/feeds/service_types`);
|
|
51
|
-
}
|
|
52
|
-
createFeed(serviceId, topicId, feedConfiguration) {
|
|
53
|
-
return this.webClient.post(`/api/feeds/services/${serviceId}/topics/${topicId}/feeds`, feedConfiguration);
|
|
54
|
-
}
|
|
55
|
-
updateFeed(feed) {
|
|
56
|
-
return this.webClient.put(`/api/feeds/${feed.id}`, feed);
|
|
57
|
-
}
|
|
58
|
-
deleteFeed(feed) {
|
|
59
|
-
return this.webClient.delete(`/api/feeds/${feed.id}`, { responseType: 'text' });
|
|
60
|
-
}
|
|
61
|
-
deleteService(service) {
|
|
62
|
-
console.log('delete');
|
|
63
|
-
return this.webClient.delete(`/api/feeds/services/${service.id}`, { responseType: 'text' });
|
|
64
|
-
}
|
|
65
|
-
fetchFeeds(eventId) {
|
|
66
|
-
const subject = new Subject();
|
|
67
|
-
this.webClient.get(`/api/events/${eventId}/feeds`).subscribe(feeds => {
|
|
68
|
-
feeds.map(feed => {
|
|
69
|
-
feed.id = feed.id.toString();
|
|
70
|
-
return feed;
|
|
71
|
-
});
|
|
72
|
-
feeds.forEach(feed => {
|
|
73
|
-
let feedItems = this._feedItems.get(feed.id);
|
|
74
|
-
if (!feedItems) {
|
|
75
|
-
feedItems = new BehaviorSubject([]);
|
|
76
|
-
this._feedItems.set(feed.id, feedItems);
|
|
77
|
-
}
|
|
78
|
-
});
|
|
79
|
-
subject.next(feeds);
|
|
80
|
-
this._feeds.next(feeds);
|
|
81
|
-
});
|
|
82
|
-
return subject;
|
|
83
|
-
}
|
|
84
|
-
fetchFeedItems(event, feed) {
|
|
85
|
-
const feedItems = this._feedItems.get(feed.id);
|
|
86
|
-
return this.webClient.post(`/api/events/${event.id}/feeds/${feed.id}/content`, {}).pipe(map(content => {
|
|
87
|
-
const features = content.items.features;
|
|
88
|
-
features.forEach((feature) => {
|
|
89
|
-
feature.id = String(feature.id);
|
|
90
|
-
feature.properties = feature.properties || {};
|
|
91
|
-
});
|
|
92
|
-
feedItems.next(features);
|
|
93
|
-
return content;
|
|
94
|
-
}));
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
FeedService.ɵfac = function FeedService_Factory(t) { return new (t || FeedService)(i0.ɵɵinject(i1.HttpClient)); };
|
|
98
|
-
FeedService.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: FeedService, factory: FeedService.ɵfac, providedIn: 'root' });
|
|
99
|
-
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(FeedService, [{
|
|
100
|
-
type: Injectable,
|
|
101
|
-
args: [{
|
|
102
|
-
providedIn: 'root'
|
|
103
|
-
}]
|
|
104
|
-
}], function () { return [{ type: i1.HttpClient }]; }, null); })();
|
|
105
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"feed.service.js","sourceRoot":"","sources":["../../../../projects/core-lib/feed/feed.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { Feature } from 'geojson'\nimport { BehaviorSubject, Observable, Subject } from 'rxjs'\nimport { map } from 'rxjs/operators'\nimport { Feed, FeedContent, FeedExpanded, FeedPost, FeedPreview, FeedTopic, Service, ServiceType, StyledFeature } from './feed.model'\n\n\nexport interface FeedPreviewOptions {\n  skipContentFetch?: boolean\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class FeedService {\n\n  constructor(private webClient: HttpClient) { }\n\n  // TODO: there is probably a better solution than maintaining this map here\n  private _feeds = new BehaviorSubject<Array<Feed>>([]);\n  readonly feeds$ = this._feeds.asObservable();\n\n  private _feedItems = new Map<string, BehaviorSubject<Array<Feature>>>();\n  feedItems(feedId: string): Observable<Array<Feature>> {\n    return this._feedItems.get(feedId).asObservable();\n  }\n\n  fetchAllFeeds(): Observable<Array<Feed>> {\n    return this.webClient.get<Array<Feed>>('/api/feeds/');\n  }\n\n  fetchFeed(feedId: string): Observable<FeedExpanded> {\n    return this.webClient.get<FeedExpanded>(`/api/feeds/${feedId}`);\n  }\n\n  fetchService(serviceId: string): Observable<Service> {\n    return this.webClient.get<Service>(`/api/feeds/services/${serviceId}`);\n  }\n\n  createService(service: { title: string, summary?: string, serviceType: string, config: any}): Observable<Service> {\n    return this.webClient.post<Service>(`/api/feeds/services`, service);\n  }\n\n  fetchServices(): Observable<Array<Service>> {\n    return this.webClient.get<Array<Service>>(`/api/feeds/services`);\n  }\n\n  fetchServiceFeeds(serviceId: string): Observable<Array<Feed>> {\n    return this.webClient.get<Array<Feed>>(`/api/feeds/services/${serviceId}/feeds`);\n  }\n\n  fetchServiceType(serviceTypeId: string): Observable<ServiceType> {\n    return this.webClient.get<ServiceType>(`/api/feeds/service_types/${serviceTypeId}`);\n  }\n\n  fetchTopics(serviceId: string): Observable<Array<FeedTopic>> {\n    return this.webClient.get<Array<FeedTopic>>(`/api/feeds/services/${serviceId}/topics`);\n  }\n\n  previewFeed(serviceId: string, topicId: string, feedSpec: Partial<Omit<FeedPost, 'service' | 'topic'>>, opts?: FeedPreviewOptions): Observable<FeedPreview> {\n    opts = opts || {}\n    const skipContentFetch: boolean = opts.skipContentFetch === true\n    return this.webClient.post<FeedPreview>(\n      `/api/feeds/services/${serviceId}/topics/${topicId}/feed_preview?skip_content_fetch=${skipContentFetch}`,\n      { feed: feedSpec });\n  }\n\n  fetchTopic(serviceId: string, topicId: string): Observable<FeedTopic> {\n    return this.webClient.get<FeedTopic>(`/api/feeds/services/${serviceId}/topics/${topicId}`);\n  }\n\n  fetchServiceTypes(): Observable<Array<ServiceType>> {\n    return this.webClient.get<Array<ServiceType>>(`/api/feeds/service_types`);\n  }\n\n  createFeed(serviceId: string, topicId: string, feedConfiguration: any): Observable<FeedExpanded> {\n    return this.webClient.post<FeedExpanded>(`/api/feeds/services/${serviceId}/topics/${topicId}/feeds`, feedConfiguration);\n  }\n\n  updateFeed(feed: Partial<Omit<FeedPost, 'id'>> & Pick<Feed, 'id'>): Observable<FeedExpanded> {\n    return this.webClient.put<FeedExpanded>(`/api/feeds/${feed.id}`, feed);\n  }\n\n  deleteFeed(feed: Feed | FeedExpanded): Observable<{}> {\n    return this.webClient.delete(`/api/feeds/${feed.id}`, {responseType: 'text'});\n  }\n\n  deleteService(service: Service): Observable<{}> {\n    console.log('delete')\n    return this.webClient.delete(`/api/feeds/services/${service.id}`, { responseType: 'text' });\n  }\n\n  fetchFeeds(eventId: number): Observable<Array<Feed>> {\n    const subject = new Subject<Array<Feed>>();\n    this.webClient.get<Array<Feed>>(`/api/events/${eventId}/feeds`).subscribe(feeds => {\n      feeds.map(feed => {\n        feed.id = feed.id.toString();\n        return feed;\n      });\n\n      feeds.forEach(feed => {\n        let feedItems = this._feedItems.get(feed.id);\n        if (!feedItems) {\n          feedItems = new BehaviorSubject<Array<Feature>>([]);\n          this._feedItems.set(feed.id, feedItems);\n        }\n      })\n\n      subject.next(feeds);\n      this._feeds.next(feeds);\n    });\n\n    return subject;\n  }\n\n  fetchFeedItems(event: any, feed: Feed): Observable<FeedContent> {\n    const feedItems = this._feedItems.get(feed.id)\n    return this.webClient.post<FeedContent>(`/api/events/${event.id}/feeds/${feed.id}/content`, {}).pipe(\n      map(content => {\n        const features = content.items.features\n        features.forEach((feature: StyledFeature) => {\n          feature.id = String(feature.id)\n          feature.properties = feature.properties || {}\n        })\n        feedItems.next(features)\n        return content\n      })\n    )\n  }\n}\n"]}
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
import { DataSource } from '@angular/cdk/collections';
|
|
2
|
-
import { BehaviorSubject, Subscription } from 'rxjs';
|
|
3
|
-
import { pageForItemIndex } from './paging.model';
|
|
4
|
-
/**
|
|
5
|
-
* This class is an adaptation from the [Angular Material Guide](https://v8.material.angular.io/cdk/scrolling/overview), _"Specifying data" example_, also
|
|
6
|
-
* available on [StackBlitz](https://stackblitz.com/angular/mrbkjagnnra?file=src%2Fapp%2Fcdk-virtual-scroll-data-source-example.ts).
|
|
7
|
-
*/
|
|
8
|
-
export class PagingDataSource extends DataSource {
|
|
9
|
-
constructor(pageSize, fetchPage) {
|
|
10
|
-
super();
|
|
11
|
-
this.pageSize = pageSize;
|
|
12
|
-
this.fetchPage = fetchPage;
|
|
13
|
-
this.data = null;
|
|
14
|
-
this.data$ = new BehaviorSubject([]);
|
|
15
|
-
this.fetchedPages = new Set();
|
|
16
|
-
this.subscription = new Subscription();
|
|
17
|
-
}
|
|
18
|
-
connect(collectionViewer) {
|
|
19
|
-
this.subscription.add(collectionViewer.viewChange.subscribe(range => {
|
|
20
|
-
const startPage = this.pageForItemIndex(range.start);
|
|
21
|
-
const endPage = this.pageForItemIndex(range.end - 1);
|
|
22
|
-
for (let page = startPage; page <= endPage; page++) {
|
|
23
|
-
this.fetch(page);
|
|
24
|
-
}
|
|
25
|
-
}));
|
|
26
|
-
return this.data$;
|
|
27
|
-
}
|
|
28
|
-
disconnect() {
|
|
29
|
-
this.subscription.unsubscribe();
|
|
30
|
-
}
|
|
31
|
-
pageForItemIndex(index) {
|
|
32
|
-
return pageForItemIndex(index, this.pageSize);
|
|
33
|
-
}
|
|
34
|
-
fetch(pageIndex) {
|
|
35
|
-
if (this.fetchedPages.has(pageIndex)) {
|
|
36
|
-
return;
|
|
37
|
-
}
|
|
38
|
-
this.fetchedPages.add(pageIndex);
|
|
39
|
-
const includeTotalCount = !this.data;
|
|
40
|
-
this.fetchPage({ pageSize: this.pageSize, pageIndex: pageIndex, includeTotalCount }).subscribe(page => {
|
|
41
|
-
if (!this.data) {
|
|
42
|
-
if (typeof (page.totalCount) !== 'number') {
|
|
43
|
-
throw new Error('data is null and no total count is available to inform allocation');
|
|
44
|
-
}
|
|
45
|
-
this.data = Array.from({ length: page.totalCount });
|
|
46
|
-
}
|
|
47
|
-
this.data.splice(pageIndex * this.pageSize, this.pageSize, ...page.items);
|
|
48
|
-
this.data$.next(this.data);
|
|
49
|
-
});
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5nLmNkay1kYXRhLXNvdXJjZS5hZGFwdGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS1saWIvcGFnaW5nL3BhZ2luZy5jZGstZGF0YS1zb3VyY2UuYWRhcHRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQW9CLFVBQVUsRUFBRSxNQUFNLDBCQUEwQixDQUFBO0FBQ3ZFLE9BQU8sRUFBRSxlQUFlLEVBQWMsWUFBWSxFQUFFLE1BQU0sTUFBTSxDQUFBO0FBQ2hFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBNEIsTUFBTSxnQkFBZ0IsQ0FBQTtBQUUzRTs7O0dBR0c7QUFDSCxNQUFNLE9BQU8sZ0JBQW9CLFNBQVEsVUFBYTtJQU9wRCxZQUFvQixRQUFnQixFQUFVLFNBQThEO1FBQzFHLEtBQUssRUFBRSxDQUFBO1FBRFcsYUFBUSxHQUFSLFFBQVEsQ0FBUTtRQUFVLGNBQVMsR0FBVCxTQUFTLENBQXFEO1FBTHBHLFNBQUksR0FBZSxJQUFJLENBQUE7UUFDdkIsVUFBSyxHQUFHLElBQUksZUFBZSxDQUFNLEVBQUUsQ0FBQyxDQUFBO1FBQ3BDLGlCQUFZLEdBQUcsSUFBSSxHQUFHLEVBQVUsQ0FBQTtRQUNoQyxpQkFBWSxHQUFHLElBQUksWUFBWSxFQUFFLENBQUE7SUFJekMsQ0FBQztJQUVELE9BQU8sQ0FBQyxnQkFBa0M7UUFDeEMsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUNsRSxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFBO1lBQ3BELE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFBO1lBQ3BELEtBQUssSUFBSSxJQUFJLEdBQUcsU0FBUyxFQUFFLElBQUksSUFBSSxPQUFPLEVBQUUsSUFBSSxFQUFFLEVBQUU7Z0JBQ2xELElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUE7YUFDakI7UUFDSCxDQUFDLENBQUMsQ0FBQyxDQUFBO1FBQ0gsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFBO0lBQ25CLENBQUM7SUFFRCxVQUFVO1FBQ1IsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLEVBQUUsQ0FBQTtJQUNqQyxDQUFDO0lBRU8sZ0JBQWdCLENBQUMsS0FBYTtRQUNwQyxPQUFPLGdCQUFnQixDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUE7SUFDL0MsQ0FBQztJQUVPLEtBQUssQ0FBQyxTQUFpQjtRQUM3QixJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxFQUFFO1lBQ3BDLE9BQU07U0FDUDtRQUNELElBQUksQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFBO1FBQ2hDLE1BQU0saUJBQWlCLEdBQUcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFBO1FBQ3BDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLGlCQUFpQixFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDcEcsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUU7Z0JBQ2QsSUFBSSxPQUFNLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLFFBQVEsRUFBRTtvQkFDeEMsTUFBTSxJQUFJLEtBQUssQ0FBQyxtRUFBbUUsQ0FBQyxDQUFBO2lCQUNyRjtnQkFDRCxJQUFJLENBQUMsSUFBSSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsRUFBRSxNQUFNLEVBQUUsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDLENBQUE7YUFDcEQ7WUFDRCxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFBO1lBQ3pFLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQTtRQUM1QixDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbGxlY3Rpb25WaWV3ZXIsIERhdGFTb3VyY2UgfSBmcm9tICdAYW5ndWxhci9jZGsvY29sbGVjdGlvbnMnXG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGUsIFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnXG5pbXBvcnQgeyBwYWdlRm9ySXRlbUluZGV4LCBQYWdlT2YsIFBhZ2luZ1BhcmFtZXRlcnMgfSBmcm9tICcuL3BhZ2luZy5tb2RlbCdcblxuLyoqXG4gKiBUaGlzIGNsYXNzIGlzIGFuIGFkYXB0YXRpb24gZnJvbSB0aGUgW0FuZ3VsYXIgTWF0ZXJpYWwgR3VpZGVdKGh0dHBzOi8vdjgubWF0ZXJpYWwuYW5ndWxhci5pby9jZGsvc2Nyb2xsaW5nL292ZXJ2aWV3KSwgX1wiU3BlY2lmeWluZyBkYXRhXCIgZXhhbXBsZV8sIGFsc29cbiAqIGF2YWlsYWJsZSBvbiBbU3RhY2tCbGl0el0oaHR0cHM6Ly9zdGFja2JsaXR6LmNvbS9hbmd1bGFyL21yYmtqYWdubnJhP2ZpbGU9c3JjJTJGYXBwJTJGY2RrLXZpcnR1YWwtc2Nyb2xsLWRhdGEtc291cmNlLWV4YW1wbGUudHMpLlxuICovXG5leHBvcnQgY2xhc3MgUGFnaW5nRGF0YVNvdXJjZTxUPiBleHRlbmRzIERhdGFTb3VyY2U8VD4ge1xuXG4gIHByaXZhdGUgZGF0YTogVFtdIHwgbnVsbCA9IG51bGxcbiAgcHJpdmF0ZSBkYXRhJCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8VFtdPihbXSlcbiAgcHJpdmF0ZSBmZXRjaGVkUGFnZXMgPSBuZXcgU2V0PG51bWJlcj4oKVxuICBwcml2YXRlIHN1YnNjcmlwdGlvbiA9IG5ldyBTdWJzY3JpcHRpb24oKVxuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcGFnZVNpemU6IG51bWJlciwgcHJpdmF0ZSBmZXRjaFBhZ2U6IChwYWdpbmc6IFBhZ2luZ1BhcmFtZXRlcnMpID0+IE9ic2VydmFibGU8UGFnZU9mPFQ+Pikge1xuICAgIHN1cGVyKClcbiAgfVxuXG4gIGNvbm5lY3QoY29sbGVjdGlvblZpZXdlcjogQ29sbGVjdGlvblZpZXdlcik6IE9ic2VydmFibGU8cmVhZG9ubHkgVFtdPiB7XG4gICAgdGhpcy5zdWJzY3JpcHRpb24uYWRkKGNvbGxlY3Rpb25WaWV3ZXIudmlld0NoYW5nZS5zdWJzY3JpYmUocmFuZ2UgPT4ge1xuICAgICAgY29uc3Qgc3RhcnRQYWdlID0gdGhpcy5wYWdlRm9ySXRlbUluZGV4KHJhbmdlLnN0YXJ0KVxuICAgICAgY29uc3QgZW5kUGFnZSA9IHRoaXMucGFnZUZvckl0ZW1JbmRleChyYW5nZS5lbmQgLSAxKVxuICAgICAgZm9yIChsZXQgcGFnZSA9IHN0YXJ0UGFnZTsgcGFnZSA8PSBlbmRQYWdlOyBwYWdlKyspIHtcbiAgICAgICAgdGhpcy5mZXRjaChwYWdlKVxuICAgICAgfVxuICAgIH0pKVxuICAgIHJldHVybiB0aGlzLmRhdGEkXG4gIH1cblxuICBkaXNjb25uZWN0KCk6IHZvaWQge1xuICAgIHRoaXMuc3Vic2NyaXB0aW9uLnVuc3Vic2NyaWJlKClcbiAgfVxuXG4gIHByaXZhdGUgcGFnZUZvckl0ZW1JbmRleChpbmRleDogbnVtYmVyKTogbnVtYmVyIHtcbiAgICByZXR1cm4gcGFnZUZvckl0ZW1JbmRleChpbmRleCwgdGhpcy5wYWdlU2l6ZSlcbiAgfVxuXG4gIHByaXZhdGUgZmV0Y2gocGFnZUluZGV4OiBudW1iZXIpIHtcbiAgICBpZiAodGhpcy5mZXRjaGVkUGFnZXMuaGFzKHBhZ2VJbmRleCkpIHtcbiAgICAgIHJldHVyblxuICAgIH1cbiAgICB0aGlzLmZldGNoZWRQYWdlcy5hZGQocGFnZUluZGV4KVxuICAgIGNvbnN0IGluY2x1ZGVUb3RhbENvdW50ID0gIXRoaXMuZGF0YVxuICAgIHRoaXMuZmV0Y2hQYWdlKHsgcGFnZVNpemU6IHRoaXMucGFnZVNpemUsIHBhZ2VJbmRleDogcGFnZUluZGV4LCBpbmNsdWRlVG90YWxDb3VudCB9KS5zdWJzY3JpYmUocGFnZSA9PiB7XG4gICAgICBpZiAoIXRoaXMuZGF0YSkge1xuICAgICAgICBpZiAodHlwZW9mKHBhZ2UudG90YWxDb3VudCkgIT09ICdudW1iZXInKSB7XG4gICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdkYXRhIGlzIG51bGwgYW5kIG5vIHRvdGFsIGNvdW50IGlzIGF2YWlsYWJsZSB0byBpbmZvcm0gYWxsb2NhdGlvbicpXG4gICAgICAgIH1cbiAgICAgICAgdGhpcy5kYXRhID0gQXJyYXkuZnJvbSh7IGxlbmd0aDogcGFnZS50b3RhbENvdW50IH0pXG4gICAgICB9XG4gICAgICB0aGlzLmRhdGEuc3BsaWNlKHBhZ2VJbmRleCAqIHRoaXMucGFnZVNpemUsIHRoaXMucGFnZVNpemUsIC4uLnBhZ2UuaXRlbXMpXG4gICAgICB0aGlzLmRhdGEkLm5leHQodGhpcy5kYXRhKVxuICAgIH0pXG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
export const pageForItemIndex = (itemIndex, pageSize) => {
|
|
2
|
-
if (typeof pageSize === 'object') {
|
|
3
|
-
pageSize = pageSize.pageSize;
|
|
4
|
-
}
|
|
5
|
-
return Math.floor(itemIndex / pageSize);
|
|
6
|
-
};
|
|
7
|
-
/**
|
|
8
|
-
* Return the range of item indexes for the given page and page size. The last
|
|
9
|
-
* end portion of the range is exclusive, so when indexing an array the last
|
|
10
|
-
* item of the page would have position `end - 1`. This allows one to pass the
|
|
11
|
-
* values to `Array.slice()`.
|
|
12
|
-
* @param pageIndex
|
|
13
|
-
* @param pageSize
|
|
14
|
-
* @returns
|
|
15
|
-
*/
|
|
16
|
-
export const itemRangeOfPage = (pageIndex, pageSize) => {
|
|
17
|
-
if (typeof pageIndex === 'object') {
|
|
18
|
-
pageSize = pageIndex.pageSize;
|
|
19
|
-
pageIndex = pageIndex.pageIndex;
|
|
20
|
-
}
|
|
21
|
-
const start = pageSize * pageIndex;
|
|
22
|
-
const end = start + pageSize;
|
|
23
|
-
return [start, end];
|
|
24
|
-
};
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5nLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS1saWIvcGFnaW5nL3BhZ2luZy5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQkEsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsQ0FBQyxTQUFpQixFQUFFLFFBQW1DLEVBQVUsRUFBRTtJQUNqRyxJQUFJLE9BQU8sUUFBUSxLQUFLLFFBQVEsRUFBRTtRQUNoQyxRQUFRLEdBQUcsUUFBUSxDQUFDLFFBQVEsQ0FBQTtLQUM3QjtJQUNELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLEdBQUcsUUFBUSxDQUFDLENBQUE7QUFDekMsQ0FBQyxDQUFBO0FBRUQ7Ozs7Ozs7O0dBUUc7QUFDSCxNQUFNLENBQUMsTUFBTSxlQUFlLEdBR3hCLENBQUMsU0FBb0MsRUFBRSxRQUFpQixFQUFzQixFQUFFO0lBQ2xGLElBQUksT0FBTyxTQUFTLEtBQUssUUFBUSxFQUFFO1FBQ2pDLFFBQVEsR0FBRyxTQUFTLENBQUMsUUFBUSxDQUFBO1FBQzdCLFNBQVMsR0FBRyxTQUFTLENBQUMsU0FBUyxDQUFBO0tBQ2hDO0lBQ0QsTUFBTSxLQUFLLEdBQUcsUUFBUSxHQUFHLFNBQVMsQ0FBQTtJQUNsQyxNQUFNLEdBQUcsR0FBRyxLQUFLLEdBQUcsUUFBUSxDQUFBO0lBQzVCLE9BQU8sQ0FBRSxLQUFLLEVBQUUsR0FBRyxDQUFFLENBQUE7QUFDdkIsQ0FBQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiXG5leHBvcnQgaW50ZXJmYWNlIFBhZ2luZ1BhcmFtZXRlcnMge1xuICBwYWdlU2l6ZTogbnVtYmVyLFxuICBwYWdlSW5kZXg6IG51bWJlcixcbiAgaW5jbHVkZVRvdGFsQ291bnQ/OiBib29sZWFuIHwgbnVsbFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBhZ2VPZjxUPiB7XG4gIHBhZ2VTaXplOiBudW1iZXIsXG4gIHBhZ2VJbmRleDogbnVtYmVyLFxuICB0b3RhbENvdW50PzogbnVtYmVyIHwgbnVsbCxcbiAgbmV4dD86IFBhZ2luZ1BhcmFtZXRlcnMgfCBudWxsXG4gIHByZXY/OiBQYWdpbmdQYXJhbWV0ZXJzIHwgbnVsbFxuICBpdGVtczogVFtdXG59XG5cbmV4cG9ydCBjb25zdCBwYWdlRm9ySXRlbUluZGV4ID0gKGl0ZW1JbmRleDogbnVtYmVyLCBwYWdlU2l6ZTogbnVtYmVyIHwgUGFnaW5nUGFyYW1ldGVycyk6IG51bWJlciA9PiB7XG4gIGlmICh0eXBlb2YgcGFnZVNpemUgPT09ICdvYmplY3QnKSB7XG4gICAgcGFnZVNpemUgPSBwYWdlU2l6ZS5wYWdlU2l6ZVxuICB9XG4gIHJldHVybiBNYXRoLmZsb29yKGl0ZW1JbmRleCAvIHBhZ2VTaXplKVxufVxuXG4vKipcbiAqIFJldHVybiB0aGUgcmFuZ2Ugb2YgaXRlbSBpbmRleGVzIGZvciB0aGUgZ2l2ZW4gcGFnZSBhbmQgcGFnZSBzaXplLiAgVGhlIGxhc3RcbiAqIGVuZCBwb3J0aW9uIG9mIHRoZSByYW5nZSBpcyBleGNsdXNpdmUsIHNvIHdoZW4gaW5kZXhpbmcgYW4gYXJyYXkgdGhlIGxhc3RcbiAqIGl0ZW0gb2YgdGhlIHBhZ2Ugd291bGQgaGF2ZSBwb3NpdGlvbiBgZW5kIC0gMWAuICBUaGlzIGFsbG93cyBvbmUgdG8gcGFzcyB0aGVcbiAqIHZhbHVlcyB0byBgQXJyYXkuc2xpY2UoKWAuXG4gKiBAcGFyYW0gcGFnZUluZGV4XG4gKiBAcGFyYW0gcGFnZVNpemVcbiAqIEByZXR1cm5zXG4gKi9cbmV4cG9ydCBjb25zdCBpdGVtUmFuZ2VPZlBhZ2U6IHtcbiAgKHBhZ2VJbmRleDogbnVtYmVyLCBwYWdlU2l6ZTogbnVtYmVyKTogWyBudW1iZXIsIG51bWJlciBdXG4gIChwYWdpbmc6IFBhZ2luZ1BhcmFtZXRlcnMpXG59ID0gKHBhZ2VJbmRleDogbnVtYmVyIHwgUGFnaW5nUGFyYW1ldGVycywgcGFnZVNpemU/OiBudW1iZXIpOiBbIG51bWJlciwgbnVtYmVyIF0gPT4ge1xuICBpZiAodHlwZW9mIHBhZ2VJbmRleCA9PT0gJ29iamVjdCcpIHtcbiAgICBwYWdlU2l6ZSA9IHBhZ2VJbmRleC5wYWdlU2l6ZVxuICAgIHBhZ2VJbmRleCA9IHBhZ2VJbmRleC5wYWdlSW5kZXhcbiAgfVxuICBjb25zdCBzdGFydCA9IHBhZ2VTaXplICogcGFnZUluZGV4XG4gIGNvbnN0IGVuZCA9IHN0YXJ0ICsgcGFnZVNpemVcbiAgcmV0dXJuIFsgc3RhcnQsIGVuZCBdXG59XG4iXX0=
|
|
@@ -1,145 +0,0 @@
|
|
|
1
|
-
import { Component } from '@angular/core';
|
|
2
|
-
import { UntypedFormControl, UntypedFormGroup, NG_VALIDATORS, NG_VALUE_ACCESSOR, Validators } from '@angular/forms';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "../static-icon.service";
|
|
5
|
-
import * as i2 from "@angular/common/http";
|
|
6
|
-
import * as i3 from "@angular/platform-browser";
|
|
7
|
-
import * as i4 from "@angular/forms";
|
|
8
|
-
import * as i5 from "@ngageoint/mage.web-core-lib/common";
|
|
9
|
-
export class StaticIconFormFieldComponent {
|
|
10
|
-
constructor(iconService, httpClient, sanitizer) {
|
|
11
|
-
this.iconService = iconService;
|
|
12
|
-
this.httpClient = httpClient;
|
|
13
|
-
this.sanitizer = sanitizer;
|
|
14
|
-
this.iconRef = null;
|
|
15
|
-
this.form = new UntypedFormGroup({
|
|
16
|
-
iconRefToken: new UntypedFormControl(null),
|
|
17
|
-
iconRefType: new UntypedFormControl(null, Validators.required)
|
|
18
|
-
});
|
|
19
|
-
this.onChange = (iconRef) => { };
|
|
20
|
-
this.onValidatorChange = () => { };
|
|
21
|
-
this.onTouched = () => { };
|
|
22
|
-
this.form.valueChanges.subscribe((x) => {
|
|
23
|
-
this.iconRef = iconRefForFormValue(x);
|
|
24
|
-
this.onChange(this.iconRef);
|
|
25
|
-
});
|
|
26
|
-
}
|
|
27
|
-
registerOnValidatorChange(fn) {
|
|
28
|
-
this.onValidatorChange = fn;
|
|
29
|
-
}
|
|
30
|
-
ngOnChanges(changes) { }
|
|
31
|
-
ngOnDestroy() { }
|
|
32
|
-
onSelectIcon() { }
|
|
33
|
-
writeValue(iconRef) {
|
|
34
|
-
this.iconRef = iconRef;
|
|
35
|
-
const formValue = formValueForIconRef(iconRef);
|
|
36
|
-
this.form.setValue(formValue, { emitEvent: false });
|
|
37
|
-
this.resolveIconRef();
|
|
38
|
-
}
|
|
39
|
-
registerOnChange(fn) {
|
|
40
|
-
this.onChange = fn;
|
|
41
|
-
}
|
|
42
|
-
registerOnTouched(fn) {
|
|
43
|
-
this.onTouched = fn;
|
|
44
|
-
}
|
|
45
|
-
setDisabledState(isDisabled) {
|
|
46
|
-
if (isDisabled) {
|
|
47
|
-
this.form.disable();
|
|
48
|
-
}
|
|
49
|
-
else {
|
|
50
|
-
this.form.enable();
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
validate(control) {
|
|
54
|
-
return this.form.errors;
|
|
55
|
-
}
|
|
56
|
-
resolveIconRef() {
|
|
57
|
-
if (!this.iconRef) {
|
|
58
|
-
this.icon = null;
|
|
59
|
-
return;
|
|
60
|
-
}
|
|
61
|
-
this.iconService.fetchIconByReference(this.iconRef).subscribe(x => {
|
|
62
|
-
this.icon = x;
|
|
63
|
-
if (!this.icon) {
|
|
64
|
-
return;
|
|
65
|
-
}
|
|
66
|
-
});
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
StaticIconFormFieldComponent.ɵfac = function StaticIconFormFieldComponent_Factory(t) { return new (t || StaticIconFormFieldComponent)(i0.ɵɵdirectiveInject(i1.StaticIconService), i0.ɵɵdirectiveInject(i2.HttpClient), i0.ɵɵdirectiveInject(i3.DomSanitizer)); };
|
|
70
|
-
StaticIconFormFieldComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: StaticIconFormFieldComponent, selectors: [["mage-static-icon-form-field"]], features: [i0.ɵɵProvidersFeature([
|
|
71
|
-
{
|
|
72
|
-
provide: NG_VALUE_ACCESSOR,
|
|
73
|
-
multi: true,
|
|
74
|
-
useExisting: StaticIconFormFieldComponent
|
|
75
|
-
},
|
|
76
|
-
{
|
|
77
|
-
provide: NG_VALIDATORS,
|
|
78
|
-
multi: true,
|
|
79
|
-
useExisting: StaticIconFormFieldComponent
|
|
80
|
-
},
|
|
81
|
-
]), i0.ɵɵNgOnChangesFeature], decls: 4, vars: 2, consts: [[3, "formGroup"], [1, "icon-image", 3, "src"], ["type", "hidden", "formControlName", "iconRefType"], ["type", "hidden", "formControlName", "iconRefToken"]], template: function StaticIconFormFieldComponent_Template(rf, ctx) { if (rf & 1) {
|
|
82
|
-
i0.ɵɵelementStart(0, "div", 0);
|
|
83
|
-
i0.ɵɵelement(1, "mage-xhr-img", 1)(2, "input", 2)(3, "input", 3);
|
|
84
|
-
i0.ɵɵelementEnd();
|
|
85
|
-
} if (rf & 2) {
|
|
86
|
-
i0.ɵɵproperty("formGroup", ctx.form);
|
|
87
|
-
i0.ɵɵadvance(1);
|
|
88
|
-
i0.ɵɵproperty("src", ctx.icon == null ? null : ctx.icon.contentPath);
|
|
89
|
-
} }, dependencies: [i4.DefaultValueAccessor, i4.NgControlStatus, i4.NgControlStatusGroup, i4.FormGroupDirective, i4.FormControlName, i5.XhrImgComponent], styles: [".icon-image[_ngcontent-%COMP%]{display:block;height:3em;width:3em}"] });
|
|
90
|
-
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(StaticIconFormFieldComponent, [{
|
|
91
|
-
type: Component,
|
|
92
|
-
args: [{ selector: 'mage-static-icon-form-field', providers: [
|
|
93
|
-
{
|
|
94
|
-
provide: NG_VALUE_ACCESSOR,
|
|
95
|
-
multi: true,
|
|
96
|
-
useExisting: StaticIconFormFieldComponent
|
|
97
|
-
},
|
|
98
|
-
{
|
|
99
|
-
provide: NG_VALIDATORS,
|
|
100
|
-
multi: true,
|
|
101
|
-
useExisting: StaticIconFormFieldComponent
|
|
102
|
-
},
|
|
103
|
-
], template: "<div [formGroup]=\"form\">\n <mage-xhr-img class=\"icon-image\" [src]=\"icon?.contentPath\"></mage-xhr-img>\n <input type=\"hidden\" formControlName=\"iconRefType\"/>\n <input type=\"hidden\" formControlName=\"iconRefToken\"/>\n</div>", styles: [".icon-image{display:block;height:3em;width:3em}\n"] }]
|
|
104
|
-
}], function () { return [{ type: i1.StaticIconService }, { type: i2.HttpClient }, { type: i3.DomSanitizer }]; }, null); })();
|
|
105
|
-
var IconRefType;
|
|
106
|
-
(function (IconRefType) {
|
|
107
|
-
IconRefType["Registered"] = "id";
|
|
108
|
-
IconRefType["SourceUrl"] = "sourceUrl";
|
|
109
|
-
})(IconRefType || (IconRefType = {}));
|
|
110
|
-
function iconRefForFormValue(x) {
|
|
111
|
-
if (!x.iconRefType) {
|
|
112
|
-
return null;
|
|
113
|
-
}
|
|
114
|
-
switch (x.iconRefType) {
|
|
115
|
-
case IconRefType.Registered:
|
|
116
|
-
return { [IconRefType.Registered]: x.iconRefToken };
|
|
117
|
-
case IconRefType.SourceUrl:
|
|
118
|
-
return { [IconRefType.SourceUrl]: x.iconRefToken };
|
|
119
|
-
default:
|
|
120
|
-
throw new Error('invalid icon ref type: ' + x.iconRefToken);
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
function formValueForIconRef(x) {
|
|
124
|
-
if (!x) {
|
|
125
|
-
return {
|
|
126
|
-
iconRefType: null,
|
|
127
|
-
iconRefToken: null
|
|
128
|
-
};
|
|
129
|
-
}
|
|
130
|
-
let iconRefType = null;
|
|
131
|
-
let iconRefToken = null;
|
|
132
|
-
if (x.hasOwnProperty(IconRefType.Registered)) {
|
|
133
|
-
iconRefType = IconRefType.Registered || null;
|
|
134
|
-
iconRefToken = x[IconRefType.Registered] || null;
|
|
135
|
-
}
|
|
136
|
-
else if (x.hasOwnProperty(IconRefType.SourceUrl)) {
|
|
137
|
-
iconRefType = IconRefType.SourceUrl || null;
|
|
138
|
-
iconRefToken = x[IconRefType.SourceUrl] || null;
|
|
139
|
-
}
|
|
140
|
-
return {
|
|
141
|
-
iconRefType,
|
|
142
|
-
iconRefToken
|
|
143
|
-
};
|
|
144
|
-
}
|
|
145
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"static-icon-form-field.component.js","sourceRoot":"","sources":["../../../../../projects/core-lib/static-icon/static-icon-form-field/static-icon-form-field.component.ts","../../../../../projects/core-lib/static-icon/static-icon-form-field/static-icon-form-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http'\nimport { Component, OnChanges, OnDestroy, SimpleChanges } from '@angular/core'\nimport { AbstractControl, ControlValueAccessor, UntypedFormControl, UntypedFormGroup, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors, Validator, Validators } from '@angular/forms'\nimport { DomSanitizer } from '@angular/platform-browser'\nimport { StaticIcon, StaticIconReference } from '../static-icon.model'\nimport { StaticIconService } from '../static-icon.service'\n\n\n@Component({\n  selector: 'mage-static-icon-form-field',\n  templateUrl: './static-icon-form-field.component.html',\n  styleUrls: ['./static-icon-form-field.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      multi: true,\n      useExisting: StaticIconFormFieldComponent\n    },\n    {\n      provide: NG_VALIDATORS,\n      multi: true,\n      useExisting: StaticIconFormFieldComponent\n    },\n  ]\n})\nexport class StaticIconFormFieldComponent implements OnChanges, OnDestroy, ControlValueAccessor, Validator {\n\n  iconRef: StaticIconReference = null\n\n  form: UntypedFormGroup = new UntypedFormGroup({\n    iconRefToken: new UntypedFormControl(null),\n    iconRefType: new UntypedFormControl(null, Validators.required)\n  })\n  icon: StaticIcon | null\n\n  private onChange: (iconRef: StaticIconReference) => void = (iconRef: StaticIconReference) => {}\n  private onValidatorChange: () => void = () => {}\n  private onTouched: () => void = () => {}\n\n  constructor(private iconService: StaticIconService, private httpClient: HttpClient, private sanitizer: DomSanitizer) {\n    this.form.valueChanges.subscribe((x: IconRefFormValue) => {\n      this.iconRef = iconRefForFormValue(x)\n      this.onChange(this.iconRef)\n    })\n  }\n\n  registerOnValidatorChange?(fn: () => void): void {\n    this.onValidatorChange = fn\n  }\n\n  ngOnChanges(changes: SimpleChanges) { }\n\n  ngOnDestroy() { }\n\n  onSelectIcon() { }\n\n  writeValue(iconRef: StaticIconReference): void {\n    this.iconRef = iconRef\n    const formValue = formValueForIconRef(iconRef)\n    this.form.setValue(formValue, { emitEvent: false })\n    this.resolveIconRef()\n  }\n\n  registerOnChange(fn: (x: StaticIconReference | null) => void): void {\n    this.onChange = fn\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    if (isDisabled) {\n      this.form.disable()\n    }\n    else {\n      this.form.enable()\n    }\n  }\n\n  validate(control: AbstractControl): ValidationErrors {\n    return this.form.errors\n  }\n\n  private resolveIconRef() {\n    if (!this.iconRef) {\n      this.icon = null\n      return\n    }\n    this.iconService.fetchIconByReference(this.iconRef).subscribe(x => {\n      this.icon = x\n      if (!this.icon) {\n        return\n      }\n    })\n  }\n}\n\nenum IconRefType {\n  Registered = 'id',\n  SourceUrl = 'sourceUrl'\n}\n\ntype IconRefFormValue = {\n  iconRefToken: string | null\n  iconRefType: IconRefType | null\n}\n\nfunction iconRefForFormValue(x: IconRefFormValue): StaticIconReference | null {\n  if (!x.iconRefType) {\n    return null\n  }\n  switch (x.iconRefType) {\n    case IconRefType.Registered:\n      return { [IconRefType.Registered]: x.iconRefToken }\n    case IconRefType.SourceUrl:\n      return { [IconRefType.SourceUrl]: x.iconRefToken }\n    default:\n      throw new Error('invalid icon ref type: ' + x.iconRefToken)\n  }\n}\n\nfunction formValueForIconRef(x: StaticIconReference | null): IconRefFormValue {\n  if (!x) {\n    return {\n      iconRefType: null,\n      iconRefToken: null\n    }\n  }\n  let iconRefType: IconRefType | null = null\n  let iconRefToken: string | null = null\n  if (x.hasOwnProperty(IconRefType.Registered)) {\n    iconRefType = IconRefType.Registered || null\n    iconRefToken = x[IconRefType.Registered] || null\n  }\n  else if (x.hasOwnProperty(IconRefType.SourceUrl)) {\n    iconRefType = IconRefType.SourceUrl || null\n    iconRefToken = x[IconRefType.SourceUrl] || null\n  }\n  return {\n    iconRefType,\n    iconRefToken\n  }\n}\n","<div [formGroup]=\"form\">\n  <mage-xhr-img class=\"icon-image\" [src]=\"icon?.contentPath\"></mage-xhr-img>\n  <input type=\"hidden\" formControlName=\"iconRefType\"/>\n  <input type=\"hidden\" formControlName=\"iconRefToken\"/>\n</div>"]}
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
-
import { contentPathOfIcon } from '../static-icon.model';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@ngageoint/mage.web-core-lib/common";
|
|
5
|
-
export class StaticIconImgComponent {
|
|
6
|
-
constructor() { }
|
|
7
|
-
ngOnInit() {
|
|
8
|
-
}
|
|
9
|
-
ngOnChanges(changes) {
|
|
10
|
-
if (changes.iconRef) {
|
|
11
|
-
if (this.iconRef) {
|
|
12
|
-
this.iconPath = contentPathOfIcon(this.iconRef);
|
|
13
|
-
}
|
|
14
|
-
else {
|
|
15
|
-
this.iconPath = null;
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
StaticIconImgComponent.ɵfac = function StaticIconImgComponent_Factory(t) { return new (t || StaticIconImgComponent)(); };
|
|
21
|
-
StaticIconImgComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: StaticIconImgComponent, selectors: [["mage-static-icon-img"]], inputs: { iconRef: "iconRef" }, features: [i0.ɵɵNgOnChangesFeature], decls: 1, vars: 1, consts: [[3, "src"]], template: function StaticIconImgComponent_Template(rf, ctx) { if (rf & 1) {
|
|
22
|
-
i0.ɵɵelement(0, "mage-xhr-img", 0);
|
|
23
|
-
} if (rf & 2) {
|
|
24
|
-
i0.ɵɵproperty("src", ctx.iconPath);
|
|
25
|
-
} }, dependencies: [i1.XhrImgComponent], encapsulation: 2 });
|
|
26
|
-
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(StaticIconImgComponent, [{
|
|
27
|
-
type: Component,
|
|
28
|
-
args: [{
|
|
29
|
-
selector: 'mage-static-icon-img',
|
|
30
|
-
template: `<mage-xhr-img [src]="iconPath"></mage-xhr-img>`,
|
|
31
|
-
}]
|
|
32
|
-
}], function () { return []; }, { iconRef: [{
|
|
33
|
-
type: Input
|
|
34
|
-
}] }); })();
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdGljLWljb24taW1nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUtbGliL3N0YXRpYy1pY29uL3N0YXRpYy1pY29uLWltZy9zdGF0aWMtaWNvbi1pbWcuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFvQyxNQUFNLGVBQWUsQ0FBQztBQUNuRixPQUFPLEVBQWlDLGlCQUFpQixFQUFFLE1BQU0sc0JBQXNCLENBQUE7OztBQU12RixNQUFNLE9BQU8sc0JBQXNCO0lBTWpDLGdCQUFnQixDQUFDO0lBRWpCLFFBQVE7SUFDUixDQUFDO0lBRUQsV0FBVyxDQUFDLE9BQXNCO1FBQ2hDLElBQUksT0FBTyxDQUFDLE9BQU8sRUFBRTtZQUNuQixJQUFJLElBQUksQ0FBQyxPQUFPLEVBQUU7Z0JBQ2hCLElBQUksQ0FBQyxRQUFRLEdBQUcsaUJBQWlCLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFBO2FBQ2hEO2lCQUNJO2dCQUNILElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFBO2FBQ3JCO1NBQ0Y7SUFDSCxDQUFDOzs0RkFwQlUsc0JBQXNCO3lFQUF0QixzQkFBc0I7UUFGdEIsa0NBQThDOztRQUFoQyxrQ0FBZ0I7O3VGQUU5QixzQkFBc0I7Y0FKbEMsU0FBUztlQUFDO2dCQUNULFFBQVEsRUFBRSxzQkFBc0I7Z0JBQ2hDLFFBQVEsRUFBRSxnREFBZ0Q7YUFDM0Q7c0NBSUMsT0FBTztrQkFETixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25DaGFuZ2VzLCBPbkluaXQsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFJlZ2lzdGVyZWRTdGF0aWNJY29uUmVmZXJlbmNlLCBjb250ZW50UGF0aE9mSWNvbiB9IGZyb20gJy4uL3N0YXRpYy1pY29uLm1vZGVsJ1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdtYWdlLXN0YXRpYy1pY29uLWltZycsXG4gIHRlbXBsYXRlOiBgPG1hZ2UteGhyLWltZyBbc3JjXT1cImljb25QYXRoXCI+PC9tYWdlLXhoci1pbWc+YCxcbn0pXG5leHBvcnQgY2xhc3MgU3RhdGljSWNvbkltZ0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzIHtcblxuICBASW5wdXQoKVxuICBpY29uUmVmOiBSZWdpc3RlcmVkU3RhdGljSWNvblJlZmVyZW5jZSB8IHN0cmluZyB8IG51bGxcbiAgaWNvblBhdGg6IHN0cmluZyB8IG51bGxcblxuICBjb25zdHJ1Y3RvcigpIHsgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICB9XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcyk6IHZvaWQge1xuICAgIGlmIChjaGFuZ2VzLmljb25SZWYpIHtcbiAgICAgIGlmICh0aGlzLmljb25SZWYpIHtcbiAgICAgICAgdGhpcy5pY29uUGF0aCA9IGNvbnRlbnRQYXRoT2ZJY29uKHRoaXMuaWNvblJlZilcbiAgICAgIH1cbiAgICAgIGVsc2Uge1xuICAgICAgICB0aGlzLmljb25QYXRoID0gbnVsbFxuICAgICAgfVxuICAgIH1cbiAgfVxufVxuIl19
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
export const contentPathOfIcon = (icon) => {
|
|
2
|
-
if (!icon) {
|
|
3
|
-
return;
|
|
4
|
-
}
|
|
5
|
-
if (typeof icon !== 'string') {
|
|
6
|
-
icon = icon.id;
|
|
7
|
-
}
|
|
8
|
-
return `/api/icons/${icon}/content`;
|
|
9
|
-
};
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdGljLWljb24ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlLWxpYi9zdGF0aWMtaWNvbi9zdGF0aWMtaWNvbi5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQkEsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsQ0FBQyxJQUE2RSxFQUFzQixFQUFFO0lBQ3JJLElBQUksQ0FBQyxJQUFJLEVBQUU7UUFDVCxPQUFNO0tBQ1A7SUFDRCxJQUFJLE9BQU8sSUFBSSxLQUFLLFFBQVEsRUFBRTtRQUM1QixJQUFJLEdBQUcsSUFBSSxDQUFDLEVBQUUsQ0FBQTtLQUNmO0lBQ0QsT0FBTyxjQUFjLElBQUksVUFBVSxDQUFBO0FBQ3JDLENBQUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbIlxuZXhwb3J0IGludGVyZmFjZSBTdGF0aWNJY29uIHtcbiAgaWQ6IHN0cmluZ1xuICBzb3VyY2VVcmw6IHN0cmluZ1xuICBjb250ZW50UGF0aDogc3RyaW5nXG4gIHRpdGxlPzogc3RyaW5nXG4gIHN1bW1hcnk/OiBzdHJpbmdcbiAgZmlsZU5hbWU/OiBzdHJpbmdcbiAgdGFncz86IHN0cmluZ1tdXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVnaXN0ZXJlZFN0YXRpY0ljb25SZWZlcmVuY2Uge1xuICBpZDogc3RyaW5nXG4gIHNvdXJjZVVybD86IG5ldmVyXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU291cmNlVXJsU3RhdGljSWNvblJlZmVyZW5jZSB7XG4gIHNvdXJjZVVybDogc3RyaW5nXG4gIGlkPzogbmV2ZXJcbn1cblxuZXhwb3J0IGNvbnN0IGNvbnRlbnRQYXRoT2ZJY29uID0gKGljb24/OiBTdGF0aWNJY29uIHwgUmVnaXN0ZXJlZFN0YXRpY0ljb25SZWZlcmVuY2UgfCBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkKTogc3RyaW5nIHwgdW5kZWZpbmVkID0+IHtcbiAgaWYgKCFpY29uKSB7XG4gICAgcmV0dXJuXG4gIH1cbiAgaWYgKHR5cGVvZiBpY29uICE9PSAnc3RyaW5nJykge1xuICAgIGljb24gPSBpY29uLmlkXG4gIH1cbiAgcmV0dXJuIGAvYXBpL2ljb25zLyR7aWNvbn0vY29udGVudGBcbn1cblxuZXhwb3J0IHR5cGUgU3RhdGljSWNvblJlZmVyZW5jZSA9IFJlZ2lzdGVyZWRTdGF0aWNJY29uUmVmZXJlbmNlIHwgU291cmNlVXJsU3RhdGljSWNvblJlZmVyZW5jZVxuIl19
|