@sitecore-jss/sitecore-jss-angular 21.6.2-canary.2 → 21.6.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/LICENSE.txt +202 -202
- package/README.md +7 -7
- package/angular.json +48 -48
- package/dist/README.md +7 -7
- 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/esm2022/components/data-resolver-factory.mjs +58 -58
- package/dist/esm2022/components/date.directive.mjs +67 -67
- package/dist/esm2022/components/editframe.component.mjs +70 -70
- package/dist/esm2022/components/file.directive.mjs +48 -48
- package/dist/esm2022/components/generic-link.directive.mjs +67 -67
- package/dist/esm2022/components/guard-resolver-factory.mjs +85 -85
- package/dist/esm2022/components/hidden-rendering.component.mjs +20 -20
- package/dist/esm2022/components/image.directive.mjs +150 -150
- package/dist/esm2022/components/link.directive.mjs +122 -122
- package/dist/esm2022/components/missing-component.component.mjs +16 -16
- package/dist/esm2022/components/placeholder-loading.directive.mjs +16 -16
- package/dist/esm2022/components/placeholder.component.mjs +271 -271
- package/dist/esm2022/components/placeholder.token.mjs +27 -27
- package/dist/esm2022/components/raw.component.mjs +38 -38
- package/dist/esm2022/components/render-component.component.mjs +98 -98
- package/dist/esm2022/components/render-each.directive.mjs +16 -16
- package/dist/esm2022/components/render-empty.directive.mjs +16 -16
- package/dist/esm2022/components/rendering-field.mjs +1 -1
- package/dist/esm2022/components/rendering.mjs +7 -7
- package/dist/esm2022/components/rich-text.directive.mjs +68 -68
- package/dist/esm2022/components/router-link.directive.mjs +49 -49
- package/dist/esm2022/components/text.directive.mjs +61 -61
- package/dist/esm2022/jss-component-factory.service.mjs +87 -87
- package/dist/esm2022/lib.module.mjs +160 -160
- package/dist/esm2022/public_api.mjs +24 -24
- package/dist/esm2022/sitecore-jss-sitecore-jss-angular.mjs +4 -4
- package/dist/esm2022/utils.mjs +16 -16
- package/dist/fesm2022/sitecore-jss-sitecore-jss-angular.mjs +1507 -1507
- 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 +6 -6
- package/ng-package.json +13 -13
- package/package.json +3 -3
- package/tsconfig.json +9 -9
- package/tsconfig.spec.json +17 -17
- package/typings/README.md +2 -2
|
@@ -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
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: HiddenRenderingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
8
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: HiddenRenderingComponent, selector: "sc-hidden-rendering", host: { properties: { "style": "this.style" } }, ngImport: i0, template: '', isInline: true });
|
|
9
|
-
}
|
|
10
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.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
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: HiddenRenderingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
8
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: HiddenRenderingComponent, selector: "sc-hidden-rendering", host: { properties: { "style": "this.style" } }, ngImport: i0, template: '', isInline: true });
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGlkZGVuLXJlbmRlcmluZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9oaWRkZW4tcmVuZGVyaW5nLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFLdkQsTUFBTSxPQUFPLHdCQUF3QjtJQUNuQyxJQUEwQixLQUFLO1FBQzdCLE9BQU8sZ01BQWdNLENBQUM7SUFDMU0sQ0FBQzt3R0FIVSx3QkFBd0I7NEZBQXhCLHdCQUF3Qiw0R0FGekIsRUFBRTs7NEZBRUQsd0JBQXdCO2tCQUpwQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxxQkFBcUI7b0JBQy9CLFFBQVEsRUFBRSxFQUFFO2lCQUNiOzhCQUUyQixLQUFLO3NCQUE5QixXQUFXO3VCQUFDLE9BQU87O0FBS3RCLE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHLGtCQUFrQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBIb3N0QmluZGluZyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3NjLWhpZGRlbi1yZW5kZXJpbmcnLFxyXG4gIHRlbXBsYXRlOiAnJyxcclxufSlcclxuZXhwb3J0IGNsYXNzIEhpZGRlblJlbmRlcmluZ0NvbXBvbmVudCB7XHJcbiAgQEhvc3RCaW5kaW5nKCdzdHlsZScpIGdldCBzdHlsZSgpIHtcclxuICAgIHJldHVybiAnYmFja2dyb3VuZC1pbWFnZTogbGluZWFyLWdyYWRpZW50KDQ1ZGVnLCAjZmZmZmZmIDI1JSwgI2RjZGNkYyAyNSUsICNkY2RjZGMgNTAlLCAjZmZmZmZmIDUwJSwgI2ZmZmZmZiA3NSUsICNkY2RjZGMgNzUlLCAjZGNkY2RjIDEwMCUpOyBiYWNrZ3JvdW5kLXNpemU6IDNweCAzcHg7IGRpc3BsYXk6IGJsb2NrOyBoZWlnaHQ6IDEwMHB4Oyc7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgY29uc3QgSElEREVOX1JFTkRFUklOR19OQU1FID0gJ0hpZGRlbiBSZW5kZXJpbmcnO1xyXG4iXX0=
|
|
@@ -1,151 +1,151 @@
|
|
|
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
|
-
viewContainer;
|
|
6
|
-
templateRef;
|
|
7
|
-
renderer;
|
|
8
|
-
elementRef;
|
|
9
|
-
field;
|
|
10
|
-
editable = true;
|
|
11
|
-
/**
|
|
12
|
-
* Custom regexp that finds media URL prefix that will be replaced by `/-/jssmedia` or `/~/jssmedia`.
|
|
13
|
-
* @example
|
|
14
|
-
* /\/([-~]{1})assets\//i
|
|
15
|
-
* /-assets/website -> /-/jssmedia/website
|
|
16
|
-
* /~assets/website -> /~/jssmedia/website
|
|
17
|
-
*/
|
|
18
|
-
mediaUrlPrefix;
|
|
19
|
-
urlParams = {};
|
|
20
|
-
attrs = {};
|
|
21
|
-
inlineRef = null;
|
|
22
|
-
constructor(viewContainer, templateRef, renderer, elementRef) {
|
|
23
|
-
this.viewContainer = viewContainer;
|
|
24
|
-
this.templateRef = templateRef;
|
|
25
|
-
this.renderer = renderer;
|
|
26
|
-
this.elementRef = elementRef;
|
|
27
|
-
}
|
|
28
|
-
ngOnChanges(changes) {
|
|
29
|
-
if (changes.field || changes.editable || changes.urlParams || changes.attrs) {
|
|
30
|
-
this.viewContainer.clear();
|
|
31
|
-
if (this.inlineRef) {
|
|
32
|
-
this.inlineRef.remove();
|
|
33
|
-
this.inlineRef = null;
|
|
34
|
-
}
|
|
35
|
-
this.updateView();
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
updateView() {
|
|
39
|
-
const overrideAttrs = {
|
|
40
|
-
...this.getElementAttrs(),
|
|
41
|
-
...this.attrs,
|
|
42
|
-
};
|
|
43
|
-
const media = this.field;
|
|
44
|
-
if (!media || (!media.editable && !media.value && !media.src)) {
|
|
45
|
-
return;
|
|
46
|
-
}
|
|
47
|
-
let attrs = {};
|
|
48
|
-
// we likely have an experience editor value, should be a string
|
|
49
|
-
if (this.editable && media.editable) {
|
|
50
|
-
const foundImg = mediaApi.findEditorImageTag(media.editable);
|
|
51
|
-
if (!foundImg) {
|
|
52
|
-
return this.renderInlineWrapper(media.editable);
|
|
53
|
-
}
|
|
54
|
-
attrs = this.getImageAttrs(foundImg.attrs, overrideAttrs, this.urlParams);
|
|
55
|
-
if (!attrs) {
|
|
56
|
-
return this.renderInlineWrapper(media.editable);
|
|
57
|
-
}
|
|
58
|
-
const tempImg = this.renderer.createElement('img');
|
|
59
|
-
Object.entries(attrs).forEach(([key, attrValue]) => tempImg.setAttribute(key, attrValue));
|
|
60
|
-
const editableMarkup = media.editable.replace(foundImg.imgTag, tempImg.outerHTML);
|
|
61
|
-
return this.renderInlineWrapper(editableMarkup);
|
|
62
|
-
}
|
|
63
|
-
// some wise-guy/gal is passing in a 'raw' image object value
|
|
64
|
-
const img = media.src ? media : media.value;
|
|
65
|
-
if (!img) {
|
|
66
|
-
return null;
|
|
67
|
-
}
|
|
68
|
-
attrs = this.getImageAttrs(img, overrideAttrs, this.urlParams);
|
|
69
|
-
if (attrs) {
|
|
70
|
-
this.renderTemplate(attrs);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
getImageAttrs(fieldAttrs, parsedAttrs, imageParams) {
|
|
74
|
-
const combinedAttrs = {
|
|
75
|
-
...fieldAttrs,
|
|
76
|
-
...parsedAttrs,
|
|
77
|
-
};
|
|
78
|
-
// eslint-disable-next-line prefer-const
|
|
79
|
-
let { src, srcSet, ...otherAttrs } = combinedAttrs;
|
|
80
|
-
if (!src) {
|
|
81
|
-
return null;
|
|
82
|
-
}
|
|
83
|
-
const newAttrs = {
|
|
84
|
-
...otherAttrs,
|
|
85
|
-
};
|
|
86
|
-
// update image URL for jss handler and image rendering params
|
|
87
|
-
src = mediaApi.updateImageUrl(src, imageParams, this.mediaUrlPrefix);
|
|
88
|
-
if (srcSet) {
|
|
89
|
-
// replace with HTML-formatted srcset, including updated image URLs
|
|
90
|
-
newAttrs.srcSet = mediaApi.getSrcSet(src, srcSet, imageParams, this.mediaUrlPrefix);
|
|
91
|
-
}
|
|
92
|
-
else {
|
|
93
|
-
newAttrs.src = src;
|
|
94
|
-
}
|
|
95
|
-
return newAttrs;
|
|
96
|
-
}
|
|
97
|
-
renderTemplate(imageProps) {
|
|
98
|
-
const viewRef = this.viewContainer.createEmbeddedView(this.templateRef);
|
|
99
|
-
viewRef.rootNodes.forEach((node) => {
|
|
100
|
-
Object.entries(imageProps).forEach(([key, imgPropVal]) => this.renderer.setAttribute(node, key, imgPropVal));
|
|
101
|
-
});
|
|
102
|
-
}
|
|
103
|
-
getElementAttrs() {
|
|
104
|
-
const view = this.templateRef.createEmbeddedView(null);
|
|
105
|
-
const element = view.rootNodes[0];
|
|
106
|
-
if (!element) {
|
|
107
|
-
view.destroy();
|
|
108
|
-
return {};
|
|
109
|
-
}
|
|
110
|
-
const attrs = {};
|
|
111
|
-
for (let i = 0; i < element.attributes.length; i++) {
|
|
112
|
-
const attr = element.attributes.item(i);
|
|
113
|
-
if (attr) {
|
|
114
|
-
attrs[attr.name] = attr.value;
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
view.destroy();
|
|
118
|
-
return attrs;
|
|
119
|
-
}
|
|
120
|
-
renderInlineWrapper(editable) {
|
|
121
|
-
const span = this.renderer.createElement('span');
|
|
122
|
-
span.className = 'sc-image-wrapper';
|
|
123
|
-
span.innerHTML = editable;
|
|
124
|
-
const parentNode = this.renderer.parentNode(this.elementRef.nativeElement);
|
|
125
|
-
this.renderer.insertBefore(parentNode, span, this.elementRef.nativeElement);
|
|
126
|
-
parentNode.removeChild(this.elementRef.nativeElement);
|
|
127
|
-
this.inlineRef = span;
|
|
128
|
-
}
|
|
129
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ImageDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.TemplateRef }, { token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
130
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.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 });
|
|
131
|
-
}
|
|
132
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ImageDirective, decorators: [{
|
|
133
|
-
type: Directive,
|
|
134
|
-
args: [{ selector: '[scImage]' }]
|
|
135
|
-
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.TemplateRef }, { type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { field: [{
|
|
136
|
-
type: Input,
|
|
137
|
-
args: ['scImage']
|
|
138
|
-
}], editable: [{
|
|
139
|
-
type: Input,
|
|
140
|
-
args: ['scImageEditable']
|
|
141
|
-
}], mediaUrlPrefix: [{
|
|
142
|
-
type: Input,
|
|
143
|
-
args: ['scImageMediaUrlPrefix']
|
|
144
|
-
}], urlParams: [{
|
|
145
|
-
type: Input,
|
|
146
|
-
args: ['scImageUrlParams']
|
|
147
|
-
}], attrs: [{
|
|
148
|
-
type: Input,
|
|
149
|
-
args: ['scImageAttrs']
|
|
150
|
-
}] } });
|
|
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
|
+
viewContainer;
|
|
6
|
+
templateRef;
|
|
7
|
+
renderer;
|
|
8
|
+
elementRef;
|
|
9
|
+
field;
|
|
10
|
+
editable = true;
|
|
11
|
+
/**
|
|
12
|
+
* Custom regexp that finds media URL prefix that will be replaced by `/-/jssmedia` or `/~/jssmedia`.
|
|
13
|
+
* @example
|
|
14
|
+
* /\/([-~]{1})assets\//i
|
|
15
|
+
* /-assets/website -> /-/jssmedia/website
|
|
16
|
+
* /~assets/website -> /~/jssmedia/website
|
|
17
|
+
*/
|
|
18
|
+
mediaUrlPrefix;
|
|
19
|
+
urlParams = {};
|
|
20
|
+
attrs = {};
|
|
21
|
+
inlineRef = null;
|
|
22
|
+
constructor(viewContainer, templateRef, renderer, elementRef) {
|
|
23
|
+
this.viewContainer = viewContainer;
|
|
24
|
+
this.templateRef = templateRef;
|
|
25
|
+
this.renderer = renderer;
|
|
26
|
+
this.elementRef = elementRef;
|
|
27
|
+
}
|
|
28
|
+
ngOnChanges(changes) {
|
|
29
|
+
if (changes.field || changes.editable || changes.urlParams || changes.attrs) {
|
|
30
|
+
this.viewContainer.clear();
|
|
31
|
+
if (this.inlineRef) {
|
|
32
|
+
this.inlineRef.remove();
|
|
33
|
+
this.inlineRef = null;
|
|
34
|
+
}
|
|
35
|
+
this.updateView();
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
updateView() {
|
|
39
|
+
const overrideAttrs = {
|
|
40
|
+
...this.getElementAttrs(),
|
|
41
|
+
...this.attrs,
|
|
42
|
+
};
|
|
43
|
+
const media = this.field;
|
|
44
|
+
if (!media || (!media.editable && !media.value && !media.src)) {
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
let attrs = {};
|
|
48
|
+
// we likely have an experience editor value, should be a string
|
|
49
|
+
if (this.editable && media.editable) {
|
|
50
|
+
const foundImg = mediaApi.findEditorImageTag(media.editable);
|
|
51
|
+
if (!foundImg) {
|
|
52
|
+
return this.renderInlineWrapper(media.editable);
|
|
53
|
+
}
|
|
54
|
+
attrs = this.getImageAttrs(foundImg.attrs, overrideAttrs, this.urlParams);
|
|
55
|
+
if (!attrs) {
|
|
56
|
+
return this.renderInlineWrapper(media.editable);
|
|
57
|
+
}
|
|
58
|
+
const tempImg = this.renderer.createElement('img');
|
|
59
|
+
Object.entries(attrs).forEach(([key, attrValue]) => tempImg.setAttribute(key, attrValue));
|
|
60
|
+
const editableMarkup = media.editable.replace(foundImg.imgTag, tempImg.outerHTML);
|
|
61
|
+
return this.renderInlineWrapper(editableMarkup);
|
|
62
|
+
}
|
|
63
|
+
// some wise-guy/gal is passing in a 'raw' image object value
|
|
64
|
+
const img = media.src ? media : media.value;
|
|
65
|
+
if (!img) {
|
|
66
|
+
return null;
|
|
67
|
+
}
|
|
68
|
+
attrs = this.getImageAttrs(img, overrideAttrs, this.urlParams);
|
|
69
|
+
if (attrs) {
|
|
70
|
+
this.renderTemplate(attrs);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
getImageAttrs(fieldAttrs, parsedAttrs, imageParams) {
|
|
74
|
+
const combinedAttrs = {
|
|
75
|
+
...fieldAttrs,
|
|
76
|
+
...parsedAttrs,
|
|
77
|
+
};
|
|
78
|
+
// eslint-disable-next-line prefer-const
|
|
79
|
+
let { src, srcSet, ...otherAttrs } = combinedAttrs;
|
|
80
|
+
if (!src) {
|
|
81
|
+
return null;
|
|
82
|
+
}
|
|
83
|
+
const newAttrs = {
|
|
84
|
+
...otherAttrs,
|
|
85
|
+
};
|
|
86
|
+
// update image URL for jss handler and image rendering params
|
|
87
|
+
src = mediaApi.updateImageUrl(src, imageParams, this.mediaUrlPrefix);
|
|
88
|
+
if (srcSet) {
|
|
89
|
+
// replace with HTML-formatted srcset, including updated image URLs
|
|
90
|
+
newAttrs.srcSet = mediaApi.getSrcSet(src, srcSet, imageParams, this.mediaUrlPrefix);
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
newAttrs.src = src;
|
|
94
|
+
}
|
|
95
|
+
return newAttrs;
|
|
96
|
+
}
|
|
97
|
+
renderTemplate(imageProps) {
|
|
98
|
+
const viewRef = this.viewContainer.createEmbeddedView(this.templateRef);
|
|
99
|
+
viewRef.rootNodes.forEach((node) => {
|
|
100
|
+
Object.entries(imageProps).forEach(([key, imgPropVal]) => this.renderer.setAttribute(node, key, imgPropVal));
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
getElementAttrs() {
|
|
104
|
+
const view = this.templateRef.createEmbeddedView(null);
|
|
105
|
+
const element = view.rootNodes[0];
|
|
106
|
+
if (!element) {
|
|
107
|
+
view.destroy();
|
|
108
|
+
return {};
|
|
109
|
+
}
|
|
110
|
+
const attrs = {};
|
|
111
|
+
for (let i = 0; i < element.attributes.length; i++) {
|
|
112
|
+
const attr = element.attributes.item(i);
|
|
113
|
+
if (attr) {
|
|
114
|
+
attrs[attr.name] = attr.value;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
view.destroy();
|
|
118
|
+
return attrs;
|
|
119
|
+
}
|
|
120
|
+
renderInlineWrapper(editable) {
|
|
121
|
+
const span = this.renderer.createElement('span');
|
|
122
|
+
span.className = 'sc-image-wrapper';
|
|
123
|
+
span.innerHTML = editable;
|
|
124
|
+
const parentNode = this.renderer.parentNode(this.elementRef.nativeElement);
|
|
125
|
+
this.renderer.insertBefore(parentNode, span, this.elementRef.nativeElement);
|
|
126
|
+
parentNode.removeChild(this.elementRef.nativeElement);
|
|
127
|
+
this.inlineRef = span;
|
|
128
|
+
}
|
|
129
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ImageDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.TemplateRef }, { token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
130
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.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 });
|
|
131
|
+
}
|
|
132
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ImageDirective, decorators: [{
|
|
133
|
+
type: Directive,
|
|
134
|
+
args: [{ selector: '[scImage]' }]
|
|
135
|
+
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.TemplateRef }, { type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { field: [{
|
|
136
|
+
type: Input,
|
|
137
|
+
args: ['scImage']
|
|
138
|
+
}], editable: [{
|
|
139
|
+
type: Input,
|
|
140
|
+
args: ['scImageEditable']
|
|
141
|
+
}], mediaUrlPrefix: [{
|
|
142
|
+
type: Input,
|
|
143
|
+
args: ['scImageMediaUrlPrefix']
|
|
144
|
+
}], urlParams: [{
|
|
145
|
+
type: Input,
|
|
146
|
+
args: ['scImageUrlParams']
|
|
147
|
+
}], attrs: [{
|
|
148
|
+
type: Input,
|
|
149
|
+
args: ['scImageAttrs']
|
|
150
|
+
}] } });
|
|
151
151
|
//# 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"]}
|