From 83916750a064bceb17274b5001d813d21a7097fb Mon Sep 17 00:00:00 2001 From: Luka Trovic Date: Mon, 25 Nov 2024 19:32:24 +0100 Subject: [PATCH] feat: render text inserted from assistant Signed-off-by: Luka Trovic --- src/components/Assistant.vue | 7 ++++- .../Suggestion/LinkPicker/suggestions.js | 27 ++----------------- src/markdownit/hasMarkdownSyntax.js | 25 +++++++++++++++++ src/markdownit/isValidMarkdown.js | 19 +++++++++++++ 4 files changed, 52 insertions(+), 26 deletions(-) create mode 100644 src/markdownit/hasMarkdownSyntax.js create mode 100644 src/markdownit/isValidMarkdown.js diff --git a/src/components/Assistant.vue b/src/components/Assistant.vue index 1b09040693c..072d2418ed0 100644 --- a/src/components/Assistant.vue +++ b/src/components/Assistant.vue @@ -133,6 +133,9 @@ import { } from './Editor.provider.js' import { FloatingMenu } from '@tiptap/vue-2' import { emit, subscribe, unsubscribe } from '@nextcloud/event-bus' +import hasMarkdownSyntax from '../markdownit/hasMarkdownSyntax.js' +import isValidMarkdown from '../markdownit/isValidMarkdown.js' +import markdownit from '../markdownit/index.js' const limitInRange = (num, min, max) => { return Math.min(Math.max(parseInt(num), parseInt(min)), parseInt(max)) @@ -302,7 +305,9 @@ export default { }) }, async insertResult(task) { - this.$editor.commands.insertContent(task.output.output) + const isMarkdown = hasMarkdownSyntax(task.output.output) && isValidMarkdown(task.output.output) + const content = isMarkdown ? markdownit.render(task.output.output) : task.output.output + this.$editor.commands.insertContent(content) this.showTaskList = false }, async copyResult(task) { diff --git a/src/components/Suggestion/LinkPicker/suggestions.js b/src/components/Suggestion/LinkPicker/suggestions.js index 06e2ff16672..16feb78bd0f 100644 --- a/src/components/Suggestion/LinkPicker/suggestions.js +++ b/src/components/Suggestion/LinkPicker/suggestions.js @@ -9,6 +9,8 @@ import { searchProvider, getLinkWithPicker } from '@nextcloud/vue/dist/Component import menuEntries from './../../Menu/entries.js' import { getIsActive } from '../../Menu/utils.js' import markdownit from '../../../markdownit/index.js' +import hasMarkdownSyntax from '../../../markdownit/hasMarkdownSyntax.js' +import isValidMarkdown from '../../../markdownit/isValidMarkdown.js' const suggestGroupFormat = t('text', 'Formatting') const suggestGroupPicker = t('text', 'Smart picker') @@ -19,31 +21,6 @@ const filterOut = (e) => { const important = ['task-list', 'table'] -const hasMarkdownSyntax = (content) => { - // Regular expressions for common Markdown patterns - const markdownPatterns = [ - /\*\*.*?\*\*/, // Bold: **text** - /\*.*?\*/, // Italics: *text* - /\[.*?\(.*?\)/, // Links: [text](url) - /^#{1,6}\s.*$/, // Headings: # text - /^\s*[-+*]\s.*/m, // Unordered list: - item - /^\s\d\..*/m, // Ordered list: 1. item - /^>+\s.*/, // Blockquote: > text - /`.*?`/, // Code: `code` - ] - - return markdownPatterns.some(pattern => pattern.test(content)) -} - -const isValidMarkdown = (content) => { - try { - markdownit.parse(content) - return true - } catch (e) { - return false - } -} - const isValidUrl = (url) => { try { return Boolean(new URL(url)) diff --git a/src/markdownit/hasMarkdownSyntax.js b/src/markdownit/hasMarkdownSyntax.js new file mode 100644 index 00000000000..61e59ea62ab --- /dev/null +++ b/src/markdownit/hasMarkdownSyntax.js @@ -0,0 +1,25 @@ +/** + * SPDX-FileCopyrightText: 2022 Nextcloud GmbH and Nextcloud contributors + * SPDX-License-Identifier: AGPL-3.0-or-later + */ + +/** + * Check if the content has Markdown syntax + * + * @param {string} content Markdown object + */ +export default function hasMarkdownSyntax(content) { + // Regular expressions for common Markdown patterns + const markdownPatterns = [ + /\*\*.*?\*\*/, // Bold: **text** + /\*.*?\*/, // Italics: *text* + /\[.*?\(.*?\)/, // Links: [text](url) + /^#{1,6}\s.*$/, // Headings: # text + /^\s*[-+*]\s.*/m, // Unordered list: - item + /^\s\d\..*/m, // Ordered list: 1. item + /^>+\s.*/, // Blockquote: > text + /`.*?`/, // Code: `code` + ] + + return markdownPatterns.some(pattern => pattern.test(content)) +} diff --git a/src/markdownit/isValidMarkdown.js b/src/markdownit/isValidMarkdown.js new file mode 100644 index 00000000000..c722b7d5e26 --- /dev/null +++ b/src/markdownit/isValidMarkdown.js @@ -0,0 +1,19 @@ +/** + * SPDX-FileCopyrightText: 2022 Nextcloud GmbH and Nextcloud contributors + * SPDX-License-Identifier: AGPL-3.0-or-later + */ +import markdownit from './index.js' + +/** + * Check if the content is valid Markdown syntax + * + * @param {string} content Markdown object + */ +export default function isValidMarkdown(content) { + try { + markdownit.parse(content) + return true + } catch (e) { + return false + } +}