imm-element-ui 2.4.7 → 2.4.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/am/am.component.mjs +3 -1
- package/esm2022/lib/form/form/form.component.mjs +17 -6
- package/esm2022/lib/form/form-type/codemirror.type.mjs +3 -3
- package/esm2022/lib/grid/cell-render/async-link-renderer.mjs +45 -0
- package/esm2022/lib/grid/grid/grid.component.mjs +4 -3
- package/esm2022/lib/grid/mock-data.mjs +4 -2
- package/esm2022/lib/page-form/page-form.component.mjs +316 -37
- package/esm2022/lib/page-form/page-form.interface.mjs +1 -1
- package/esm2022/lib/share/data-utils.mjs +156 -0
- package/esm2022/lib/share/utils.mjs +1 -1
- package/fesm2022/imm-element-ui.mjs +533 -46
- package/fesm2022/imm-element-ui.mjs.map +1 -1
- package/lib/am/am.component.d.ts +2 -0
- package/lib/form/form/form.component.d.ts +2 -0
- package/lib/grid/cell-render/async-link-renderer.d.ts +14 -0
- package/lib/grid/grid/grid.component.d.ts +2 -0
- package/lib/grid/mock-data.d.ts +2 -0
- package/lib/page-form/page-form.component.d.ts +43 -1
- package/lib/page-form/page-form.interface.d.ts +11 -0
- package/lib/share/data-utils.d.ts +49 -0
- package/package.json +1 -1
- package/src/lib/page-form/page-form.component.scss +18 -0
|
@@ -101,8 +101,8 @@ export class CodeMirrorComponent {
|
|
|
101
101
|
'.cm-activeLineGutter': {
|
|
102
102
|
backgroundColor: 'transparent',
|
|
103
103
|
},
|
|
104
|
-
'&': { minHeight: this.props.minHeight ?? '
|
|
105
|
-
'.cm-scroller': { overflow: 'auto', minHeight: this.props.minHeight ?? '
|
|
104
|
+
'&': { minHeight: this.props.minHeight ?? '68px', maxHeight: this.props.maxHeight || '204px' },
|
|
105
|
+
'.cm-scroller': { overflow: 'auto', minHeight: this.props.minHeight ?? '68px' },
|
|
106
106
|
}),
|
|
107
107
|
this.getLanguageExtension(),
|
|
108
108
|
EditorView.updateListener.of((update) => {
|
|
@@ -212,4 +212,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
212
212
|
type: ViewChild,
|
|
213
213
|
args: ['codeContainer', { static: false }]
|
|
214
214
|
}] } });
|
|
215
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"codemirror.type.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/form/form-type/codemirror.type.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, ViewChild, input, effect, Renderer2, output } from '@angular/core';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { FormField, FieldProps } from '../form-field/form-field';\nimport { javascript } from '@codemirror/lang-javascript';\nimport { html } from '@codemirror/lang-html';\nimport { json } from '@codemirror/lang-json';\nimport { EditorState, StateEffect } from '@codemirror/state';\nimport {\n\tEditorView,\n\tkeymap,\n\thighlightSpecialChars,\n\tdrawSelection,\n\tdropCursor,\n\trectangularSelection,\n\tcrosshairCursor,\n\tlineNumbers,\n\thighlightActiveLineGutter,\n\tplaceholder,\n} from '@codemirror/view';\nimport { defaultHighlightStyle, syntaxHighlighting, indentOnInput, bracketMatching, foldGutter, foldKeymap } from '@codemirror/language';\nimport { defaultKeymap, history, historyKeymap } from '@codemirror/commands';\nimport { searchKeymap, highlightSelectionMatches } from '@codemirror/search';\nimport { autocompletion, completionKeymap, closeBrackets, closeBracketsKeymap } from '@codemirror/autocomplete';\nimport { ActionService } from '../../service/action.service';\nimport { lintKeymap } from '@codemirror/lint';\nimport prettier from 'prettier';\nimport typescript from 'prettier/plugins/typescript';\nimport estree from 'prettier/plugins/estree';\nimport { sql } from '@codemirror/lang-sql';\nexport interface CodeMirrorProps extends FieldProps {\n\tlanguage?: 'html' | 'javascript' | 'json' | 'sql';\n\tmaxHeight?: string;\n\tminHeight?: string;\n\tplaceholder?: string;\n\ttemplates?: string[];\n}\n\n@Component({\n\tselector: 'form-codemirror',\n\tstandalone: true,\n\timports: [ReactiveFormsModule],\n\ttemplate: `<div #codeContainer></div>`,\n\tstyleUrl: '../../styles/styles.scss',\n})\nexport class CodeMirrorComponent {\n\t@ViewChild('codeContainer', { static: false }) codeContainer!: ElementRef;\n\tcmEditor!: ElementRef;\n\tfield = input<FormField>();\n\tprops: CodeMirrorProps = {};\n\teditorView!: EditorView;\n\ttemplateIndex = 0;\n\n\tchange = output<string>();\n\n\tconstructor(\n\t\tprivate action: ActionService,\n\t\tprivate renderer: Renderer2,\n\t) {\n\t\teffect(() => {\n\t\t\tif (this.field()) {\n\t\t\t\tthis.props = this.field()!.codeMirrorProps!;\n\t\t\t\tthis.handleHookChange();\n\t\t\t\tthis.handleExtensions();\n\t\t\t}\n\t\t});\n\t\teffect(() => {\n\t\t\tconst labelAction = this.action.getFieldLabelAction();\n\t\t\tif (!labelAction || labelAction?.key != this.field()?.uuid) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (labelAction.type == 'mouseenter') {\n\t\t\t\tthis.renderer.addClass(this.cmEditor, 'ng-hovered');\n\t\t\t} else if (labelAction.type == 'mouseleave') {\n\t\t\t\tthis.renderer.removeClass(this.cmEditor, 'ng-hovered');\n\t\t\t} else if (labelAction.type == 'click') {\n\t\t\t\tthis.editorView.focus();\n\t\t\t} else if (labelAction.type == 'dblclick') {\n\t\t\t\tif (!this.props.templates || !this.props.templates.length) return;\n\t\t\t\tthis.field()?.fieldControl?.setValue(\n\t\t\t\t\tthis.props.templates[\n\t\t\t\t\t\t((this.templateIndex % this.props.templates.length) + this.props.templates.length) % this.props.templates.length\n\t\t\t\t\t],\n\t\t\t\t\t{ emitEvent: true },\n\t\t\t\t\ttrue,\n\t\t\t\t);\n\t\t\t\tthis.templateIndex++;\n\t\t\t}\n\t\t});\n\t}\n\n\tngAfterViewInit() {\n\t\tthis.editorView = new EditorView({\n\t\t\tstate: EditorState.create({\n\t\t\t\tdoc: this.field()?.fieldControl?.value,\n\t\t\t}),\n\t\t\tparent: this.codeContainer.nativeElement,\n\t\t});\n\t\tthis.cmEditor = this.codeContainer.nativeElement.querySelector('.cm-editor');\n\t}\n\n\tngOnDestroy() {\n\t\tthis.editorView.destroy();\n\t}\n\n\thandleExtensions() {\n\t\tconst extendsions = [\n\t\t\tlineNumbers(),\n\t\t\tfoldGutter(),\n\t\t\thighlightSpecialChars(),\n\t\t\thistory(),\n\t\t\tdrawSelection(),\n\t\t\tdropCursor(),\n\t\t\tEditorState.allowMultipleSelections.of(true),\n\t\t\tindentOnInput(),\n\t\t\tsyntaxHighlighting(defaultHighlightStyle),\n\t\t\tbracketMatching(),\n\t\t\tcloseBrackets(),\n\t\t\tautocompletion(),\n\t\t\trectangularSelection(),\n\t\t\tcrosshairCursor(),\n\t\t\thighlightActiveLineGutter(),\n\t\t\thighlightSelectionMatches(),\n\t\t\tthis.formatting(),\n\t\t\tkeymap.of([\n\t\t\t\t...closeBracketsKeymap,\n\t\t\t\t...defaultKeymap,\n\t\t\t\t...searchKeymap,\n\t\t\t\t...historyKeymap,\n\t\t\t\t...foldKeymap,\n\t\t\t\t...completionKeymap,\n\t\t\t\t...lintKeymap,\n\t\t\t]),\n\t\t\tEditorView.theme({\n\t\t\t\t'.cm-gutters': {\n\t\t\t\t\tbackgroundColor: 'transparent',\n\t\t\t\t\tborder: 'none',\n\t\t\t\t},\n\t\t\t\t'.cm-activeLineGutter': {\n\t\t\t\t\tbackgroundColor: 'transparent',\n\t\t\t\t},\n\t\t\t\t'&': { minHeight: this.props.minHeight ?? '88px', maxHeight: this.props.maxHeight || '204px' },\n\t\t\t\t'.cm-scroller': { overflow: 'auto', minHeight: this.props.minHeight ?? '88px' },\n\t\t\t}),\n\t\t\tthis.getLanguageExtension(),\n\t\t\tEditorView.updateListener.of((update) => {\n\t\t\t\tif (update.transactions.some((tr) => tr.isUserEvent('input') || tr.isUserEvent('delete'))) {\n\t\t\t\t\tconst newValue = update.state.doc.toString();\n\t\t\t\t\tthis.field()?.fieldControl?.setValue(newValue);\n\t\t\t\t\tthis.change.emit(newValue);\n\t\t\t\t}\n\t\t\t}),\n\t\t];\n\t\tif (this.props.placeholder) {\n\t\t\textendsions.unshift(placeholder(this.props.placeholder));\n\t\t}\n\t\tif (this.props.disabled) {\n\t\t\textendsions.push(EditorView.editable.of(false));\n\t\t}\n\t\tthis.editorView.dispatch({\n\t\t\teffects: StateEffect.reconfigure.of(extendsions),\n\t\t});\n\t}\n\n\thandleHookChange() {\n\t\tthis.field()?.fieldControl?.hookChange?.subscribe((value) => {\n\t\t\t// 改进判断逻辑：只有在值为 null 且编辑器为空时才返回\n\t\t\tif (value == null && !this.editorView.state.doc.length) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tthis.props.onHookChange?.(this.field()!, { value });\n\t\t\tconst transaction = this.editorView.state.update({\n\t\t\t\tchanges: { from: 0, to: this.editorView.state.doc.length, insert: value || '' },\n\t\t\t});\n\t\t\tthis.editorView.dispatch(transaction);\n\t\t});\n\t}\n\n\tgetLanguageExtension() {\n\t\tswitch (this.props.language) {\n\t\t\tcase 'html':\n\t\t\t\treturn html();\n\t\t\tcase 'javascript':\n\t\t\t\treturn javascript();\n\t\t\tcase 'json':\n\t\t\t\treturn json();\n\t\t\tcase 'sql':\n\t\t\t\treturn sql()\n\t\t\tdefault:\n\t\t\t\treturn javascript();\n\t\t}\n\t}\n\n\tminLines(min: number) {\n\t\treturn EditorView.updateListener.of((v) => {\n\t\t\tconst doc = v.state.doc;\n\t\t\tconst lineCount = doc.lines;\n\t\t\tif (lineCount < min) {\n\t\t\t\tconst newLines = Array(min + 1 - lineCount)\n\t\t\t\t\t.fill('')\n\t\t\t\t\t.join('\\n');\n\t\t\t\tconst transaction = v.state.update({\n\t\t\t\t\tchanges: { from: doc.length, insert: newLines },\n\t\t\t\t});\n\t\t\t\tv.view.dispatch(transaction);\n\t\t\t}\n\t\t});\n\t}\n\n\tformatting() {\n\t\tconst formatCommand = (view: any) => {\n\t\t\ttry {\n\t\t\t\tprettier\n\t\t\t\t\t.format(view.state.doc.toString(), {\n\t\t\t\t\t\tparser: 'typescript',\n\t\t\t\t\t\tplugins: [typescript, estree],\n\t\t\t\t\t\tsemi: true,\n\t\t\t\t\t\tsingleQuote: true,\n\t\t\t\t\t\ttabWidth: 2,\n\t\t\t\t\t\tprintWidth: 80,\n\t\t\t\t\t\ttrailingComma: 'all',\n\t\t\t\t\t\tarrowParens: 'always',\n\t\t\t\t\t})\n\t\t\t\t\t.then((formatted) => {\n\t\t\t\t\t\tconst transaction = this.editorView.state.update({\n\t\t\t\t\t\t\tchanges: { from: 0, to: this.editorView.state.doc.length, insert: formatted },\n\t\t\t\t\t\t});\n\t\t\t\t\t\tthis.editorView.dispatch(transaction);\n\t\t\t\t\t\t// console.log('格式化成功:', formatted);\n\t\t\t\t\t});\n\t\t\t\treturn true;\n\t\t\t} catch (error) {\n\t\t\t\t// console.error('格式化错误:', error);\n\t\t\t\treturn false;\n\t\t\t}\n\t\t};\n\t\treturn keymap.of([\n\t\t\t{\n\t\t\t\tkey: 'Shift-Alt-f',\n\t\t\t\tmac: 'Shift-Cmd-f',\n\t\t\t\trun: formatCommand,\n\t\t\t\tpreventDefault: true,\n\t\t\t},\n\t\t]);\n\t}\n}\n"]}
|
|
215
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"codemirror.type.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/form/form-type/codemirror.type.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, ViewChild, input, effect, Renderer2, output } from '@angular/core';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { FormField, FieldProps } from '../form-field/form-field';\nimport { javascript } from '@codemirror/lang-javascript';\nimport { html } from '@codemirror/lang-html';\nimport { json } from '@codemirror/lang-json';\nimport { EditorState, StateEffect } from '@codemirror/state';\nimport {\n\tEditorView,\n\tkeymap,\n\thighlightSpecialChars,\n\tdrawSelection,\n\tdropCursor,\n\trectangularSelection,\n\tcrosshairCursor,\n\tlineNumbers,\n\thighlightActiveLineGutter,\n\tplaceholder,\n} from '@codemirror/view';\nimport { defaultHighlightStyle, syntaxHighlighting, indentOnInput, bracketMatching, foldGutter, foldKeymap } from '@codemirror/language';\nimport { defaultKeymap, history, historyKeymap } from '@codemirror/commands';\nimport { searchKeymap, highlightSelectionMatches } from '@codemirror/search';\nimport { autocompletion, completionKeymap, closeBrackets, closeBracketsKeymap } from '@codemirror/autocomplete';\nimport { ActionService } from '../../service/action.service';\nimport { lintKeymap } from '@codemirror/lint';\nimport prettier from 'prettier';\nimport typescript from 'prettier/plugins/typescript';\nimport estree from 'prettier/plugins/estree';\nimport { sql } from '@codemirror/lang-sql';\nexport interface CodeMirrorProps extends FieldProps {\n\tlanguage?: 'html' | 'javascript' | 'json' | 'sql';\n\tmaxHeight?: string;\n\tminHeight?: string;\n\tplaceholder?: string;\n\ttemplates?: string[];\n}\n\n@Component({\n\tselector: 'form-codemirror',\n\tstandalone: true,\n\timports: [ReactiveFormsModule],\n\ttemplate: `<div #codeContainer></div>`,\n\tstyleUrl: '../../styles/styles.scss',\n})\nexport class CodeMirrorComponent {\n\t@ViewChild('codeContainer', { static: false }) codeContainer!: ElementRef;\n\tcmEditor!: ElementRef;\n\tfield = input<FormField>();\n\tprops: CodeMirrorProps = {};\n\teditorView!: EditorView;\n\ttemplateIndex = 0;\n\n\tchange = output<string>();\n\n\tconstructor(\n\t\tprivate action: ActionService,\n\t\tprivate renderer: Renderer2,\n\t) {\n\t\teffect(() => {\n\t\t\tif (this.field()) {\n\t\t\t\tthis.props = this.field()!.codeMirrorProps!;\n\t\t\t\tthis.handleHookChange();\n\t\t\t\tthis.handleExtensions();\n\t\t\t}\n\t\t});\n\t\teffect(() => {\n\t\t\tconst labelAction = this.action.getFieldLabelAction();\n\t\t\tif (!labelAction || labelAction?.key != this.field()?.uuid) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (labelAction.type == 'mouseenter') {\n\t\t\t\tthis.renderer.addClass(this.cmEditor, 'ng-hovered');\n\t\t\t} else if (labelAction.type == 'mouseleave') {\n\t\t\t\tthis.renderer.removeClass(this.cmEditor, 'ng-hovered');\n\t\t\t} else if (labelAction.type == 'click') {\n\t\t\t\tthis.editorView.focus();\n\t\t\t} else if (labelAction.type == 'dblclick') {\n\t\t\t\tif (!this.props.templates || !this.props.templates.length) return;\n\t\t\t\tthis.field()?.fieldControl?.setValue(\n\t\t\t\t\tthis.props.templates[\n\t\t\t\t\t\t((this.templateIndex % this.props.templates.length) + this.props.templates.length) % this.props.templates.length\n\t\t\t\t\t],\n\t\t\t\t\t{ emitEvent: true },\n\t\t\t\t\ttrue,\n\t\t\t\t);\n\t\t\t\tthis.templateIndex++;\n\t\t\t}\n\t\t});\n\t}\n\n\tngAfterViewInit() {\n\t\tthis.editorView = new EditorView({\n\t\t\tstate: EditorState.create({\n\t\t\t\tdoc: this.field()?.fieldControl?.value,\n\t\t\t}),\n\t\t\tparent: this.codeContainer.nativeElement,\n\t\t});\n\t\tthis.cmEditor = this.codeContainer.nativeElement.querySelector('.cm-editor');\n\t}\n\n\tngOnDestroy() {\n\t\tthis.editorView.destroy();\n\t}\n\n\thandleExtensions() {\n\t\tconst extendsions = [\n\t\t\tlineNumbers(),\n\t\t\tfoldGutter(),\n\t\t\thighlightSpecialChars(),\n\t\t\thistory(),\n\t\t\tdrawSelection(),\n\t\t\tdropCursor(),\n\t\t\tEditorState.allowMultipleSelections.of(true),\n\t\t\tindentOnInput(),\n\t\t\tsyntaxHighlighting(defaultHighlightStyle),\n\t\t\tbracketMatching(),\n\t\t\tcloseBrackets(),\n\t\t\tautocompletion(),\n\t\t\trectangularSelection(),\n\t\t\tcrosshairCursor(),\n\t\t\thighlightActiveLineGutter(),\n\t\t\thighlightSelectionMatches(),\n\t\t\tthis.formatting(),\n\t\t\tkeymap.of([\n\t\t\t\t...closeBracketsKeymap,\n\t\t\t\t...defaultKeymap,\n\t\t\t\t...searchKeymap,\n\t\t\t\t...historyKeymap,\n\t\t\t\t...foldKeymap,\n\t\t\t\t...completionKeymap,\n\t\t\t\t...lintKeymap,\n\t\t\t]),\n\t\t\tEditorView.theme({\n\t\t\t\t'.cm-gutters': {\n\t\t\t\t\tbackgroundColor: 'transparent',\n\t\t\t\t\tborder: 'none',\n\t\t\t\t},\n\t\t\t\t'.cm-activeLineGutter': {\n\t\t\t\t\tbackgroundColor: 'transparent',\n\t\t\t\t},\n\t\t\t\t'&': { minHeight: this.props.minHeight ?? '68px', maxHeight: this.props.maxHeight || '204px' },\n\t\t\t\t'.cm-scroller': { overflow: 'auto', minHeight: this.props.minHeight ?? '68px' },\n\t\t\t}),\n\t\t\tthis.getLanguageExtension(),\n\t\t\tEditorView.updateListener.of((update) => {\n\t\t\t\tif (update.transactions.some((tr) => tr.isUserEvent('input') || tr.isUserEvent('delete'))) {\n\t\t\t\t\tconst newValue = update.state.doc.toString();\n\t\t\t\t\tthis.field()?.fieldControl?.setValue(newValue);\n\t\t\t\t\tthis.change.emit(newValue);\n\t\t\t\t}\n\t\t\t}),\n\t\t];\n\t\tif (this.props.placeholder) {\n\t\t\textendsions.unshift(placeholder(this.props.placeholder));\n\t\t}\n\t\tif (this.props.disabled) {\n\t\t\textendsions.push(EditorView.editable.of(false));\n\t\t}\n\t\tthis.editorView.dispatch({\n\t\t\teffects: StateEffect.reconfigure.of(extendsions),\n\t\t});\n\t}\n\n\thandleHookChange() {\n\t\tthis.field()?.fieldControl?.hookChange?.subscribe((value) => {\n\t\t\t// 改进判断逻辑：只有在值为 null 且编辑器为空时才返回\n\t\t\tif (value == null && !this.editorView.state.doc.length) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tthis.props.onHookChange?.(this.field()!, { value });\n\t\t\tconst transaction = this.editorView.state.update({\n\t\t\t\tchanges: { from: 0, to: this.editorView.state.doc.length, insert: value || '' },\n\t\t\t});\n\t\t\tthis.editorView.dispatch(transaction);\n\t\t});\n\t}\n\n\tgetLanguageExtension() {\n\t\tswitch (this.props.language) {\n\t\t\tcase 'html':\n\t\t\t\treturn html();\n\t\t\tcase 'javascript':\n\t\t\t\treturn javascript();\n\t\t\tcase 'json':\n\t\t\t\treturn json();\n\t\t\tcase 'sql':\n\t\t\t\treturn sql()\n\t\t\tdefault:\n\t\t\t\treturn javascript();\n\t\t}\n\t}\n\n\tminLines(min: number) {\n\t\treturn EditorView.updateListener.of((v) => {\n\t\t\tconst doc = v.state.doc;\n\t\t\tconst lineCount = doc.lines;\n\t\t\tif (lineCount < min) {\n\t\t\t\tconst newLines = Array(min + 1 - lineCount)\n\t\t\t\t\t.fill('')\n\t\t\t\t\t.join('\\n');\n\t\t\t\tconst transaction = v.state.update({\n\t\t\t\t\tchanges: { from: doc.length, insert: newLines },\n\t\t\t\t});\n\t\t\t\tv.view.dispatch(transaction);\n\t\t\t}\n\t\t});\n\t}\n\n\tformatting() {\n\t\tconst formatCommand = (view: any) => {\n\t\t\ttry {\n\t\t\t\tprettier\n\t\t\t\t\t.format(view.state.doc.toString(), {\n\t\t\t\t\t\tparser: 'typescript',\n\t\t\t\t\t\tplugins: [typescript, estree],\n\t\t\t\t\t\tsemi: true,\n\t\t\t\t\t\tsingleQuote: true,\n\t\t\t\t\t\ttabWidth: 2,\n\t\t\t\t\t\tprintWidth: 80,\n\t\t\t\t\t\ttrailingComma: 'all',\n\t\t\t\t\t\tarrowParens: 'always',\n\t\t\t\t\t})\n\t\t\t\t\t.then((formatted) => {\n\t\t\t\t\t\tconst transaction = this.editorView.state.update({\n\t\t\t\t\t\t\tchanges: { from: 0, to: this.editorView.state.doc.length, insert: formatted },\n\t\t\t\t\t\t});\n\t\t\t\t\t\tthis.editorView.dispatch(transaction);\n\t\t\t\t\t\t// console.log('格式化成功:', formatted);\n\t\t\t\t\t});\n\t\t\t\treturn true;\n\t\t\t} catch (error) {\n\t\t\t\t// console.error('格式化错误:', error);\n\t\t\t\treturn false;\n\t\t\t}\n\t\t};\n\t\treturn keymap.of([\n\t\t\t{\n\t\t\t\tkey: 'Shift-Alt-f',\n\t\t\t\tmac: 'Shift-Cmd-f',\n\t\t\t\trun: formatCommand,\n\t\t\t\tpreventDefault: true,\n\t\t\t},\n\t\t]);\n\t}\n}\n"]}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { AsyncPipe } from '@angular/common';
|
|
2
|
+
import { Component, inject } from '@angular/core';
|
|
3
|
+
import { CommonModule } from '@angular/common';
|
|
4
|
+
import { Router } from '@angular/router';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class AsyncLinkRenderer {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.router = inject(Router);
|
|
9
|
+
}
|
|
10
|
+
agInit(params) {
|
|
11
|
+
this.params = params;
|
|
12
|
+
this.optionsHook = params.optionsHook;
|
|
13
|
+
this.triggerOptionsHook(params.value);
|
|
14
|
+
}
|
|
15
|
+
triggerOptionsHook(value) {
|
|
16
|
+
if (this.optionsHook) {
|
|
17
|
+
this.optionsHook(value).subscribe((res) => {
|
|
18
|
+
this.label = res?.find((item) => item.value === value)?.label || '';
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
onLink() {
|
|
23
|
+
const { url, queryParam } = this.params;
|
|
24
|
+
if (url) {
|
|
25
|
+
let urlStr = typeof url == 'function' ? url(this.params.data) : '';
|
|
26
|
+
let query = typeof queryParam === 'function' ? queryParam(this.params.data) : {};
|
|
27
|
+
urlStr !== '' && this.router.navigate([urlStr], { queryParams: query });
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AsyncLinkRenderer, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
31
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: AsyncLinkRenderer, isStandalone: true, selector: "ng-component", providers: [AsyncPipe], ngImport: i0, template: ` <span
|
|
32
|
+
class="cell-link"
|
|
33
|
+
(click)="onLink()"
|
|
34
|
+
>{{ label }}</span
|
|
35
|
+
>`, isInline: true, styles: [".cell-link{color:var(--p-primary-color);cursor:pointer}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
|
|
36
|
+
}
|
|
37
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AsyncLinkRenderer, decorators: [{
|
|
38
|
+
type: Component,
|
|
39
|
+
args: [{ standalone: true, imports: [CommonModule], providers: [AsyncPipe], template: ` <span
|
|
40
|
+
class="cell-link"
|
|
41
|
+
(click)="onLink()"
|
|
42
|
+
>{{ label }}</span
|
|
43
|
+
>`, styles: [".cell-link{color:var(--p-primary-color);cursor:pointer}\n"] }]
|
|
44
|
+
}] });
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXN5bmMtbGluay1yZW5kZXJlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ltbS1lbGVtZW50LXVpL3NyYy9saWIvZ3JpZC9jZWxsLXJlbmRlci9hc3luYy1saW5rLXJlbmRlcmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUM1QyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFL0MsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQWtCekMsTUFBTSxPQUFPLGlCQUFpQjtJQWhCOUI7UUFtQkUsV0FBTSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztLQXlCekI7SUF0QkMsTUFBTSxDQUFDLE1BQVc7UUFDaEIsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFDckIsSUFBSSxDQUFDLFdBQVcsR0FBRyxNQUFNLENBQUMsV0FBVyxDQUFDO1FBQ3RDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVELGtCQUFrQixDQUFDLEtBQVU7UUFDM0IsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDckIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxHQUFRLEVBQUUsRUFBRTtnQkFDN0MsSUFBSSxDQUFDLEtBQUssR0FBRyxHQUFHLEVBQUUsSUFBSSxDQUFDLENBQUMsSUFBUyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxLQUFLLEtBQUssQ0FBQyxFQUFFLEtBQUssSUFBSSxFQUFFLENBQUM7WUFDM0UsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDO0lBQ0gsQ0FBQztJQUVELE1BQU07UUFDTixNQUFNLEVBQUUsR0FBRyxFQUFFLFVBQVUsRUFBRSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUM7UUFDeEMsSUFBSSxHQUFHLEVBQUUsQ0FBQztZQUNULElBQUksTUFBTSxHQUFHLE9BQU8sR0FBRyxJQUFJLFVBQVUsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztZQUNuRSxJQUFJLEtBQUssR0FBRyxPQUFPLFVBQVUsS0FBSyxVQUFVLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7WUFDakYsTUFBTSxLQUFLLEVBQUUsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxFQUFFLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7UUFDekUsQ0FBQztJQUNGLENBQUM7K0dBM0JXLGlCQUFpQjttR0FBakIsaUJBQWlCLDJEQWJqQixDQUFDLFNBQVMsQ0FBQywwQkFPWjs7OztJQUlSLGtJQVpRLFlBQVk7OzRGQWNYLGlCQUFpQjtrQkFoQjdCLFNBQVM7aUNBQ0ksSUFBSSxXQUNQLENBQUMsWUFBWSxDQUFDLGFBQ1osQ0FBQyxTQUFTLENBQUMsWUFPWjs7OztJQUlSIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXN5bmNQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgUm91dGVyIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcblxuQENvbXBvbmVudCh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICBwcm92aWRlcnM6IFtBc3luY1BpcGVdLFxuICBzdHlsZXM6IGBcblx0XHQuY2VsbC1saW5rIHtcblx0XHRcdGNvbG9yOiB2YXIoLS1wLXByaW1hcnktY29sb3IpO1xuXHRcdFx0Y3Vyc29yOiBwb2ludGVyO1xuXHRcdH1cblx0YCxcbiAgdGVtcGxhdGU6IGBcdDxzcGFuXG5cdFx0XHRjbGFzcz1cImNlbGwtbGlua1wiXG5cdFx0XHQoY2xpY2spPVwib25MaW5rKClcIlxuXHRcdFx0Pnt7IGxhYmVsIH19PC9zcGFuXG5cdFx0PmAsXG59KVxuZXhwb3J0IGNsYXNzIEFzeW5jTGlua1JlbmRlcmVyIHtcbiAgbGFiZWw6IGFueTtcbiAgcGFyYW1zITogYW55O1xuICByb3V0ZXIgPSBpbmplY3QoUm91dGVyKTtcbiAgb3B0aW9uc0hvb2s/OiAodmFsdWU6IGFueSkgPT4gT2JzZXJ2YWJsZTxhbnlbXT47XG5cbiAgYWdJbml0KHBhcmFtczogYW55KTogdm9pZCB7XG4gICAgdGhpcy5wYXJhbXMgPSBwYXJhbXM7XG4gICAgdGhpcy5vcHRpb25zSG9vayA9IHBhcmFtcy5vcHRpb25zSG9vaztcbiAgICB0aGlzLnRyaWdnZXJPcHRpb25zSG9vayhwYXJhbXMudmFsdWUpO1xuICB9XG5cbiAgdHJpZ2dlck9wdGlvbnNIb29rKHZhbHVlOiBhbnkpIHtcbiAgICBpZiAodGhpcy5vcHRpb25zSG9vaykge1xuICAgICAgdGhpcy5vcHRpb25zSG9vayh2YWx1ZSkuc3Vic2NyaWJlKChyZXM6IGFueSkgPT4ge1xuICAgICAgICB0aGlzLmxhYmVsID0gcmVzPy5maW5kKChpdGVtOiBhbnkpID0+IGl0ZW0udmFsdWUgPT09IHZhbHVlKT8ubGFiZWwgfHwgJyc7XG4gICAgICB9KTtcbiAgICB9XG4gIH1cblxuICBvbkxpbmsoKSB7XG5cdFx0Y29uc3QgeyB1cmwsIHF1ZXJ5UGFyYW0gfSA9IHRoaXMucGFyYW1zO1xuXHRcdGlmICh1cmwpIHtcblx0XHRcdGxldCB1cmxTdHIgPSB0eXBlb2YgdXJsID09ICdmdW5jdGlvbicgPyB1cmwodGhpcy5wYXJhbXMuZGF0YSkgOiAnJztcblx0XHRcdGxldCBxdWVyeSA9IHR5cGVvZiBxdWVyeVBhcmFtID09PSAnZnVuY3Rpb24nID8gcXVlcnlQYXJhbSh0aGlzLnBhcmFtcy5kYXRhKSA6IHt9O1xuXHRcdFx0dXJsU3RyICE9PSAnJyAmJiB0aGlzLnJvdXRlci5uYXZpZ2F0ZShbdXJsU3RyXSwgeyBxdWVyeVBhcmFtczogcXVlcnkgfSk7XG5cdFx0fVxuXHR9XG59XG4iXX0=
|