@libs-ui/components-preview-text-data 0.2.350-0 → 0.2.351-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.
@@ -1,7 +1,11 @@
1
1
  import { signal } from '@angular/core';
2
2
  import { returnListObject } from '@libs-ui/services-http-request';
3
3
  import { UtilsHttpParamsRequest } from '@libs-ui/utils';
4
- export const optionsLang = () => [
4
+ /**
5
+ * Danh sách các ngôn ngữ được hỗ trợ
6
+ * Sử dụng const array để tránh tạo mới mỗi lần truy cập
7
+ */
8
+ export const optionsLangData = [
5
9
  { id: 'text', label: 'Plain Text' },
6
10
  { id: 'javascript', label: 'JavaScript/TypeScript' },
7
11
  { id: 'html', label: 'HTML' },
@@ -21,7 +25,7 @@ export const httpRequestConfigGetOptionsLang = () => {
21
25
  return {
22
26
  type: 'text',
23
27
  httpRequestData: signal({
24
- objectInstance: returnListObject(optionsLang()),
28
+ objectInstance: returnListObject([...optionsLangData]),
25
29
  functionName: 'list',
26
30
  argumentsValue: [new UtilsHttpParamsRequest({ fromObject: { page: 1, per_page: 40 } })],
27
31
  }),
@@ -31,4 +35,100 @@ export const httpRequestConfigGetOptionsLang = () => {
31
35
  }),
32
36
  };
33
37
  };
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJldmlldy10ZXh0LWRhdGEuZGVmaW5lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL3ByZXZpZXctdGV4dC1kYXRhL3NyYy9wcmV2aWV3LXRleHQtZGF0YS5kZWZpbmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV2QyxPQUFPLEVBQXNCLGdCQUFnQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDdEYsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFeEQsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHLEdBQUcsRUFBRSxDQUFDO0lBQy9CLEVBQUUsRUFBRSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsWUFBWSxFQUFFO0lBQ25DLEVBQUUsRUFBRSxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsdUJBQXVCLEVBQUU7SUFDcEQsRUFBRSxFQUFFLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUU7SUFDN0IsRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxlQUFlLEVBQUU7SUFDckMsRUFBRSxFQUFFLEVBQUUsVUFBVSxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUU7SUFDckMsRUFBRSxFQUFFLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUU7SUFDN0IsRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUU7SUFDM0IsRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUU7SUFDM0IsRUFBRSxFQUFFLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUU7SUFDN0IsRUFBRSxFQUFFLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBRSxRQUFRLEVBQUU7SUFDakMsRUFBRSxFQUFFLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUU7SUFDN0IsRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUU7SUFDN0IsRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUU7SUFDM0IsRUFBRSxFQUFFLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUU7Q0FDMUIsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLCtCQUErQixHQUFHLEdBQW9CLEVBQUU7SUFDbkUsT0FBTztRQUNMLElBQUksRUFBRSxNQUFNO1FBQ1osZUFBZSxFQUFFLE1BQU0sQ0FBcUI7WUFDMUMsY0FBYyxFQUFFLGdCQUFnQixDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQy9DLFlBQVksRUFBRSxNQUFNO1lBQ3BCLGNBQWMsRUFBRSxDQUFDLElBQUksc0JBQXNCLENBQUMsRUFBRSxVQUFVLEVBQUUsRUFBRSxJQUFJLEVBQUUsQ0FBQyxFQUFFLFFBQVEsRUFBRSxFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUM7U0FDeEYsQ0FBQztRQUNGLGtCQUFrQixFQUFFLE1BQU0sQ0FBQztZQUN6QixRQUFRLEVBQUUsSUFBSTtZQUNkLG1CQUFtQixFQUFFLElBQUk7U0FDMUIsQ0FBQztLQUNILENBQUM7QUFDSixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBzaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElMaXN0Q29uZmlnSXRlbSB9IGZyb20gJ0BsaWJzLXVpL2NvbXBvbmVudHMtbGlzdCc7XG5pbXBvcnQgeyBJSHR0cFJlcXVlc3RDb25maWcsIHJldHVybkxpc3RPYmplY3QgfSBmcm9tICdAbGlicy11aS9zZXJ2aWNlcy1odHRwLXJlcXVlc3QnO1xuaW1wb3J0IHsgVXRpbHNIdHRwUGFyYW1zUmVxdWVzdCB9IGZyb20gJ0BsaWJzLXVpL3V0aWxzJztcblxuZXhwb3J0IGNvbnN0IG9wdGlvbnNMYW5nID0gKCkgPT4gW1xuICB7IGlkOiAndGV4dCcsIGxhYmVsOiAnUGxhaW4gVGV4dCcgfSxcbiAgeyBpZDogJ2phdmFzY3JpcHQnLCBsYWJlbDogJ0phdmFTY3JpcHQvVHlwZVNjcmlwdCcgfSxcbiAgeyBpZDogJ2h0bWwnLCBsYWJlbDogJ0hUTUwnIH0sXG4gIHsgaWQ6ICdjc3MnLCBsYWJlbDogJ0NTUy9TQ1NTL1NBU1MnIH0sXG4gIHsgaWQ6ICdtYXJrZG93bicsIGxhYmVsOiAnTWFya2Rvd24nIH0sXG4gIHsgaWQ6ICdqc29uJywgbGFiZWw6ICdKU09OJyB9LFxuICB7IGlkOiAnc3FsJywgbGFiZWw6ICdTUUwnIH0sXG4gIHsgaWQ6ICd4bWwnLCBsYWJlbDogJ1hNTCcgfSxcbiAgeyBpZDogJ3lhbWwnLCBsYWJlbDogJ1lBTUwnIH0sXG4gIHsgaWQ6ICdweXRob24nLCBsYWJlbDogJ1B5dGhvbicgfSxcbiAgeyBpZDogJ2phdmEnLCBsYWJlbDogJ0phdmEnIH0sXG4gIHsgaWQ6ICdjcHAnLCBsYWJlbDogJ0MvQysrJyB9LFxuICB7IGlkOiAncGhwJywgbGFiZWw6ICdQSFAnIH0sXG4gIHsgaWQ6ICdnbycsIGxhYmVsOiAnR28nIH0sXG5dO1xuXG5leHBvcnQgY29uc3QgaHR0cFJlcXVlc3RDb25maWdHZXRPcHRpb25zTGFuZyA9ICgpOiBJTGlzdENvbmZpZ0l0ZW0gPT4ge1xuICByZXR1cm4ge1xuICAgIHR5cGU6ICd0ZXh0JyxcbiAgICBodHRwUmVxdWVzdERhdGE6IHNpZ25hbDxJSHR0cFJlcXVlc3RDb25maWc+KHtcbiAgICAgIG9iamVjdEluc3RhbmNlOiByZXR1cm5MaXN0T2JqZWN0KG9wdGlvbnNMYW5nKCkpLFxuICAgICAgZnVuY3Rpb25OYW1lOiAnbGlzdCcsXG4gICAgICBhcmd1bWVudHNWYWx1ZTogW25ldyBVdGlsc0h0dHBQYXJhbXNSZXF1ZXN0KHsgZnJvbU9iamVjdDogeyBwYWdlOiAxLCBwZXJfcGFnZTogNDAgfSB9KV0sXG4gICAgfSksXG4gICAgY29uZmlnVGVtcGxhdGVUZXh0OiBzaWduYWwoe1xuICAgICAgZmllbGRLZXk6ICdpZCcsXG4gICAgICBub3RVc2VWaXJ0dWFsU2Nyb2xsOiB0cnVlLFxuICAgIH0pLFxuICB9O1xufTtcbiJdfQ==
38
+ export const languageRegistry = {
39
+ javascript: {
40
+ loader: async () => {
41
+ const { javascript } = await import('@codemirror/lang-javascript');
42
+ return javascript({ jsx: true, typescript: true });
43
+ },
44
+ linter: async (component) => component.createJsLinter(),
45
+ },
46
+ html: {
47
+ loader: async () => {
48
+ const { html } = await import('@codemirror/lang-html');
49
+ return html();
50
+ },
51
+ },
52
+ css: {
53
+ loader: async () => {
54
+ const { css } = await import('@codemirror/lang-css');
55
+ return css();
56
+ },
57
+ },
58
+ markdown: {
59
+ loader: async () => {
60
+ const { markdown } = await import('@codemirror/lang-markdown');
61
+ return markdown();
62
+ },
63
+ },
64
+ json: {
65
+ loader: async () => {
66
+ const { json } = await import('@codemirror/lang-json');
67
+ return json();
68
+ },
69
+ linter: async (component) => component.createJsonLinter(),
70
+ },
71
+ sql: {
72
+ loader: async () => {
73
+ const { sql } = await import('@codemirror/lang-sql');
74
+ return sql();
75
+ },
76
+ linter: async (component) => component.createSqlLinter(),
77
+ },
78
+ xml: {
79
+ loader: async () => {
80
+ const { xml } = await import('@codemirror/lang-xml');
81
+ return xml();
82
+ },
83
+ },
84
+ yaml: {
85
+ loader: async () => {
86
+ const { yaml } = await import('@codemirror/lang-yaml');
87
+ return yaml();
88
+ },
89
+ },
90
+ python: {
91
+ loader: async () => {
92
+ const { python } = await import('@codemirror/lang-python');
93
+ return python();
94
+ },
95
+ },
96
+ java: {
97
+ loader: async () => {
98
+ const { java } = await import('@codemirror/lang-java');
99
+ return java();
100
+ },
101
+ },
102
+ cpp: {
103
+ loader: async () => {
104
+ const { cpp } = await import('@codemirror/lang-cpp');
105
+ return cpp();
106
+ },
107
+ },
108
+ php: {
109
+ loader: async () => {
110
+ const { php } = await import('@codemirror/lang-php');
111
+ return php();
112
+ },
113
+ },
114
+ go: {
115
+ loader: async () => {
116
+ const { go } = await import('@codemirror/lang-go');
117
+ return go();
118
+ },
119
+ },
120
+ };
121
+ /**
122
+ * Tạo default language extension cho plain text
123
+ * Sử dụng khi ngôn ngữ không được hỗ trợ
124
+ */
125
+ export const createDefaultLanguage = async () => {
126
+ const { StreamLanguage } = await import('@codemirror/language');
127
+ return StreamLanguage.define({
128
+ token(stream) {
129
+ stream.skipToEnd();
130
+ return null;
131
+ },
132
+ });
133
+ };
134
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"preview-text-data.define.js","sourceRoot":"","sources":["../../../../../libs-ui/components/preview-text-data/src/preview-text-data.define.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAGvC,OAAO,EAAsB,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AACtF,OAAO,EAAE,sBAAsB,EAAE,MAAM,gBAAgB,CAAC;AAGxD;;;GAGG;AACH,MAAM,CAAC,MAAM,eAAe,GAAG;IAC7B,EAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,YAAY,EAAE;IACnC,EAAE,EAAE,EAAE,YAAY,EAAE,KAAK,EAAE,uBAAuB,EAAE;IACpD,EAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE;IAC7B,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,eAAe,EAAE;IACrC,EAAE,EAAE,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,EAAE;IACrC,EAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE;IAC7B,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;IAC3B,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;IAC3B,EAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE;IAC7B,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE;IACjC,EAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE;IAC7B,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE;IAC7B,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;IAC3B,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE;CACjB,CAAC;AAEX,MAAM,CAAC,MAAM,+BAA+B,GAAG,GAAoB,EAAE;IACnE,OAAO;QACL,IAAI,EAAE,MAAM;QACZ,eAAe,EAAE,MAAM,CAAqB;YAC1C,cAAc,EAAE,gBAAgB,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC;YACtD,YAAY,EAAE,MAAM;YACpB,cAAc,EAAE,CAAC,IAAI,sBAAsB,CAAC,EAAE,UAAU,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;SACxF,CAAC;QACF,kBAAkB,EAAE,MAAM,CAAC;YACzB,QAAQ,EAAE,IAAI;YACd,mBAAmB,EAAE,IAAI;SAC1B,CAAC;KACH,CAAC;AACJ,CAAC,CAAC;AASF,MAAM,CAAC,MAAM,gBAAgB,GAA2C;IACtE,UAAU,EAAE;QACV,MAAM,EAAE,KAAK,IAAI,EAAE;YACjB,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,MAAM,CAAC,6BAA6B,CAAC,CAAC;YACnE,OAAO,UAAU,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC;QACrD,CAAC;QACD,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,cAAc,EAAE;KACxD;IACD,IAAI,EAAE;QACJ,MAAM,EAAE,KAAK,IAAI,EAAE;YACjB,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,MAAM,CAAC,uBAAuB,CAAC,CAAC;YACvD,OAAO,IAAI,EAAE,CAAC;QAChB,CAAC;KACF;IACD,GAAG,EAAE;QACH,MAAM,EAAE,KAAK,IAAI,EAAE;YACjB,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,MAAM,CAAC,sBAAsB,CAAC,CAAC;YACrD,OAAO,GAAG,EAAE,CAAC;QACf,CAAC;KACF;IACD,QAAQ,EAAE;QACR,MAAM,EAAE,KAAK,IAAI,EAAE;YACjB,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,MAAM,CAAC,2BAA2B,CAAC,CAAC;YAC/D,OAAO,QAAQ,EAAE,CAAC;QACpB,CAAC;KACF;IACD,IAAI,EAAE;QACJ,MAAM,EAAE,KAAK,IAAI,EAAE;YACjB,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,MAAM,CAAC,uBAAuB,CAAC,CAAC;YACvD,OAAO,IAAI,EAAE,CAAC;QAChB,CAAC;QACD,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,gBAAgB,EAAE;KAC1D;IACD,GAAG,EAAE;QACH,MAAM,EAAE,KAAK,IAAI,EAAE;YACjB,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,MAAM,CAAC,sBAAsB,CAAC,CAAC;YACrD,OAAO,GAAG,EAAE,CAAC;QACf,CAAC;QACD,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,eAAe,EAAE;KACzD;IACD,GAAG,EAAE;QACH,MAAM,EAAE,KAAK,IAAI,EAAE;YACjB,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,MAAM,CAAC,sBAAsB,CAAC,CAAC;YACrD,OAAO,GAAG,EAAE,CAAC;QACf,CAAC;KACF;IACD,IAAI,EAAE;QACJ,MAAM,EAAE,KAAK,IAAI,EAAE;YACjB,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,MAAM,CAAC,uBAAuB,CAAC,CAAC;YACvD,OAAO,IAAI,EAAE,CAAC;QAChB,CAAC;KACF;IACD,MAAM,EAAE;QACN,MAAM,EAAE,KAAK,IAAI,EAAE;YACjB,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,MAAM,CAAC,yBAAyB,CAAC,CAAC;YAC3D,OAAO,MAAM,EAAE,CAAC;QAClB,CAAC;KACF;IACD,IAAI,EAAE;QACJ,MAAM,EAAE,KAAK,IAAI,EAAE;YACjB,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,MAAM,CAAC,uBAAuB,CAAC,CAAC;YACvD,OAAO,IAAI,EAAE,CAAC;QAChB,CAAC;KACF;IACD,GAAG,EAAE;QACH,MAAM,EAAE,KAAK,IAAI,EAAE;YACjB,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,MAAM,CAAC,sBAAsB,CAAC,CAAC;YACrD,OAAO,GAAG,EAAE,CAAC;QACf,CAAC;KACF;IACD,GAAG,EAAE;QACH,MAAM,EAAE,KAAK,IAAI,EAAE;YACjB,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,MAAM,CAAC,sBAAsB,CAAC,CAAC;YACrD,OAAO,GAAG,EAAE,CAAC;QACf,CAAC;KACF;IACD,EAAE,EAAE;QACF,MAAM,EAAE,KAAK,IAAI,EAAE;YACjB,MAAM,EAAE,EAAE,EAAE,GAAG,MAAM,MAAM,CAAC,qBAAqB,CAAC,CAAC;YACnD,OAAO,EAAE,EAAE,CAAC;QACd,CAAC;KACF;CACF,CAAC;AAEF;;;GAGG;AACH,MAAM,CAAC,MAAM,qBAAqB,GAAG,KAAK,IAAwB,EAAE;IAClE,MAAM,EAAE,cAAc,EAAE,GAAG,MAAM,MAAM,CAAC,sBAAsB,CAAC,CAAC;IAChE,OAAO,cAAc,CAAC,MAAM,CAAC;QAC3B,KAAK,CAAC,MAAM;YACV,MAAM,CAAC,SAAS,EAAE,CAAC;YACnB,OAAO,IAAI,CAAC;QACd,CAAC;KACF,CAAC,CAAC;AACL,CAAC,CAAC","sourcesContent":["import { signal } from '@angular/core';\nimport { Extension } from '@codemirror/state';\nimport { IListConfigItem } from '@libs-ui/components-list';\nimport { IHttpRequestConfig, returnListObject } from '@libs-ui/services-http-request';\nimport { UtilsHttpParamsRequest } from '@libs-ui/utils';\nimport { LibsUiComponentsPreviewTextDataComponent } from './preview-text-data.component';\n\n/**\n * Danh sách các ngôn ngữ được hỗ trợ\n * Sử dụng const array để tránh tạo mới mỗi lần truy cập\n */\nexport const optionsLangData = [\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] as const;\n\nexport const httpRequestConfigGetOptionsLang = (): IListConfigItem => {\n  return {\n    type: 'text',\n    httpRequestData: signal<IHttpRequestConfig>({\n      objectInstance: returnListObject([...optionsLangData]),\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\ntype T_LanguageLoader = () => Promise<Extension>;\ntype T_LinterLoader = (component: LibsUiComponentsPreviewTextDataComponent) => Promise<Extension>;\ninterface I_LanguageRegistryItem {\n  loader: T_LanguageLoader;\n  linter?: T_LinterLoader;\n}\n\nexport const languageRegistry: Record<string, I_LanguageRegistryItem> = {\n  javascript: {\n    loader: async () => {\n      const { javascript } = await import('@codemirror/lang-javascript');\n      return javascript({ jsx: true, typescript: true });\n    },\n    linter: async (component) => component.createJsLinter(),\n  },\n  html: {\n    loader: async () => {\n      const { html } = await import('@codemirror/lang-html');\n      return html();\n    },\n  },\n  css: {\n    loader: async () => {\n      const { css } = await import('@codemirror/lang-css');\n      return css();\n    },\n  },\n  markdown: {\n    loader: async () => {\n      const { markdown } = await import('@codemirror/lang-markdown');\n      return markdown();\n    },\n  },\n  json: {\n    loader: async () => {\n      const { json } = await import('@codemirror/lang-json');\n      return json();\n    },\n    linter: async (component) => component.createJsonLinter(),\n  },\n  sql: {\n    loader: async () => {\n      const { sql } = await import('@codemirror/lang-sql');\n      return sql();\n    },\n    linter: async (component) => component.createSqlLinter(),\n  },\n  xml: {\n    loader: async () => {\n      const { xml } = await import('@codemirror/lang-xml');\n      return xml();\n    },\n  },\n  yaml: {\n    loader: async () => {\n      const { yaml } = await import('@codemirror/lang-yaml');\n      return yaml();\n    },\n  },\n  python: {\n    loader: async () => {\n      const { python } = await import('@codemirror/lang-python');\n      return python();\n    },\n  },\n  java: {\n    loader: async () => {\n      const { java } = await import('@codemirror/lang-java');\n      return java();\n    },\n  },\n  cpp: {\n    loader: async () => {\n      const { cpp } = await import('@codemirror/lang-cpp');\n      return cpp();\n    },\n  },\n  php: {\n    loader: async () => {\n      const { php } = await import('@codemirror/lang-php');\n      return php();\n    },\n  },\n  go: {\n    loader: async () => {\n      const { go } = await import('@codemirror/lang-go');\n      return go();\n    },\n  },\n};\n\n/**\n * Tạo default language extension cho plain text\n * Sử dụng khi ngôn ngữ không được hỗ trợ\n */\nexport const createDefaultLanguage = async (): Promise<Extension> => {\n  const { StreamLanguage } = await import('@codemirror/language');\n  return StreamLanguage.define({\n    token(stream) {\n      stream.skipToEnd();\n      return null;\n    },\n  });\n};\n"]}