Инструмент сравнения текстов на ExtJS

MergeTool — это инструмент-виджет, написанный на ExtJS, для визуального отображения различий между двумя текстами. Функции этого инструмента позволяют осуществлять навигацию по различиям в тексте, переход на определенную строку текста, показывать/скрывать нумерацию строку, скрывать идентичные отрезки текстов, искать определенные слова в текстах.

Для использования виджета требуется ExtJS версии 5 или 6. В качестве основы этого виджета был использован фреймворк CodeMirror (его измененный код присутствует в исходниках к этому инструменту).

Пример простого использования виджета:

Ext.onReady(function() {
    // init texts variable
    var textLeft,
        textRight,
        UniText1 = "Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.\nUt wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi.\n\n\n",
        UniText2 = "Sed ut perspiciatis, unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam eaque ipsa, quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt, explicabo.\nnemo enim ipsam voluptatem, quia voluptas sit, aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos, qui ratione voluptatem sequi nesciunt, neque porro quisquam est, qui dolorem ipsum, quia dolor sit, amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt, ut labore et dolore magnam aliquam quaerat voluptatem. ut enim ad minima veniam, quis nostrum exercitationem ullam corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? quis autem vel eum iure reprehenderit, qui in ea voluptate velit esse, quam nihil molestiae consequatur, vel illum, qui dolorem eum fugiat, quo voluptas nulla pariatur?\n\n\n",
        repeat = 5;

    textLeft = Ext.String.trim( Ext.String.repeat(UniText1, repeat) + Ext.String.repeat(UniText1, repeat - 1) );
    textRight = Ext.String.trim( UniText2 + Ext.String.repeat(UniText1, repeat - 2) + UniText2 + Ext.String.repeat(UniText1, repeat - 3) + UniText2);

    Ext.create('Ext.container.Viewport',{
        layout: 'fit',
        items: [
            {
                xtype: 'mergetoolpanel',
                title: 'MergeTool - Simple Example',
                border: 1,
                lineNumbers: true,
                lineWrapping: true,
                textLeft: textLeft,
                textRight: textRight,
            }
        ]
    });
});
<!-- ExtJS source -->
<link rel="stylesheet" type="text/css" href="../libs/extjs/css/theme-classic-all-debug.css">
<script type="text/javascript" src="../libs/extjs/ext-all.js"></script>

<!-- CodeMirror source -->
<script type="text/javascript" src="../src/codemirror/codemirror-merge-tool.min.js"></script>
<link rel=stylesheet href="../src/codemirror/codemirror-merge-tool.css" />

<!-- MergeTool source -->
<script type="text/javascript" src="../src/MergeTool.js"></script>
<!-- MergeTool localization -->
<script type="text/javascript" src="../src/l10n/ru.js"></script>

Также инструмент сравнения текстов, позволяет динамически устанавливать текст в правую и левую панель, использую следующие методы:

setLeftText( text ) — установка текста в левую панель. text: String — текст, который будет помещен в левую панель.
setRightText( text ) — установка текста в правую панель. text: String — текст, который будет помещен в правую панель.
setTexts( leftText, rightText ) — установка текстов в левую и правую панели. leftText: String — текст, который будет помещен в левую панель; rightText: String — текст, который будет помещен в правую панель.

 

Пример использования динамической установки текстов в панели:

Ext.onReady(function() {
    // init texts variable
    var textLeft,
        textRight,
        UniText1 = "Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.\nUt wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi.\n\n\n",
        UniText2 = "Sed ut perspiciatis, unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam eaque ipsa, quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt, explicabo.\nnemo enim ipsam voluptatem, quia voluptas sit, aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos, qui ratione voluptatem sequi nesciunt, neque porro quisquam est, qui dolorem ipsum, quia dolor sit, amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt, ut labore et dolore magnam aliquam quaerat voluptatem. ut enim ad minima veniam, quis nostrum exercitationem ullam corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? quis autem vel eum iure reprehenderit, qui in ea voluptate velit esse, quam nihil molestiae consequatur, vel illum, qui dolorem eum fugiat, quo voluptas nulla pariatur?\n\n\n",
        repeat = 5;

    textLeft = Ext.String.trim( Ext.String.repeat(UniText1, repeat) + Ext.String.repeat(UniText1, repeat - 1) );
    textRight = Ext.String.trim( UniText2 + Ext.String.repeat(UniText1, repeat - 2) + UniText2 + Ext.String.repeat(UniText1, repeat - 2) + UniText2);

    Ext.create('Ext.container.Viewport',{
        layout: 'fit',
        items: [
            {
                xtype: 'mergetoolpanel',
                title: 'MergeTool - Set Texts Into Panels',
                border: 1,
                lineNumbers: false,
                collapseIdentical: true,
                textLeft: textLeft,
                textRight: textRight,
                dockedItems: [
                    {
                        xtype: 'toolbar',
                        dock: 'left',
                        items: [
                            {
                                text: 'Поменять текст слева',
                                listeners: {
                                    click: function( button ) {
                                        var mergeToolPanel = button.up('mergetoolpanel');
                                        mergeToolPanel.setLeftText( textRight );
                                    }
                                }
                            },
                            '-',
                            {
                                text: 'Поменять текст справа',
                                listeners: {
                                    click: function( button ) {
                                        var mergeToolPanel = button.up('mergetoolpanel');
                                        mergeToolPanel.setRightText( textLeft );
                                    }
                                }
                            },
                            '-',
                            {
                                text: 'Установить тексты с одним различием',
                                listeners: {
                                    click: function( button ) {
                                        var mergeToolPanel = button.up('mergetoolpanel'),
                                            textLeft = UniText1 + UniText1,
                                            textRight = UniText1 + UniText2;
                                        mergeToolPanel.setTexts( textLeft, textRight );
                                    }
                                }
                            },
                            '-',
                            {
                                text: 'Установить идентичные тексты',
                                listeners: {
                                    click: function( button ) {
                                        var mergeToolPanel = button.up('mergetoolpanel'),
                                            text = UniText1 + UniText2 + UniText1;
                                        mergeToolPanel.setTexts( text, text );
                                    }
                                }
                            },
                            '-'
                        ]
                    }
                ]
            }
        ]
    });

});

Виджет можно локализовать под другие языки или изменить подписи кнопок, не изменяя исходный код. Файл локализации необзодимо подключать после подключения файла инструмента сравнения текстов. Пример файла локализации:

Ext.define("Ext.locale.ru.ux.MergeTool", {
    override: "Ext.ux.MergeTool",

    prevDiffText: 'Предыдущее различие',
    nextDiffText: 'Следующее различие',
    goToDiffText: 'Перейти на различие',
    noDiffsText: 'Нет различий',
    goToLineText: 'Перейти на линию',
    optionsText: 'Настройка',
    lineNumbersText: 'Нумерация линий',
    lineWrapText: 'Перенос строк',
    collapseIdenticalText: 'Сокращение идентичного текста',
    findText: 'Найти',
    leftText: 'Слева',
    rightText: 'Справа',
    lineNumberWindowText: 'Номер линии',

});

Исходный код виджета доступен для скачивания на github: https://github.com/mrfratello/ExtJS-Merge-Tool

Добавить комментарий

Ваш e-mail не будет опубликован. Обязательные поля помечены *