const HtmlDiffer = require('@markedjs/html-differ').HtmlDiffer;
const htmlDiffer = new HtmlDiffer({ignoreSelfClosingSlash: true});
module.exports = {
  isEqual: htmlDiffer.isEqual.bind(htmlDiffer),
  firstDiff: (actual, expected, padding) => {
    padding = padding || 30;
    const result = htmlDiffer
      .diffHtml(actual, expected)
      .reduce((obj, diff) => {
        if (diff.added) {
          if (obj.firstIndex === null) {
            obj.firstIndex = obj.expected.length;
          }
          obj.expected += diff.value;
        } else if (diff.removed) {
          if (obj.firstIndex === null) {
            obj.firstIndex = obj.actual.length;
          }
          obj.actual += diff.value;
        } else {
          obj.actual += diff.value;
          obj.expected += diff.value;
        }
        return obj;
      }, {
        firstIndex: null,
        actual: '',
        expected: ''
      });
    return {
      actual: result.actual.substring(result.firstIndex - padding, result.firstIndex + padding),
      expected: result.expected.substring(result.firstIndex - padding, result.firstIndex + padding)
    };
  }
};