keevo-components 1.8.468 → 1.8.469
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/esm2022/lib/components/kv-carousel/kv-carousel.component.mjs +3 -2
- package/esm2022/lib/components/kv-inputs/kv-editor/kv-editor.component.mjs +28 -5
- package/fesm2022/keevo-components.mjs +29 -5
- package/fesm2022/keevo-components.mjs.map +1 -1
- package/package.json +1 -1
- package/src/lib/components/kv-table/kv-table.component.scss +0 -8
|
@@ -17,7 +17,8 @@ export class KvCarouselComponent {
|
|
|
17
17
|
this.isCollapsed = false;
|
|
18
18
|
}
|
|
19
19
|
navigateToLink(link) {
|
|
20
|
-
|
|
20
|
+
if (link !== null && link !== undefined && link !== '')
|
|
21
|
+
window.open(link, '_blank');
|
|
21
22
|
}
|
|
22
23
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvCarouselComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
23
24
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "17.3.8", type: KvCarouselComponent, selector: "kv-carousel", inputs: { heightCarousel: { classPropertyName: "heightCarousel", publicName: "heightCarousel", isSignal: true, isRequired: false, transformFunction: null }, carouselData: { classPropertyName: "carouselData", publicName: "carouselData", isSignal: false, isRequired: false, transformFunction: null }, autoplayInterval: { classPropertyName: "autoplayInterval", publicName: "autoplayInterval", isSignal: false, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "carouselContainer", first: true, predicate: Carousel, descendants: true, isSignal: true }], ngImport: i0, template: "<p-carousel\r\n [value]=\"carouselData\"\r\n [indicatorStyleClass]=\"'carousel-indicator'\"\r\n [autoplayInterval]=\"autoplayInterval\"\r\n [showIndicators]=\"true\"\r\n [showNavigators]=\"false\"\r\n [numVisible]=\"1\"\r\n [numScroll]=\"1\"\r\n [circular]=\"true\"\r\n styleClass=\"h-full\"\r\n>\r\n >\r\n <ng-template\r\n pTemplate=\"item\"\r\n let-banner\r\n class=\"justify-content-center align-items-center\"\r\n >\r\n <img\r\n [src]=\"banner.img\"\r\n class=\"w-full border-round-banner\"\r\n [style.height.px]=\"heightComputed()\"\r\n (click)=\"navigateToLink(banner.link)\"\r\n />\r\n </ng-template>\r\n</p-carousel>\r\n", styles: ["::ng-deep .p-carousel-indicators{position:absolute;left:50%;transform:translate(-50%);bottom:-1rem}::ng-deep .carousel-indicator{width:15px!important;height:4px!important;margin:-3px!important;padding:0!important;background-color:#eeeeeed0}::ng-deep .carousel-indicator:hover{background-color:#efefef}button.p-carousel-indicator.p-link{background-color:#f0f8ff!important}::ng-deep .p-carousel .p-carousel-content{overflow:hidden!important;position:relative}::ng-deep .border-round-banner{border-radius:20px!important;max-height:500px}\n"], dependencies: [{ kind: "directive", type: i1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i2.Carousel, selector: "p-carousel", inputs: ["page", "numVisible", "numScroll", "responsiveOptions", "orientation", "verticalViewPortHeight", "contentClass", "indicatorsContentClass", "indicatorsContentStyle", "indicatorStyleClass", "indicatorStyle", "value", "circular", "showIndicators", "showNavigators", "autoplayInterval", "style", "styleClass"], outputs: ["onPage"] }] }); }
|
|
@@ -30,4 +31,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
30
31
|
}], autoplayInterval: [{
|
|
31
32
|
type: Input
|
|
32
33
|
}] } });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3YtY2Fyb3VzZWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMva3YtY2Fyb3VzZWwva3YtY2Fyb3VzZWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMva3YtY2Fyb3VzZWwva3YtY2Fyb3VzZWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFDVCxLQUFLLEVBQ0wsUUFBUSxFQUNSLEtBQUssRUFDTCxTQUFTLEVBQ1YsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGtCQUFrQixDQUFDOzs7O0FBTzVDLE1BQU0sT0FBTyxtQkFBbUI7SUFrQjlCLFlBQW9CLEVBQXFCO1FBQXJCLE9BQUUsR0FBRixFQUFFLENBQW1CO1FBakJ6QyxzQkFBaUIsR0FBRyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUM7UUFFeEMsbUJBQWMsR0FBRyxLQUFLLEVBQVUsQ0FBQztRQUVqQyxtQkFBYyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDN0IsT0FBTyxDQUNMLElBQUksQ0FBQyxjQUFjLEVBQUU7Z0JBQ3JCLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxFQUFFLEVBQUUsQ0FBQyxhQUFhLENBQUMsWUFBWSxDQUN4RCxDQUFDO1FBQ0osQ0FBQyxDQUFDLENBQUM7UUFFTSxpQkFBWSxHQUFVLEVBQUUsQ0FBQztRQUN6QixxQkFBZ0IsR0FBVyxJQUFJLENBQUM7UUFHekMsZ0JBQVcsR0FBWSxLQUFLLENBQUM7SUFFZSxDQUFDO0lBRTdDLGNBQWMsQ0FBQyxJQUFZO1FBQ3pCLElBQUcsSUFBSSxLQUFLLElBQUksSUFBSSxJQUFJLEtBQUssU0FBUyxJQUFJLElBQUksS0FBSyxFQUFFO1lBQ3JELE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLFFBQVEsQ0FBQyxDQUFDO0lBQzlCLENBQUM7OEdBdkJVLG1CQUFtQjtrR0FBbkIsbUJBQW1CLDZpQkFDQSxRQUFRLGdFQ2hCeEMsc3FCQXlCQTs7MkZEVmEsbUJBQW1CO2tCQUwvQixTQUFTOytCQUNFLGFBQWE7c0ZBZ0JkLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csZ0JBQWdCO3NCQUF4QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBDaGFuZ2VEZXRlY3RvclJlZixcclxuICBDb21wb25lbnQsXHJcbiAgSW5wdXQsXHJcbiAgY29tcHV0ZWQsXHJcbiAgaW5wdXQsXHJcbiAgdmlld0NoaWxkXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENhcm91c2VsIH0gZnJvbSAncHJpbWVuZy9jYXJvdXNlbCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2t2LWNhcm91c2VsJyxcclxuICB0ZW1wbGF0ZVVybDogJy4va3YtY2Fyb3VzZWwuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2t2LWNhcm91c2VsLmNvbXBvbmVudC5zY3NzJ10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBLdkNhcm91c2VsQ29tcG9uZW50IHtcclxuICBjYXJvdXNlbENvbnRhaW5lciA9IHZpZXdDaGlsZChDYXJvdXNlbCk7XHJcblxyXG4gIGhlaWdodENhcm91c2VsID0gaW5wdXQ8bnVtYmVyPigpO1xyXG5cclxuICBoZWlnaHRDb21wdXRlZCA9IGNvbXB1dGVkKCgpID0+IHtcclxuICAgIHJldHVybiAoXHJcbiAgICAgIHRoaXMuaGVpZ2h0Q2Fyb3VzZWwoKSA/P1xyXG4gICAgICB0aGlzLmNhcm91c2VsQ29udGFpbmVyKCk/LmVsLm5hdGl2ZUVsZW1lbnQub2Zmc2V0SGVpZ2h0XHJcbiAgICApO1xyXG4gIH0pO1xyXG5cclxuICBASW5wdXQoKSBjYXJvdXNlbERhdGE6IGFueVtdID0gW107XHJcbiAgQElucHV0KCkgYXV0b3BsYXlJbnRlcnZhbDogbnVtYmVyID0gNTAwMDtcclxuXHJcbiAgd2lkdGhDYXJvdXNlbCE6IG51bWJlcjtcclxuICBpc0NvbGxhcHNlZDogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGNkOiBDaGFuZ2VEZXRlY3RvclJlZikge31cclxuXHJcbiAgbmF2aWdhdGVUb0xpbmsobGluazogc3RyaW5nKTogdm9pZCB7XHJcbiAgICBpZihsaW5rICE9PSBudWxsICYmIGxpbmsgIT09IHVuZGVmaW5lZCAmJiBsaW5rICE9PSAnJykgXHJcbiAgICB3aW5kb3cub3BlbihsaW5rLCAnX2JsYW5rJyk7XHJcbiAgfVxyXG59XHJcbiIsIjxwLWNhcm91c2VsXHJcbiAgW3ZhbHVlXT1cImNhcm91c2VsRGF0YVwiXHJcbiAgW2luZGljYXRvclN0eWxlQ2xhc3NdPVwiJ2Nhcm91c2VsLWluZGljYXRvcidcIlxyXG4gIFthdXRvcGxheUludGVydmFsXT1cImF1dG9wbGF5SW50ZXJ2YWxcIlxyXG4gIFtzaG93SW5kaWNhdG9yc109XCJ0cnVlXCJcclxuICBbc2hvd05hdmlnYXRvcnNdPVwiZmFsc2VcIlxyXG4gIFtudW1WaXNpYmxlXT1cIjFcIlxyXG4gIFtudW1TY3JvbGxdPVwiMVwiXHJcbiAgW2NpcmN1bGFyXT1cInRydWVcIlxyXG4gIHN0eWxlQ2xhc3M9XCJoLWZ1bGxcIlxyXG4+XHJcbiAgPlxyXG4gIDxuZy10ZW1wbGF0ZVxyXG4gICAgcFRlbXBsYXRlPVwiaXRlbVwiXHJcbiAgICBsZXQtYmFubmVyXHJcbiAgICBjbGFzcz1cImp1c3RpZnktY29udGVudC1jZW50ZXIgYWxpZ24taXRlbXMtY2VudGVyXCJcclxuICA+XHJcbiAgICA8aW1nXHJcbiAgICAgIFtzcmNdPVwiYmFubmVyLmltZ1wiXHJcbiAgICAgIGNsYXNzPVwidy1mdWxsIGJvcmRlci1yb3VuZC1iYW5uZXJcIlxyXG4gICAgICBbc3R5bGUuaGVpZ2h0LnB4XT1cImhlaWdodENvbXB1dGVkKClcIlxyXG4gICAgICAoY2xpY2spPVwibmF2aWdhdGVUb0xpbmsoYmFubmVyLmxpbmspXCJcclxuICAgIC8+XHJcbiAgPC9uZy10ZW1wbGF0ZT5cclxuPC9wLWNhcm91c2VsPlxyXG4iXX0=
|
|
@@ -43,12 +43,31 @@ export class KvEditorComponent extends BaseComponentInput {
|
|
|
43
43
|
Quill.register(SizeStyle, true);
|
|
44
44
|
Quill.register(Font, true);
|
|
45
45
|
Quill.register(Size, true);
|
|
46
|
-
//
|
|
47
|
-
|
|
46
|
+
// Customizando o comportamento do Enter
|
|
47
|
+
const bindings = Quill.import('modules/keyboard').DEFAULTS.bindings;
|
|
48
|
+
bindings['enter'] = {
|
|
49
|
+
key: 13, // Código da tecla Enter
|
|
50
|
+
handler: (range) => {
|
|
51
|
+
const quill = this.quill;
|
|
52
|
+
quill.insertEmbed(range.index, 'break', true, Quill.sources.USER);
|
|
53
|
+
quill.setSelection(range.index + 1, Quill.sources.SILENT);
|
|
54
|
+
return false; // Evita o comportamento padrão de criar um <p>
|
|
55
|
+
},
|
|
56
|
+
};
|
|
57
|
+
// Custom blot for <br> tag
|
|
58
|
+
const BlockEmbed = Quill.import('blots/block/embed');
|
|
59
|
+
class Break extends BlockEmbed {
|
|
60
|
+
static { this.blotName = 'break'; }
|
|
61
|
+
static { this.tagName = 'br'; }
|
|
62
|
+
}
|
|
63
|
+
Quill.register(Break);
|
|
48
64
|
this.quill = new Quill('#kv-editor', {
|
|
49
65
|
theme: 'snow',
|
|
50
66
|
modules: {
|
|
51
67
|
toolbar: '#kv-editor-toolbar',
|
|
68
|
+
keyboard: {
|
|
69
|
+
bindings: bindings,
|
|
70
|
+
},
|
|
52
71
|
},
|
|
53
72
|
placeholder: this.label ? this.label : '',
|
|
54
73
|
readOnly: this.readonly,
|
|
@@ -58,14 +77,18 @@ export class KvEditorComponent extends BaseComponentInput {
|
|
|
58
77
|
this.onSelectionChange.emit({
|
|
59
78
|
range: range,
|
|
60
79
|
oldRange: oldRange,
|
|
61
|
-
source: source
|
|
80
|
+
source: source,
|
|
62
81
|
});
|
|
63
82
|
});
|
|
64
83
|
this.quill.on('text-change', (delta, oldContents, source) => {
|
|
65
84
|
if (!this.updatingEditor) {
|
|
66
85
|
this.updatingEditor = false;
|
|
67
86
|
this.escrevaValor(this.quill.getSemanticHTML(), this.quill.getText());
|
|
68
|
-
this.onTextChange.emit({
|
|
87
|
+
this.onTextChange.emit({
|
|
88
|
+
delta: delta,
|
|
89
|
+
oldContents: oldContents,
|
|
90
|
+
source: source,
|
|
91
|
+
});
|
|
69
92
|
this.outputRaw.emit(this.quill.getText());
|
|
70
93
|
this.outputHtml.emit(this.quill.getSemanticHTML());
|
|
71
94
|
}
|
|
@@ -109,4 +132,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
109
132
|
}], contentType: [{
|
|
110
133
|
type: Input
|
|
111
134
|
}] } });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/keevo-components/src/lib/components/kv-inputs/kv-editor/kv-editor.component.ts","../../../../../../../projects/keevo-components/src/lib/components/kv-inputs/kv-editor/kv-editor.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,MAAM,GACP,MAAM,eAAe,CAAC;AAEvB,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,4DAA4D;AAG5D,OAAO,EAAE,kBAAkB,EAAE,MAAM,mDAAmD,CAAC;AACvF,OAAO,EAAE,kBAAkB,EAAE,MAAM,0CAA0C,CAAC;;;;;;AAS9E,MAAM,OAAO,iBAAkB,SAAQ,kBAA0B;IAC/D,sCAAsC;IAGtC,YACE,gBAAkC;QAClC,KAAK,CAAC,gBAAgB,CAAC,CAAC;QAGjB,aAAQ,GAAY,KAAK,CAAC;QAC1B,gBAAW,GAAW,OAAO,CAAC;QAC9B,UAAK,GAAY,KAAK,CAAC;QAEtB,iBAAY,GAAsB,IAAI,YAAY,EAAE,CAAC;QACrD,sBAAiB,GAAsB,IAAI,YAAY,EAAE,CAAC;QAE1D,cAAS,GAAyB,IAAI,YAAY,EAAE,CAAC;QACrD,eAAU,GAAyB,IAAI,YAAY,EAAE,CAAC;QAGxD,mBAAc,GAAY,KAAK,CAAC;QAKxC;;WAEG;QACM,gBAAW,GAAoB,MAAM,CAAC;IArB/C,CAAC;IAyBQ,QAAQ;QACf,KAAK,CAAC,QAAQ,EAAE,CAAA;QAChB,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC/B,CAAC;IACH,CAAC;IAGD,qBAAqB;QACnB,MAAM,UAAU,GAAQ,KAAK,CAAC,MAAM,CAAC,yBAAyB,CAAC,CAAC;QAChE,MAAM,UAAU,GAAQ,KAAK,CAAC,MAAM,CAAC,yBAAyB,CAAC,CAAC;QAChE,MAAM,SAAS,GAAQ,KAAK,CAAC,MAAM,CAAC,wBAAwB,CAAC,CAAC;QAC9D,MAAM,IAAI,GAAQ,KAAK,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;QAC/C,MAAM,IAAI,GAAQ,KAAK,CAAC,MAAM,CAAC,wBAAwB,CAAC,CAAC;QAEzD,IAAI,CAAC,SAAS,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;QAC1E,IAAI,CAAC,SAAS,GAAG,CAAC,WAAW,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QAE3D,KAAK,CAAC,QAAQ,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;QACjC,KAAK,CAAC,QAAQ,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QAChC,KAAK,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAC3B,KAAK,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAE3B,+DAA+D;QAG/D,oBAAoB;QACpB,IAAI,CAAC,KAAK,GAAG,IAAI,KAAK,CAAC,YAAY,EAAE;YACnC,KAAK,EAAE,MAAM;YACb,OAAO,EAAE;gBACP,OAAO,EAAE,oBAAoB;aAC9B;YAED,WAAW,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE;YACzC,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,KAAK,EAAE,IAAI,CAAC,KAAK;SAClB,CAAC,CAAC;QAGH,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,kBAAkB,EAAE,CAAC,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE;YAC5D,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;gBAC1B,KAAK,EAAE,KAAK;gBACZ,QAAQ,EAAE,QAAQ;gBAClB,MAAM,EAAE,MAAM;aACf,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE,EAAE;YAC1D,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;gBACzB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;gBAE5B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,eAAe,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAA;gBAErE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;gBACnF,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAA;gBACzC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,eAAe,EAAE,CAAC,CAAA;YAEpD,CAAC;QACH,CAAC,CAAC,CAAC;IAEL,CAAC;IAEQ,UAAU,CAAC,KAAU;QAC5B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAA;QAC1B,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAA;IAC1B,CAAC;IAGD,YAAY,CAAC,SAAc,EAAE,QAAa;QACxC,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YAEf,IAAG,IAAI,CAAC,cAAc,EAAC,CAAC;gBACtB,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAA;YACtD,CAAC;YAED,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;YAC5B,IAAI,CAAC,KAAK,GAAE,SAAS,CAAA;YAErB,IAAG,QAAQ,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,IAAG,IAAI;gBACtC,IAAI,CAAC,KAAK,GAAG,EAAE,CAAA;QAEnB,CAAC;IACH,CAAC;8GAlHU,iBAAiB;kGAAjB,iBAAiB,mRAFjB,kBAAkB,CAAC,iBAAiB,CAAC,iDCpBlD,ggJAiHA;;2FD3Fa,iBAAiB;kBAN7B,SAAS;+BACE,WAAW,aAGV,kBAAkB,mBAAmB;qFAWvC,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBAEI,YAAY;sBAArB,MAAM;gBACG,iBAAiB;sBAA1B,MAAM;gBAEG,SAAS;sBAAlB,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBAWE,WAAW;sBAAnB,KAAK","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n} from '@angular/core';\r\n\r\nimport Quill from 'quill';\r\n// import QuillBlotFormatter  from 'quill-blot-formatter-2';\r\n\r\n\r\nimport { BaseComponentInput } from '../../../api/base-components/base-component-input';\r\nimport { ComponentProviders } from '../../../api/helpers/component-providers';\r\nimport { ComponentService } from '../../../api/services/component.service';\r\n\r\n@Component({\r\n  selector: 'kv-editor',\r\n  templateUrl: './kv-editor.component.html',\r\n  styleUrls: ['./kv-editor.component.scss',],\r\n  providers: ComponentProviders(KvEditorComponent),\r\n})\r\nexport class KvEditorComponent extends BaseComponentInput<string> implements OnInit {\r\n  // BlotFormatter = QuillBlotFormatter;\r\n\r\n\r\n  constructor(\r\n    componentService: ComponentService) {\r\n    super(componentService);\r\n  }\r\n\r\n  @Input() readonly: boolean = false;\r\n  @Input() canvaHeigth: string = '380px';\r\n  @Input() debug: boolean = false;\r\n\r\n  @Output() onTextChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSelectionChange: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output() outputRaw: EventEmitter<string> = new EventEmitter();\r\n  @Output() outputHtml: EventEmitter<string> = new EventEmitter();\r\n\r\n\r\n  private updatingEditor: boolean = false;\r\n\r\n  quill!: Quill;\r\n\r\n\r\n  /**\r\n   * caso defina como \"text\" o texto ira ser enviado sem formatação\r\n   */\r\n  @Input() contentType: 'html' | 'text' = 'html';\r\n\r\n\r\n\r\n  override ngOnInit() {\r\n    super.ngOnInit()\r\n    if (!this.quill) {\r\n      this.initializeQuillEditor();\r\n    }\r\n  }\r\n\r\n\r\n  initializeQuillEditor() {\r\n    const ColorClass: any = Quill.import('attributors/class/color');\r\n    const ColorStyle: any = Quill.import('attributors/style/color');\r\n    const SizeStyle: any = Quill.import('attributors/style/size');\r\n    const Font: any = Quill.import('formats/font');\r\n    const Size: any = Quill.import('attributors/style/size');\r\n\r\n    Size.whitelist = ['15px', '20px', '30px', '40px', '50px', '70px', '90px'];\r\n    Font.whitelist = ['monospace', 'roboto', 'serif', 'inter'];\r\n\r\n    Quill.register(ColorStyle, true);\r\n    Quill.register(SizeStyle, true);\r\n    Quill.register(Font, true);\r\n    Quill.register(Size, true);\r\n\r\n    // Quill.register('modules/blotFormatter', this.BlotFormatter);\r\n\r\n\r\n    // blotFormatter: {}\r\n    this.quill = new Quill('#kv-editor', {\r\n      theme: 'snow',\r\n      modules: {\r\n        toolbar: '#kv-editor-toolbar',\r\n      },\r\n\r\n      placeholder: this.label ? this.label : '',\r\n      readOnly: this.readonly,\r\n      debug: this.debug,\r\n    });\r\n\r\n\r\n    this.quill.on('selection-change', (range, oldRange, source) => {\r\n      this.onSelectionChange.emit({\r\n        range: range,\r\n        oldRange: oldRange,\r\n        source: source\r\n      });\r\n    });\r\n\r\n    this.quill.on('text-change', (delta, oldContents, source) => {\r\n      if (!this.updatingEditor) {\r\n        this.updatingEditor = false;\r\n\r\n        this.escrevaValor(this.quill.getSemanticHTML(), this.quill.getText())\r\n\r\n        this.onTextChange.emit({ delta: delta, oldContents: oldContents, source: source });\r\n        this.outputRaw.emit(this.quill.getText())\r\n        this.outputHtml.emit(this.quill.getSemanticHTML())\r\n\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n  override writeValue(value: any): void {\r\n    this.updatingEditor = true\r\n    this.escrevaValor(value)\r\n  }\r\n\r\n\r\n  escrevaValor(htmlvalue: any, rawvalue?:any){\r\n    if (this.quill) {\r\n\r\n      if(this.updatingEditor){\r\n        this.quill.clipboard.dangerouslyPasteHTML(htmlvalue)\r\n      }\r\n\r\n      this.updatingEditor = false;\r\n      this.value= htmlvalue\r\n\r\n      if(rawvalue == \"\\n\" || this.value ==\"\\n\")\r\n        this.value = ''\r\n\r\n    }\r\n  }\r\n}\r\n","<div class=\"kv-editor-container\">\r\n  <div #editor id=\"kv-editor-toolbar\" [ngClass]=\"{'error-border-toolbar': hasControlError()}\" >\r\n    <span class=\"ql-formats\">\r\n      <select class=\"ql-font\">\r\n        <option value=\"roboto\">Roboto</option>\r\n        <option value=\"monospace\">Monospace</option>\r\n        <option value=\"inter\">Inter</option>\r\n        <option selected>Sans Serif</option>\r\n        <option value=\"serif\">Serif</option>\r\n      </select>\r\n\r\n      <select class=\"ql-header\">\r\n        <option value=\"1\">Titulo</option>\r\n        <option value=\"2\">Subtitulo</option>\r\n        <option selected>Normal</option>\r\n      </select>\r\n\r\n      <span class=\"ql-format-group\">\r\n        <select title=\"Size\" class=\"ql-size\">\r\n          <option value=\"15px\">15px</option>\r\n          <option value=\"20px\">20px</option>\r\n          <option value=\"30px\">30px</option>\r\n          <option value=\"40px\">40px</option>\r\n          <option value=\"50px\">50px</option>\r\n          <option value=\"70px\">70px</option>\r\n          <option value=\"90px\">90px</option>\r\n        </select>\r\n      </span>\r\n    </span>\r\n\r\n    <span class=\"ql-formats\">\r\n      <button class=\"ql-bold\"></button>\r\n      <button class=\"ql-italic\"></button>\r\n      <button class=\"ql-underline\"></button>\r\n      <button class=\"ql-strike\"></button>\r\n    </span>\r\n\r\n    <span class=\"ql-formats\">\r\n      <select class=\"ql-color\"></select>\r\n      <select class=\"ql-background\"></select>\r\n    </span>\r\n\r\n    <span class=\"ql-formats\">\r\n      <button class=\"ql-script\" value=\"sub\"></button>\r\n      <button class=\"ql-script\" value=\"super\"></button>\r\n    </span>\r\n\r\n    <span class=\"ql-formats\">\r\n      <button class=\"ql-header\" value=\"1\"></button>\r\n      <button class=\"ql-header\" value=\"2\"></button>\r\n      <button class=\"ql-blockquote\"></button>\r\n      <button class=\"ql-code-block\"></button>\r\n    </span>\r\n\r\n    <span class=\"ql-formats\">\r\n      <button class=\"ql-list\" value=\"ordered\"></button>\r\n      <button class=\"ql-list\" value=\"bullet\"></button>\r\n      <button class=\"ql-indent\" value=\"-1\"></button>\r\n      <button class=\"ql-indent\" value=\"+1\"></button>\r\n    </span>\r\n\r\n    <span class=\"ql-formats\">\r\n      <button class=\"ql-direction\" value=\"rtl\"></button>\r\n      <select class=\"ql-align\"></select>\r\n    </span>\r\n\r\n    <span class=\"ql-formats\">\r\n      <button class=\"ql-link\"></button>\r\n      <button class=\"ql-image\"></button>\r\n      <button class=\"ql-video\"></button>\r\n    </span>\r\n\r\n    <span class=\"ql-formats\">\r\n      <button class=\"ql-clean\"></button>\r\n    </span>\r\n  </div>\r\n\r\n  <div id=\"kv-editor\" [style.height]=\"canvaHeigth\" [ngClass]=\"{'error-border': hasControlError()}\" ></div>\r\n</div>\r\n<kv-error [hasError]=\"hasControlError()\">{{ erroMessage() }}</kv-error>\r\n\r\n\r\n<!------------------------------------------------------------------------------------------------------------------->\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  <link href=\"https://cdn.jsdelivr.net/npm/quill@2.0.2/dist/quill.snow.css\" rel=\"stylesheet\" />\r\n  <link href=\"https://fonts.googleapis.com/css?family=Roboto\" rel=\"stylesheet\">\r\n  <script src=\"https://cdn.jsdelivr.net/npm/quill@2.0.2/dist/quill.js\"></script>\r\n  <script src=\"https://cdn.jsdelivr.net/npm/katex@0.16.9/dist/katex.min.js\"></script>\r\n\r\n\r\n  <link rel=\"stylesheet\" href=\"https://cdn.jsdelivr.net/npm/quill@2.0.2/dist/quill.bubble.css\" />\r\n  <link rel=\"stylesheet\" href=\"https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.9.0/styles/atom-one-dark.min.css\" />\r\n  <link rel=\"stylesheet\" href=\"https://cdn.jsdelivr.net/npm/katex@0.16.9/dist/katex.min.css\" />\r\n\r\n\r\n  <!-- Import fonts -->\r\n\r\n  <link rel=\"preconnect\" href=\"https://fonts.googleapis.com\">\r\n  <link rel=\"preconnect\" href=\"https://fonts.gstatic.com\" crossorigin>\r\n\r\n  <link href=\"https://fonts.googleapis.com/css2?family=Baloo+2:wght@400;500;600;700;800&family=Inter:wght@100..900&family=JetBrains+Mono:ital,wght@0,100..800;1,100..800&display=swap\" rel=\"stylesheet\">\r\n  <link href=\"https://fonts.googleapis.com/css2?family=Baloo+2:wght@400;500;600;700;800&family=Inter:wght@100..900&family=JetBrains+Mono:ital,wght@0,100..800;1,100..800&family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap\" rel=\"stylesheet\">\r\n"]}
|
|
135
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/keevo-components/src/lib/components/kv-inputs/kv-editor/kv-editor.component.ts","../../../../../../../projects/keevo-components/src/lib/components/kv-inputs/kv-editor/kv-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n} from '@angular/core';\r\n\r\nimport Quill from 'quill';\r\n// import QuillBlotFormatter  from 'quill-blot-formatter-2';\r\n\r\n\r\nimport { BaseComponentInput } from '../../../api/base-components/base-component-input';\r\nimport { ComponentProviders } from '../../../api/helpers/component-providers';\r\nimport { ComponentService } from '../../../api/services/component.service';\r\n\r\n@Component({\r\n  selector: 'kv-editor',\r\n  templateUrl: './kv-editor.component.html',\r\n  styleUrls: ['./kv-editor.component.scss',],\r\n  providers: ComponentProviders(KvEditorComponent),\r\n})\r\nexport class KvEditorComponent extends BaseComponentInput<string> implements OnInit {\r\n  // BlotFormatter = QuillBlotFormatter;\r\n\r\n\r\n  constructor(\r\n    componentService: ComponentService) {\r\n    super(componentService);\r\n  }\r\n\r\n  @Input() readonly: boolean = false;\r\n  @Input() canvaHeigth: string = '380px';\r\n  @Input() debug: boolean = false;\r\n\r\n  @Output() onTextChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSelectionChange: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output() outputRaw: EventEmitter<string> = new EventEmitter();\r\n  @Output() outputHtml: EventEmitter<string> = new EventEmitter();\r\n\r\n\r\n  private updatingEditor: boolean = false;\r\n\r\n  quill!: Quill;\r\n\r\n\r\n  /**\r\n   * caso defina como \"text\" o texto ira ser enviado sem formatação\r\n   */\r\n  @Input() contentType: 'html' | 'text' = 'html';\r\n\r\n\r\n\r\n  override ngOnInit() {\r\n    super.ngOnInit()\r\n    if (!this.quill) {\r\n      this.initializeQuillEditor();\r\n    }\r\n  }\r\n\r\n\r\n  initializeQuillEditor() {\r\n    const ColorClass: any = Quill.import('attributors/class/color');\r\n    const ColorStyle: any = Quill.import('attributors/style/color');\r\n    const SizeStyle: any = Quill.import('attributors/style/size');\r\n    const Font: any = Quill.import('formats/font');\r\n    const Size: any = Quill.import('attributors/style/size');\r\n  \r\n    Size.whitelist = ['15px', '20px', '30px', '40px', '50px', '70px', '90px'];\r\n    Font.whitelist = ['monospace', 'roboto', 'serif', 'inter'];\r\n  \r\n    Quill.register(ColorStyle, true);\r\n    Quill.register(SizeStyle, true);\r\n    Quill.register(Font, true);\r\n    Quill.register(Size, true);\r\n  \r\n    // Customizando o comportamento do Enter\r\n    const bindings = (Quill.import('modules/keyboard') as any).DEFAULTS.bindings;\r\n    \r\n    bindings['enter'] = {\r\n      key: 13, // Código da tecla Enter\r\n      handler: (range: any) => {\r\n      const quill = this.quill;\r\n      quill.insertEmbed(range.index, 'break', true, Quill.sources.USER);\r\n      quill.setSelection(range.index + 1, Quill.sources.SILENT);\r\n      return false; // Evita o comportamento padrão de criar um <p>\r\n      },\r\n    };\r\n\r\n    // Custom blot for <br> tag\r\n    const BlockEmbed = Quill.import('blots/block/embed');\r\n    class Break extends (BlockEmbed as any) {\r\n      static blotName = 'break';\r\n      static tagName = 'br';\r\n    }\r\n    Quill.register(Break);\r\n  \r\n    this.quill = new Quill('#kv-editor', {\r\n      theme: 'snow',\r\n      modules: {\r\n        toolbar: '#kv-editor-toolbar',\r\n        keyboard: {\r\n          bindings: bindings,\r\n        },\r\n      },\r\n      placeholder: this.label ? this.label : '',\r\n      readOnly: this.readonly,\r\n      debug: this.debug,\r\n    });\r\n  \r\n    this.quill.on('selection-change', (range, oldRange, source) => {\r\n      this.onSelectionChange.emit({\r\n        range: range,\r\n        oldRange: oldRange,\r\n        source: source,\r\n      });\r\n    });\r\n  \r\n    this.quill.on('text-change', (delta, oldContents, source) => {\r\n      if (!this.updatingEditor) {\r\n        this.updatingEditor = false;\r\n  \r\n        this.escrevaValor(this.quill.getSemanticHTML(), this.quill.getText());\r\n  \r\n        this.onTextChange.emit({\r\n          delta: delta,\r\n          oldContents: oldContents,\r\n          source: source,\r\n        });\r\n        this.outputRaw.emit(this.quill.getText());\r\n        this.outputHtml.emit(this.quill.getSemanticHTML());\r\n      }\r\n    });\r\n  }\r\n  \r\n\r\n  override writeValue(value: any): void {\r\n    this.updatingEditor = true\r\n    this.escrevaValor(value)\r\n  }\r\n\r\n\r\n  escrevaValor(htmlvalue: any, rawvalue?:any){\r\n    if (this.quill) {\r\n\r\n      if(this.updatingEditor){\r\n        this.quill.clipboard.dangerouslyPasteHTML(htmlvalue)\r\n      }\r\n\r\n      this.updatingEditor = false;\r\n      this.value= htmlvalue\r\n\r\n      if(rawvalue == \"\\n\" || this.value ==\"\\n\")\r\n        this.value = ''\r\n\r\n    }\r\n  }\r\n}\r\n","<div class=\"kv-editor-container\">\r\n  <div #editor id=\"kv-editor-toolbar\" [ngClass]=\"{'error-border-toolbar': hasControlError()}\" >\r\n    <span class=\"ql-formats\">\r\n      <select class=\"ql-font\">\r\n        <option value=\"roboto\">Roboto</option>\r\n        <option value=\"monospace\">Monospace</option>\r\n        <option value=\"inter\">Inter</option>\r\n        <option selected>Sans Serif</option>\r\n        <option value=\"serif\">Serif</option>\r\n      </select>\r\n\r\n      <select class=\"ql-header\">\r\n        <option value=\"1\">Titulo</option>\r\n        <option value=\"2\">Subtitulo</option>\r\n        <option selected>Normal</option>\r\n      </select>\r\n\r\n      <span class=\"ql-format-group\">\r\n        <select title=\"Size\" class=\"ql-size\">\r\n          <option value=\"15px\">15px</option>\r\n          <option value=\"20px\">20px</option>\r\n          <option value=\"30px\">30px</option>\r\n          <option value=\"40px\">40px</option>\r\n          <option value=\"50px\">50px</option>\r\n          <option value=\"70px\">70px</option>\r\n          <option value=\"90px\">90px</option>\r\n        </select>\r\n      </span>\r\n    </span>\r\n\r\n    <span class=\"ql-formats\">\r\n      <button class=\"ql-bold\"></button>\r\n      <button class=\"ql-italic\"></button>\r\n      <button class=\"ql-underline\"></button>\r\n      <button class=\"ql-strike\"></button>\r\n    </span>\r\n\r\n    <span class=\"ql-formats\">\r\n      <select class=\"ql-color\"></select>\r\n      <select class=\"ql-background\"></select>\r\n    </span>\r\n\r\n    <span class=\"ql-formats\">\r\n      <button class=\"ql-script\" value=\"sub\"></button>\r\n      <button class=\"ql-script\" value=\"super\"></button>\r\n    </span>\r\n\r\n    <span class=\"ql-formats\">\r\n      <button class=\"ql-header\" value=\"1\"></button>\r\n      <button class=\"ql-header\" value=\"2\"></button>\r\n      <button class=\"ql-blockquote\"></button>\r\n      <button class=\"ql-code-block\"></button>\r\n    </span>\r\n\r\n    <span class=\"ql-formats\">\r\n      <button class=\"ql-list\" value=\"ordered\"></button>\r\n      <button class=\"ql-list\" value=\"bullet\"></button>\r\n      <button class=\"ql-indent\" value=\"-1\"></button>\r\n      <button class=\"ql-indent\" value=\"+1\"></button>\r\n    </span>\r\n\r\n    <span class=\"ql-formats\">\r\n      <button class=\"ql-direction\" value=\"rtl\"></button>\r\n      <select class=\"ql-align\"></select>\r\n    </span>\r\n\r\n    <span class=\"ql-formats\">\r\n      <button class=\"ql-link\"></button>\r\n      <button class=\"ql-image\"></button>\r\n      <button class=\"ql-video\"></button>\r\n    </span>\r\n\r\n    <span class=\"ql-formats\">\r\n      <button class=\"ql-clean\"></button>\r\n    </span>\r\n  </div>\r\n\r\n  <div id=\"kv-editor\" [style.height]=\"canvaHeigth\" [ngClass]=\"{'error-border': hasControlError()}\" ></div>\r\n</div>\r\n<kv-error [hasError]=\"hasControlError()\">{{ erroMessage() }}</kv-error>\r\n\r\n\r\n<!------------------------------------------------------------------------------------------------------------------->\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  <link href=\"https://cdn.jsdelivr.net/npm/quill@2.0.2/dist/quill.snow.css\" rel=\"stylesheet\" />\r\n  <link href=\"https://fonts.googleapis.com/css?family=Roboto\" rel=\"stylesheet\">\r\n  <script src=\"https://cdn.jsdelivr.net/npm/quill@2.0.2/dist/quill.js\"></script>\r\n  <script src=\"https://cdn.jsdelivr.net/npm/katex@0.16.9/dist/katex.min.js\"></script>\r\n\r\n\r\n  <link rel=\"stylesheet\" href=\"https://cdn.jsdelivr.net/npm/quill@2.0.2/dist/quill.bubble.css\" />\r\n  <link rel=\"stylesheet\" href=\"https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.9.0/styles/atom-one-dark.min.css\" />\r\n  <link rel=\"stylesheet\" href=\"https://cdn.jsdelivr.net/npm/katex@0.16.9/dist/katex.min.css\" />\r\n\r\n\r\n  <!-- Import fonts -->\r\n\r\n  <link rel=\"preconnect\" href=\"https://fonts.googleapis.com\">\r\n  <link rel=\"preconnect\" href=\"https://fonts.gstatic.com\" crossorigin>\r\n\r\n  <link href=\"https://fonts.googleapis.com/css2?family=Baloo+2:wght@400;500;600;700;800&family=Inter:wght@100..900&family=JetBrains+Mono:ital,wght@0,100..800;1,100..800&display=swap\" rel=\"stylesheet\">\r\n  <link href=\"https://fonts.googleapis.com/css2?family=Baloo+2:wght@400;500;600;700;800&family=Inter:wght@100..900&family=JetBrains+Mono:ital,wght@0,100..800;1,100..800&family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap\" rel=\"stylesheet\">\r\n"]}
|
|
@@ -4696,7 +4696,8 @@ class KvCarouselComponent {
|
|
|
4696
4696
|
this.isCollapsed = false;
|
|
4697
4697
|
}
|
|
4698
4698
|
navigateToLink(link) {
|
|
4699
|
-
|
|
4699
|
+
if (link !== null && link !== undefined && link !== '')
|
|
4700
|
+
window.open(link, '_blank');
|
|
4700
4701
|
}
|
|
4701
4702
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvCarouselComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
4702
4703
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "17.3.8", type: KvCarouselComponent, selector: "kv-carousel", inputs: { heightCarousel: { classPropertyName: "heightCarousel", publicName: "heightCarousel", isSignal: true, isRequired: false, transformFunction: null }, carouselData: { classPropertyName: "carouselData", publicName: "carouselData", isSignal: false, isRequired: false, transformFunction: null }, autoplayInterval: { classPropertyName: "autoplayInterval", publicName: "autoplayInterval", isSignal: false, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "carouselContainer", first: true, predicate: Carousel, descendants: true, isSignal: true }], ngImport: i0, template: "<p-carousel\r\n [value]=\"carouselData\"\r\n [indicatorStyleClass]=\"'carousel-indicator'\"\r\n [autoplayInterval]=\"autoplayInterval\"\r\n [showIndicators]=\"true\"\r\n [showNavigators]=\"false\"\r\n [numVisible]=\"1\"\r\n [numScroll]=\"1\"\r\n [circular]=\"true\"\r\n styleClass=\"h-full\"\r\n>\r\n >\r\n <ng-template\r\n pTemplate=\"item\"\r\n let-banner\r\n class=\"justify-content-center align-items-center\"\r\n >\r\n <img\r\n [src]=\"banner.img\"\r\n class=\"w-full border-round-banner\"\r\n [style.height.px]=\"heightComputed()\"\r\n (click)=\"navigateToLink(banner.link)\"\r\n />\r\n </ng-template>\r\n</p-carousel>\r\n", styles: ["::ng-deep .p-carousel-indicators{position:absolute;left:50%;transform:translate(-50%);bottom:-1rem}::ng-deep .carousel-indicator{width:15px!important;height:4px!important;margin:-3px!important;padding:0!important;background-color:#eeeeeed0}::ng-deep .carousel-indicator:hover{background-color:#efefef}button.p-carousel-indicator.p-link{background-color:#f0f8ff!important}::ng-deep .p-carousel .p-carousel-content{overflow:hidden!important;position:relative}::ng-deep .border-round-banner{border-radius:20px!important;max-height:500px}\n"], dependencies: [{ kind: "directive", type: i1$2.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i2$2.Carousel, selector: "p-carousel", inputs: ["page", "numVisible", "numScroll", "responsiveOptions", "orientation", "verticalViewPortHeight", "contentClass", "indicatorsContentClass", "indicatorsContentStyle", "indicatorStyleClass", "indicatorStyle", "value", "circular", "showIndicators", "showNavigators", "autoplayInterval", "style", "styleClass"], outputs: ["onPage"] }] }); }
|
|
@@ -4815,12 +4816,31 @@ class KvEditorComponent extends BaseComponentInput {
|
|
|
4815
4816
|
Quill.register(SizeStyle, true);
|
|
4816
4817
|
Quill.register(Font, true);
|
|
4817
4818
|
Quill.register(Size, true);
|
|
4818
|
-
//
|
|
4819
|
-
|
|
4819
|
+
// Customizando o comportamento do Enter
|
|
4820
|
+
const bindings = Quill.import('modules/keyboard').DEFAULTS.bindings;
|
|
4821
|
+
bindings['enter'] = {
|
|
4822
|
+
key: 13, // Código da tecla Enter
|
|
4823
|
+
handler: (range) => {
|
|
4824
|
+
const quill = this.quill;
|
|
4825
|
+
quill.insertEmbed(range.index, 'break', true, Quill.sources.USER);
|
|
4826
|
+
quill.setSelection(range.index + 1, Quill.sources.SILENT);
|
|
4827
|
+
return false; // Evita o comportamento padrão de criar um <p>
|
|
4828
|
+
},
|
|
4829
|
+
};
|
|
4830
|
+
// Custom blot for <br> tag
|
|
4831
|
+
const BlockEmbed = Quill.import('blots/block/embed');
|
|
4832
|
+
class Break extends BlockEmbed {
|
|
4833
|
+
static { this.blotName = 'break'; }
|
|
4834
|
+
static { this.tagName = 'br'; }
|
|
4835
|
+
}
|
|
4836
|
+
Quill.register(Break);
|
|
4820
4837
|
this.quill = new Quill('#kv-editor', {
|
|
4821
4838
|
theme: 'snow',
|
|
4822
4839
|
modules: {
|
|
4823
4840
|
toolbar: '#kv-editor-toolbar',
|
|
4841
|
+
keyboard: {
|
|
4842
|
+
bindings: bindings,
|
|
4843
|
+
},
|
|
4824
4844
|
},
|
|
4825
4845
|
placeholder: this.label ? this.label : '',
|
|
4826
4846
|
readOnly: this.readonly,
|
|
@@ -4830,14 +4850,18 @@ class KvEditorComponent extends BaseComponentInput {
|
|
|
4830
4850
|
this.onSelectionChange.emit({
|
|
4831
4851
|
range: range,
|
|
4832
4852
|
oldRange: oldRange,
|
|
4833
|
-
source: source
|
|
4853
|
+
source: source,
|
|
4834
4854
|
});
|
|
4835
4855
|
});
|
|
4836
4856
|
this.quill.on('text-change', (delta, oldContents, source) => {
|
|
4837
4857
|
if (!this.updatingEditor) {
|
|
4838
4858
|
this.updatingEditor = false;
|
|
4839
4859
|
this.escrevaValor(this.quill.getSemanticHTML(), this.quill.getText());
|
|
4840
|
-
this.onTextChange.emit({
|
|
4860
|
+
this.onTextChange.emit({
|
|
4861
|
+
delta: delta,
|
|
4862
|
+
oldContents: oldContents,
|
|
4863
|
+
source: source,
|
|
4864
|
+
});
|
|
4841
4865
|
this.outputRaw.emit(this.quill.getText());
|
|
4842
4866
|
this.outputHtml.emit(this.quill.getSemanticHTML());
|
|
4843
4867
|
}
|