mirror of
https://github.com/hcengineering/platform.git
synced 2025-04-14 04:08:19 +00:00
EZQMS-398: Add StringDiffViewer (#4085)
Signed-off-by: Anna No <anna.no@xored.com>
This commit is contained in:
parent
13cdaa7f66
commit
72bb3c9c60
36
packages/text-editor/src/components/StringDiffViewer.svelte
Normal file
36
packages/text-editor/src/components/StringDiffViewer.svelte
Normal file
@ -0,0 +1,36 @@
|
||||
<!--
|
||||
//
|
||||
// Copyright © 2022, 2023 Hardcore Engineering Inc.
|
||||
//
|
||||
// Licensed under the Eclipse Public License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License. You may
|
||||
// obtain a copy of the License at https://www.eclipse.org/legal/epl-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
//
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
//
|
||||
-->
|
||||
<script lang="ts">
|
||||
import * as Diff from 'diff'
|
||||
|
||||
export let value: string
|
||||
export let compareTo: string
|
||||
export let method: 'diffChars' | 'diffWords' | 'diffWordsWithSpace' = 'diffChars'
|
||||
|
||||
const handleDiff = (oldValue: string, newValue: string) => Diff[method](oldValue, newValue)
|
||||
|
||||
$: changes = handleDiff(value, compareTo)
|
||||
</script>
|
||||
|
||||
{#each changes as change}
|
||||
<span
|
||||
class:text-editor-highlighted-node-add={change.added}
|
||||
class:text-editor-highlighted-node-delete={change.removed}
|
||||
>
|
||||
{change.value}
|
||||
</span>
|
||||
{/each}
|
@ -23,6 +23,7 @@ export { default as CollaboratorEditor } from './components/CollaboratorEditor.s
|
||||
export { default as FullDescriptionBox } from './components/FullDescriptionBox.svelte'
|
||||
export { default as MarkupDiffViewer } from './components/MarkupDiffViewer.svelte'
|
||||
export { default as ReferenceInput } from './components/ReferenceInput.svelte'
|
||||
export { default as StringDiffViewer } from './components/StringDiffViewer.svelte'
|
||||
export { default as StyleButton } from './components/StyleButton.svelte'
|
||||
export { default as StyledTextArea } from './components/StyledTextArea.svelte'
|
||||
export { default as StyledTextBox } from './components/StyledTextBox.svelte'
|
||||
|
Loading…
Reference in New Issue
Block a user