@sitecore-jss/sitecore-jss-angular 21.2.3 → 21.2.4-canary.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/dist/components/data-resolver-factory.d.ts +13 -13
- package/dist/components/date.directive.d.ts +20 -20
- package/dist/components/editframe.component.d.ts +22 -22
- package/dist/components/file.directive.d.ts +17 -17
- package/dist/components/generic-link.directive.d.ts +20 -20
- package/dist/components/guard-resolver-factory.d.ts +11 -11
- package/dist/components/hidden-rendering.component.d.ts +7 -7
- package/dist/components/image.directive.d.ts +35 -35
- package/dist/components/link.directive.d.ts +26 -26
- package/dist/components/missing-component.component.d.ts +7 -7
- package/dist/components/placeholder-loading.directive.d.ts +8 -8
- package/dist/components/placeholder.component.d.ts +59 -59
- package/dist/components/placeholder.token.d.ts +64 -64
- package/dist/components/raw.component.d.ts +12 -12
- package/dist/components/render-component.component.d.ts +33 -33
- package/dist/components/render-each.directive.d.ts +8 -8
- package/dist/components/render-empty.directive.d.ts +8 -8
- package/dist/components/rendering-field.d.ts +41 -41
- package/dist/components/rendering.d.ts +5 -5
- package/dist/components/rich-text.directive.d.ts +18 -18
- package/dist/components/router-link.directive.d.ts +19 -19
- package/dist/components/text.directive.d.ts +16 -16
- package/dist/esm2020/components/data-resolver-factory.mjs +57 -57
- package/dist/esm2020/components/date.directive.mjs +59 -59
- package/dist/esm2020/components/editframe.component.mjs +65 -65
- package/dist/esm2020/components/file.directive.mjs +44 -44
- package/dist/esm2020/components/generic-link.directive.mjs +64 -64
- package/dist/esm2020/components/guard-resolver-factory.mjs +87 -87
- package/dist/esm2020/components/hidden-rendering.component.mjs +20 -20
- package/dist/esm2020/components/image.directive.mjs +137 -137
- package/dist/esm2020/components/link.directive.mjs +117 -117
- package/dist/esm2020/components/missing-component.component.mjs +15 -15
- package/dist/esm2020/components/placeholder-loading.directive.mjs +15 -15
- package/dist/esm2020/components/placeholder.component.mjs +250 -250
- package/dist/esm2020/components/placeholder.token.mjs +23 -23
- package/dist/esm2020/components/raw.component.mjs +35 -35
- package/dist/esm2020/components/render-component.component.mjs +90 -90
- package/dist/esm2020/components/render-each.directive.mjs +15 -15
- package/dist/esm2020/components/render-empty.directive.mjs +15 -15
- package/dist/esm2020/components/rendering-field.mjs +1 -1
- package/dist/esm2020/components/rendering.mjs +7 -7
- package/dist/esm2020/components/rich-text.directive.mjs +62 -62
- package/dist/esm2020/components/router-link.directive.mjs +47 -47
- package/dist/esm2020/components/text.directive.mjs +57 -57
- package/dist/esm2020/jss-component-factory.service.mjs +83 -83
- package/dist/esm2020/lib.module.mjs +167 -167
- package/dist/esm2020/public_api.mjs +24 -24
- package/dist/esm2020/sitecore-jss-sitecore-jss-angular.mjs +4 -4
- package/dist/esm2020/utils.mjs +16 -16
- package/dist/fesm2015/sitecore-jss-sitecore-jss-angular.mjs +1415 -1415
- package/dist/fesm2020/sitecore-jss-sitecore-jss-angular.mjs +1422 -1422
- package/dist/index.d.ts +5 -5
- package/dist/jss-component-factory.service.d.ts +25 -25
- package/dist/lib.module.d.ts +46 -46
- package/dist/package.json +2 -2
- package/dist/public_api.d.ts +25 -25
- package/dist/utils.d.ts +7 -7
- package/package.json +3 -3
|
@@ -1,88 +1,88 @@
|
|
|
1
|
-
import { UrlTree } from '@angular/router';
|
|
2
|
-
import { take, mergeMap } from 'rxjs/operators';
|
|
3
|
-
import { wrapIntoObservable } from '../utils';
|
|
4
|
-
import { throwError, of } from 'rxjs';
|
|
5
|
-
/**
|
|
6
|
-
* @param {boolean | string | string[] | UrlTree} value
|
|
7
|
-
* @returns instance of value
|
|
8
|
-
*/
|
|
9
|
-
function isRedirectValue(value) {
|
|
10
|
-
return value instanceof UrlTree || typeof value === 'string' || Array.isArray(value);
|
|
11
|
-
}
|
|
12
|
-
/**
|
|
13
|
-
* Resolves components based on provided guards
|
|
14
|
-
* @param {Injector} injector
|
|
15
|
-
* @param {ActivatedRoute} activatedRoute
|
|
16
|
-
* @param {Router} router
|
|
17
|
-
* @returns {(factories: ComponentFactoryResult[]) => Promise<ComponentFactoryResult[]>} factory
|
|
18
|
-
*/
|
|
19
|
-
export function guardResolverFactory(injector, activatedRoute, router) {
|
|
20
|
-
/**
|
|
21
|
-
* @param {JssCanActivate | Type<JssCanActivate> | JssCanActivateFn} guard
|
|
22
|
-
* @returns resolved guard
|
|
23
|
-
*/
|
|
24
|
-
function getGuardInstance(guard) {
|
|
25
|
-
if ('canActivate' in guard) {
|
|
26
|
-
return guard;
|
|
27
|
-
}
|
|
28
|
-
try {
|
|
29
|
-
// Class is provided
|
|
30
|
-
return injector.get(guard);
|
|
31
|
-
}
|
|
32
|
-
catch {
|
|
33
|
-
// Function is provided
|
|
34
|
-
return guard;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
/**
|
|
38
|
-
* @param {ComponentFactoryResult} factory
|
|
39
|
-
* @returns {(JssCanActivate | JssCanActivateFn)[]} guard instances
|
|
40
|
-
*/
|
|
41
|
-
function collectGuardInstances(factory) {
|
|
42
|
-
if (factory.canActivate) {
|
|
43
|
-
return Array.isArray(factory.canActivate)
|
|
44
|
-
? factory.canActivate.map(getGuardInstance)
|
|
45
|
-
: [getGuardInstance(factory.canActivate)];
|
|
46
|
-
}
|
|
47
|
-
return [];
|
|
48
|
-
}
|
|
49
|
-
/**
|
|
50
|
-
*
|
|
51
|
-
* @param {JssCanActivate | JssCanActivateFn} guard
|
|
52
|
-
* @param {ComponentFactoryResult} factory
|
|
53
|
-
* @returns canActivate
|
|
54
|
-
*/
|
|
55
|
-
function resolveGuard(guard, factory) {
|
|
56
|
-
const canActivate = 'canActivate' in guard ? guard.canActivate : guard;
|
|
57
|
-
const guardValue = canActivate({
|
|
58
|
-
activatedRoute: activatedRoute.snapshot,
|
|
59
|
-
routerState: router.routerState.snapshot,
|
|
60
|
-
rendering: factory.componentDefinition,
|
|
61
|
-
});
|
|
62
|
-
const canActivate$ = wrapIntoObservable(guardValue);
|
|
63
|
-
return canActivate$
|
|
64
|
-
.pipe(take(1), mergeMap((value) => {
|
|
65
|
-
if (isRedirectValue(value)) {
|
|
66
|
-
return throwError(value);
|
|
67
|
-
}
|
|
68
|
-
else {
|
|
69
|
-
return of(value);
|
|
70
|
-
}
|
|
71
|
-
}))
|
|
72
|
-
.toPromise();
|
|
73
|
-
}
|
|
74
|
-
return function resolveGuards(factories) {
|
|
75
|
-
const resolved = factories.map((factory) => {
|
|
76
|
-
const guards = collectGuardInstances(factory);
|
|
77
|
-
const pending = guards.map((guard) => resolveGuard(guard, factory));
|
|
78
|
-
return Promise.all(pending)
|
|
79
|
-
.then((canActive) => canActive.every((v) => v))
|
|
80
|
-
.then((canActivate) => ({
|
|
81
|
-
factory,
|
|
82
|
-
canActivate,
|
|
83
|
-
}));
|
|
84
|
-
});
|
|
85
|
-
return Promise.all(resolved).then((mapped) => mapped.filter((m) => m.canActivate).map((m) => m.factory));
|
|
86
|
-
};
|
|
87
|
-
}
|
|
1
|
+
import { UrlTree } from '@angular/router';
|
|
2
|
+
import { take, mergeMap } from 'rxjs/operators';
|
|
3
|
+
import { wrapIntoObservable } from '../utils';
|
|
4
|
+
import { throwError, of } from 'rxjs';
|
|
5
|
+
/**
|
|
6
|
+
* @param {boolean | string | string[] | UrlTree} value
|
|
7
|
+
* @returns instance of value
|
|
8
|
+
*/
|
|
9
|
+
function isRedirectValue(value) {
|
|
10
|
+
return value instanceof UrlTree || typeof value === 'string' || Array.isArray(value);
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Resolves components based on provided guards
|
|
14
|
+
* @param {Injector} injector
|
|
15
|
+
* @param {ActivatedRoute} activatedRoute
|
|
16
|
+
* @param {Router} router
|
|
17
|
+
* @returns {(factories: ComponentFactoryResult[]) => Promise<ComponentFactoryResult[]>} factory
|
|
18
|
+
*/
|
|
19
|
+
export function guardResolverFactory(injector, activatedRoute, router) {
|
|
20
|
+
/**
|
|
21
|
+
* @param {JssCanActivate | Type<JssCanActivate> | JssCanActivateFn} guard
|
|
22
|
+
* @returns resolved guard
|
|
23
|
+
*/
|
|
24
|
+
function getGuardInstance(guard) {
|
|
25
|
+
if ('canActivate' in guard) {
|
|
26
|
+
return guard;
|
|
27
|
+
}
|
|
28
|
+
try {
|
|
29
|
+
// Class is provided
|
|
30
|
+
return injector.get(guard);
|
|
31
|
+
}
|
|
32
|
+
catch {
|
|
33
|
+
// Function is provided
|
|
34
|
+
return guard;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* @param {ComponentFactoryResult} factory
|
|
39
|
+
* @returns {(JssCanActivate | JssCanActivateFn)[]} guard instances
|
|
40
|
+
*/
|
|
41
|
+
function collectGuardInstances(factory) {
|
|
42
|
+
if (factory.canActivate) {
|
|
43
|
+
return Array.isArray(factory.canActivate)
|
|
44
|
+
? factory.canActivate.map(getGuardInstance)
|
|
45
|
+
: [getGuardInstance(factory.canActivate)];
|
|
46
|
+
}
|
|
47
|
+
return [];
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
*
|
|
51
|
+
* @param {JssCanActivate | JssCanActivateFn} guard
|
|
52
|
+
* @param {ComponentFactoryResult} factory
|
|
53
|
+
* @returns canActivate
|
|
54
|
+
*/
|
|
55
|
+
function resolveGuard(guard, factory) {
|
|
56
|
+
const canActivate = 'canActivate' in guard ? guard.canActivate : guard;
|
|
57
|
+
const guardValue = canActivate({
|
|
58
|
+
activatedRoute: activatedRoute.snapshot,
|
|
59
|
+
routerState: router.routerState.snapshot,
|
|
60
|
+
rendering: factory.componentDefinition,
|
|
61
|
+
});
|
|
62
|
+
const canActivate$ = wrapIntoObservable(guardValue);
|
|
63
|
+
return canActivate$
|
|
64
|
+
.pipe(take(1), mergeMap((value) => {
|
|
65
|
+
if (isRedirectValue(value)) {
|
|
66
|
+
return throwError(value);
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
return of(value);
|
|
70
|
+
}
|
|
71
|
+
}))
|
|
72
|
+
.toPromise();
|
|
73
|
+
}
|
|
74
|
+
return function resolveGuards(factories) {
|
|
75
|
+
const resolved = factories.map((factory) => {
|
|
76
|
+
const guards = collectGuardInstances(factory);
|
|
77
|
+
const pending = guards.map((guard) => resolveGuard(guard, factory));
|
|
78
|
+
return Promise.all(pending)
|
|
79
|
+
.then((canActive) => canActive.every((v) => v))
|
|
80
|
+
.then((canActivate) => ({
|
|
81
|
+
factory,
|
|
82
|
+
canActivate,
|
|
83
|
+
}));
|
|
84
|
+
});
|
|
85
|
+
return Promise.all(resolved).then((mapped) => mapped.filter((m) => m.canActivate).map((m) => m.factory));
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
88
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"guard-resolver-factory.js","sourceRoot":"","sources":["../../../src/components/guard-resolver-factory.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injector, Type } from '@angular/core';\r\nimport { ActivatedRoute, Router, UrlTree } from '@angular/router';\r\nimport { take, mergeMap } from 'rxjs/operators';\r\nimport { ComponentFactoryResult } from '../jss-component-factory.service';\r\nimport { wrapIntoObservable } from '../utils';\r\nimport { JssCanActivate, JssCanActivateFn } from './placeholder.token';\r\nimport { ComponentRendering } from '@sitecore-jss/sitecore-jss/layout';\r\nimport { throwError, of } from 'rxjs';\r\n\r\n/**\r\n * @param {boolean | string | string[] | UrlTree} value\r\n * @returns instance of value\r\n */\r\nfunction isRedirectValue(\r\n  value: boolean | string | string[] | UrlTree\r\n): value is string | string[] | UrlTree {\r\n  return value instanceof UrlTree || typeof value === 'string' || Array.isArray(value);\r\n}\r\n\r\n/**\r\n * Resolves components based on provided guards\r\n * @param {Injector} injector\r\n * @param {ActivatedRoute} activatedRoute\r\n * @param {Router} router\r\n * @returns {(factories: ComponentFactoryResult[]) => Promise<ComponentFactoryResult[]>} factory\r\n */\r\nexport function guardResolverFactory(\r\n  injector: Injector,\r\n  activatedRoute: ActivatedRoute,\r\n  router: Router\r\n) {\r\n  /**\r\n   * @param {JssCanActivate | Type<JssCanActivate> | JssCanActivateFn} guard\r\n   * @returns resolved guard\r\n   */\r\n  function getGuardInstance(\r\n    guard: JssCanActivate | Type<JssCanActivate> | JssCanActivateFn\r\n  ): JssCanActivate | JssCanActivateFn {\r\n    if ('canActivate' in guard) {\r\n      return guard;\r\n    }\r\n\r\n    try {\r\n      // Class is provided\r\n      return injector.get(guard);\r\n    } catch {\r\n      // Function is provided\r\n      return guard as JssCanActivateFn;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * @param {ComponentFactoryResult} factory\r\n   * @returns {(JssCanActivate | JssCanActivateFn)[]} guard instances\r\n   */\r\n  function collectGuardInstances(\r\n    factory: ComponentFactoryResult\r\n  ): (JssCanActivate | JssCanActivateFn)[] {\r\n    if (factory.canActivate) {\r\n      return Array.isArray(factory.canActivate)\r\n        ? factory.canActivate.map(getGuardInstance)\r\n        : [getGuardInstance(factory.canActivate)];\r\n    }\r\n\r\n    return [];\r\n  }\r\n\r\n  /**\r\n   *\r\n   * @param {JssCanActivate | JssCanActivateFn} guard\r\n   * @param {ComponentFactoryResult} factory\r\n   * @returns canActivate\r\n   */\r\n  function resolveGuard(guard: JssCanActivate | JssCanActivateFn, factory: ComponentFactoryResult) {\r\n    const canActivate = 'canActivate' in guard ? guard.canActivate : guard;\r\n    const guardValue = canActivate({\r\n      activatedRoute: activatedRoute.snapshot,\r\n      routerState: router.routerState.snapshot,\r\n      rendering: factory.componentDefinition as ComponentRendering,\r\n    });\r\n\r\n    const canActivate$ = wrapIntoObservable(guardValue);\r\n\r\n    return canActivate$\r\n      .pipe(\r\n        take(1),\r\n        mergeMap((value) => {\r\n          if (isRedirectValue(value)) {\r\n            return throwError(value);\r\n          } else {\r\n            return of(value);\r\n          }\r\n        })\r\n      )\r\n      .toPromise();\r\n  }\r\n\r\n  return function resolveGuards(factories: ComponentFactoryResult[]) {\r\n    const resolved = factories.map((factory) => {\r\n      const guards = collectGuardInstances(factory);\r\n      const pending = guards.map((guard) => resolveGuard(guard, factory));\r\n      return Promise.all(pending)\r\n        .then((canActive) => canActive.every((v) => v))\r\n        .then((canActivate) => ({\r\n          factory,\r\n          canActivate,\r\n        }));\r\n    });\r\n\r\n    return Promise.all(resolved).then((mapped) =>\r\n      mapped.filter((m) => m.canActivate).map((m) => m.factory)\r\n    );\r\n  };\r\n}\r\n"]}
|
|
@@ -1,21 +1,21 @@
|
|
|
1
|
-
import { Component, HostBinding } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class HiddenRenderingComponent {
|
|
4
|
-
get style() {
|
|
5
|
-
return 'background-image: linear-gradient(45deg, #ffffff 25%, #dcdcdc 25%, #dcdcdc 50%, #ffffff 50%, #ffffff 75%, #dcdcdc 75%, #dcdcdc 100%); background-size: 3px 3px; display: block; height: 100px;';
|
|
6
|
-
}
|
|
7
|
-
}
|
|
8
|
-
HiddenRenderingComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: HiddenRenderingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
9
|
-
HiddenRenderingComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: HiddenRenderingComponent, selector: "sc-hidden-rendering", host: { properties: { "style": "this.style" } }, ngImport: i0, template: '', isInline: true });
|
|
10
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: HiddenRenderingComponent, decorators: [{
|
|
11
|
-
type: Component,
|
|
12
|
-
args: [{
|
|
13
|
-
selector: 'sc-hidden-rendering',
|
|
14
|
-
template: '',
|
|
15
|
-
}]
|
|
16
|
-
}], propDecorators: { style: [{
|
|
17
|
-
type: HostBinding,
|
|
18
|
-
args: ['style']
|
|
19
|
-
}] } });
|
|
20
|
-
export const HIDDEN_RENDERING_NAME = 'Hidden Rendering';
|
|
1
|
+
import { Component, HostBinding } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class HiddenRenderingComponent {
|
|
4
|
+
get style() {
|
|
5
|
+
return 'background-image: linear-gradient(45deg, #ffffff 25%, #dcdcdc 25%, #dcdcdc 50%, #ffffff 50%, #ffffff 75%, #dcdcdc 75%, #dcdcdc 100%); background-size: 3px 3px; display: block; height: 100px;';
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
HiddenRenderingComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: HiddenRenderingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
9
|
+
HiddenRenderingComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: HiddenRenderingComponent, selector: "sc-hidden-rendering", host: { properties: { "style": "this.style" } }, ngImport: i0, template: '', isInline: true });
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: HiddenRenderingComponent, decorators: [{
|
|
11
|
+
type: Component,
|
|
12
|
+
args: [{
|
|
13
|
+
selector: 'sc-hidden-rendering',
|
|
14
|
+
template: '',
|
|
15
|
+
}]
|
|
16
|
+
}], propDecorators: { style: [{
|
|
17
|
+
type: HostBinding,
|
|
18
|
+
args: ['style']
|
|
19
|
+
}] } });
|
|
20
|
+
export const HIDDEN_RENDERING_NAME = 'Hidden Rendering';
|
|
21
21
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGlkZGVuLXJlbmRlcmluZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9oaWRkZW4tcmVuZGVyaW5nLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFLdkQsTUFBTSxPQUFPLHdCQUF3QjtJQUNuQyxJQUEwQixLQUFLO1FBQzdCLE9BQU8sZ01BQWdNLENBQUM7SUFDMU0sQ0FBQzs7c0hBSFUsd0JBQXdCOzBHQUF4Qix3QkFBd0IsNEdBRnpCLEVBQUU7NEZBRUQsd0JBQXdCO2tCQUpwQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxxQkFBcUI7b0JBQy9CLFFBQVEsRUFBRSxFQUFFO2lCQUNiOzhCQUUyQixLQUFLO3NCQUE5QixXQUFXO3VCQUFDLE9BQU87O0FBS3RCLE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHLGtCQUFrQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBIb3N0QmluZGluZyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3NjLWhpZGRlbi1yZW5kZXJpbmcnLFxyXG4gIHRlbXBsYXRlOiAnJyxcclxufSlcclxuZXhwb3J0IGNsYXNzIEhpZGRlblJlbmRlcmluZ0NvbXBvbmVudCB7XHJcbiAgQEhvc3RCaW5kaW5nKCdzdHlsZScpIGdldCBzdHlsZSgpIHtcclxuICAgIHJldHVybiAnYmFja2dyb3VuZC1pbWFnZTogbGluZWFyLWdyYWRpZW50KDQ1ZGVnLCAjZmZmZmZmIDI1JSwgI2RjZGNkYyAyNSUsICNkY2RjZGMgNTAlLCAjZmZmZmZmIDUwJSwgI2ZmZmZmZiA3NSUsICNkY2RjZGMgNzUlLCAjZGNkY2RjIDEwMCUpOyBiYWNrZ3JvdW5kLXNpemU6IDNweCAzcHg7IGRpc3BsYXk6IGJsb2NrOyBoZWlnaHQ6IDEwMHB4Oyc7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgY29uc3QgSElEREVOX1JFTkRFUklOR19OQU1FID0gJ0hpZGRlbiBSZW5kZXJpbmcnO1xyXG4iXX0=
|
|
@@ -1,138 +1,138 @@
|
|
|
1
|
-
import { Directive, Input, } from '@angular/core';
|
|
2
|
-
import { mediaApi } from '@sitecore-jss/sitecore-jss/media';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export class ImageDirective {
|
|
5
|
-
constructor(viewContainer, templateRef, renderer, elementRef) {
|
|
6
|
-
this.viewContainer = viewContainer;
|
|
7
|
-
this.templateRef = templateRef;
|
|
8
|
-
this.renderer = renderer;
|
|
9
|
-
this.elementRef = elementRef;
|
|
10
|
-
this.editable = true;
|
|
11
|
-
this.urlParams = {};
|
|
12
|
-
this.attrs = {};
|
|
13
|
-
this.inlineRef = null;
|
|
14
|
-
}
|
|
15
|
-
ngOnChanges(changes) {
|
|
16
|
-
if (changes.field || changes.editable || changes.urlParams || changes.attrs) {
|
|
17
|
-
this.viewContainer.clear();
|
|
18
|
-
if (this.inlineRef) {
|
|
19
|
-
this.inlineRef.remove();
|
|
20
|
-
this.inlineRef = null;
|
|
21
|
-
}
|
|
22
|
-
this.updateView();
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
updateView() {
|
|
26
|
-
const overrideAttrs = {
|
|
27
|
-
...this.getElementAttrs(),
|
|
28
|
-
...this.attrs,
|
|
29
|
-
};
|
|
30
|
-
const media = this.field;
|
|
31
|
-
if (!media || (!media.editable && !media.value && !media.src)) {
|
|
32
|
-
return;
|
|
33
|
-
}
|
|
34
|
-
let attrs = {};
|
|
35
|
-
// we likely have an experience editor value, should be a string
|
|
36
|
-
if (this.editable && media.editable) {
|
|
37
|
-
const foundImg = mediaApi.findEditorImageTag(media.editable);
|
|
38
|
-
if (!foundImg) {
|
|
39
|
-
return this.renderInlineWrapper(media.editable);
|
|
40
|
-
}
|
|
41
|
-
attrs = this.getImageAttrs(foundImg.attrs, overrideAttrs, this.urlParams);
|
|
42
|
-
if (!attrs) {
|
|
43
|
-
return this.renderInlineWrapper(media.editable);
|
|
44
|
-
}
|
|
45
|
-
const tempImg = this.renderer.createElement('img');
|
|
46
|
-
Object.entries(attrs).forEach(([key, attrValue]) => tempImg.setAttribute(key, attrValue));
|
|
47
|
-
const editableMarkup = media.editable.replace(foundImg.imgTag, tempImg.outerHTML);
|
|
48
|
-
return this.renderInlineWrapper(editableMarkup);
|
|
49
|
-
}
|
|
50
|
-
// some wise-guy/gal is passing in a 'raw' image object value
|
|
51
|
-
const img = media.src ? media : media.value;
|
|
52
|
-
if (!img) {
|
|
53
|
-
return null;
|
|
54
|
-
}
|
|
55
|
-
attrs = this.getImageAttrs(img, overrideAttrs, this.urlParams);
|
|
56
|
-
if (attrs) {
|
|
57
|
-
this.renderTemplate(attrs);
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
getImageAttrs(fieldAttrs, parsedAttrs, imageParams) {
|
|
61
|
-
const combinedAttrs = {
|
|
62
|
-
...fieldAttrs,
|
|
63
|
-
...parsedAttrs,
|
|
64
|
-
};
|
|
65
|
-
// eslint-disable-next-line prefer-const
|
|
66
|
-
let { src, srcSet, ...otherAttrs } = combinedAttrs;
|
|
67
|
-
if (!src) {
|
|
68
|
-
return null;
|
|
69
|
-
}
|
|
70
|
-
const newAttrs = {
|
|
71
|
-
...otherAttrs,
|
|
72
|
-
};
|
|
73
|
-
// update image URL for jss handler and image rendering params
|
|
74
|
-
src = mediaApi.updateImageUrl(src, imageParams, this.mediaUrlPrefix);
|
|
75
|
-
if (srcSet) {
|
|
76
|
-
// replace with HTML-formatted srcset, including updated image URLs
|
|
77
|
-
newAttrs.srcSet = mediaApi.getSrcSet(src, srcSet, imageParams, this.mediaUrlPrefix);
|
|
78
|
-
}
|
|
79
|
-
else {
|
|
80
|
-
newAttrs.src = src;
|
|
81
|
-
}
|
|
82
|
-
return newAttrs;
|
|
83
|
-
}
|
|
84
|
-
renderTemplate(imageProps) {
|
|
85
|
-
const viewRef = this.viewContainer.createEmbeddedView(this.templateRef);
|
|
86
|
-
viewRef.rootNodes.forEach((node) => {
|
|
87
|
-
Object.entries(imageProps).forEach(([key, imgPropVal]) => this.renderer.setAttribute(node, key, imgPropVal));
|
|
88
|
-
});
|
|
89
|
-
}
|
|
90
|
-
getElementAttrs() {
|
|
91
|
-
const view = this.templateRef.createEmbeddedView(null);
|
|
92
|
-
const element = view.rootNodes[0];
|
|
93
|
-
if (!element) {
|
|
94
|
-
view.destroy();
|
|
95
|
-
return {};
|
|
96
|
-
}
|
|
97
|
-
const attrs = {};
|
|
98
|
-
for (let i = 0; i < element.attributes.length; i++) {
|
|
99
|
-
const attr = element.attributes.item(i);
|
|
100
|
-
if (attr) {
|
|
101
|
-
attrs[attr.name] = attr.value;
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
view.destroy();
|
|
105
|
-
return attrs;
|
|
106
|
-
}
|
|
107
|
-
renderInlineWrapper(editable) {
|
|
108
|
-
const span = this.renderer.createElement('span');
|
|
109
|
-
span.className = 'sc-image-wrapper';
|
|
110
|
-
span.innerHTML = editable;
|
|
111
|
-
const parentNode = this.renderer.parentNode(this.elementRef.nativeElement);
|
|
112
|
-
this.renderer.insertBefore(parentNode, span, this.elementRef.nativeElement);
|
|
113
|
-
parentNode.removeChild(this.elementRef.nativeElement);
|
|
114
|
-
this.inlineRef = span;
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
ImageDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ImageDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.TemplateRef }, { token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
118
|
-
ImageDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: ImageDirective, selector: "[scImage]", inputs: { field: ["scImage", "field"], editable: ["scImageEditable", "editable"], mediaUrlPrefix: ["scImageMediaUrlPrefix", "mediaUrlPrefix"], urlParams: ["scImageUrlParams", "urlParams"], attrs: ["scImageAttrs", "attrs"] }, usesOnChanges: true, ngImport: i0 });
|
|
119
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ImageDirective, decorators: [{
|
|
120
|
-
type: Directive,
|
|
121
|
-
args: [{ selector: '[scImage]' }]
|
|
122
|
-
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.TemplateRef }, { type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { field: [{
|
|
123
|
-
type: Input,
|
|
124
|
-
args: ['scImage']
|
|
125
|
-
}], editable: [{
|
|
126
|
-
type: Input,
|
|
127
|
-
args: ['scImageEditable']
|
|
128
|
-
}], mediaUrlPrefix: [{
|
|
129
|
-
type: Input,
|
|
130
|
-
args: ['scImageMediaUrlPrefix']
|
|
131
|
-
}], urlParams: [{
|
|
132
|
-
type: Input,
|
|
133
|
-
args: ['scImageUrlParams']
|
|
134
|
-
}], attrs: [{
|
|
135
|
-
type: Input,
|
|
136
|
-
args: ['scImageAttrs']
|
|
137
|
-
}] } });
|
|
1
|
+
import { Directive, Input, } from '@angular/core';
|
|
2
|
+
import { mediaApi } from '@sitecore-jss/sitecore-jss/media';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class ImageDirective {
|
|
5
|
+
constructor(viewContainer, templateRef, renderer, elementRef) {
|
|
6
|
+
this.viewContainer = viewContainer;
|
|
7
|
+
this.templateRef = templateRef;
|
|
8
|
+
this.renderer = renderer;
|
|
9
|
+
this.elementRef = elementRef;
|
|
10
|
+
this.editable = true;
|
|
11
|
+
this.urlParams = {};
|
|
12
|
+
this.attrs = {};
|
|
13
|
+
this.inlineRef = null;
|
|
14
|
+
}
|
|
15
|
+
ngOnChanges(changes) {
|
|
16
|
+
if (changes.field || changes.editable || changes.urlParams || changes.attrs) {
|
|
17
|
+
this.viewContainer.clear();
|
|
18
|
+
if (this.inlineRef) {
|
|
19
|
+
this.inlineRef.remove();
|
|
20
|
+
this.inlineRef = null;
|
|
21
|
+
}
|
|
22
|
+
this.updateView();
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
updateView() {
|
|
26
|
+
const overrideAttrs = {
|
|
27
|
+
...this.getElementAttrs(),
|
|
28
|
+
...this.attrs,
|
|
29
|
+
};
|
|
30
|
+
const media = this.field;
|
|
31
|
+
if (!media || (!media.editable && !media.value && !media.src)) {
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
let attrs = {};
|
|
35
|
+
// we likely have an experience editor value, should be a string
|
|
36
|
+
if (this.editable && media.editable) {
|
|
37
|
+
const foundImg = mediaApi.findEditorImageTag(media.editable);
|
|
38
|
+
if (!foundImg) {
|
|
39
|
+
return this.renderInlineWrapper(media.editable);
|
|
40
|
+
}
|
|
41
|
+
attrs = this.getImageAttrs(foundImg.attrs, overrideAttrs, this.urlParams);
|
|
42
|
+
if (!attrs) {
|
|
43
|
+
return this.renderInlineWrapper(media.editable);
|
|
44
|
+
}
|
|
45
|
+
const tempImg = this.renderer.createElement('img');
|
|
46
|
+
Object.entries(attrs).forEach(([key, attrValue]) => tempImg.setAttribute(key, attrValue));
|
|
47
|
+
const editableMarkup = media.editable.replace(foundImg.imgTag, tempImg.outerHTML);
|
|
48
|
+
return this.renderInlineWrapper(editableMarkup);
|
|
49
|
+
}
|
|
50
|
+
// some wise-guy/gal is passing in a 'raw' image object value
|
|
51
|
+
const img = media.src ? media : media.value;
|
|
52
|
+
if (!img) {
|
|
53
|
+
return null;
|
|
54
|
+
}
|
|
55
|
+
attrs = this.getImageAttrs(img, overrideAttrs, this.urlParams);
|
|
56
|
+
if (attrs) {
|
|
57
|
+
this.renderTemplate(attrs);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
getImageAttrs(fieldAttrs, parsedAttrs, imageParams) {
|
|
61
|
+
const combinedAttrs = {
|
|
62
|
+
...fieldAttrs,
|
|
63
|
+
...parsedAttrs,
|
|
64
|
+
};
|
|
65
|
+
// eslint-disable-next-line prefer-const
|
|
66
|
+
let { src, srcSet, ...otherAttrs } = combinedAttrs;
|
|
67
|
+
if (!src) {
|
|
68
|
+
return null;
|
|
69
|
+
}
|
|
70
|
+
const newAttrs = {
|
|
71
|
+
...otherAttrs,
|
|
72
|
+
};
|
|
73
|
+
// update image URL for jss handler and image rendering params
|
|
74
|
+
src = mediaApi.updateImageUrl(src, imageParams, this.mediaUrlPrefix);
|
|
75
|
+
if (srcSet) {
|
|
76
|
+
// replace with HTML-formatted srcset, including updated image URLs
|
|
77
|
+
newAttrs.srcSet = mediaApi.getSrcSet(src, srcSet, imageParams, this.mediaUrlPrefix);
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
newAttrs.src = src;
|
|
81
|
+
}
|
|
82
|
+
return newAttrs;
|
|
83
|
+
}
|
|
84
|
+
renderTemplate(imageProps) {
|
|
85
|
+
const viewRef = this.viewContainer.createEmbeddedView(this.templateRef);
|
|
86
|
+
viewRef.rootNodes.forEach((node) => {
|
|
87
|
+
Object.entries(imageProps).forEach(([key, imgPropVal]) => this.renderer.setAttribute(node, key, imgPropVal));
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
getElementAttrs() {
|
|
91
|
+
const view = this.templateRef.createEmbeddedView(null);
|
|
92
|
+
const element = view.rootNodes[0];
|
|
93
|
+
if (!element) {
|
|
94
|
+
view.destroy();
|
|
95
|
+
return {};
|
|
96
|
+
}
|
|
97
|
+
const attrs = {};
|
|
98
|
+
for (let i = 0; i < element.attributes.length; i++) {
|
|
99
|
+
const attr = element.attributes.item(i);
|
|
100
|
+
if (attr) {
|
|
101
|
+
attrs[attr.name] = attr.value;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
view.destroy();
|
|
105
|
+
return attrs;
|
|
106
|
+
}
|
|
107
|
+
renderInlineWrapper(editable) {
|
|
108
|
+
const span = this.renderer.createElement('span');
|
|
109
|
+
span.className = 'sc-image-wrapper';
|
|
110
|
+
span.innerHTML = editable;
|
|
111
|
+
const parentNode = this.renderer.parentNode(this.elementRef.nativeElement);
|
|
112
|
+
this.renderer.insertBefore(parentNode, span, this.elementRef.nativeElement);
|
|
113
|
+
parentNode.removeChild(this.elementRef.nativeElement);
|
|
114
|
+
this.inlineRef = span;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
ImageDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ImageDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.TemplateRef }, { token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
118
|
+
ImageDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: ImageDirective, selector: "[scImage]", inputs: { field: ["scImage", "field"], editable: ["scImageEditable", "editable"], mediaUrlPrefix: ["scImageMediaUrlPrefix", "mediaUrlPrefix"], urlParams: ["scImageUrlParams", "urlParams"], attrs: ["scImageAttrs", "attrs"] }, usesOnChanges: true, ngImport: i0 });
|
|
119
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ImageDirective, decorators: [{
|
|
120
|
+
type: Directive,
|
|
121
|
+
args: [{ selector: '[scImage]' }]
|
|
122
|
+
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.TemplateRef }, { type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { field: [{
|
|
123
|
+
type: Input,
|
|
124
|
+
args: ['scImage']
|
|
125
|
+
}], editable: [{
|
|
126
|
+
type: Input,
|
|
127
|
+
args: ['scImageEditable']
|
|
128
|
+
}], mediaUrlPrefix: [{
|
|
129
|
+
type: Input,
|
|
130
|
+
args: ['scImageMediaUrlPrefix']
|
|
131
|
+
}], urlParams: [{
|
|
132
|
+
type: Input,
|
|
133
|
+
args: ['scImageUrlParams']
|
|
134
|
+
}], attrs: [{
|
|
135
|
+
type: Input,
|
|
136
|
+
args: ['scImageAttrs']
|
|
137
|
+
}] } });
|
|
138
138
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.directive.js","sourceRoot":"","sources":["../../../src/components/image.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  Input,\r\n  OnChanges,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  TemplateRef,\r\n  ViewContainerRef,\r\n} from '@angular/core';\r\nimport { mediaApi } from '@sitecore-jss/sitecore-jss/media';\r\nimport { ImageField, ImageFieldValue } from './rendering-field';\r\n\r\n@Directive({ selector: '[scImage]' })\r\nexport class ImageDirective implements OnChanges {\r\n  @Input('scImage') field: ImageField | '';\r\n\r\n  @Input('scImageEditable') editable = true;\r\n\r\n  /**\r\n   * Custom regexp that finds media URL prefix that will be replaced by `/-/jssmedia` or `/~/jssmedia`.\r\n   * @example\r\n   * /\\/([-~]{1})assets\\//i\r\n   * /-assets/website -> /-/jssmedia/website\r\n   * /~assets/website -> /~/jssmedia/website\r\n   */\r\n  @Input('scImageMediaUrlPrefix') mediaUrlPrefix?: RegExp;\r\n\r\n  @Input('scImageUrlParams') urlParams: { [param: string]: string | number } = {};\r\n\r\n  @Input('scImageAttrs') attrs: { [param: string]: unknown } = {};\r\n\r\n  private inlineRef: HTMLSpanElement | null = null;\r\n\r\n  constructor(\r\n    private viewContainer: ViewContainerRef,\r\n    private templateRef: TemplateRef<unknown>,\r\n    private renderer: Renderer2,\r\n    private elementRef: ElementRef\r\n  ) {}\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.field || changes.editable || changes.urlParams || changes.attrs) {\r\n      this.viewContainer.clear();\r\n      if (this.inlineRef) {\r\n        this.inlineRef.remove();\r\n        this.inlineRef = null;\r\n      }\r\n\r\n      this.updateView();\r\n    }\r\n  }\r\n\r\n  private updateView() {\r\n    const overrideAttrs = {\r\n      ...this.getElementAttrs(),\r\n      ...this.attrs,\r\n    };\r\n    const media = this.field;\r\n\r\n    if (!media || (!media.editable && !media.value && !media.src)) {\r\n      return;\r\n    }\r\n\r\n    let attrs: { [attr: string]: string } | null = {};\r\n\r\n    // we likely have an experience editor value, should be a string\r\n    if (this.editable && media.editable) {\r\n      const foundImg = mediaApi.findEditorImageTag(media.editable);\r\n      if (!foundImg) {\r\n        return this.renderInlineWrapper(media.editable);\r\n      }\r\n      attrs = this.getImageAttrs(foundImg.attrs, overrideAttrs, this.urlParams);\r\n      if (!attrs) {\r\n        return this.renderInlineWrapper(media.editable);\r\n      }\r\n      const tempImg: HTMLImageElement = this.renderer.createElement('img');\r\n      Object.entries(attrs).forEach(([key, attrValue]: [string, string]) =>\r\n        tempImg.setAttribute(key, attrValue)\r\n      );\r\n      const editableMarkup = media.editable.replace(foundImg.imgTag, tempImg.outerHTML);\r\n      return this.renderInlineWrapper(editableMarkup);\r\n    }\r\n\r\n    // some wise-guy/gal is passing in a 'raw' image object value\r\n    const img = media.src ? media : media.value;\r\n    if (!img) {\r\n      return null;\r\n    }\r\n\r\n    attrs = this.getImageAttrs(img, overrideAttrs, this.urlParams);\r\n    if (attrs) {\r\n      this.renderTemplate(attrs);\r\n    }\r\n  }\r\n\r\n  private getImageAttrs(\r\n    fieldAttrs: ImageFieldValue,\r\n    parsedAttrs: { [attr: string]: unknown },\r\n    imageParams: { [param: string]: string | number }\r\n  ): { [attr: string]: string } | null {\r\n    const combinedAttrs = {\r\n      ...fieldAttrs,\r\n      ...parsedAttrs,\r\n    };\r\n    // eslint-disable-next-line prefer-const\r\n    let { src, srcSet, ...otherAttrs } = combinedAttrs;\r\n    if (!src) {\r\n      return null;\r\n    }\r\n    const newAttrs: { [attr: string]: string } = {\r\n      ...(otherAttrs as { [key: string]: string }),\r\n    };\r\n    // update image URL for jss handler and image rendering params\r\n    src = mediaApi.updateImageUrl(src, imageParams, this.mediaUrlPrefix);\r\n    if (srcSet) {\r\n      // replace with HTML-formatted srcset, including updated image URLs\r\n      newAttrs.srcSet = mediaApi.getSrcSet(src, srcSet, imageParams, this.mediaUrlPrefix);\r\n    } else {\r\n      newAttrs.src = src;\r\n    }\r\n    return newAttrs;\r\n  }\r\n\r\n  private renderTemplate(imageProps: { [prop: string]: string }) {\r\n    const viewRef = this.viewContainer.createEmbeddedView(this.templateRef);\r\n    viewRef.rootNodes.forEach((node) => {\r\n      Object.entries(imageProps).forEach(([key, imgPropVal]: [string, string]) =>\r\n        this.renderer.setAttribute(node, key, imgPropVal)\r\n      );\r\n    });\r\n  }\r\n\r\n  private getElementAttrs(): { [key: string]: string } {\r\n    const view = this.templateRef.createEmbeddedView(null);\r\n    const element: Element = view.rootNodes[0];\r\n    if (!element) {\r\n      view.destroy();\r\n      return {};\r\n    }\r\n    const attrs: { [key: string]: string } = {};\r\n    for (let i = 0; i < element.attributes.length; i++) {\r\n      const attr = element.attributes.item(i);\r\n      if (attr) {\r\n        attrs[attr.name] = attr.value;\r\n      }\r\n    }\r\n    view.destroy();\r\n    return attrs;\r\n  }\r\n\r\n  private renderInlineWrapper(editable: string) {\r\n    const span: HTMLSpanElement = this.renderer.createElement('span');\r\n    span.className = 'sc-image-wrapper';\r\n    span.innerHTML = editable;\r\n\r\n    const parentNode = this.renderer.parentNode(this.elementRef.nativeElement);\r\n    this.renderer.insertBefore(parentNode, span, this.elementRef.nativeElement);\r\n    parentNode.removeChild(this.elementRef.nativeElement);\r\n\r\n    this.inlineRef = span;\r\n  }\r\n}\r\n"]}
|