@libs-ui/components-preview-text-data 0.2.337-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/README.md ADDED
@@ -0,0 +1,3 @@
1
+ # preview-text-data
2
+
3
+ This library was generated with [Nx](https://nx.dev).
@@ -0,0 +1,4 @@
1
+ export * from './preview-text-data.component';
2
+ export * from './preview-text-data.interfaces';
3
+ export * from './preview-text-data.define';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvcHJldmlldy10ZXh0LWRhdGEvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLDRCQUE0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9wcmV2aWV3LXRleHQtZGF0YS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9wcmV2aWV3LXRleHQtZGF0YS5pbnRlcmZhY2VzJztcbmV4cG9ydCAqIGZyb20gJy4vcHJldmlldy10ZXh0LWRhdGEuZGVmaW5lJztcbiJdfQ==
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlicy11aS1jb21wb25lbnRzLXByZXZpZXctdGV4dC1kYXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL3ByZXZpZXctdGV4dC1kYXRhL3NyYy9saWJzLXVpLWNvbXBvbmVudHMtcHJldmlldy10ZXh0LWRhdGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
@@ -0,0 +1,255 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ import { ChangeDetectionStrategy, Component, computed, inject, input, model, output, signal, viewChild } from '@angular/core';
3
+ import { cpp } from '@codemirror/lang-cpp';
4
+ import { css } from '@codemirror/lang-css';
5
+ import { go } from '@codemirror/lang-go';
6
+ import { html } from '@codemirror/lang-html';
7
+ import { java } from '@codemirror/lang-java';
8
+ import { javascript } from '@codemirror/lang-javascript';
9
+ import { json } from '@codemirror/lang-json';
10
+ import { markdown } from '@codemirror/lang-markdown';
11
+ import { php } from '@codemirror/lang-php';
12
+ import { python } from '@codemirror/lang-python';
13
+ import { sql } from '@codemirror/lang-sql';
14
+ import { xml } from '@codemirror/lang-xml';
15
+ import { yaml } from '@codemirror/lang-yaml';
16
+ import { StreamLanguage } from '@codemirror/language';
17
+ import { linter, lintGutter } from '@codemirror/lint';
18
+ import { Compartment, EditorState } from '@codemirror/state';
19
+ import { lineNumbers } from '@codemirror/view';
20
+ import { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';
21
+ import { LibsUiComponentsDropdownComponent } from '@libs-ui/components-dropdown';
22
+ import { LibsUiNotificationService } from '@libs-ui/services-notification';
23
+ import { get } from '@libs-ui/utils';
24
+ import { basicSetup, EditorView } from 'codemirror';
25
+ import { Parser } from 'node-sql-parser';
26
+ import { httpRequestConfigGetOptionsLang, optionsLang } from './preview-text-data.define';
27
+ import * as i0 from "@angular/core";
28
+ const sqlParser = new Parser();
29
+ export class LibsUiComponentsPreviewTextDataComponent {
30
+ editorViewInstance;
31
+ wrapCompartment = new Compartment();
32
+ languageCompartment = new Compartment();
33
+ lineNumberCompartment = new Compartment();
34
+ isWrap = signal(true);
35
+ configLoadDataIsHttpConfig = httpRequestConfigGetOptionsLang();
36
+ labelLang = computed(() => optionsLang().find((item) => item.id === this.langSelected())?.label);
37
+ content = input('', { transform: (value) => value ?? '' });
38
+ langSelected = model.required();
39
+ editable = input(false, { transform: (value) => value ?? false });
40
+ hiddenAction = input(false, { transform: (value) => value ?? false });
41
+ lintIgnorePatterns = input(['Cannot use import statement outside a module', 'Unexpected token export', 'import ', '@angular/core'], {
42
+ transform: (value) => value ?? ['Cannot use import statement outside a module', 'Unexpected token export', 'import ', '@angular/core'],
43
+ });
44
+ background = input('#f8f9fa', { transform: (value) => value ?? '#f8f9fa' });
45
+ outChange = output();
46
+ syntaxErrors = output();
47
+ containerPreview = viewChild.required('containerPreview');
48
+ notificationService = inject(LibsUiNotificationService);
49
+ ngAfterViewInit() {
50
+ this.editorViewInstance = new EditorView({ ...this.getExtensionsByLanguage(this.langSelected()), doc: this.content(), parent: this.containerPreview().nativeElement });
51
+ }
52
+ getExtensionsByLanguage(lang) {
53
+ let formatByLangFunction = StreamLanguage.define({
54
+ token(stream) {
55
+ stream.skipToEnd();
56
+ return null;
57
+ },
58
+ });
59
+ let lintFunction = linter(() => []);
60
+ const lowerLang = lang.toLowerCase();
61
+ switch (lowerLang) {
62
+ case 'javascript':
63
+ formatByLangFunction = javascript({ jsx: true, typescript: true });
64
+ lintFunction = this.jsLinterFn();
65
+ break;
66
+ case 'html':
67
+ formatByLangFunction = html();
68
+ break;
69
+ case 'css':
70
+ formatByLangFunction = css();
71
+ break;
72
+ case 'markdown':
73
+ formatByLangFunction = markdown();
74
+ break;
75
+ case 'json':
76
+ formatByLangFunction = json();
77
+ lintFunction = this.jsonLinterFn();
78
+ break;
79
+ case 'sql':
80
+ formatByLangFunction = sql();
81
+ lintFunction = this.sqlLinterFn();
82
+ break;
83
+ case 'xml':
84
+ formatByLangFunction = xml();
85
+ break;
86
+ case 'yaml':
87
+ formatByLangFunction = yaml();
88
+ break;
89
+ case 'python':
90
+ formatByLangFunction = python();
91
+ break;
92
+ case 'java':
93
+ formatByLangFunction = java();
94
+ break;
95
+ case 'cpp':
96
+ formatByLangFunction = cpp();
97
+ break;
98
+ case 'php':
99
+ formatByLangFunction = php();
100
+ break;
101
+ case 'go':
102
+ formatByLangFunction = go();
103
+ break;
104
+ }
105
+ return {
106
+ extensions: [
107
+ basicSetup,
108
+ this.languageCompartment.of(formatByLangFunction),
109
+ this.lightTheme(),
110
+ EditorView.editable.of(this.editable()),
111
+ this.wrapCompartment.of(EditorView.lineWrapping),
112
+ this.lineNumberCompartment.of(lineNumbers()),
113
+ lintGutter(),
114
+ this.customBracketTheme(),
115
+ lintFunction,
116
+ EditorView.updateListener.of((update) => {
117
+ if (update.docChanged && this.editable()) {
118
+ const newValue = update.state.doc.toString();
119
+ this.outChange.emit({
120
+ content: newValue,
121
+ isWrap: this.isWrap(),
122
+ language: this.langSelected(),
123
+ contextChange: 'content',
124
+ });
125
+ }
126
+ }),
127
+ ],
128
+ };
129
+ }
130
+ lightTheme() {
131
+ return EditorView.theme({
132
+ '&': { backgroundColor: this.background(), color: '#333' },
133
+ '.cm-content': { caretColor: '#111' },
134
+ '.cm-activeLine': { backgroundColor: '#f0f0f0' },
135
+ });
136
+ }
137
+ customBracketTheme() {
138
+ return EditorView.theme({
139
+ '.cm-matchingBracket': {
140
+ backgroundColor: 'rgba(100, 200, 255, 0.15)', // xanh nhẹ trong suốt
141
+ border: '1px solid rgba(100, 200, 255, 0.4)',
142
+ borderRadius: '3px',
143
+ transition: 'all 0.2s ease',
144
+ },
145
+ '.cm-nonmatchingBracket': {
146
+ backgroundColor: 'rgba(255, 100, 100, 0.15)', // đỏ nhẹ
147
+ border: '1px solid rgba(255, 100, 100, 0.3)',
148
+ borderRadius: '3px',
149
+ },
150
+ });
151
+ }
152
+ jsLinterFn() {
153
+ return linter((view) => {
154
+ const text = view.state.doc.toString();
155
+ const diagnostics = [];
156
+ try {
157
+ new Function(text); // test parse code
158
+ }
159
+ catch (err) {
160
+ if (!this.lintIgnorePatterns().some((pattern) => err.message.includes(pattern))) {
161
+ diagnostics.push({
162
+ from: 0,
163
+ to: text.length,
164
+ severity: 'error',
165
+ message: err.message,
166
+ });
167
+ this.syntaxErrors.emit(diagnostics);
168
+ }
169
+ }
170
+ return diagnostics;
171
+ });
172
+ }
173
+ jsonLinterFn() {
174
+ return linter((view) => {
175
+ const text = view.state.doc.toString();
176
+ const diagnostics = [];
177
+ try {
178
+ JSON.parse(text);
179
+ }
180
+ catch (err) {
181
+ diagnostics.push({
182
+ from: 0,
183
+ to: text.length,
184
+ severity: 'error',
185
+ message: get(err, 'message', ''),
186
+ });
187
+ }
188
+ this.syntaxErrors.emit(diagnostics);
189
+ return diagnostics;
190
+ });
191
+ }
192
+ sqlLinterFn() {
193
+ return linter((view) => {
194
+ const text = view.state.doc.toString();
195
+ const diagnostics = [];
196
+ try {
197
+ sqlParser.astify(text);
198
+ }
199
+ catch (err) {
200
+ diagnostics.push({
201
+ from: 0,
202
+ to: text.length,
203
+ severity: 'error',
204
+ message: get(err, 'message', ''),
205
+ });
206
+ }
207
+ this.syntaxErrors.emit(diagnostics);
208
+ return diagnostics;
209
+ });
210
+ }
211
+ handlerCopy() {
212
+ navigator.clipboard.writeText(this.content() || '');
213
+ this.notificationService.showCompTypeTextInfo('Sao chép thành công');
214
+ }
215
+ handlerLineWrap() {
216
+ this.isWrap.update((val) => !val);
217
+ this.editorViewInstance?.dispatch({
218
+ effects: this.wrapCompartment.reconfigure(this.isWrap() ? EditorView.lineWrapping : []),
219
+ });
220
+ this.editorViewInstance?.dispatch({
221
+ effects: this.lineNumberCompartment.reconfigure(this.isWrap() ? lineNumbers() : [] // 👈 nếu tắt thì remove extension
222
+ ),
223
+ });
224
+ this.outChange.emit({
225
+ content: this.content(),
226
+ isWrap: this.isWrap(),
227
+ language: this.langSelected(),
228
+ contextChange: 'isWrap',
229
+ });
230
+ }
231
+ handlerSelectKey(data) {
232
+ if (!data || !data.key) {
233
+ return;
234
+ }
235
+ this.langSelected.set(data.key);
236
+ const extensions = this.getExtensionsByLanguage(this.langSelected());
237
+ this.editorViewInstance?.setState(EditorState.create({
238
+ doc: this.editorViewInstance?.state.doc.toString(),
239
+ ...extensions,
240
+ }));
241
+ this.outChange.emit({
242
+ content: this.content(),
243
+ isWrap: this.isWrap(),
244
+ language: this.langSelected(),
245
+ contextChange: 'language',
246
+ });
247
+ }
248
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsPreviewTextDataComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
249
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: LibsUiComponentsPreviewTextDataComponent, isStandalone: true, selector: "libs_ui-components-preview_text_data", inputs: { content: { classPropertyName: "content", publicName: "content", isSignal: true, isRequired: false, transformFunction: null }, langSelected: { classPropertyName: "langSelected", publicName: "langSelected", isSignal: true, isRequired: true, transformFunction: null }, editable: { classPropertyName: "editable", publicName: "editable", isSignal: true, isRequired: false, transformFunction: null }, hiddenAction: { classPropertyName: "hiddenAction", publicName: "hiddenAction", isSignal: true, isRequired: false, transformFunction: null }, lintIgnorePatterns: { classPropertyName: "lintIgnorePatterns", publicName: "lintIgnorePatterns", isSignal: true, isRequired: false, transformFunction: null }, background: { classPropertyName: "background", publicName: "background", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { langSelected: "langSelectedChange", outChange: "outChange", syntaxErrors: "syntaxErrors" }, viewQueries: [{ propertyName: "containerPreview", first: true, predicate: ["containerPreview"], descendants: true, isSignal: true }], ngImport: i0, template: "<div\n class=\"libs-ui-preview-data-container flex flex-col w-full h-auto rounded-[8px] libs-ui-border-general px-[8px]\"\n [style.--background-color]=\"background()\"\n [class.pt-[8px]]=\"!hiddenAction()\">\n @if (!hiddenAction()) {\n <div class=\"flex items-center content-between color-[#6a7383]\">\n <libs_ui-components-dropdown\n classInclude=\"w-[200px]\"\n [listConfig]=\"configLoadDataIsHttpConfig\"\n [listMaxItemShow]=\"5\"\n [isNgContent]=\"true\"\n [readonly]=\"!editable()\"\n [listHasButtonUnSelectOption]=\"false\"\n (outSelectKey)=\"handlerSelectKey($event)\">\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [label]=\"labelLang() || ''\"\n [sizeButton]=\"'small'\"\n [classIconRight]=\"editable() ? 'libs-ui-icon-move-right rotate-90' : ''\"\n [classInclude]=\"'!p-[0px]' + (editable() ? '' : '!pointer-events-none !cursor-default hover:!text-[#6A7383]')\" />\n </libs_ui-components-dropdown>\n <div class=\"flex items-center\">\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [label]=\"isWrap() ? 'i18n_remove_line_wrap' : 'i18n_line_wrap'\"\n [sizeButton]=\"'small'\"\n [classIconLeft]=\"isWrap() ? 'libs-ui-icon-unwrap' : 'libs-ui-icon-wrap'\"\n [classInclude]=\"'mo-lib-p-0px mo-lib-mr-16px'\"\n (outClick)=\"handlerLineWrap()\" />\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [label]=\"'i18n_copy'\"\n [sizeButton]=\"'small'\"\n [classIconLeft]=\"'libs-ui-icon-copy'\"\n [classInclude]=\"'mo-lib-p-0px'\"\n (outClick)=\"handlerCopy()\" />\n </div>\n </div>\n }\n <div #containerPreview></div>\n</div>\n", styles: [":host ::ng-deep .libs-ui-preview-data-container{background-color:var(--background-color)!important}:host ::ng-deep .libs-ui-preview-data-container .cm-line{white-space:pre-wrap}:host ::ng-deep .libs-ui-preview-data-container .cm-lintRange-error{background-color:#ff323233;border-bottom:2px solid red}:host ::ng-deep .libs-ui-preview-data-container .cm-lintRange-warning{background-color:#ffc80026}:host ::ng-deep .libs-ui-preview-data-container .cm-tooltip-lint{background:#fff8f8;color:#d32f2f;border:1px solid #f44336;padding:8px 10px;font-size:13px;font-family:Inter,sans-serif;border-radius:6px;box-shadow:0 2px 8px #ff000026}:host ::ng-deep .libs-ui-preview-data-container .cm-focused{outline:none!important}:host ::ng-deep .libs-ui-preview-data-container .cm-gutters{background-color:var(--background-color)!important}\n"], dependencies: [{ kind: "component", type: LibsUiComponentsDropdownComponent, selector: "libs_ui-components-dropdown", inputs: ["useXssFilter", "popoverElementRefCustom", "classInclude", "ignoreStopPropagationEvent", "flagMouse", "flagMouseContent", "popoverCustomConfig", "isNgContent", "zIndex", "convertItemSelected", "getPopoverItemSelected", "httpRequestDetailItemById", "lengthKeys", "textDisplayWhenNoSelect", "textDisplayWhenMultiSelect", "classIncludeTextDisplayWhenNoSelect", "fieldLabel", "fieldGetLabel", "labelPopoverConfig", "labelPopoverFullWidth", "hasContentUnitRight", "listSearchNoDataTemplateRef", "fieldGetImage", "imageSize", "typeShape", "fieldGetIcon", "fieldGetTextAvatar", "fieldGetColorAvatar", "classAvatarInclude", "getLastTextAfterSpace", "linkImageError", "showError", "showBorderError", "disable", "readonly", "labelConfig", "disableLabel", "listSearchConfig", "isSearchOnline", "listHiddenInputSearch", "listSearchPadding", "listKeySearch", "listDividerClassInclude", "listConfig", "listButtonsOther", "listHasButtonUnSelectOption", "listClickExactly", "listBackgroundCustom", "listMaxItemShow", "listKeySelected", "listMultiKeySelected", "listKeysDisable", "listKeysHidden", "validRequired", "validMaxItemSelected", "changeValidUndefinedResetError", "allowSelectItemMultiple", "focusInputSearch", "onlyEmitDataWhenReset", "resetKeyWhenSelectAllKey", "listConfigHasDivider", "classIncludeIcon", "classIncludeContent", "listIgnoreClassDisableDefaultWhenUseKeysDisableItem", "tabKeyActive", "tabsConfig", "ignoreBorderBottom"], outputs: ["flagMouseChange", "flagMouseContentChange", "lengthKeysChange", "showBorderErrorChange", "listKeySelectedChange", "listMultiKeySelectedChange", "tabKeyActiveChange", "outSelectKey", "outSelectMultiKey", "outFunctionsControl", "outValidEvent", "outChangStageFlagMouse", "outDataChange", "outClickButtonOther", "outShowList", "outChangeTabKeyActive"] }, { kind: "component", type: LibsUiComponentsButtonsButtonComponent, selector: "libs_ui-components-buttons-button", inputs: ["flagMouse", "type", "buttonCustom", "sizeButton", "label", "disable", "isPending", "imageLeft", "classInclude", "classIconLeft", "classIconRight", "classLabel", "iconOnlyType", "popover", "ignoreStopPropagationEvent", "zIndex", "widthLabelPopover", "styleIconLeft", "styleButton", "ignoreFocusWhenInputTab", "ignoreSetClickWhenShowPopover", "ignorePointerEvent", "isActive", "isHandlerEnterDocumentClickButton"], outputs: ["outClick", "outPopoverEvent", "outFunctionsControl"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
250
+ }
251
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsPreviewTextDataComponent, decorators: [{
252
+ type: Component,
253
+ args: [{ selector: 'libs_ui-components-preview_text_data', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [LibsUiComponentsDropdownComponent, LibsUiComponentsButtonsButtonComponent], template: "<div\n class=\"libs-ui-preview-data-container flex flex-col w-full h-auto rounded-[8px] libs-ui-border-general px-[8px]\"\n [style.--background-color]=\"background()\"\n [class.pt-[8px]]=\"!hiddenAction()\">\n @if (!hiddenAction()) {\n <div class=\"flex items-center content-between color-[#6a7383]\">\n <libs_ui-components-dropdown\n classInclude=\"w-[200px]\"\n [listConfig]=\"configLoadDataIsHttpConfig\"\n [listMaxItemShow]=\"5\"\n [isNgContent]=\"true\"\n [readonly]=\"!editable()\"\n [listHasButtonUnSelectOption]=\"false\"\n (outSelectKey)=\"handlerSelectKey($event)\">\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [label]=\"labelLang() || ''\"\n [sizeButton]=\"'small'\"\n [classIconRight]=\"editable() ? 'libs-ui-icon-move-right rotate-90' : ''\"\n [classInclude]=\"'!p-[0px]' + (editable() ? '' : '!pointer-events-none !cursor-default hover:!text-[#6A7383]')\" />\n </libs_ui-components-dropdown>\n <div class=\"flex items-center\">\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [label]=\"isWrap() ? 'i18n_remove_line_wrap' : 'i18n_line_wrap'\"\n [sizeButton]=\"'small'\"\n [classIconLeft]=\"isWrap() ? 'libs-ui-icon-unwrap' : 'libs-ui-icon-wrap'\"\n [classInclude]=\"'mo-lib-p-0px mo-lib-mr-16px'\"\n (outClick)=\"handlerLineWrap()\" />\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [label]=\"'i18n_copy'\"\n [sizeButton]=\"'small'\"\n [classIconLeft]=\"'libs-ui-icon-copy'\"\n [classInclude]=\"'mo-lib-p-0px'\"\n (outClick)=\"handlerCopy()\" />\n </div>\n </div>\n }\n <div #containerPreview></div>\n</div>\n", styles: [":host ::ng-deep .libs-ui-preview-data-container{background-color:var(--background-color)!important}:host ::ng-deep .libs-ui-preview-data-container .cm-line{white-space:pre-wrap}:host ::ng-deep .libs-ui-preview-data-container .cm-lintRange-error{background-color:#ff323233;border-bottom:2px solid red}:host ::ng-deep .libs-ui-preview-data-container .cm-lintRange-warning{background-color:#ffc80026}:host ::ng-deep .libs-ui-preview-data-container .cm-tooltip-lint{background:#fff8f8;color:#d32f2f;border:1px solid #f44336;padding:8px 10px;font-size:13px;font-family:Inter,sans-serif;border-radius:6px;box-shadow:0 2px 8px #ff000026}:host ::ng-deep .libs-ui-preview-data-container .cm-focused{outline:none!important}:host ::ng-deep .libs-ui-preview-data-container .cm-gutters{background-color:var(--background-color)!important}\n"] }]
254
+ }] });
255
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"preview-text-data.component.js","sourceRoot":"","sources":["../../../../../libs-ui/components/preview-text-data/src/preview-text-data.component.ts","../../../../../libs-ui/components/preview-text-data/src/preview-text-data.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { AfterViewInit, ChangeDetectionStrategy, Component, computed, ElementRef, inject, input, model, output, signal, viewChild } from '@angular/core';\nimport { cpp } from '@codemirror/lang-cpp';\nimport { css } from '@codemirror/lang-css';\nimport { go } from '@codemirror/lang-go';\nimport { html } from '@codemirror/lang-html';\nimport { java } from '@codemirror/lang-java';\nimport { javascript } from '@codemirror/lang-javascript';\nimport { json } from '@codemirror/lang-json';\nimport { markdown } from '@codemirror/lang-markdown';\nimport { php } from '@codemirror/lang-php';\nimport { python } from '@codemirror/lang-python';\nimport { sql } from '@codemirror/lang-sql';\nimport { xml } from '@codemirror/lang-xml';\nimport { yaml } from '@codemirror/lang-yaml';\nimport { StreamLanguage } from '@codemirror/language';\nimport { Diagnostic, linter, lintGutter } from '@codemirror/lint';\nimport { Compartment, EditorState } from '@codemirror/state';\nimport { lineNumbers } from '@codemirror/view';\nimport { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';\nimport { IEmitSelectKey, LibsUiComponentsDropdownComponent } from '@libs-ui/components-dropdown';\nimport { LibsUiNotificationService } from '@libs-ui/services-notification';\nimport { get } from '@libs-ui/utils';\nimport { basicSetup, EditorView } from 'codemirror';\nimport { Parser } from 'node-sql-parser';\nimport { httpRequestConfigGetOptionsLang, optionsLang } from './preview-text-data.define';\nimport { IPreviewTextDataChange, PREVIEW_TEXT_DATA_LANGUAGE_SUPPORT } from './preview-text-data.interfaces';\n\nconst sqlParser = new Parser();\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-preview_text_data',\n  templateUrl: './preview-text-data.component.html',\n  styleUrls: ['./preview-text-data.component.scss'],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [LibsUiComponentsDropdownComponent, LibsUiComponentsButtonsButtonComponent],\n})\nexport class LibsUiComponentsPreviewTextDataComponent implements AfterViewInit {\n  private editorViewInstance?: EditorView;\n  private wrapCompartment = new Compartment();\n  private languageCompartment = new Compartment();\n  private lineNumberCompartment = new Compartment();\n\n  protected isWrap = signal<boolean>(true);\n  protected configLoadDataIsHttpConfig = httpRequestConfigGetOptionsLang();\n  protected labelLang = computed(() => optionsLang().find((item) => item.id === this.langSelected())?.label);\n\n  readonly content = input<string, string | undefined>('', { transform: (value?: string) => value ?? '' });\n  readonly langSelected = model.required<PREVIEW_TEXT_DATA_LANGUAGE_SUPPORT>();\n  readonly editable = input<boolean, boolean | undefined>(false, { transform: (value?: boolean) => value ?? false });\n  readonly hiddenAction = input<boolean, boolean | undefined>(false, { transform: (value?: boolean) => value ?? false });\n  readonly lintIgnorePatterns = input<Array<string>, Array<string> | undefined>(['Cannot use import statement outside a module', 'Unexpected token export', 'import ', '@angular/core'], {\n    transform: (value?: Array<string>) => value ?? ['Cannot use import statement outside a module', 'Unexpected token export', 'import ', '@angular/core'],\n  });\n\n  readonly background = input<string, string | undefined>('#f8f9fa', { transform: (value?: string) => value ?? '#f8f9fa' });\n\n  readonly outChange = output<IPreviewTextDataChange>();\n  readonly syntaxErrors = output<Diagnostic[]>();\n\n  private containerPreview = viewChild.required<ElementRef<HTMLDivElement>>('containerPreview');\n\n  private notificationService = inject(LibsUiNotificationService);\n  ngAfterViewInit() {\n    this.editorViewInstance = new EditorView({ ...this.getExtensionsByLanguage(this.langSelected()), doc: this.content(), parent: this.containerPreview().nativeElement });\n  }\n\n  private getExtensionsByLanguage(lang: PREVIEW_TEXT_DATA_LANGUAGE_SUPPORT): any {\n    let formatByLangFunction: any = StreamLanguage.define({\n      token(stream: any) {\n        stream.skipToEnd();\n        return null;\n      },\n    });\n    let lintFunction = linter(() => []);\n\n    const lowerLang = lang.toLowerCase();\n\n    switch (lowerLang) {\n      case 'javascript':\n        formatByLangFunction = javascript({ jsx: true, typescript: true });\n        lintFunction = this.jsLinterFn();\n        break;\n\n      case 'html':\n        formatByLangFunction = html();\n        break;\n\n      case 'css':\n        formatByLangFunction = css();\n        break;\n\n      case 'markdown':\n        formatByLangFunction = markdown();\n        break;\n\n      case 'json':\n        formatByLangFunction = json();\n        lintFunction = this.jsonLinterFn();\n        break;\n\n      case 'sql':\n        formatByLangFunction = sql();\n        lintFunction = this.sqlLinterFn();\n        break;\n\n      case 'xml':\n        formatByLangFunction = xml();\n        break;\n\n      case 'yaml':\n        formatByLangFunction = yaml();\n        break;\n\n      case 'python':\n        formatByLangFunction = python();\n        break;\n\n      case 'java':\n        formatByLangFunction = java();\n        break;\n\n      case 'cpp':\n        formatByLangFunction = cpp();\n        break;\n\n      case 'php':\n        formatByLangFunction = php();\n        break;\n\n      case 'go':\n        formatByLangFunction = go();\n        break;\n    }\n\n    return {\n      extensions: [\n        basicSetup,\n        this.languageCompartment.of(formatByLangFunction),\n        this.lightTheme(),\n        EditorView.editable.of(this.editable()),\n        this.wrapCompartment.of(EditorView.lineWrapping),\n        this.lineNumberCompartment.of(lineNumbers()),\n        lintGutter(),\n        this.customBracketTheme(),\n        lintFunction,\n        EditorView.updateListener.of((update: any) => {\n          if (update.docChanged && this.editable()) {\n            const newValue = update.state.doc.toString();\n\n            this.outChange.emit({\n              content: newValue,\n              isWrap: this.isWrap(),\n              language: this.langSelected(),\n              contextChange: 'content',\n            });\n          }\n        }),\n      ],\n    };\n  }\n\n  private lightTheme() {\n    return EditorView.theme({\n      '&': { backgroundColor: this.background(), color: '#333' },\n      '.cm-content': { caretColor: '#111' },\n      '.cm-activeLine': { backgroundColor: '#f0f0f0' },\n    });\n  }\n\n  private customBracketTheme() {\n    return EditorView.theme({\n      '.cm-matchingBracket': {\n        backgroundColor: 'rgba(100, 200, 255, 0.15)', // xanh nhẹ trong suốt\n        border: '1px solid rgba(100, 200, 255, 0.4)',\n        borderRadius: '3px',\n        transition: 'all 0.2s ease',\n      },\n      '.cm-nonmatchingBracket': {\n        backgroundColor: 'rgba(255, 100, 100, 0.15)', // đỏ nhẹ\n        border: '1px solid rgba(255, 100, 100, 0.3)',\n        borderRadius: '3px',\n      },\n    });\n  }\n\n  private jsLinterFn() {\n    return linter((view: any) => {\n      const text = view.state.doc.toString();\n      const diagnostics: Diagnostic[] = [];\n      try {\n        new Function(text); // test parse code\n      } catch (err: any) {\n        if (!this.lintIgnorePatterns().some((pattern: any) => err.message.includes(pattern))) {\n          diagnostics.push({\n            from: 0,\n            to: text.length,\n            severity: 'error',\n            message: err.message,\n          });\n          this.syntaxErrors.emit(diagnostics);\n        }\n      }\n      return diagnostics;\n    });\n  }\n\n  private jsonLinterFn() {\n    return linter((view: any) => {\n      const text = view.state.doc.toString();\n      const diagnostics: Diagnostic[] = [];\n      try {\n        JSON.parse(text);\n      } catch (err: unknown) {\n        diagnostics.push({\n          from: 0,\n          to: text.length,\n          severity: 'error',\n          message: get(err, 'message', ''),\n        });\n      }\n      this.syntaxErrors.emit(diagnostics);\n      return diagnostics;\n    });\n  }\n\n  private sqlLinterFn() {\n    return linter((view: any) => {\n      const text = view.state.doc.toString();\n      const diagnostics: Diagnostic[] = [];\n      try {\n        sqlParser.astify(text);\n      } catch (err: unknown) {\n        diagnostics.push({\n          from: 0,\n          to: text.length,\n          severity: 'error',\n          message: get(err, 'message', ''),\n        });\n      }\n      this.syntaxErrors.emit(diagnostics);\n      return diagnostics;\n    });\n  }\n\n  protected handlerCopy() {\n    navigator.clipboard.writeText(this.content() || '');\n    this.notificationService.showCompTypeTextInfo('Sao chép thành công');\n  }\n\n  protected handlerLineWrap() {\n    this.isWrap.update((val: any) => !val);\n    this.editorViewInstance?.dispatch({\n      effects: this.wrapCompartment.reconfigure(this.isWrap() ? EditorView.lineWrapping : []),\n    });\n\n    this.editorViewInstance?.dispatch({\n      effects: this.lineNumberCompartment.reconfigure(\n        this.isWrap() ? lineNumbers() : [] // 👈 nếu tắt thì remove extension\n      ),\n    });\n    this.outChange.emit({\n      content: this.content(),\n      isWrap: this.isWrap(),\n      language: this.langSelected(),\n      contextChange: 'isWrap',\n    });\n  }\n\n  protected handlerSelectKey(data?: IEmitSelectKey) {\n    if (!data || !data.key) {\n      return;\n    }\n    this.langSelected.set(data.key as PREVIEW_TEXT_DATA_LANGUAGE_SUPPORT);\n    const extensions = this.getExtensionsByLanguage(this.langSelected());\n    this.editorViewInstance?.setState(\n      EditorState.create({\n        doc: this.editorViewInstance?.state.doc.toString(),\n        ...extensions,\n      })\n    );\n    this.outChange.emit({\n      content: this.content(),\n      isWrap: this.isWrap(),\n      language: this.langSelected(),\n      contextChange: 'language',\n    });\n  }\n}\n","<div\n  class=\"libs-ui-preview-data-container flex flex-col w-full h-auto rounded-[8px] libs-ui-border-general px-[8px]\"\n  [style.--background-color]=\"background()\"\n  [class.pt-[8px]]=\"!hiddenAction()\">\n  @if (!hiddenAction()) {\n    <div class=\"flex items-center content-between color-[#6a7383]\">\n      <libs_ui-components-dropdown\n        classInclude=\"w-[200px]\"\n        [listConfig]=\"configLoadDataIsHttpConfig\"\n        [listMaxItemShow]=\"5\"\n        [isNgContent]=\"true\"\n        [readonly]=\"!editable()\"\n        [listHasButtonUnSelectOption]=\"false\"\n        (outSelectKey)=\"handlerSelectKey($event)\">\n        <libs_ui-components-buttons-button\n          [type]=\"'button-link-third'\"\n          [label]=\"labelLang() || ''\"\n          [sizeButton]=\"'small'\"\n          [classIconRight]=\"editable() ? 'libs-ui-icon-move-right rotate-90' : ''\"\n          [classInclude]=\"'!p-[0px]' + (editable() ? '' : '!pointer-events-none !cursor-default hover:!text-[#6A7383]')\" />\n      </libs_ui-components-dropdown>\n      <div class=\"flex items-center\">\n        <libs_ui-components-buttons-button\n          [type]=\"'button-link-third'\"\n          [label]=\"isWrap() ? 'i18n_remove_line_wrap' : 'i18n_line_wrap'\"\n          [sizeButton]=\"'small'\"\n          [classIconLeft]=\"isWrap() ? 'libs-ui-icon-unwrap' : 'libs-ui-icon-wrap'\"\n          [classInclude]=\"'mo-lib-p-0px mo-lib-mr-16px'\"\n          (outClick)=\"handlerLineWrap()\" />\n        <libs_ui-components-buttons-button\n          [type]=\"'button-link-third'\"\n          [label]=\"'i18n_copy'\"\n          [sizeButton]=\"'small'\"\n          [classIconLeft]=\"'libs-ui-icon-copy'\"\n          [classInclude]=\"'mo-lib-p-0px'\"\n          (outClick)=\"handlerCopy()\" />\n      </div>\n    </div>\n  }\n  <div #containerPreview></div>\n</div>\n"]}
@@ -0,0 +1,34 @@
1
+ import { signal } from '@angular/core';
2
+ import { returnListObject } from '@libs-ui/services-http-request';
3
+ import { UtilsHttpParamsRequest } from '@libs-ui/utils';
4
+ export const optionsLang = () => [
5
+ { id: 'text', label: 'Plain Text' },
6
+ { id: 'javascript', label: 'JavaScript/TypeScript' },
7
+ { id: 'html', label: 'HTML' },
8
+ { id: 'css', label: 'CSS/SCSS/SASS' },
9
+ { id: 'markdown', label: 'Markdown' },
10
+ { id: 'json', label: 'JSON' },
11
+ { id: 'sql', label: 'SQL' },
12
+ { id: 'xml', label: 'XML' },
13
+ { id: 'yaml', label: 'YAML' },
14
+ { id: 'python', label: 'Python' },
15
+ { id: 'java', label: 'Java' },
16
+ { id: 'cpp', label: 'C/C++' },
17
+ { id: 'php', label: 'PHP' },
18
+ { id: 'go', label: 'Go' },
19
+ ];
20
+ export const httpRequestConfigGetOptionsLang = () => {
21
+ return {
22
+ type: 'text',
23
+ httpRequestData: signal({
24
+ objectInstance: returnListObject(optionsLang()),
25
+ functionName: 'list',
26
+ argumentsValue: [new UtilsHttpParamsRequest({ fromObject: { page: 1, per_page: 40 } })],
27
+ }),
28
+ configTemplateText: signal({
29
+ fieldKey: 'id',
30
+ notUseVirtualScroll: true,
31
+ }),
32
+ };
33
+ };
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJldmlldy10ZXh0LWRhdGEuZGVmaW5lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL3ByZXZpZXctdGV4dC1kYXRhL3NyYy9wcmV2aWV3LXRleHQtZGF0YS5kZWZpbmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV2QyxPQUFPLEVBQXNCLGdCQUFnQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDdEYsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFeEQsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHLEdBQUcsRUFBRSxDQUFDO0lBQy9CLEVBQUUsRUFBRSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsWUFBWSxFQUFFO0lBQ25DLEVBQUUsRUFBRSxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsdUJBQXVCLEVBQUU7SUFDcEQsRUFBRSxFQUFFLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUU7SUFDN0IsRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxlQUFlLEVBQUU7SUFDckMsRUFBRSxFQUFFLEVBQUUsVUFBVSxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUU7SUFDckMsRUFBRSxFQUFFLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUU7SUFDN0IsRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUU7SUFDM0IsRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUU7SUFDM0IsRUFBRSxFQUFFLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUU7SUFDN0IsRUFBRSxFQUFFLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBRSxRQUFRLEVBQUU7SUFDakMsRUFBRSxFQUFFLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUU7SUFDN0IsRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUU7SUFDN0IsRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUU7SUFDM0IsRUFBRSxFQUFFLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUU7Q0FDMUIsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLCtCQUErQixHQUFHLEdBQW9CLEVBQUU7SUFDbkUsT0FBTztRQUNMLElBQUksRUFBRSxNQUFNO1FBQ1osZUFBZSxFQUFFLE1BQU0sQ0FBcUI7WUFDMUMsY0FBYyxFQUFFLGdCQUFnQixDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQy9DLFlBQVksRUFBRSxNQUFNO1lBQ3BCLGNBQWMsRUFBRSxDQUFDLElBQUksc0JBQXNCLENBQUMsRUFBRSxVQUFVLEVBQUUsRUFBRSxJQUFJLEVBQUUsQ0FBQyxFQUFFLFFBQVEsRUFBRSxFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUM7U0FDeEYsQ0FBQztRQUNGLGtCQUFrQixFQUFFLE1BQU0sQ0FBQztZQUN6QixRQUFRLEVBQUUsSUFBSTtZQUNkLG1CQUFtQixFQUFFLElBQUk7U0FDMUIsQ0FBQztLQUNILENBQUM7QUFDSixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBzaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElMaXN0Q29uZmlnSXRlbSB9IGZyb20gJ0BsaWJzLXVpL2NvbXBvbmVudHMtbGlzdCc7XG5pbXBvcnQgeyBJSHR0cFJlcXVlc3RDb25maWcsIHJldHVybkxpc3RPYmplY3QgfSBmcm9tICdAbGlicy11aS9zZXJ2aWNlcy1odHRwLXJlcXVlc3QnO1xuaW1wb3J0IHsgVXRpbHNIdHRwUGFyYW1zUmVxdWVzdCB9IGZyb20gJ0BsaWJzLXVpL3V0aWxzJztcblxuZXhwb3J0IGNvbnN0IG9wdGlvbnNMYW5nID0gKCkgPT4gW1xuICB7IGlkOiAndGV4dCcsIGxhYmVsOiAnUGxhaW4gVGV4dCcgfSxcbiAgeyBpZDogJ2phdmFzY3JpcHQnLCBsYWJlbDogJ0phdmFTY3JpcHQvVHlwZVNjcmlwdCcgfSxcbiAgeyBpZDogJ2h0bWwnLCBsYWJlbDogJ0hUTUwnIH0sXG4gIHsgaWQ6ICdjc3MnLCBsYWJlbDogJ0NTUy9TQ1NTL1NBU1MnIH0sXG4gIHsgaWQ6ICdtYXJrZG93bicsIGxhYmVsOiAnTWFya2Rvd24nIH0sXG4gIHsgaWQ6ICdqc29uJywgbGFiZWw6ICdKU09OJyB9LFxuICB7IGlkOiAnc3FsJywgbGFiZWw6ICdTUUwnIH0sXG4gIHsgaWQ6ICd4bWwnLCBsYWJlbDogJ1hNTCcgfSxcbiAgeyBpZDogJ3lhbWwnLCBsYWJlbDogJ1lBTUwnIH0sXG4gIHsgaWQ6ICdweXRob24nLCBsYWJlbDogJ1B5dGhvbicgfSxcbiAgeyBpZDogJ2phdmEnLCBsYWJlbDogJ0phdmEnIH0sXG4gIHsgaWQ6ICdjcHAnLCBsYWJlbDogJ0MvQysrJyB9LFxuICB7IGlkOiAncGhwJywgbGFiZWw6ICdQSFAnIH0sXG4gIHsgaWQ6ICdnbycsIGxhYmVsOiAnR28nIH0sXG5dO1xuXG5leHBvcnQgY29uc3QgaHR0cFJlcXVlc3RDb25maWdHZXRPcHRpb25zTGFuZyA9ICgpOiBJTGlzdENvbmZpZ0l0ZW0gPT4ge1xuICByZXR1cm4ge1xuICAgIHR5cGU6ICd0ZXh0JyxcbiAgICBodHRwUmVxdWVzdERhdGE6IHNpZ25hbDxJSHR0cFJlcXVlc3RDb25maWc+KHtcbiAgICAgIG9iamVjdEluc3RhbmNlOiByZXR1cm5MaXN0T2JqZWN0KG9wdGlvbnNMYW5nKCkpLFxuICAgICAgZnVuY3Rpb25OYW1lOiAnbGlzdCcsXG4gICAgICBhcmd1bWVudHNWYWx1ZTogW25ldyBVdGlsc0h0dHBQYXJhbXNSZXF1ZXN0KHsgZnJvbU9iamVjdDogeyBwYWdlOiAxLCBwZXJfcGFnZTogNDAgfSB9KV0sXG4gICAgfSksXG4gICAgY29uZmlnVGVtcGxhdGVUZXh0OiBzaWduYWwoe1xuICAgICAgZmllbGRLZXk6ICdpZCcsXG4gICAgICBub3RVc2VWaXJ0dWFsU2Nyb2xsOiB0cnVlLFxuICAgIH0pLFxuICB9O1xufTtcbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJldmlldy10ZXh0LWRhdGEuaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMtdWkvY29tcG9uZW50cy9wcmV2aWV3LXRleHQtZGF0YS9zcmMvcHJldmlldy10ZXh0LWRhdGEuaW50ZXJmYWNlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgUFJFVklFV19URVhUX0RBVEFfTEFOR1VBR0VfU1VQUE9SVCA9ICdqYXZhc2NyaXB0JyB8ICdodG1sJyB8ICdjc3MnIHwgJ21hcmtkb3duJyB8ICdqc29uJyB8ICdzcWwnIHwgJ3htbCcgfCAneWFtbCcgfCAncHl0aG9uJyB8ICdqYXZhJyB8ICdjcHAnIHwgJ3BocCcgfCAnZ28nIHwgJ3RleHQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIElQcmV2aWV3VGV4dERhdGFDaGFuZ2Uge1xuICBjb250ZW50OiBzdHJpbmc7XG4gIGlzV3JhcDogYm9vbGVhbjtcbiAgbGFuZ3VhZ2U6IFBSRVZJRVdfVEVYVF9EQVRBX0xBTkdVQUdFX1NVUFBPUlQ7XG4gIGNvbnRleHRDaGFuZ2U6ICdjb250ZW50JyB8ICdsYW5ndWFnZScgfCAnaXNXcmFwJztcbn1cbiJdfQ==
@@ -0,0 +1,293 @@
1
+ import * as i0 from '@angular/core';
2
+ import { signal, computed, input, model, output, viewChild, inject, ChangeDetectionStrategy, Component } from '@angular/core';
3
+ import { cpp } from '@codemirror/lang-cpp';
4
+ import { css } from '@codemirror/lang-css';
5
+ import { go } from '@codemirror/lang-go';
6
+ import { html } from '@codemirror/lang-html';
7
+ import { java } from '@codemirror/lang-java';
8
+ import { javascript } from '@codemirror/lang-javascript';
9
+ import { json } from '@codemirror/lang-json';
10
+ import { markdown } from '@codemirror/lang-markdown';
11
+ import { php } from '@codemirror/lang-php';
12
+ import { python } from '@codemirror/lang-python';
13
+ import { sql } from '@codemirror/lang-sql';
14
+ import { xml } from '@codemirror/lang-xml';
15
+ import { yaml } from '@codemirror/lang-yaml';
16
+ import { StreamLanguage } from '@codemirror/language';
17
+ import { linter, lintGutter } from '@codemirror/lint';
18
+ import { Compartment, EditorState } from '@codemirror/state';
19
+ import { lineNumbers } from '@codemirror/view';
20
+ import { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';
21
+ import { LibsUiComponentsDropdownComponent } from '@libs-ui/components-dropdown';
22
+ import { LibsUiNotificationService } from '@libs-ui/services-notification';
23
+ import { UtilsHttpParamsRequest, get } from '@libs-ui/utils';
24
+ import { EditorView, basicSetup } from 'codemirror';
25
+ import { Parser } from 'node-sql-parser';
26
+ import { returnListObject } from '@libs-ui/services-http-request';
27
+
28
+ const optionsLang = () => [
29
+ { id: 'text', label: 'Plain Text' },
30
+ { id: 'javascript', label: 'JavaScript/TypeScript' },
31
+ { id: 'html', label: 'HTML' },
32
+ { id: 'css', label: 'CSS/SCSS/SASS' },
33
+ { id: 'markdown', label: 'Markdown' },
34
+ { id: 'json', label: 'JSON' },
35
+ { id: 'sql', label: 'SQL' },
36
+ { id: 'xml', label: 'XML' },
37
+ { id: 'yaml', label: 'YAML' },
38
+ { id: 'python', label: 'Python' },
39
+ { id: 'java', label: 'Java' },
40
+ { id: 'cpp', label: 'C/C++' },
41
+ { id: 'php', label: 'PHP' },
42
+ { id: 'go', label: 'Go' },
43
+ ];
44
+ const httpRequestConfigGetOptionsLang = () => {
45
+ return {
46
+ type: 'text',
47
+ httpRequestData: signal({
48
+ objectInstance: returnListObject(optionsLang()),
49
+ functionName: 'list',
50
+ argumentsValue: [new UtilsHttpParamsRequest({ fromObject: { page: 1, per_page: 40 } })],
51
+ }),
52
+ configTemplateText: signal({
53
+ fieldKey: 'id',
54
+ notUseVirtualScroll: true,
55
+ }),
56
+ };
57
+ };
58
+
59
+ /* eslint-disable @typescript-eslint/no-explicit-any */
60
+ const sqlParser = new Parser();
61
+ class LibsUiComponentsPreviewTextDataComponent {
62
+ editorViewInstance;
63
+ wrapCompartment = new Compartment();
64
+ languageCompartment = new Compartment();
65
+ lineNumberCompartment = new Compartment();
66
+ isWrap = signal(true);
67
+ configLoadDataIsHttpConfig = httpRequestConfigGetOptionsLang();
68
+ labelLang = computed(() => optionsLang().find((item) => item.id === this.langSelected())?.label);
69
+ content = input('', { transform: (value) => value ?? '' });
70
+ langSelected = model.required();
71
+ editable = input(false, { transform: (value) => value ?? false });
72
+ hiddenAction = input(false, { transform: (value) => value ?? false });
73
+ lintIgnorePatterns = input(['Cannot use import statement outside a module', 'Unexpected token export', 'import ', '@angular/core'], {
74
+ transform: (value) => value ?? ['Cannot use import statement outside a module', 'Unexpected token export', 'import ', '@angular/core'],
75
+ });
76
+ background = input('#f8f9fa', { transform: (value) => value ?? '#f8f9fa' });
77
+ outChange = output();
78
+ syntaxErrors = output();
79
+ containerPreview = viewChild.required('containerPreview');
80
+ notificationService = inject(LibsUiNotificationService);
81
+ ngAfterViewInit() {
82
+ this.editorViewInstance = new EditorView({ ...this.getExtensionsByLanguage(this.langSelected()), doc: this.content(), parent: this.containerPreview().nativeElement });
83
+ }
84
+ getExtensionsByLanguage(lang) {
85
+ let formatByLangFunction = StreamLanguage.define({
86
+ token(stream) {
87
+ stream.skipToEnd();
88
+ return null;
89
+ },
90
+ });
91
+ let lintFunction = linter(() => []);
92
+ const lowerLang = lang.toLowerCase();
93
+ switch (lowerLang) {
94
+ case 'javascript':
95
+ formatByLangFunction = javascript({ jsx: true, typescript: true });
96
+ lintFunction = this.jsLinterFn();
97
+ break;
98
+ case 'html':
99
+ formatByLangFunction = html();
100
+ break;
101
+ case 'css':
102
+ formatByLangFunction = css();
103
+ break;
104
+ case 'markdown':
105
+ formatByLangFunction = markdown();
106
+ break;
107
+ case 'json':
108
+ formatByLangFunction = json();
109
+ lintFunction = this.jsonLinterFn();
110
+ break;
111
+ case 'sql':
112
+ formatByLangFunction = sql();
113
+ lintFunction = this.sqlLinterFn();
114
+ break;
115
+ case 'xml':
116
+ formatByLangFunction = xml();
117
+ break;
118
+ case 'yaml':
119
+ formatByLangFunction = yaml();
120
+ break;
121
+ case 'python':
122
+ formatByLangFunction = python();
123
+ break;
124
+ case 'java':
125
+ formatByLangFunction = java();
126
+ break;
127
+ case 'cpp':
128
+ formatByLangFunction = cpp();
129
+ break;
130
+ case 'php':
131
+ formatByLangFunction = php();
132
+ break;
133
+ case 'go':
134
+ formatByLangFunction = go();
135
+ break;
136
+ }
137
+ return {
138
+ extensions: [
139
+ basicSetup,
140
+ this.languageCompartment.of(formatByLangFunction),
141
+ this.lightTheme(),
142
+ EditorView.editable.of(this.editable()),
143
+ this.wrapCompartment.of(EditorView.lineWrapping),
144
+ this.lineNumberCompartment.of(lineNumbers()),
145
+ lintGutter(),
146
+ this.customBracketTheme(),
147
+ lintFunction,
148
+ EditorView.updateListener.of((update) => {
149
+ if (update.docChanged && this.editable()) {
150
+ const newValue = update.state.doc.toString();
151
+ this.outChange.emit({
152
+ content: newValue,
153
+ isWrap: this.isWrap(),
154
+ language: this.langSelected(),
155
+ contextChange: 'content',
156
+ });
157
+ }
158
+ }),
159
+ ],
160
+ };
161
+ }
162
+ lightTheme() {
163
+ return EditorView.theme({
164
+ '&': { backgroundColor: this.background(), color: '#333' },
165
+ '.cm-content': { caretColor: '#111' },
166
+ '.cm-activeLine': { backgroundColor: '#f0f0f0' },
167
+ });
168
+ }
169
+ customBracketTheme() {
170
+ return EditorView.theme({
171
+ '.cm-matchingBracket': {
172
+ backgroundColor: 'rgba(100, 200, 255, 0.15)', // xanh nhẹ trong suốt
173
+ border: '1px solid rgba(100, 200, 255, 0.4)',
174
+ borderRadius: '3px',
175
+ transition: 'all 0.2s ease',
176
+ },
177
+ '.cm-nonmatchingBracket': {
178
+ backgroundColor: 'rgba(255, 100, 100, 0.15)', // đỏ nhẹ
179
+ border: '1px solid rgba(255, 100, 100, 0.3)',
180
+ borderRadius: '3px',
181
+ },
182
+ });
183
+ }
184
+ jsLinterFn() {
185
+ return linter((view) => {
186
+ const text = view.state.doc.toString();
187
+ const diagnostics = [];
188
+ try {
189
+ new Function(text); // test parse code
190
+ }
191
+ catch (err) {
192
+ if (!this.lintIgnorePatterns().some((pattern) => err.message.includes(pattern))) {
193
+ diagnostics.push({
194
+ from: 0,
195
+ to: text.length,
196
+ severity: 'error',
197
+ message: err.message,
198
+ });
199
+ this.syntaxErrors.emit(diagnostics);
200
+ }
201
+ }
202
+ return diagnostics;
203
+ });
204
+ }
205
+ jsonLinterFn() {
206
+ return linter((view) => {
207
+ const text = view.state.doc.toString();
208
+ const diagnostics = [];
209
+ try {
210
+ JSON.parse(text);
211
+ }
212
+ catch (err) {
213
+ diagnostics.push({
214
+ from: 0,
215
+ to: text.length,
216
+ severity: 'error',
217
+ message: get(err, 'message', ''),
218
+ });
219
+ }
220
+ this.syntaxErrors.emit(diagnostics);
221
+ return diagnostics;
222
+ });
223
+ }
224
+ sqlLinterFn() {
225
+ return linter((view) => {
226
+ const text = view.state.doc.toString();
227
+ const diagnostics = [];
228
+ try {
229
+ sqlParser.astify(text);
230
+ }
231
+ catch (err) {
232
+ diagnostics.push({
233
+ from: 0,
234
+ to: text.length,
235
+ severity: 'error',
236
+ message: get(err, 'message', ''),
237
+ });
238
+ }
239
+ this.syntaxErrors.emit(diagnostics);
240
+ return diagnostics;
241
+ });
242
+ }
243
+ handlerCopy() {
244
+ navigator.clipboard.writeText(this.content() || '');
245
+ this.notificationService.showCompTypeTextInfo('Sao chép thành công');
246
+ }
247
+ handlerLineWrap() {
248
+ this.isWrap.update((val) => !val);
249
+ this.editorViewInstance?.dispatch({
250
+ effects: this.wrapCompartment.reconfigure(this.isWrap() ? EditorView.lineWrapping : []),
251
+ });
252
+ this.editorViewInstance?.dispatch({
253
+ effects: this.lineNumberCompartment.reconfigure(this.isWrap() ? lineNumbers() : [] // 👈 nếu tắt thì remove extension
254
+ ),
255
+ });
256
+ this.outChange.emit({
257
+ content: this.content(),
258
+ isWrap: this.isWrap(),
259
+ language: this.langSelected(),
260
+ contextChange: 'isWrap',
261
+ });
262
+ }
263
+ handlerSelectKey(data) {
264
+ if (!data || !data.key) {
265
+ return;
266
+ }
267
+ this.langSelected.set(data.key);
268
+ const extensions = this.getExtensionsByLanguage(this.langSelected());
269
+ this.editorViewInstance?.setState(EditorState.create({
270
+ doc: this.editorViewInstance?.state.doc.toString(),
271
+ ...extensions,
272
+ }));
273
+ this.outChange.emit({
274
+ content: this.content(),
275
+ isWrap: this.isWrap(),
276
+ language: this.langSelected(),
277
+ contextChange: 'language',
278
+ });
279
+ }
280
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsPreviewTextDataComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
281
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: LibsUiComponentsPreviewTextDataComponent, isStandalone: true, selector: "libs_ui-components-preview_text_data", inputs: { content: { classPropertyName: "content", publicName: "content", isSignal: true, isRequired: false, transformFunction: null }, langSelected: { classPropertyName: "langSelected", publicName: "langSelected", isSignal: true, isRequired: true, transformFunction: null }, editable: { classPropertyName: "editable", publicName: "editable", isSignal: true, isRequired: false, transformFunction: null }, hiddenAction: { classPropertyName: "hiddenAction", publicName: "hiddenAction", isSignal: true, isRequired: false, transformFunction: null }, lintIgnorePatterns: { classPropertyName: "lintIgnorePatterns", publicName: "lintIgnorePatterns", isSignal: true, isRequired: false, transformFunction: null }, background: { classPropertyName: "background", publicName: "background", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { langSelected: "langSelectedChange", outChange: "outChange", syntaxErrors: "syntaxErrors" }, viewQueries: [{ propertyName: "containerPreview", first: true, predicate: ["containerPreview"], descendants: true, isSignal: true }], ngImport: i0, template: "<div\n class=\"libs-ui-preview-data-container flex flex-col w-full h-auto rounded-[8px] libs-ui-border-general px-[8px]\"\n [style.--background-color]=\"background()\"\n [class.pt-[8px]]=\"!hiddenAction()\">\n @if (!hiddenAction()) {\n <div class=\"flex items-center content-between color-[#6a7383]\">\n <libs_ui-components-dropdown\n classInclude=\"w-[200px]\"\n [listConfig]=\"configLoadDataIsHttpConfig\"\n [listMaxItemShow]=\"5\"\n [isNgContent]=\"true\"\n [readonly]=\"!editable()\"\n [listHasButtonUnSelectOption]=\"false\"\n (outSelectKey)=\"handlerSelectKey($event)\">\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [label]=\"labelLang() || ''\"\n [sizeButton]=\"'small'\"\n [classIconRight]=\"editable() ? 'libs-ui-icon-move-right rotate-90' : ''\"\n [classInclude]=\"'!p-[0px]' + (editable() ? '' : '!pointer-events-none !cursor-default hover:!text-[#6A7383]')\" />\n </libs_ui-components-dropdown>\n <div class=\"flex items-center\">\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [label]=\"isWrap() ? 'i18n_remove_line_wrap' : 'i18n_line_wrap'\"\n [sizeButton]=\"'small'\"\n [classIconLeft]=\"isWrap() ? 'libs-ui-icon-unwrap' : 'libs-ui-icon-wrap'\"\n [classInclude]=\"'mo-lib-p-0px mo-lib-mr-16px'\"\n (outClick)=\"handlerLineWrap()\" />\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [label]=\"'i18n_copy'\"\n [sizeButton]=\"'small'\"\n [classIconLeft]=\"'libs-ui-icon-copy'\"\n [classInclude]=\"'mo-lib-p-0px'\"\n (outClick)=\"handlerCopy()\" />\n </div>\n </div>\n }\n <div #containerPreview></div>\n</div>\n", styles: [":host ::ng-deep .libs-ui-preview-data-container{background-color:var(--background-color)!important}:host ::ng-deep .libs-ui-preview-data-container .cm-line{white-space:pre-wrap}:host ::ng-deep .libs-ui-preview-data-container .cm-lintRange-error{background-color:#ff323233;border-bottom:2px solid red}:host ::ng-deep .libs-ui-preview-data-container .cm-lintRange-warning{background-color:#ffc80026}:host ::ng-deep .libs-ui-preview-data-container .cm-tooltip-lint{background:#fff8f8;color:#d32f2f;border:1px solid #f44336;padding:8px 10px;font-size:13px;font-family:Inter,sans-serif;border-radius:6px;box-shadow:0 2px 8px #ff000026}:host ::ng-deep .libs-ui-preview-data-container .cm-focused{outline:none!important}:host ::ng-deep .libs-ui-preview-data-container .cm-gutters{background-color:var(--background-color)!important}\n"], dependencies: [{ kind: "component", type: LibsUiComponentsDropdownComponent, selector: "libs_ui-components-dropdown", inputs: ["useXssFilter", "popoverElementRefCustom", "classInclude", "ignoreStopPropagationEvent", "flagMouse", "flagMouseContent", "popoverCustomConfig", "isNgContent", "zIndex", "convertItemSelected", "getPopoverItemSelected", "httpRequestDetailItemById", "lengthKeys", "textDisplayWhenNoSelect", "textDisplayWhenMultiSelect", "classIncludeTextDisplayWhenNoSelect", "fieldLabel", "fieldGetLabel", "labelPopoverConfig", "labelPopoverFullWidth", "hasContentUnitRight", "listSearchNoDataTemplateRef", "fieldGetImage", "imageSize", "typeShape", "fieldGetIcon", "fieldGetTextAvatar", "fieldGetColorAvatar", "classAvatarInclude", "getLastTextAfterSpace", "linkImageError", "showError", "showBorderError", "disable", "readonly", "labelConfig", "disableLabel", "listSearchConfig", "isSearchOnline", "listHiddenInputSearch", "listSearchPadding", "listKeySearch", "listDividerClassInclude", "listConfig", "listButtonsOther", "listHasButtonUnSelectOption", "listClickExactly", "listBackgroundCustom", "listMaxItemShow", "listKeySelected", "listMultiKeySelected", "listKeysDisable", "listKeysHidden", "validRequired", "validMaxItemSelected", "changeValidUndefinedResetError", "allowSelectItemMultiple", "focusInputSearch", "onlyEmitDataWhenReset", "resetKeyWhenSelectAllKey", "listConfigHasDivider", "classIncludeIcon", "classIncludeContent", "listIgnoreClassDisableDefaultWhenUseKeysDisableItem", "tabKeyActive", "tabsConfig", "ignoreBorderBottom"], outputs: ["flagMouseChange", "flagMouseContentChange", "lengthKeysChange", "showBorderErrorChange", "listKeySelectedChange", "listMultiKeySelectedChange", "tabKeyActiveChange", "outSelectKey", "outSelectMultiKey", "outFunctionsControl", "outValidEvent", "outChangStageFlagMouse", "outDataChange", "outClickButtonOther", "outShowList", "outChangeTabKeyActive"] }, { kind: "component", type: LibsUiComponentsButtonsButtonComponent, selector: "libs_ui-components-buttons-button", inputs: ["flagMouse", "type", "buttonCustom", "sizeButton", "label", "disable", "isPending", "imageLeft", "classInclude", "classIconLeft", "classIconRight", "classLabel", "iconOnlyType", "popover", "ignoreStopPropagationEvent", "zIndex", "widthLabelPopover", "styleIconLeft", "styleButton", "ignoreFocusWhenInputTab", "ignoreSetClickWhenShowPopover", "ignorePointerEvent", "isActive", "isHandlerEnterDocumentClickButton"], outputs: ["outClick", "outPopoverEvent", "outFunctionsControl"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
282
+ }
283
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsPreviewTextDataComponent, decorators: [{
284
+ type: Component,
285
+ args: [{ selector: 'libs_ui-components-preview_text_data', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [LibsUiComponentsDropdownComponent, LibsUiComponentsButtonsButtonComponent], template: "<div\n class=\"libs-ui-preview-data-container flex flex-col w-full h-auto rounded-[8px] libs-ui-border-general px-[8px]\"\n [style.--background-color]=\"background()\"\n [class.pt-[8px]]=\"!hiddenAction()\">\n @if (!hiddenAction()) {\n <div class=\"flex items-center content-between color-[#6a7383]\">\n <libs_ui-components-dropdown\n classInclude=\"w-[200px]\"\n [listConfig]=\"configLoadDataIsHttpConfig\"\n [listMaxItemShow]=\"5\"\n [isNgContent]=\"true\"\n [readonly]=\"!editable()\"\n [listHasButtonUnSelectOption]=\"false\"\n (outSelectKey)=\"handlerSelectKey($event)\">\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [label]=\"labelLang() || ''\"\n [sizeButton]=\"'small'\"\n [classIconRight]=\"editable() ? 'libs-ui-icon-move-right rotate-90' : ''\"\n [classInclude]=\"'!p-[0px]' + (editable() ? '' : '!pointer-events-none !cursor-default hover:!text-[#6A7383]')\" />\n </libs_ui-components-dropdown>\n <div class=\"flex items-center\">\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [label]=\"isWrap() ? 'i18n_remove_line_wrap' : 'i18n_line_wrap'\"\n [sizeButton]=\"'small'\"\n [classIconLeft]=\"isWrap() ? 'libs-ui-icon-unwrap' : 'libs-ui-icon-wrap'\"\n [classInclude]=\"'mo-lib-p-0px mo-lib-mr-16px'\"\n (outClick)=\"handlerLineWrap()\" />\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [label]=\"'i18n_copy'\"\n [sizeButton]=\"'small'\"\n [classIconLeft]=\"'libs-ui-icon-copy'\"\n [classInclude]=\"'mo-lib-p-0px'\"\n (outClick)=\"handlerCopy()\" />\n </div>\n </div>\n }\n <div #containerPreview></div>\n</div>\n", styles: [":host ::ng-deep .libs-ui-preview-data-container{background-color:var(--background-color)!important}:host ::ng-deep .libs-ui-preview-data-container .cm-line{white-space:pre-wrap}:host ::ng-deep .libs-ui-preview-data-container .cm-lintRange-error{background-color:#ff323233;border-bottom:2px solid red}:host ::ng-deep .libs-ui-preview-data-container .cm-lintRange-warning{background-color:#ffc80026}:host ::ng-deep .libs-ui-preview-data-container .cm-tooltip-lint{background:#fff8f8;color:#d32f2f;border:1px solid #f44336;padding:8px 10px;font-size:13px;font-family:Inter,sans-serif;border-radius:6px;box-shadow:0 2px 8px #ff000026}:host ::ng-deep .libs-ui-preview-data-container .cm-focused{outline:none!important}:host ::ng-deep .libs-ui-preview-data-container .cm-gutters{background-color:var(--background-color)!important}\n"] }]
286
+ }] });
287
+
288
+ /**
289
+ * Generated bundle index. Do not edit.
290
+ */
291
+
292
+ export { LibsUiComponentsPreviewTextDataComponent, httpRequestConfigGetOptionsLang, optionsLang };
293
+ //# sourceMappingURL=libs-ui-components-preview-text-data.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"libs-ui-components-preview-text-data.mjs","sources":["../../../../../libs-ui/components/preview-text-data/src/preview-text-data.define.ts","../../../../../libs-ui/components/preview-text-data/src/preview-text-data.component.ts","../../../../../libs-ui/components/preview-text-data/src/preview-text-data.component.html","../../../../../libs-ui/components/preview-text-data/src/libs-ui-components-preview-text-data.ts"],"sourcesContent":["import { signal } from '@angular/core';\nimport { IListConfigItem } from '@libs-ui/components-list';\nimport { IHttpRequestConfig, returnListObject } from '@libs-ui/services-http-request';\nimport { UtilsHttpParamsRequest } from '@libs-ui/utils';\n\nexport const optionsLang = () => [\n { id: 'text', label: 'Plain Text' },\n { id: 'javascript', label: 'JavaScript/TypeScript' },\n { id: 'html', label: 'HTML' },\n { id: 'css', label: 'CSS/SCSS/SASS' },\n { id: 'markdown', label: 'Markdown' },\n { id: 'json', label: 'JSON' },\n { id: 'sql', label: 'SQL' },\n { id: 'xml', label: 'XML' },\n { id: 'yaml', label: 'YAML' },\n { id: 'python', label: 'Python' },\n { id: 'java', label: 'Java' },\n { id: 'cpp', label: 'C/C++' },\n { id: 'php', label: 'PHP' },\n { id: 'go', label: 'Go' },\n];\n\nexport const httpRequestConfigGetOptionsLang = (): IListConfigItem => {\n return {\n type: 'text',\n httpRequestData: signal<IHttpRequestConfig>({\n objectInstance: returnListObject(optionsLang()),\n functionName: 'list',\n argumentsValue: [new UtilsHttpParamsRequest({ fromObject: { page: 1, per_page: 40 } })],\n }),\n configTemplateText: signal({\n fieldKey: 'id',\n notUseVirtualScroll: true,\n }),\n };\n};\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { AfterViewInit, ChangeDetectionStrategy, Component, computed, ElementRef, inject, input, model, output, signal, viewChild } from '@angular/core';\nimport { cpp } from '@codemirror/lang-cpp';\nimport { css } from '@codemirror/lang-css';\nimport { go } from '@codemirror/lang-go';\nimport { html } from '@codemirror/lang-html';\nimport { java } from '@codemirror/lang-java';\nimport { javascript } from '@codemirror/lang-javascript';\nimport { json } from '@codemirror/lang-json';\nimport { markdown } from '@codemirror/lang-markdown';\nimport { php } from '@codemirror/lang-php';\nimport { python } from '@codemirror/lang-python';\nimport { sql } from '@codemirror/lang-sql';\nimport { xml } from '@codemirror/lang-xml';\nimport { yaml } from '@codemirror/lang-yaml';\nimport { StreamLanguage } from '@codemirror/language';\nimport { Diagnostic, linter, lintGutter } from '@codemirror/lint';\nimport { Compartment, EditorState } from '@codemirror/state';\nimport { lineNumbers } from '@codemirror/view';\nimport { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';\nimport { IEmitSelectKey, LibsUiComponentsDropdownComponent } from '@libs-ui/components-dropdown';\nimport { LibsUiNotificationService } from '@libs-ui/services-notification';\nimport { get } from '@libs-ui/utils';\nimport { basicSetup, EditorView } from 'codemirror';\nimport { Parser } from 'node-sql-parser';\nimport { httpRequestConfigGetOptionsLang, optionsLang } from './preview-text-data.define';\nimport { IPreviewTextDataChange, PREVIEW_TEXT_DATA_LANGUAGE_SUPPORT } from './preview-text-data.interfaces';\n\nconst sqlParser = new Parser();\n\n@Component({\n // eslint-disable-next-line @angular-eslint/component-selector\n selector: 'libs_ui-components-preview_text_data',\n templateUrl: './preview-text-data.component.html',\n styleUrls: ['./preview-text-data.component.scss'],\n standalone: true,\n changeDetection: ChangeDetectionStrategy.OnPush,\n imports: [LibsUiComponentsDropdownComponent, LibsUiComponentsButtonsButtonComponent],\n})\nexport class LibsUiComponentsPreviewTextDataComponent implements AfterViewInit {\n private editorViewInstance?: EditorView;\n private wrapCompartment = new Compartment();\n private languageCompartment = new Compartment();\n private lineNumberCompartment = new Compartment();\n\n protected isWrap = signal<boolean>(true);\n protected configLoadDataIsHttpConfig = httpRequestConfigGetOptionsLang();\n protected labelLang = computed(() => optionsLang().find((item) => item.id === this.langSelected())?.label);\n\n readonly content = input<string, string | undefined>('', { transform: (value?: string) => value ?? '' });\n readonly langSelected = model.required<PREVIEW_TEXT_DATA_LANGUAGE_SUPPORT>();\n readonly editable = input<boolean, boolean | undefined>(false, { transform: (value?: boolean) => value ?? false });\n readonly hiddenAction = input<boolean, boolean | undefined>(false, { transform: (value?: boolean) => value ?? false });\n readonly lintIgnorePatterns = input<Array<string>, Array<string> | undefined>(['Cannot use import statement outside a module', 'Unexpected token export', 'import ', '@angular/core'], {\n transform: (value?: Array<string>) => value ?? ['Cannot use import statement outside a module', 'Unexpected token export', 'import ', '@angular/core'],\n });\n\n readonly background = input<string, string | undefined>('#f8f9fa', { transform: (value?: string) => value ?? '#f8f9fa' });\n\n readonly outChange = output<IPreviewTextDataChange>();\n readonly syntaxErrors = output<Diagnostic[]>();\n\n private containerPreview = viewChild.required<ElementRef<HTMLDivElement>>('containerPreview');\n\n private notificationService = inject(LibsUiNotificationService);\n ngAfterViewInit() {\n this.editorViewInstance = new EditorView({ ...this.getExtensionsByLanguage(this.langSelected()), doc: this.content(), parent: this.containerPreview().nativeElement });\n }\n\n private getExtensionsByLanguage(lang: PREVIEW_TEXT_DATA_LANGUAGE_SUPPORT): any {\n let formatByLangFunction: any = StreamLanguage.define({\n token(stream: any) {\n stream.skipToEnd();\n return null;\n },\n });\n let lintFunction = linter(() => []);\n\n const lowerLang = lang.toLowerCase();\n\n switch (lowerLang) {\n case 'javascript':\n formatByLangFunction = javascript({ jsx: true, typescript: true });\n lintFunction = this.jsLinterFn();\n break;\n\n case 'html':\n formatByLangFunction = html();\n break;\n\n case 'css':\n formatByLangFunction = css();\n break;\n\n case 'markdown':\n formatByLangFunction = markdown();\n break;\n\n case 'json':\n formatByLangFunction = json();\n lintFunction = this.jsonLinterFn();\n break;\n\n case 'sql':\n formatByLangFunction = sql();\n lintFunction = this.sqlLinterFn();\n break;\n\n case 'xml':\n formatByLangFunction = xml();\n break;\n\n case 'yaml':\n formatByLangFunction = yaml();\n break;\n\n case 'python':\n formatByLangFunction = python();\n break;\n\n case 'java':\n formatByLangFunction = java();\n break;\n\n case 'cpp':\n formatByLangFunction = cpp();\n break;\n\n case 'php':\n formatByLangFunction = php();\n break;\n\n case 'go':\n formatByLangFunction = go();\n break;\n }\n\n return {\n extensions: [\n basicSetup,\n this.languageCompartment.of(formatByLangFunction),\n this.lightTheme(),\n EditorView.editable.of(this.editable()),\n this.wrapCompartment.of(EditorView.lineWrapping),\n this.lineNumberCompartment.of(lineNumbers()),\n lintGutter(),\n this.customBracketTheme(),\n lintFunction,\n EditorView.updateListener.of((update: any) => {\n if (update.docChanged && this.editable()) {\n const newValue = update.state.doc.toString();\n\n this.outChange.emit({\n content: newValue,\n isWrap: this.isWrap(),\n language: this.langSelected(),\n contextChange: 'content',\n });\n }\n }),\n ],\n };\n }\n\n private lightTheme() {\n return EditorView.theme({\n '&': { backgroundColor: this.background(), color: '#333' },\n '.cm-content': { caretColor: '#111' },\n '.cm-activeLine': { backgroundColor: '#f0f0f0' },\n });\n }\n\n private customBracketTheme() {\n return EditorView.theme({\n '.cm-matchingBracket': {\n backgroundColor: 'rgba(100, 200, 255, 0.15)', // xanh nhẹ trong suốt\n border: '1px solid rgba(100, 200, 255, 0.4)',\n borderRadius: '3px',\n transition: 'all 0.2s ease',\n },\n '.cm-nonmatchingBracket': {\n backgroundColor: 'rgba(255, 100, 100, 0.15)', // đỏ nhẹ\n border: '1px solid rgba(255, 100, 100, 0.3)',\n borderRadius: '3px',\n },\n });\n }\n\n private jsLinterFn() {\n return linter((view: any) => {\n const text = view.state.doc.toString();\n const diagnostics: Diagnostic[] = [];\n try {\n new Function(text); // test parse code\n } catch (err: any) {\n if (!this.lintIgnorePatterns().some((pattern: any) => err.message.includes(pattern))) {\n diagnostics.push({\n from: 0,\n to: text.length,\n severity: 'error',\n message: err.message,\n });\n this.syntaxErrors.emit(diagnostics);\n }\n }\n return diagnostics;\n });\n }\n\n private jsonLinterFn() {\n return linter((view: any) => {\n const text = view.state.doc.toString();\n const diagnostics: Diagnostic[] = [];\n try {\n JSON.parse(text);\n } catch (err: unknown) {\n diagnostics.push({\n from: 0,\n to: text.length,\n severity: 'error',\n message: get(err, 'message', ''),\n });\n }\n this.syntaxErrors.emit(diagnostics);\n return diagnostics;\n });\n }\n\n private sqlLinterFn() {\n return linter((view: any) => {\n const text = view.state.doc.toString();\n const diagnostics: Diagnostic[] = [];\n try {\n sqlParser.astify(text);\n } catch (err: unknown) {\n diagnostics.push({\n from: 0,\n to: text.length,\n severity: 'error',\n message: get(err, 'message', ''),\n });\n }\n this.syntaxErrors.emit(diagnostics);\n return diagnostics;\n });\n }\n\n protected handlerCopy() {\n navigator.clipboard.writeText(this.content() || '');\n this.notificationService.showCompTypeTextInfo('Sao chép thành công');\n }\n\n protected handlerLineWrap() {\n this.isWrap.update((val: any) => !val);\n this.editorViewInstance?.dispatch({\n effects: this.wrapCompartment.reconfigure(this.isWrap() ? EditorView.lineWrapping : []),\n });\n\n this.editorViewInstance?.dispatch({\n effects: this.lineNumberCompartment.reconfigure(\n this.isWrap() ? lineNumbers() : [] // 👈 nếu tắt thì remove extension\n ),\n });\n this.outChange.emit({\n content: this.content(),\n isWrap: this.isWrap(),\n language: this.langSelected(),\n contextChange: 'isWrap',\n });\n }\n\n protected handlerSelectKey(data?: IEmitSelectKey) {\n if (!data || !data.key) {\n return;\n }\n this.langSelected.set(data.key as PREVIEW_TEXT_DATA_LANGUAGE_SUPPORT);\n const extensions = this.getExtensionsByLanguage(this.langSelected());\n this.editorViewInstance?.setState(\n EditorState.create({\n doc: this.editorViewInstance?.state.doc.toString(),\n ...extensions,\n })\n );\n this.outChange.emit({\n content: this.content(),\n isWrap: this.isWrap(),\n language: this.langSelected(),\n contextChange: 'language',\n });\n }\n}\n","<div\n class=\"libs-ui-preview-data-container flex flex-col w-full h-auto rounded-[8px] libs-ui-border-general px-[8px]\"\n [style.--background-color]=\"background()\"\n [class.pt-[8px]]=\"!hiddenAction()\">\n @if (!hiddenAction()) {\n <div class=\"flex items-center content-between color-[#6a7383]\">\n <libs_ui-components-dropdown\n classInclude=\"w-[200px]\"\n [listConfig]=\"configLoadDataIsHttpConfig\"\n [listMaxItemShow]=\"5\"\n [isNgContent]=\"true\"\n [readonly]=\"!editable()\"\n [listHasButtonUnSelectOption]=\"false\"\n (outSelectKey)=\"handlerSelectKey($event)\">\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [label]=\"labelLang() || ''\"\n [sizeButton]=\"'small'\"\n [classIconRight]=\"editable() ? 'libs-ui-icon-move-right rotate-90' : ''\"\n [classInclude]=\"'!p-[0px]' + (editable() ? '' : '!pointer-events-none !cursor-default hover:!text-[#6A7383]')\" />\n </libs_ui-components-dropdown>\n <div class=\"flex items-center\">\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [label]=\"isWrap() ? 'i18n_remove_line_wrap' : 'i18n_line_wrap'\"\n [sizeButton]=\"'small'\"\n [classIconLeft]=\"isWrap() ? 'libs-ui-icon-unwrap' : 'libs-ui-icon-wrap'\"\n [classInclude]=\"'mo-lib-p-0px mo-lib-mr-16px'\"\n (outClick)=\"handlerLineWrap()\" />\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [label]=\"'i18n_copy'\"\n [sizeButton]=\"'small'\"\n [classIconLeft]=\"'libs-ui-icon-copy'\"\n [classInclude]=\"'mo-lib-p-0px'\"\n (outClick)=\"handlerCopy()\" />\n </div>\n </div>\n }\n <div #containerPreview></div>\n</div>\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
package/index.d.ts ADDED
@@ -0,0 +1,3 @@
1
+ export * from './preview-text-data.component';
2
+ export * from './preview-text-data.interfaces';
3
+ export * from './preview-text-data.define';
package/package.json ADDED
@@ -0,0 +1,43 @@
1
+ {
2
+ "name": "@libs-ui/components-preview-text-data",
3
+ "version": "0.2.337-0",
4
+ "peerDependencies": {
5
+ "@codemirror/lang-angular": "0.1.4",
6
+ "@codemirror/lang-cpp": "6.0.3",
7
+ "@codemirror/lang-css": "6.3.1",
8
+ "@codemirror/lang-go": "6.0.1",
9
+ "@codemirror/lang-html": "6.4.11",
10
+ "@codemirror/lang-java": "6.0.2",
11
+ "@codemirror/lang-javascript": "6.2.4",
12
+ "@codemirror/lang-json": "6.0.2",
13
+ "@codemirror/lang-markdown": "6.5.0",
14
+ "@codemirror/lang-php": "6.0.2",
15
+ "@codemirror/lang-python": "6.2.1",
16
+ "@codemirror/lang-sql": "6.10.0",
17
+ "@codemirror/lang-xml": "6.1.0",
18
+ "@codemirror/lang-yaml": "6.1.2",
19
+ "@codemirror/lint": "6.9.1",
20
+ "@codemirror/state": "6.5.2",
21
+ "@codemirror/theme-one-dark": "6.1.3",
22
+ "@codemirror/view": "6.38.6",
23
+ "node-sql-parser": "5.3.13",
24
+ "codemirror": "6.0.2"
25
+ },
26
+ "sideEffects": false,
27
+ "module": "fesm2022/libs-ui-components-preview-text-data.mjs",
28
+ "typings": "index.d.ts",
29
+ "exports": {
30
+ "./package.json": {
31
+ "default": "./package.json"
32
+ },
33
+ ".": {
34
+ "types": "./index.d.ts",
35
+ "esm2022": "./esm2022/libs-ui-components-preview-text-data.mjs",
36
+ "esm": "./esm2022/libs-ui-components-preview-text-data.mjs",
37
+ "default": "./fesm2022/libs-ui-components-preview-text-data.mjs"
38
+ }
39
+ },
40
+ "dependencies": {
41
+ "tslib": "^2.3.0"
42
+ }
43
+ }
@@ -0,0 +1,36 @@
1
+ import { AfterViewInit } from '@angular/core';
2
+ import { Diagnostic } from '@codemirror/lint';
3
+ import { IEmitSelectKey } from '@libs-ui/components-dropdown';
4
+ import { IPreviewTextDataChange, PREVIEW_TEXT_DATA_LANGUAGE_SUPPORT } from './preview-text-data.interfaces';
5
+ import * as i0 from "@angular/core";
6
+ export declare class LibsUiComponentsPreviewTextDataComponent implements AfterViewInit {
7
+ private editorViewInstance?;
8
+ private wrapCompartment;
9
+ private languageCompartment;
10
+ private lineNumberCompartment;
11
+ protected isWrap: import("@angular/core").WritableSignal<boolean>;
12
+ protected configLoadDataIsHttpConfig: import("@libs-ui/components-list").IListConfigItem;
13
+ protected labelLang: import("@angular/core").Signal<string | undefined>;
14
+ readonly content: import("@angular/core").InputSignalWithTransform<string, string | undefined>;
15
+ readonly langSelected: import("@angular/core").ModelSignal<PREVIEW_TEXT_DATA_LANGUAGE_SUPPORT>;
16
+ readonly editable: import("@angular/core").InputSignalWithTransform<boolean, boolean | undefined>;
17
+ readonly hiddenAction: import("@angular/core").InputSignalWithTransform<boolean, boolean | undefined>;
18
+ readonly lintIgnorePatterns: import("@angular/core").InputSignalWithTransform<string[], string[] | undefined>;
19
+ readonly background: import("@angular/core").InputSignalWithTransform<string, string | undefined>;
20
+ readonly outChange: import("@angular/core").OutputEmitterRef<IPreviewTextDataChange>;
21
+ readonly syntaxErrors: import("@angular/core").OutputEmitterRef<Diagnostic[]>;
22
+ private containerPreview;
23
+ private notificationService;
24
+ ngAfterViewInit(): void;
25
+ private getExtensionsByLanguage;
26
+ private lightTheme;
27
+ private customBracketTheme;
28
+ private jsLinterFn;
29
+ private jsonLinterFn;
30
+ private sqlLinterFn;
31
+ protected handlerCopy(): void;
32
+ protected handlerLineWrap(): void;
33
+ protected handlerSelectKey(data?: IEmitSelectKey): void;
34
+ static ɵfac: i0.ɵɵFactoryDeclaration<LibsUiComponentsPreviewTextDataComponent, never>;
35
+ static ɵcmp: i0.ɵɵComponentDeclaration<LibsUiComponentsPreviewTextDataComponent, "libs_ui-components-preview_text_data", never, { "content": { "alias": "content"; "required": false; "isSignal": true; }; "langSelected": { "alias": "langSelected"; "required": true; "isSignal": true; }; "editable": { "alias": "editable"; "required": false; "isSignal": true; }; "hiddenAction": { "alias": "hiddenAction"; "required": false; "isSignal": true; }; "lintIgnorePatterns": { "alias": "lintIgnorePatterns"; "required": false; "isSignal": true; }; "background": { "alias": "background"; "required": false; "isSignal": true; }; }, { "langSelected": "langSelectedChange"; "outChange": "outChange"; "syntaxErrors": "syntaxErrors"; }, never, never, true, never>;
36
+ }
@@ -0,0 +1,6 @@
1
+ import { IListConfigItem } from '@libs-ui/components-list';
2
+ export declare const optionsLang: () => {
3
+ id: string;
4
+ label: string;
5
+ }[];
6
+ export declare const httpRequestConfigGetOptionsLang: () => IListConfigItem;
@@ -0,0 +1,7 @@
1
+ export type PREVIEW_TEXT_DATA_LANGUAGE_SUPPORT = 'javascript' | 'html' | 'css' | 'markdown' | 'json' | 'sql' | 'xml' | 'yaml' | 'python' | 'java' | 'cpp' | 'php' | 'go' | 'text';
2
+ export interface IPreviewTextDataChange {
3
+ content: string;
4
+ isWrap: boolean;
5
+ language: PREVIEW_TEXT_DATA_LANGUAGE_SUPPORT;
6
+ contextChange: 'content' | 'language' | 'isWrap';
7
+ }