@ecodev/natural 40.0.0 → 40.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/ecodev-natural.umd.js +142 -4
- package/bundles/ecodev-natural.umd.js.map +1 -1
- package/ecodev-natural.metadata.json +1 -1
- package/esm2015/lib/modules/editor/editor.component.js +108 -0
- package/esm2015/lib/modules/editor/editor.module.js +13 -0
- package/esm2015/lib/modules/editor/public-api.js +6 -0
- package/esm2015/lib/modules/editor/schema.js +21 -0
- package/esm2015/public-api.js +2 -1
- package/fesm2015/ecodev-natural.js +138 -1
- package/fesm2015/ecodev-natural.js.map +1 -1
- package/lib/modules/editor/editor.component.d.ts +31 -0
- package/lib/modules/editor/editor.module.d.ts +2 -0
- package/lib/modules/editor/public-api.d.ts +2 -0
- package/lib/modules/editor/schema.d.ts +2 -0
- package/package.json +6 -1
- package/public-api.d.ts +1 -0
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import { Component, ElementRef, EventEmitter, Inject, Optional, Output, Self, ViewChild, } from '@angular/core';
|
|
2
|
+
import { NgControl } from '@angular/forms';
|
|
3
|
+
import { EditorView } from 'prosemirror-view';
|
|
4
|
+
import { EditorState } from 'prosemirror-state';
|
|
5
|
+
// @ts-ignore
|
|
6
|
+
import { exampleSetup } from 'prosemirror-example-setup';
|
|
7
|
+
import { DOMParser, DOMSerializer } from 'prosemirror-model';
|
|
8
|
+
import { schema } from './schema';
|
|
9
|
+
import { DOCUMENT } from '@angular/common';
|
|
10
|
+
/**
|
|
11
|
+
* Prosemirror component
|
|
12
|
+
* Usage :
|
|
13
|
+
* <natural-editor [(ngModel)]="htmlString"></natural-editor>
|
|
14
|
+
*/
|
|
15
|
+
// @dynamic
|
|
16
|
+
export class NaturalEditorComponent {
|
|
17
|
+
constructor(ngControl, document) {
|
|
18
|
+
this.ngControl = ngControl;
|
|
19
|
+
this.document = document;
|
|
20
|
+
this.view = null;
|
|
21
|
+
this.contentChange = new EventEmitter();
|
|
22
|
+
/**
|
|
23
|
+
* HTML string
|
|
24
|
+
*/
|
|
25
|
+
this.content = '';
|
|
26
|
+
if (this.ngControl !== null) {
|
|
27
|
+
this.ngControl.valueAccessor = this;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
ngOnInit() {
|
|
31
|
+
const serializer = DOMSerializer.fromSchema(schema);
|
|
32
|
+
const state = this.createState();
|
|
33
|
+
this.view = new EditorView(this.editor.nativeElement, {
|
|
34
|
+
state: state,
|
|
35
|
+
dispatchTransaction: (transaction) => {
|
|
36
|
+
if (!this.view) {
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
const newState = this.view.state.apply(transaction);
|
|
40
|
+
this.view.updateState(newState);
|
|
41
|
+
// Transform doc into HTML string
|
|
42
|
+
const dom = serializer.serializeFragment(this.view.state.doc);
|
|
43
|
+
const el = this.document.createElement('_');
|
|
44
|
+
el.appendChild(dom);
|
|
45
|
+
const newContent = el.innerHTML;
|
|
46
|
+
if (this.content === newContent) {
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
this.content = el.innerHTML;
|
|
50
|
+
if (this.onChange) {
|
|
51
|
+
this.onChange(this.content);
|
|
52
|
+
}
|
|
53
|
+
this.contentChange.emit(this.content);
|
|
54
|
+
},
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
writeValue(val) {
|
|
58
|
+
if (typeof val === 'string' && val !== this.content) {
|
|
59
|
+
this.content = val;
|
|
60
|
+
}
|
|
61
|
+
if (this.view !== null) {
|
|
62
|
+
const state = this.createState();
|
|
63
|
+
this.view.updateState(state);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
createState() {
|
|
67
|
+
const template = this.document.createElement('_');
|
|
68
|
+
template.innerHTML = '<div>' + this.content + '</div>';
|
|
69
|
+
if (!template.firstChild) {
|
|
70
|
+
throw new Error('child of template element could not be created');
|
|
71
|
+
}
|
|
72
|
+
const parser = DOMParser.fromSchema(schema);
|
|
73
|
+
const doc = parser.parse(template.firstChild);
|
|
74
|
+
return EditorState.create({
|
|
75
|
+
doc: doc,
|
|
76
|
+
plugins: exampleSetup({ schema }),
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
registerOnChange(fn) {
|
|
80
|
+
this.onChange = fn;
|
|
81
|
+
}
|
|
82
|
+
registerOnTouched(fn) { }
|
|
83
|
+
setDisabledState(isDisabled) {
|
|
84
|
+
// TODO disable editor ?
|
|
85
|
+
}
|
|
86
|
+
ngOnDestroy() {
|
|
87
|
+
if (this.view) {
|
|
88
|
+
this.view.destroy();
|
|
89
|
+
this.view = null;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
NaturalEditorComponent.decorators = [
|
|
94
|
+
{ type: Component, args: [{
|
|
95
|
+
selector: 'natural-editor',
|
|
96
|
+
template: ` <div #editor></div>`,
|
|
97
|
+
styles: ["@charset \"UTF-8\";::ng-deep .ProseMirror{position:relative;background:rgba(0,0,0,.1)}::ng-deep .ProseMirror{word-wrap:break-word;white-space:pre-wrap;-webkit-font-variant-ligatures:none;font-feature-settings:none;font-variant-ligatures:none}::ng-deep .ProseMirror pre{white-space:pre-wrap}::ng-deep .ProseMirror li{position:relative}::ng-deep .ProseMirror-hideselection *::selection{background:transparent}::ng-deep .ProseMirror-hideselection *::-moz-selection{background:transparent}::ng-deep .ProseMirror-hideselection{caret-color:transparent}::ng-deep .ProseMirror-selectednode{outline:2px solid #8cf}::ng-deep li.ProseMirror-selectednode{outline:none}::ng-deep li.ProseMirror-selectednode:after{content:\"\";position:absolute;left:-32px;right:-2px;top:-2px;bottom:-2px;border:2px solid #8cf;pointer-events:none}::ng-deep .ProseMirror-textblock-dropdown{min-width:3em}::ng-deep .ProseMirror-menu{margin:20px;line-height:1}::ng-deep .ProseMirror-tooltip .ProseMirror-menu{width:-moz-fit-content;width:fit-content;white-space:pre}::ng-deep .ProseMirror-menuitem{margin-right:8px;display:inline-block}::ng-deep .ProseMirror-menuseparator{border-right:1px solid rgba(255,255,255,.3);margin-right:12px}::ng-deep .ProseMirror-menu-dropdown,::ng-deep .ProseMirror-menu-dropdown-menu{white-space:nowrap}::ng-deep .ProseMirror-menu-dropdown{vertical-align:1px;cursor:pointer;position:relative;padding-right:15px}::ng-deep .ProseMirror-menu-dropdown-wrap{padding:1px 0 1px 4px;display:inline-block;position:relative}::ng-deep .ProseMirror-menu-dropdown:after{content:\"\";border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid currentColor;opacity:.6;position:absolute;right:4px;top:calc(50% - 2px)}::ng-deep .ProseMirror-menu-dropdown-menu,::ng-deep .ProseMirror-menu-submenu{position:absolute;background:white;color:#666;padding:2px;border-radius:4px;box-shadow:0 5px 5px #00000080}::ng-deep .ProseMirror-menu-dropdown-menu{z-index:15;min-width:6em;padding:6px;top:40px}::ng-deep .ProseMirror-menu-dropdown-item{cursor:pointer;padding:12px}::ng-deep .ProseMirror-menu-dropdown-item:hover{background:#f2f2f2}::ng-deep .ProseMirror-menu-submenu{padding:6px}::ng-deep .ProseMirror-menu-submenu-wrap{position:relative;margin-right:-4px}::ng-deep .ProseMirror-menu-submenu-label:after{content:\"\";border-top:4px solid transparent;border-bottom:4px solid transparent;border-left:4px solid currentColor;opacity:.6;position:absolute;right:4px;top:calc(50% - 4px)}::ng-deep .ProseMirror-menu-submenu{display:none;min-width:6em;left:100%;top:-17px}::ng-deep .ProseMirror-menu-active{background:white;color:#000}::ng-deep .ProseMirror-menu-disabled{opacity:.3}::ng-deep .ProseMirror-menu-submenu-wrap:hover .ProseMirror-menu-submenu,::ng-deep .ProseMirror-menu-submenu-wrap-active .ProseMirror-menu-submenu{display:block}::ng-deep .ProseMirror-menubar{border-top-left-radius:inherit;border-top-right-radius:inherit;position:relative;min-height:1em;color:#fffc;padding:10px 18px;top:0;left:0;right:0;background:rgba(0,0,0,.8);z-index:10;box-sizing:border-box;overflow:visible;font-size:18px}::ng-deep .ProseMirror-icon{display:inline-block;line-height:.8;vertical-align:-2px;padding:8px;cursor:pointer;border-radius:4px}::ng-deep .ProseMirror-menu-disabled.ProseMirror-icon{cursor:default}::ng-deep .ProseMirror-icon svg{fill:currentColor;height:1em}::ng-deep .ProseMirror-icon span{vertical-align:text-top}::ng-deep .ProseMirror-gapcursor{display:none;pointer-events:none;position:absolute}::ng-deep .ProseMirror-gapcursor:after{content:\"\";display:block;position:absolute;top:-2px;width:20px;border-top:1px solid black;animation:ProseMirror-cursor-blink 1.1s steps(2,start) infinite}@keyframes ProseMirror-cursor-blink{to{visibility:hidden}}::ng-deep .ProseMirror-focused .ProseMirror-gapcursor{display:block}::ng-deep .ProseMirror-example-setup-style hr{padding:2px 10px;border:none;margin:1em 0}::ng-deep .ProseMirror-example-setup-style hr:after{content:\"\";display:block;height:1px;background-color:silver;line-height:2px}::ng-deep .ProseMirror ul,::ng-deep .ProseMirror ol{padding-left:30px}::ng-deep .ProseMirror blockquote{padding-left:1em;border-left:3px solid #eee;margin-left:0;margin-right:0}::ng-deep .ProseMirror-example-setup-style img{cursor:default}::ng-deep .ProseMirror-prompt{background:white;padding:20px;position:fixed;border-radius:4px;z-index:11;box-shadow:-.5px 2px 15px #000c;font-size:16px;color:#000}::ng-deep .ProseMirror-prompt h5{margin:0;font-weight:normal;font-size:24px}::ng-deep .ProseMirror-prompt input[type=text],::ng-deep .ProseMirror-prompt textarea{background:rgba(0,0,0,.1);border:none;border-bottom:1px solid rgba(0,0,0,.8);outline:none;padding:10px 20px;margin:.4em 0;width:20em;border-top-left-radius:4px;border-top-right-radius:4px;font-size:16px;color:#000}::ng-deep .ProseMirror-prompt-close{position:absolute;left:2px;top:1px;color:#000;border:none;background:transparent;padding:0}::ng-deep .ProseMirror-prompt-close:after{content:\"\\e2\\153\\2022\";font-size:12px}::ng-deep .ProseMirror-invalid{background:#ffc;border:1px solid #cc7;border-radius:4px;padding:5px 10px;position:absolute;min-width:10em}::ng-deep .ProseMirror-prompt-buttons{margin-top:5px;display:none}::ng-deep #editor,::ng-deep .editor{background:white;color:#000;background-clip:padding-box;border-radius:4px;border:2px solid rgba(0,0,0,.2);padding:5px 0;margin-bottom:23px}::ng-deep .ProseMirror p:first-child,::ng-deep .ProseMirror h1:first-child,::ng-deep .ProseMirror h2:first-child,::ng-deep .ProseMirror h3:first-child,::ng-deep .ProseMirror h4:first-child,::ng-deep .ProseMirror h5:first-child,::ng-deep .ProseMirror h6:first-child{margin-top:10px}::ng-deep .ProseMirror{padding:4px 8px 4px 14px;line-height:1.2;outline:none}::ng-deep .ProseMirror p{margin-bottom:1em}\n"]
|
|
98
|
+
},] }
|
|
99
|
+
];
|
|
100
|
+
NaturalEditorComponent.ctorParameters = () => [
|
|
101
|
+
{ type: NgControl, decorators: [{ type: Optional }, { type: Self }] },
|
|
102
|
+
{ type: Document, decorators: [{ type: Inject, args: [DOCUMENT,] }] }
|
|
103
|
+
];
|
|
104
|
+
NaturalEditorComponent.propDecorators = {
|
|
105
|
+
editor: [{ type: ViewChild, args: ['editor', { read: ElementRef, static: true },] }],
|
|
106
|
+
contentChange: [{ type: Output }]
|
|
107
|
+
};
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"","sources":["../../../../../../projects/natural/src/lib/modules/editor/editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    EventEmitter,\n    Inject,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {ControlValueAccessor, NgControl} from '@angular/forms';\nimport {EditorView} from 'prosemirror-view';\nimport {EditorState, Transaction} from 'prosemirror-state';\n// @ts-ignore\nimport {exampleSetup} from 'prosemirror-example-setup';\nimport {DOMParser, DOMSerializer} from 'prosemirror-model';\nimport {schema} from './schema';\nimport {DOCUMENT} from '@angular/common';\n\n/**\n * Prosemirror component\n * Usage :\n * <natural-editor [(ngModel)]=\"htmlString\"></natural-editor>\n */\n// @dynamic\n@Component({\n    selector: 'natural-editor',\n    template: ` <div #editor></div>`,\n    styleUrls: ['./editor.component.scss'],\n})\nexport class NaturalEditorComponent implements OnInit, OnDestroy, ControlValueAccessor {\n    private view: EditorView | null = null;\n\n    @ViewChild('editor', {read: ElementRef, static: true}) private editor!: ElementRef;\n\n    @Output() public readonly contentChange = new EventEmitter<string>();\n\n    /**\n     * Interface with ControlValueAccessor\n     * Notifies parent model / form controller\n     */\n    private onChange?: (value: string | null) => void;\n\n    /**\n     * HTML string\n     */\n    private content = '';\n\n    constructor(\n        @Optional() @Self() public readonly ngControl: NgControl,\n        @Inject(DOCUMENT) private readonly document: Document,\n    ) {\n        if (this.ngControl !== null) {\n            this.ngControl.valueAccessor = this;\n        }\n    }\n\n    public ngOnInit(): void {\n        const serializer = DOMSerializer.fromSchema(schema);\n        const state = this.createState();\n\n        this.view = new EditorView(this.editor.nativeElement, {\n            state: state,\n            dispatchTransaction: (transaction: Transaction) => {\n                if (!this.view) {\n                    return;\n                }\n\n                const newState = this.view.state.apply(transaction);\n                this.view.updateState(newState);\n\n                // Transform doc into HTML string\n                const dom = serializer.serializeFragment(this.view.state.doc as any);\n                const el = this.document.createElement('_');\n                el.appendChild(dom);\n\n                const newContent = el.innerHTML;\n                if (this.content === newContent) {\n                    return;\n                }\n\n                this.content = el.innerHTML;\n\n                if (this.onChange) {\n                    this.onChange(this.content);\n                }\n                this.contentChange.emit(this.content);\n            },\n        });\n    }\n\n    public writeValue(val: string | undefined): void {\n        if (typeof val === 'string' && val !== this.content) {\n            this.content = val;\n        }\n\n        if (this.view !== null) {\n            const state = this.createState();\n            this.view.updateState(state);\n        }\n    }\n\n    private createState(): EditorState {\n        const template = this.document.createElement('_');\n        template.innerHTML = '<div>' + this.content + '</div>';\n        if (!template.firstChild) {\n            throw new Error('child of template element could not be created');\n        }\n\n        const parser = DOMParser.fromSchema(schema);\n        const doc = parser.parse(template.firstChild);\n\n        return EditorState.create({\n            doc: doc,\n            plugins: exampleSetup({schema}),\n        });\n    }\n\n    public registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    public registerOnTouched(fn: any): void {}\n\n    public setDisabledState(isDisabled: boolean): void {\n        // TODO disable editor ?\n    }\n\n    public ngOnDestroy(): void {\n        if (this.view) {\n            this.view.destroy();\n            this.view = null;\n        }\n    }\n}\n"]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { NaturalEditorComponent } from './editor.component';
|
|
4
|
+
export class NaturalEditorModule {
|
|
5
|
+
}
|
|
6
|
+
NaturalEditorModule.decorators = [
|
|
7
|
+
{ type: NgModule, args: [{
|
|
8
|
+
declarations: [NaturalEditorComponent],
|
|
9
|
+
imports: [CommonModule],
|
|
10
|
+
exports: [NaturalEditorComponent],
|
|
11
|
+
},] }
|
|
12
|
+
];
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdG9yLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL2VkaXRvci9lZGl0b3IubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxzQkFBc0IsRUFBQyxNQUFNLG9CQUFvQixDQUFDO0FBTzFELE1BQU0sT0FBTyxtQkFBbUI7OztZQUwvQixRQUFRLFNBQUM7Z0JBQ04sWUFBWSxFQUFFLENBQUMsc0JBQXNCLENBQUM7Z0JBQ3RDLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztnQkFDdkIsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7YUFDcEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtOYXR1cmFsRWRpdG9yQ29tcG9uZW50fSBmcm9tICcuL2VkaXRvci5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogW05hdHVyYWxFZGl0b3JDb21wb25lbnRdLFxuICAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICAgIGV4cG9ydHM6IFtOYXR1cmFsRWRpdG9yQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgTmF0dXJhbEVkaXRvck1vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Public API Surface of natural
|
|
3
|
+
*/
|
|
4
|
+
export * from './editor.component';
|
|
5
|
+
export * from './editor.module';
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL2VkaXRvci9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGlCQUFpQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBuYXR1cmFsXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9lZGl0b3IuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZWRpdG9yLm1vZHVsZSc7XG4iXX0=
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { marks, nodes } from 'prosemirror-schema-basic';
|
|
2
|
+
import { addListNodes } from 'prosemirror-schema-list';
|
|
3
|
+
import { Schema } from 'prosemirror-model';
|
|
4
|
+
const myNodes = {
|
|
5
|
+
heading: nodes.heading,
|
|
6
|
+
doc: nodes.doc,
|
|
7
|
+
paragraph: nodes.paragraph,
|
|
8
|
+
text: nodes.text,
|
|
9
|
+
hard_break: nodes.hard_break,
|
|
10
|
+
};
|
|
11
|
+
const myMarks = {
|
|
12
|
+
link: marks.link,
|
|
13
|
+
em: marks.em,
|
|
14
|
+
strong: marks.strong,
|
|
15
|
+
};
|
|
16
|
+
const basicSchema = new Schema({ nodes: myNodes, marks: myMarks });
|
|
17
|
+
export const schema = new Schema({
|
|
18
|
+
nodes: addListNodes(basicSchema.spec.nodes, 'paragraph block*', 'block'),
|
|
19
|
+
marks: basicSchema.spec.marks,
|
|
20
|
+
});
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvZWRpdG9yL3NjaGVtYS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsS0FBSyxFQUFFLEtBQUssRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQ3RELE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUNyRCxPQUFPLEVBQUMsTUFBTSxFQUFDLE1BQU0sbUJBQW1CLENBQUM7QUFJekMsTUFBTSxPQUFPLEdBQWU7SUFDeEIsT0FBTyxFQUFFLEtBQUssQ0FBQyxPQUFPO0lBQ3RCLEdBQUcsRUFBRSxLQUFLLENBQUMsR0FBRztJQUNkLFNBQVMsRUFBRSxLQUFLLENBQUMsU0FBUztJQUMxQixJQUFJLEVBQUUsS0FBSyxDQUFDLElBQUk7SUFDaEIsVUFBVSxFQUFFLEtBQUssQ0FBQyxVQUFVO0NBQy9CLENBQUM7QUFHRixNQUFNLE9BQU8sR0FBZTtJQUN4QixJQUFJLEVBQUUsS0FBSyxDQUFDLElBQUk7SUFDaEIsRUFBRSxFQUFFLEtBQUssQ0FBQyxFQUFFO0lBQ1osTUFBTSxFQUFFLEtBQUssQ0FBQyxNQUFNO0NBQ3ZCLENBQUM7QUFFRixNQUFNLFdBQVcsR0FBRyxJQUFJLE1BQU0sQ0FBQyxFQUFDLEtBQUssRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBQyxDQUFDLENBQUM7QUFFakUsTUFBTSxDQUFDLE1BQU0sTUFBTSxHQUFHLElBQUksTUFBTSxDQUFDO0lBQzdCLEtBQUssRUFBRSxZQUFZLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxLQUFZLEVBQUUsa0JBQWtCLEVBQUUsT0FBTyxDQUFDO0lBQy9FLEtBQUssRUFBRSxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUs7Q0FDaEMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHttYXJrcywgbm9kZXN9IGZyb20gJ3Byb3NlbWlycm9yLXNjaGVtYS1iYXNpYyc7XG5pbXBvcnQge2FkZExpc3ROb2Rlc30gZnJvbSAncHJvc2VtaXJyb3Itc2NoZW1hLWxpc3QnO1xuaW1wb3J0IHtTY2hlbWF9IGZyb20gJ3Byb3NlbWlycm9yLW1vZGVsJztcblxuLy8gS2VlcCBvbmx5IGJhc2ljIGVsZW1lbnRzXG50eXBlIEJhc2ljTm9kZXMgPSBPbWl0PHR5cGVvZiBub2RlcywgJ2ltYWdlJyB8ICdjb2RlX2Jsb2NrJyB8ICdibG9ja3F1b3RlJyB8ICdob3Jpem9udGFsX3J1bGUnPjtcbmNvbnN0IG15Tm9kZXM6IEJhc2ljTm9kZXMgPSB7XG4gICAgaGVhZGluZzogbm9kZXMuaGVhZGluZyxcbiAgICBkb2M6IG5vZGVzLmRvYyxcbiAgICBwYXJhZ3JhcGg6IG5vZGVzLnBhcmFncmFwaCxcbiAgICB0ZXh0OiBub2Rlcy50ZXh0LFxuICAgIGhhcmRfYnJlYWs6IG5vZGVzLmhhcmRfYnJlYWssXG59O1xuXG50eXBlIEJhc2ljTWFya3MgPSBPbWl0PHR5cGVvZiBtYXJrcywgJ2NvZGUnPjtcbmNvbnN0IG15TWFya3M6IEJhc2ljTWFya3MgPSB7XG4gICAgbGluazogbWFya3MubGluayxcbiAgICBlbTogbWFya3MuZW0sXG4gICAgc3Ryb25nOiBtYXJrcy5zdHJvbmcsXG59O1xuXG5jb25zdCBiYXNpY1NjaGVtYSA9IG5ldyBTY2hlbWEoe25vZGVzOiBteU5vZGVzLCBtYXJrczogbXlNYXJrc30pO1xuXG5leHBvcnQgY29uc3Qgc2NoZW1hID0gbmV3IFNjaGVtYSh7XG4gICAgbm9kZXM6IGFkZExpc3ROb2RlcyhiYXNpY1NjaGVtYS5zcGVjLm5vZGVzIGFzIGFueSwgJ3BhcmFncmFwaCBibG9jayonLCAnYmxvY2snKSxcbiAgICBtYXJrczogYmFzaWNTY2hlbWEuc3BlYy5tYXJrcyxcbn0pO1xuIl19
|
package/esm2015/public-api.js
CHANGED
|
@@ -41,5 +41,6 @@ export * from './lib/modules/table-button/public-api';
|
|
|
41
41
|
export * from './lib/modules/dialog-trigger/public-api';
|
|
42
42
|
export * from './lib/modules/avatar/public-api';
|
|
43
43
|
export * from './lib/modules/matomo/public-api';
|
|
44
|
+
export * from './lib/modules/editor/public-api';
|
|
44
45
|
export * from './lib/directives/http-prefix.directive';
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsd0hBQXdIO0FBQ3hILE9BQU8sd0JBQXdCLENBQUM7QUFFaEM7O0dBRUc7QUFFSCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLG1CQUFtQixDQUFDO0FBRTVDLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyxtREFBbUQsQ0FBQztBQUVsRSxjQUFjLG1CQUFtQixDQUFDO0FBRWxDLGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLGlDQUFpQyxDQUFDO0FBRWhELGNBQWMsd0NBQXdDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBMb2FkIGAkbG9jYWxpemVgIG9udG8gdGhlIGdsb2JhbCBzY29wZSAtIHRvIGJlIGFibGUgdG8gdXNlIHRoYXQgZnVuY3Rpb24gdG8gdHJhbnNsYXRlIHN0cmluZ3MgaW4gY29tcG9uZW50cy9zZXJ2aWNlcy5cbmltcG9ydCAnQGFuZ3VsYXIvbG9jYWxpemUvaW5pdCc7XG5cbi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgbmF0dXJhbFxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2NsYXNzZXMvYWJzdHJhY3QtY29udHJvbGxlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jbGFzc2VzL2Fic3RyYWN0LWRldGFpbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jbGFzc2VzL2Fic3RyYWN0LWVkaXRhYmxlLWxpc3QnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2xhc3Nlcy9hYnN0cmFjdC1saXN0JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NsYXNzZXMvYWJzdHJhY3QtbmF2aWdhYmxlLWxpc3QnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2xhc3Nlcy9hcG9sbG8tdXRpbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2xhc3Nlcy9kYXRhLXNvdXJjZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jbGFzc2VzL3F1ZXJ5LXZhcmlhYmxlLW1hbmFnZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2xhc3Nlcy9yeGpzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NsYXNzZXMvdXRpbGl0eSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jbGFzc2VzL3ZhbGlkYXRvcnMnO1xuZXhwb3J0IHt2YWxpZFRsZHN9IGZyb20gJy4vbGliL2NsYXNzZXMvdGxkJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvYWJzdHJhY3QtbW9kZWwuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcy9lbnVtLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvbGluay1tdXRhdGlvbi5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlcnZpY2VzL3BlcnNpc3RlbmNlLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvc3dpc3MtcGFyc2luZy1kYXRlLWFkYXB0ZXIuc2VydmljZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3R5cGVzL3R5cGVzJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9hbGVydC9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvY29sdW1ucy1waWNrZXIvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL2NvbW1vbi9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvZGV0YWlsLWhlYWRlci9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvZHJvcGRvd24tY29tcG9uZW50cy9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvZmlsZS9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvZml4ZWQtYnV0dG9uL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9maXhlZC1idXR0b24tZGV0YWlsL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9oaWVyYXJjaGljLXNlbGVjdG9yL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9pY29uL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9wYW5lbHMvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL3JlbGF0aW9ucy9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvc2VhcmNoL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9zZWxlY3QvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL3NpZGVuYXYvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL3N0YW1wL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy90YWJsZS1idXR0b24vcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL2RpYWxvZy10cmlnZ2VyL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9hdmF0YXIvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL21hdG9tby9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvZWRpdG9yL3B1YmxpYy1hcGknO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL2h0dHAtcHJlZml4LmRpcmVjdGl2ZSc7XG4iXX0=
|
|
@@ -51,6 +51,12 @@ import { MatPaginatorModule } from '@angular/material/paginator';
|
|
|
51
51
|
import { MatSidenavContainer, MatSidenav, MatSidenavModule } from '@angular/material/sidenav';
|
|
52
52
|
import { __rest } from 'tslib';
|
|
53
53
|
import { Md5 } from 'ts-md5';
|
|
54
|
+
import { EditorView } from 'prosemirror-view';
|
|
55
|
+
import { EditorState } from 'prosemirror-state';
|
|
56
|
+
import { exampleSetup } from 'prosemirror-example-setup';
|
|
57
|
+
import { Schema, DOMSerializer, DOMParser } from 'prosemirror-model';
|
|
58
|
+
import { nodes, marks } from 'prosemirror-schema-basic';
|
|
59
|
+
import { addListNodes } from 'prosemirror-schema-list';
|
|
54
60
|
|
|
55
61
|
// tslint:disable:directive-class-suffix
|
|
56
62
|
/**
|
|
@@ -10106,6 +10112,137 @@ NaturalMatomoService.ctorParameters = () => [
|
|
|
10106
10112
|
{ type: Title }
|
|
10107
10113
|
];
|
|
10108
10114
|
|
|
10115
|
+
/*
|
|
10116
|
+
* Public API Surface of natural
|
|
10117
|
+
*/
|
|
10118
|
+
|
|
10119
|
+
const myNodes = {
|
|
10120
|
+
heading: nodes.heading,
|
|
10121
|
+
doc: nodes.doc,
|
|
10122
|
+
paragraph: nodes.paragraph,
|
|
10123
|
+
text: nodes.text,
|
|
10124
|
+
hard_break: nodes.hard_break,
|
|
10125
|
+
};
|
|
10126
|
+
const myMarks = {
|
|
10127
|
+
link: marks.link,
|
|
10128
|
+
em: marks.em,
|
|
10129
|
+
strong: marks.strong,
|
|
10130
|
+
};
|
|
10131
|
+
const basicSchema = new Schema({ nodes: myNodes, marks: myMarks });
|
|
10132
|
+
const schema = new Schema({
|
|
10133
|
+
nodes: addListNodes(basicSchema.spec.nodes, 'paragraph block*', 'block'),
|
|
10134
|
+
marks: basicSchema.spec.marks,
|
|
10135
|
+
});
|
|
10136
|
+
|
|
10137
|
+
/**
|
|
10138
|
+
* Prosemirror component
|
|
10139
|
+
* Usage :
|
|
10140
|
+
* <natural-editor [(ngModel)]="htmlString"></natural-editor>
|
|
10141
|
+
*/
|
|
10142
|
+
// @dynamic
|
|
10143
|
+
class NaturalEditorComponent {
|
|
10144
|
+
constructor(ngControl, document) {
|
|
10145
|
+
this.ngControl = ngControl;
|
|
10146
|
+
this.document = document;
|
|
10147
|
+
this.view = null;
|
|
10148
|
+
this.contentChange = new EventEmitter();
|
|
10149
|
+
/**
|
|
10150
|
+
* HTML string
|
|
10151
|
+
*/
|
|
10152
|
+
this.content = '';
|
|
10153
|
+
if (this.ngControl !== null) {
|
|
10154
|
+
this.ngControl.valueAccessor = this;
|
|
10155
|
+
}
|
|
10156
|
+
}
|
|
10157
|
+
ngOnInit() {
|
|
10158
|
+
const serializer = DOMSerializer.fromSchema(schema);
|
|
10159
|
+
const state = this.createState();
|
|
10160
|
+
this.view = new EditorView(this.editor.nativeElement, {
|
|
10161
|
+
state: state,
|
|
10162
|
+
dispatchTransaction: (transaction) => {
|
|
10163
|
+
if (!this.view) {
|
|
10164
|
+
return;
|
|
10165
|
+
}
|
|
10166
|
+
const newState = this.view.state.apply(transaction);
|
|
10167
|
+
this.view.updateState(newState);
|
|
10168
|
+
// Transform doc into HTML string
|
|
10169
|
+
const dom = serializer.serializeFragment(this.view.state.doc);
|
|
10170
|
+
const el = this.document.createElement('_');
|
|
10171
|
+
el.appendChild(dom);
|
|
10172
|
+
const newContent = el.innerHTML;
|
|
10173
|
+
if (this.content === newContent) {
|
|
10174
|
+
return;
|
|
10175
|
+
}
|
|
10176
|
+
this.content = el.innerHTML;
|
|
10177
|
+
if (this.onChange) {
|
|
10178
|
+
this.onChange(this.content);
|
|
10179
|
+
}
|
|
10180
|
+
this.contentChange.emit(this.content);
|
|
10181
|
+
},
|
|
10182
|
+
});
|
|
10183
|
+
}
|
|
10184
|
+
writeValue(val) {
|
|
10185
|
+
if (typeof val === 'string' && val !== this.content) {
|
|
10186
|
+
this.content = val;
|
|
10187
|
+
}
|
|
10188
|
+
if (this.view !== null) {
|
|
10189
|
+
const state = this.createState();
|
|
10190
|
+
this.view.updateState(state);
|
|
10191
|
+
}
|
|
10192
|
+
}
|
|
10193
|
+
createState() {
|
|
10194
|
+
const template = this.document.createElement('_');
|
|
10195
|
+
template.innerHTML = '<div>' + this.content + '</div>';
|
|
10196
|
+
if (!template.firstChild) {
|
|
10197
|
+
throw new Error('child of template element could not be created');
|
|
10198
|
+
}
|
|
10199
|
+
const parser = DOMParser.fromSchema(schema);
|
|
10200
|
+
const doc = parser.parse(template.firstChild);
|
|
10201
|
+
return EditorState.create({
|
|
10202
|
+
doc: doc,
|
|
10203
|
+
plugins: exampleSetup({ schema }),
|
|
10204
|
+
});
|
|
10205
|
+
}
|
|
10206
|
+
registerOnChange(fn) {
|
|
10207
|
+
this.onChange = fn;
|
|
10208
|
+
}
|
|
10209
|
+
registerOnTouched(fn) { }
|
|
10210
|
+
setDisabledState(isDisabled) {
|
|
10211
|
+
// TODO disable editor ?
|
|
10212
|
+
}
|
|
10213
|
+
ngOnDestroy() {
|
|
10214
|
+
if (this.view) {
|
|
10215
|
+
this.view.destroy();
|
|
10216
|
+
this.view = null;
|
|
10217
|
+
}
|
|
10218
|
+
}
|
|
10219
|
+
}
|
|
10220
|
+
NaturalEditorComponent.decorators = [
|
|
10221
|
+
{ type: Component, args: [{
|
|
10222
|
+
selector: 'natural-editor',
|
|
10223
|
+
template: ` <div #editor></div>`,
|
|
10224
|
+
styles: ["@charset \"UTF-8\";::ng-deep .ProseMirror{position:relative;background:rgba(0,0,0,.1)}::ng-deep .ProseMirror{word-wrap:break-word;white-space:pre-wrap;-webkit-font-variant-ligatures:none;font-feature-settings:none;font-variant-ligatures:none}::ng-deep .ProseMirror pre{white-space:pre-wrap}::ng-deep .ProseMirror li{position:relative}::ng-deep .ProseMirror-hideselection *::selection{background:transparent}::ng-deep .ProseMirror-hideselection *::-moz-selection{background:transparent}::ng-deep .ProseMirror-hideselection{caret-color:transparent}::ng-deep .ProseMirror-selectednode{outline:2px solid #8cf}::ng-deep li.ProseMirror-selectednode{outline:none}::ng-deep li.ProseMirror-selectednode:after{content:\"\";position:absolute;left:-32px;right:-2px;top:-2px;bottom:-2px;border:2px solid #8cf;pointer-events:none}::ng-deep .ProseMirror-textblock-dropdown{min-width:3em}::ng-deep .ProseMirror-menu{margin:20px;line-height:1}::ng-deep .ProseMirror-tooltip .ProseMirror-menu{width:-moz-fit-content;width:fit-content;white-space:pre}::ng-deep .ProseMirror-menuitem{margin-right:8px;display:inline-block}::ng-deep .ProseMirror-menuseparator{border-right:1px solid rgba(255,255,255,.3);margin-right:12px}::ng-deep .ProseMirror-menu-dropdown,::ng-deep .ProseMirror-menu-dropdown-menu{white-space:nowrap}::ng-deep .ProseMirror-menu-dropdown{vertical-align:1px;cursor:pointer;position:relative;padding-right:15px}::ng-deep .ProseMirror-menu-dropdown-wrap{padding:1px 0 1px 4px;display:inline-block;position:relative}::ng-deep .ProseMirror-menu-dropdown:after{content:\"\";border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid currentColor;opacity:.6;position:absolute;right:4px;top:calc(50% - 2px)}::ng-deep .ProseMirror-menu-dropdown-menu,::ng-deep .ProseMirror-menu-submenu{position:absolute;background:white;color:#666;padding:2px;border-radius:4px;box-shadow:0 5px 5px #00000080}::ng-deep .ProseMirror-menu-dropdown-menu{z-index:15;min-width:6em;padding:6px;top:40px}::ng-deep .ProseMirror-menu-dropdown-item{cursor:pointer;padding:12px}::ng-deep .ProseMirror-menu-dropdown-item:hover{background:#f2f2f2}::ng-deep .ProseMirror-menu-submenu{padding:6px}::ng-deep .ProseMirror-menu-submenu-wrap{position:relative;margin-right:-4px}::ng-deep .ProseMirror-menu-submenu-label:after{content:\"\";border-top:4px solid transparent;border-bottom:4px solid transparent;border-left:4px solid currentColor;opacity:.6;position:absolute;right:4px;top:calc(50% - 4px)}::ng-deep .ProseMirror-menu-submenu{display:none;min-width:6em;left:100%;top:-17px}::ng-deep .ProseMirror-menu-active{background:white;color:#000}::ng-deep .ProseMirror-menu-disabled{opacity:.3}::ng-deep .ProseMirror-menu-submenu-wrap:hover .ProseMirror-menu-submenu,::ng-deep .ProseMirror-menu-submenu-wrap-active .ProseMirror-menu-submenu{display:block}::ng-deep .ProseMirror-menubar{border-top-left-radius:inherit;border-top-right-radius:inherit;position:relative;min-height:1em;color:#fffc;padding:10px 18px;top:0;left:0;right:0;background:rgba(0,0,0,.8);z-index:10;box-sizing:border-box;overflow:visible;font-size:18px}::ng-deep .ProseMirror-icon{display:inline-block;line-height:.8;vertical-align:-2px;padding:8px;cursor:pointer;border-radius:4px}::ng-deep .ProseMirror-menu-disabled.ProseMirror-icon{cursor:default}::ng-deep .ProseMirror-icon svg{fill:currentColor;height:1em}::ng-deep .ProseMirror-icon span{vertical-align:text-top}::ng-deep .ProseMirror-gapcursor{display:none;pointer-events:none;position:absolute}::ng-deep .ProseMirror-gapcursor:after{content:\"\";display:block;position:absolute;top:-2px;width:20px;border-top:1px solid black;animation:ProseMirror-cursor-blink 1.1s steps(2,start) infinite}@keyframes ProseMirror-cursor-blink{to{visibility:hidden}}::ng-deep .ProseMirror-focused .ProseMirror-gapcursor{display:block}::ng-deep .ProseMirror-example-setup-style hr{padding:2px 10px;border:none;margin:1em 0}::ng-deep .ProseMirror-example-setup-style hr:after{content:\"\";display:block;height:1px;background-color:silver;line-height:2px}::ng-deep .ProseMirror ul,::ng-deep .ProseMirror ol{padding-left:30px}::ng-deep .ProseMirror blockquote{padding-left:1em;border-left:3px solid #eee;margin-left:0;margin-right:0}::ng-deep .ProseMirror-example-setup-style img{cursor:default}::ng-deep .ProseMirror-prompt{background:white;padding:20px;position:fixed;border-radius:4px;z-index:11;box-shadow:-.5px 2px 15px #000c;font-size:16px;color:#000}::ng-deep .ProseMirror-prompt h5{margin:0;font-weight:normal;font-size:24px}::ng-deep .ProseMirror-prompt input[type=text],::ng-deep .ProseMirror-prompt textarea{background:rgba(0,0,0,.1);border:none;border-bottom:1px solid rgba(0,0,0,.8);outline:none;padding:10px 20px;margin:.4em 0;width:20em;border-top-left-radius:4px;border-top-right-radius:4px;font-size:16px;color:#000}::ng-deep .ProseMirror-prompt-close{position:absolute;left:2px;top:1px;color:#000;border:none;background:transparent;padding:0}::ng-deep .ProseMirror-prompt-close:after{content:\"\\e2\\153\\2022\";font-size:12px}::ng-deep .ProseMirror-invalid{background:#ffc;border:1px solid #cc7;border-radius:4px;padding:5px 10px;position:absolute;min-width:10em}::ng-deep .ProseMirror-prompt-buttons{margin-top:5px;display:none}::ng-deep #editor,::ng-deep .editor{background:white;color:#000;background-clip:padding-box;border-radius:4px;border:2px solid rgba(0,0,0,.2);padding:5px 0;margin-bottom:23px}::ng-deep .ProseMirror p:first-child,::ng-deep .ProseMirror h1:first-child,::ng-deep .ProseMirror h2:first-child,::ng-deep .ProseMirror h3:first-child,::ng-deep .ProseMirror h4:first-child,::ng-deep .ProseMirror h5:first-child,::ng-deep .ProseMirror h6:first-child{margin-top:10px}::ng-deep .ProseMirror{padding:4px 8px 4px 14px;line-height:1.2;outline:none}::ng-deep .ProseMirror p{margin-bottom:1em}\n"]
|
|
10225
|
+
},] }
|
|
10226
|
+
];
|
|
10227
|
+
NaturalEditorComponent.ctorParameters = () => [
|
|
10228
|
+
{ type: NgControl, decorators: [{ type: Optional }, { type: Self }] },
|
|
10229
|
+
{ type: Document, decorators: [{ type: Inject, args: [DOCUMENT,] }] }
|
|
10230
|
+
];
|
|
10231
|
+
NaturalEditorComponent.propDecorators = {
|
|
10232
|
+
editor: [{ type: ViewChild, args: ['editor', { read: ElementRef, static: true },] }],
|
|
10233
|
+
contentChange: [{ type: Output }]
|
|
10234
|
+
};
|
|
10235
|
+
|
|
10236
|
+
class NaturalEditorModule {
|
|
10237
|
+
}
|
|
10238
|
+
NaturalEditorModule.decorators = [
|
|
10239
|
+
{ type: NgModule, args: [{
|
|
10240
|
+
declarations: [NaturalEditorComponent],
|
|
10241
|
+
imports: [CommonModule],
|
|
10242
|
+
exports: [NaturalEditorComponent],
|
|
10243
|
+
},] }
|
|
10244
|
+
];
|
|
10245
|
+
|
|
10109
10246
|
/*
|
|
10110
10247
|
* Public API Surface of natural
|
|
10111
10248
|
*/
|
|
@@ -10116,5 +10253,5 @@ NaturalMatomoService.ctorParameters = () => [
|
|
|
10116
10253
|
* Generated bundle index. Do not edit.
|
|
10117
10254
|
*/
|
|
10118
10255
|
|
|
10119
|
-
export { AvatarComponent, AvatarService, FileComponent, IconsConfigService, LOCAL_STORAGE, NATURAL_DROPDOWN_DATA, NATURAL_SEO_CONFIG, NaturalAbstractController, NaturalAbstractDetail, NaturalAbstractEditableList, NaturalAbstractList, NaturalAbstractModelService, NaturalAbstractNavigableList, NaturalAbstractPanel, NaturalAlertModule, NaturalAlertService, NaturalAvatarModule, NaturalCapitalizePipe, NaturalColumnsPickerColumnDirective, NaturalColumnsPickerComponent, NaturalColumnsPickerModule, NaturalCommonModule, NaturalConfirmComponent, NaturalDataSource, NaturalDetailHeaderComponent, NaturalDetailHeaderModule, NaturalDialogTriggerComponent, NaturalDialogTriggerModule, NaturalDropdownComponentsModule, NaturalDropdownRef, NaturalEllipsisPipe, NaturalEnumPipe, NaturalEnumService, NaturalFileDropDirective, NaturalFileModule, NaturalFileSelectDirective, NaturalFileService, NaturalFixedButtonComponent, NaturalFixedButtonDetailComponent, NaturalFixedButtonDetailModule, NaturalFixedButtonModule, NaturalHierarchicSelectorComponent, NaturalHierarchicSelectorDialogComponent, NaturalHierarchicSelectorDialogService, NaturalHierarchicSelectorModule, NaturalHierarchicSelectorService, NaturalHttpPrefixDirective, NaturalIconComponent, NaturalIconModule, NaturalLinkMutationService, NaturalLinkableTabDirective, NaturalMatomoModule, NaturalMatomoService, NaturalMemoryStorage, NaturalPanelsComponent, NaturalPanelsModule, NaturalPanelsService, NaturalPersistenceService, NaturalQueryVariablesManager, NaturalRelationsComponent, NaturalRelationsModule, NaturalSearchComponent, NaturalSearchModule, NaturalSelectComponent, NaturalSelectEnumComponent, NaturalSelectHierarchicComponent, NaturalSelectModule, NaturalSeoService, NaturalSidenavComponent, NaturalSidenavContainerComponent, NaturalSidenavContentComponent, NaturalSidenavModule, NaturalSidenavService, NaturalSidenavStackService, NaturalSrcDensityDirective, NaturalStampComponent, NaturalStampModule, NaturalSwissDatePipe, NaturalSwissParsingDateAdapter, NaturalTableButtonComponent, NaturalTableButtonModule, PanelsHooksConfig, ReactiveAsteriskDirective, SESSION_STORAGE, SortingOrder, TypeDateComponent, TypeDateRangeComponent, TypeHierarchicSelectorComponent, TypeNaturalSelectComponent, TypeNumberComponent, TypeSelectComponent, TypeTextComponent, available, cancellableTimeout, cleanSameValues, collectErrors, debug, decimal, deliverableEmail, ensureHttpPrefix, fallbackIfNoOpenedPanels, formatIsoDate, formatIsoDateTime, fromUrl, getForegroundColor, hasFilesAndProcessDate, ifValid, integer, localStorageFactory, localStorageProvider, lowerCaseFirstLetter, makePlural, memoryLocalStorageProvider, memorySessionStorageProvider, mergeOverrideArray, money, naturalPanelsUrlMatcher, relationsToIds, replaceObjectKeepingReference, replaceOperatorByField, replaceOperatorByName, sessionStorageFactory, sessionStorageProvider, toGraphQLDoctrineFilter, toNavigationParameters, toUrl, unique, upperCaseFirstLetter, urlValidator, validTlds, validateAllFormControls, wrapLike, NaturalAbstractFile as ɵa, NaturalDropdownService as ɵb, AbstractAssociationSelectComponent as ɵc, NATURAL_DROPDOWN_CONTAINER_DATA as ɵd, NaturalDropdownContainerComponent as ɵe, naturalDropdownAnimations as ɵf, AbstractSelect as ɵg, NaturalGroupComponent as ɵh, NaturalInputComponent as ɵi, FacetSelectorComponent as ɵj };
|
|
10256
|
+
export { AvatarComponent, AvatarService, FileComponent, IconsConfigService, LOCAL_STORAGE, NATURAL_DROPDOWN_DATA, NATURAL_SEO_CONFIG, NaturalAbstractController, NaturalAbstractDetail, NaturalAbstractEditableList, NaturalAbstractList, NaturalAbstractModelService, NaturalAbstractNavigableList, NaturalAbstractPanel, NaturalAlertModule, NaturalAlertService, NaturalAvatarModule, NaturalCapitalizePipe, NaturalColumnsPickerColumnDirective, NaturalColumnsPickerComponent, NaturalColumnsPickerModule, NaturalCommonModule, NaturalConfirmComponent, NaturalDataSource, NaturalDetailHeaderComponent, NaturalDetailHeaderModule, NaturalDialogTriggerComponent, NaturalDialogTriggerModule, NaturalDropdownComponentsModule, NaturalDropdownRef, NaturalEditorComponent, NaturalEditorModule, NaturalEllipsisPipe, NaturalEnumPipe, NaturalEnumService, NaturalFileDropDirective, NaturalFileModule, NaturalFileSelectDirective, NaturalFileService, NaturalFixedButtonComponent, NaturalFixedButtonDetailComponent, NaturalFixedButtonDetailModule, NaturalFixedButtonModule, NaturalHierarchicSelectorComponent, NaturalHierarchicSelectorDialogComponent, NaturalHierarchicSelectorDialogService, NaturalHierarchicSelectorModule, NaturalHierarchicSelectorService, NaturalHttpPrefixDirective, NaturalIconComponent, NaturalIconModule, NaturalLinkMutationService, NaturalLinkableTabDirective, NaturalMatomoModule, NaturalMatomoService, NaturalMemoryStorage, NaturalPanelsComponent, NaturalPanelsModule, NaturalPanelsService, NaturalPersistenceService, NaturalQueryVariablesManager, NaturalRelationsComponent, NaturalRelationsModule, NaturalSearchComponent, NaturalSearchModule, NaturalSelectComponent, NaturalSelectEnumComponent, NaturalSelectHierarchicComponent, NaturalSelectModule, NaturalSeoService, NaturalSidenavComponent, NaturalSidenavContainerComponent, NaturalSidenavContentComponent, NaturalSidenavModule, NaturalSidenavService, NaturalSidenavStackService, NaturalSrcDensityDirective, NaturalStampComponent, NaturalStampModule, NaturalSwissDatePipe, NaturalSwissParsingDateAdapter, NaturalTableButtonComponent, NaturalTableButtonModule, PanelsHooksConfig, ReactiveAsteriskDirective, SESSION_STORAGE, SortingOrder, TypeDateComponent, TypeDateRangeComponent, TypeHierarchicSelectorComponent, TypeNaturalSelectComponent, TypeNumberComponent, TypeSelectComponent, TypeTextComponent, available, cancellableTimeout, cleanSameValues, collectErrors, debug, decimal, deliverableEmail, ensureHttpPrefix, fallbackIfNoOpenedPanels, formatIsoDate, formatIsoDateTime, fromUrl, getForegroundColor, hasFilesAndProcessDate, ifValid, integer, localStorageFactory, localStorageProvider, lowerCaseFirstLetter, makePlural, memoryLocalStorageProvider, memorySessionStorageProvider, mergeOverrideArray, money, naturalPanelsUrlMatcher, relationsToIds, replaceObjectKeepingReference, replaceOperatorByField, replaceOperatorByName, sessionStorageFactory, sessionStorageProvider, toGraphQLDoctrineFilter, toNavigationParameters, toUrl, unique, upperCaseFirstLetter, urlValidator, validTlds, validateAllFormControls, wrapLike, NaturalAbstractFile as ɵa, NaturalDropdownService as ɵb, AbstractAssociationSelectComponent as ɵc, NATURAL_DROPDOWN_CONTAINER_DATA as ɵd, NaturalDropdownContainerComponent as ɵe, naturalDropdownAnimations as ɵf, AbstractSelect as ɵg, NaturalGroupComponent as ɵh, NaturalInputComponent as ɵi, FacetSelectorComponent as ɵj };
|
|
10120
10257
|
//# sourceMappingURL=ecodev-natural.js.map
|