mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-01-20 06:29:53 +01:00
Merge branch 'develop' of github.com:ether/etherpad-lite into develop
This commit is contained in:
commit
716b1c6113
3 changed files with 292 additions and 19 deletions
|
@ -305,10 +305,12 @@ function getHTMLFromAtext(pad, atext, authorColors)
|
||||||
// want to deal gracefully with blank lines.
|
// want to deal gracefully with blank lines.
|
||||||
// => keeps track of the parents level of indentation
|
// => keeps track of the parents level of indentation
|
||||||
var lists = []; // e.g. [[1,'bullet'], [3,'bullet'], ...]
|
var lists = []; // e.g. [[1,'bullet'], [3,'bullet'], ...]
|
||||||
|
var listLevels = []
|
||||||
for (var i = 0; i < textLines.length; i++)
|
for (var i = 0; i < textLines.length; i++)
|
||||||
{
|
{
|
||||||
var line = _analyzeLine(textLines[i], attribLines[i], apool);
|
var line = _analyzeLine(textLines[i], attribLines[i], apool);
|
||||||
var lineContent = getLineHTML(line.text, line.aline);
|
var lineContent = getLineHTML(line.text, line.aline);
|
||||||
|
listLevels.push(line.listLevel)
|
||||||
|
|
||||||
if (line.listLevel)//If we are inside a list
|
if (line.listLevel)//If we are inside a list
|
||||||
{
|
{
|
||||||
|
@ -328,13 +330,27 @@ function getHTMLFromAtext(pad, atext, authorColors)
|
||||||
|
|
||||||
if (whichList >= lists.length)//means we are on a deeper level of indentation than the previous line
|
if (whichList >= lists.length)//means we are on a deeper level of indentation than the previous line
|
||||||
{
|
{
|
||||||
|
if(lists.length > 0){
|
||||||
|
pieces.push('</li>')
|
||||||
|
}
|
||||||
lists.push([line.listLevel, line.listTypeName]);
|
lists.push([line.listLevel, line.listTypeName]);
|
||||||
|
|
||||||
|
// if there is a previous list we need to open x tags, where x is the difference of the levels
|
||||||
|
// if there is no previous list we need to open x tags, where x is the wanted level
|
||||||
|
var toOpen = lists.length > 1 ? line.listLevel - lists[lists.length - 2][0] - 1 : line.listLevel - 1
|
||||||
|
|
||||||
if(line.listTypeName == "number")
|
if(line.listTypeName == "number")
|
||||||
{
|
{
|
||||||
|
if(toOpen > 0){
|
||||||
|
pieces.push(new Array(toOpen + 1).join('<ol>'))
|
||||||
|
}
|
||||||
pieces.push('<ol class="'+line.listTypeName+'"><li>', lineContent || '<br>');
|
pieces.push('<ol class="'+line.listTypeName+'"><li>', lineContent || '<br>');
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
if(toOpen > 0){
|
||||||
|
pieces.push(new Array(toOpen + 1).join('<ul>'))
|
||||||
|
}
|
||||||
pieces.push('<ul class="'+line.listTypeName+'"><li>', lineContent || '<br>');
|
pieces.push('<ul class="'+line.listTypeName+'"><li>', lineContent || '<br>');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -363,37 +379,40 @@ function getHTMLFromAtext(pad, atext, authorColors)
|
||||||
pieces.push('<br><br>');
|
pieces.push('<br><br>');
|
||||||
}
|
}
|
||||||
}*/
|
}*/
|
||||||
else//means we are getting closer to the lowest level of indentation
|
else//means we are getting closer to the lowest level of indentation or are at the same level
|
||||||
{
|
{
|
||||||
while (whichList < lists.length - 1)
|
var toClose = lists.length > 0 ? listLevels[listLevels.length - 2] - line.listLevel : 0
|
||||||
{
|
if( toClose > 0){
|
||||||
|
pieces.push('</li>')
|
||||||
if(lists[lists.length - 1][1] == "number")
|
if(lists[lists.length - 1][1] == "number")
|
||||||
{
|
{
|
||||||
pieces.push('</li></ol>');
|
pieces.push(new Array(toClose+1).join('</ol>'))
|
||||||
|
pieces.push('<li>', lineContent || '<br>');
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
pieces.push('</li></ul>');
|
pieces.push(new Array(toClose+1).join('</ul>'))
|
||||||
|
pieces.push('<li>', lineContent || '<br>');
|
||||||
}
|
}
|
||||||
lists.length--;
|
lists = lists.slice(0,whichList+1)
|
||||||
|
} else {
|
||||||
|
pieces.push('</li><li>', lineContent || '<br>');
|
||||||
}
|
}
|
||||||
pieces.push('</li><li>', lineContent || '<br>');
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else//outside any list
|
else//outside any list, need to close line.listLevel of lists
|
||||||
{
|
{
|
||||||
while (lists.length > 0)//if was in a list: close it before
|
if(lists.length > 0){
|
||||||
{
|
if(lists[lists.length - 1][1] == "number"){
|
||||||
if(lists[lists.length - 1][1] == "number")
|
|
||||||
{
|
|
||||||
pieces.push('</li></ol>');
|
pieces.push('</li></ol>');
|
||||||
}
|
pieces.push(new Array(listLevels[listLevels.length - 2]).join('</ol>'))
|
||||||
else
|
} else {
|
||||||
{
|
|
||||||
pieces.push('</li></ul>');
|
pieces.push('</li></ul>');
|
||||||
|
pieces.push(new Array(listLevels[listLevels.length - 2]).join('</ul>'))
|
||||||
}
|
}
|
||||||
lists.length--;
|
|
||||||
}
|
}
|
||||||
|
lists = []
|
||||||
|
|
||||||
var lineContentFromHook = hooks.callAllStr("getLineHTMLForExport",
|
var lineContentFromHook = hooks.callAllStr("getLineHTMLForExport",
|
||||||
{
|
{
|
||||||
line: line,
|
line: line,
|
||||||
|
|
|
@ -507,6 +507,10 @@ exports.opAssembler = function () {
|
||||||
*/
|
*/
|
||||||
exports.stringIterator = function (str) {
|
exports.stringIterator = function (str) {
|
||||||
var curIndex = 0;
|
var curIndex = 0;
|
||||||
|
var newLines = str.split("\n").length - 1
|
||||||
|
function getnewLines(){
|
||||||
|
return newLines
|
||||||
|
}
|
||||||
|
|
||||||
function assertRemaining(n) {
|
function assertRemaining(n) {
|
||||||
exports.assert(n <= remaining(), "!(", n, " <= ", remaining(), ")");
|
exports.assert(n <= remaining(), "!(", n, " <= ", remaining(), ")");
|
||||||
|
@ -515,6 +519,7 @@ exports.stringIterator = function (str) {
|
||||||
function take(n) {
|
function take(n) {
|
||||||
assertRemaining(n);
|
assertRemaining(n);
|
||||||
var s = str.substr(curIndex, n);
|
var s = str.substr(curIndex, n);
|
||||||
|
newLines -= s.split("\n").length - 1
|
||||||
curIndex += n;
|
curIndex += n;
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
@ -537,7 +542,8 @@ exports.stringIterator = function (str) {
|
||||||
take: take,
|
take: take,
|
||||||
skip: skip,
|
skip: skip,
|
||||||
remaining: remaining,
|
remaining: remaining,
|
||||||
peek: peek
|
peek: peek,
|
||||||
|
newlines: getnewLines
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -910,6 +916,8 @@ exports.applyToText = function (cs, str) {
|
||||||
var csIter = exports.opIterator(unpacked.ops);
|
var csIter = exports.opIterator(unpacked.ops);
|
||||||
var bankIter = exports.stringIterator(unpacked.charBank);
|
var bankIter = exports.stringIterator(unpacked.charBank);
|
||||||
var strIter = exports.stringIterator(str);
|
var strIter = exports.stringIterator(str);
|
||||||
|
var newlines = 0
|
||||||
|
var newlinefail = false
|
||||||
var assem = exports.stringAssembler();
|
var assem = exports.stringAssembler();
|
||||||
while (csIter.hasNext()) {
|
while (csIter.hasNext()) {
|
||||||
var op = csIter.next();
|
var op = csIter.next();
|
||||||
|
@ -919,16 +927,24 @@ exports.applyToText = function (cs, str) {
|
||||||
break;
|
break;
|
||||||
case '-':
|
case '-':
|
||||||
removedLines += op.lines;
|
removedLines += op.lines;
|
||||||
|
newlines = strIter.newlines()
|
||||||
strIter.skip(op.chars);
|
strIter.skip(op.chars);
|
||||||
|
if(!(newlines - strIter.newlines() == 0) && (newlines - strIter.newlines() != op.lines)){
|
||||||
|
newlinefail = true
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case '=':
|
case '=':
|
||||||
|
newlines = strIter.newlines()
|
||||||
assem.append(strIter.take(op.chars));
|
assem.append(strIter.take(op.chars));
|
||||||
|
if(!(newlines - strIter.newlines() == op.lines)){
|
||||||
|
newlinefail = true
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
exports.assert(totalNrOfLines >= removedLines,"cannot remove ", removedLines, " lines from text with ", totalNrOfLines, " lines");
|
exports.assert(totalNrOfLines >= removedLines,"cannot remove ", removedLines, " lines from text with ", totalNrOfLines, " lines");
|
||||||
assem.append(strIter.take(strIter.remaining()));
|
assem.append(strIter.take(strIter.remaining()));
|
||||||
return assem.toString();
|
return [assem.toString(),newlinefail];
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1599,8 +1615,12 @@ exports.makeAText = function (text, attribs) {
|
||||||
* @param pool {AttribPool} Attribute Pool to add to
|
* @param pool {AttribPool} Attribute Pool to add to
|
||||||
*/
|
*/
|
||||||
exports.applyToAText = function (cs, atext, pool) {
|
exports.applyToAText = function (cs, atext, pool) {
|
||||||
|
var text = exports.applyToText(cs, atext.text)
|
||||||
|
if(text[1]){
|
||||||
|
throw new Error()
|
||||||
|
}
|
||||||
return {
|
return {
|
||||||
text: exports.applyToText(cs, atext.text),
|
text: text[0],
|
||||||
attribs: exports.applyToAttribution(cs, atext.attribs, pool)
|
attribs: exports.applyToAttribution(cs, atext.attribs, pool)
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
234
tests/frontend/specs/importexport.js
Normal file
234
tests/frontend/specs/importexport.js
Normal file
|
@ -0,0 +1,234 @@
|
||||||
|
describe("import functionality", function(){
|
||||||
|
beforeEach(function(cb){
|
||||||
|
helper.newPad(cb); // creates a new pad
|
||||||
|
this.timeout(60000);
|
||||||
|
});
|
||||||
|
|
||||||
|
function getinnertext(){
|
||||||
|
var inner = helper.padInner$
|
||||||
|
var newtext = ""
|
||||||
|
inner("div").each(function(line,el){
|
||||||
|
newtext += el.innerHTML+"\n"
|
||||||
|
})
|
||||||
|
return newtext
|
||||||
|
}
|
||||||
|
function importrequest(data,importurl,type){
|
||||||
|
var success;
|
||||||
|
var error;
|
||||||
|
var result = $.ajax({
|
||||||
|
url: importurl,
|
||||||
|
type: "post",
|
||||||
|
processData: false,
|
||||||
|
async: false,
|
||||||
|
contentType: 'multipart/form-data; boundary=boundary',
|
||||||
|
accepts: {
|
||||||
|
text: "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8"
|
||||||
|
},
|
||||||
|
data: 'Content-Type: multipart/form-data; boundary=--boundary\r\n\r\n--boundary\r\nContent-Disposition: form-data; name="file"; filename="import.'+type+'"\r\nContent-Type: text/plain\r\n\r\n' + data + '\r\n\r\n--boundary',
|
||||||
|
error: function(res){
|
||||||
|
error = res
|
||||||
|
}
|
||||||
|
})
|
||||||
|
expect(error).to.be(undefined)
|
||||||
|
return result
|
||||||
|
}
|
||||||
|
function exportfunc(link){
|
||||||
|
var exportresults = []
|
||||||
|
$.ajaxSetup({
|
||||||
|
async:false
|
||||||
|
})
|
||||||
|
$.get(link+"/export/html",function(data){
|
||||||
|
var start = data.indexOf("<body>")
|
||||||
|
var end = data.indexOf("</body>")
|
||||||
|
var html = data.substr(start+6,end-start-6)
|
||||||
|
exportresults.push(["html",html])
|
||||||
|
})
|
||||||
|
$.get(link+"/export/txt",function(data){
|
||||||
|
exportresults.push(["txt",data])
|
||||||
|
})
|
||||||
|
return exportresults
|
||||||
|
}
|
||||||
|
|
||||||
|
it("import a pad with newlines from txt", function(done){
|
||||||
|
var importurl = helper.padChrome$.window.location.href+'/import'
|
||||||
|
var textWithNewLines = 'imported text\nnewline'
|
||||||
|
importrequest(textWithNewLines,importurl,"txt")
|
||||||
|
helper.waitFor(function(){
|
||||||
|
return expect(getinnertext()).to.be('<span class="">imported text</span>\n<span class="">newline</span>\n<br>\n')
|
||||||
|
})
|
||||||
|
var results = exportfunc(helper.padChrome$.window.location.href)
|
||||||
|
expect(results[0][1]).to.be("imported text<br>newline<br><br>")
|
||||||
|
expect(results[1][1]).to.be("imported text\nnewline\n\n")
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
it("import a pad with newlines from html", function(done){
|
||||||
|
var importurl = helper.padChrome$.window.location.href+'/import'
|
||||||
|
var htmlWithNewLines = '<html><body>htmltext<br/>newline</body></html>'
|
||||||
|
importrequest(htmlWithNewLines,importurl,"html")
|
||||||
|
helper.waitFor(function(){
|
||||||
|
return expect(getinnertext()).to.be('<span class="">htmltext</span>\n<span class="">newline</span>\n<br>\n')
|
||||||
|
})
|
||||||
|
var results = exportfunc(helper.padChrome$.window.location.href)
|
||||||
|
expect(results[0][1]).to.be("htmltext<br>newline<br><br>")
|
||||||
|
expect(results[1][1]).to.be("htmltext\nnewline\n\n")
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
it("import a pad with attributes from html", function(done){
|
||||||
|
var importurl = helper.padChrome$.window.location.href+'/import'
|
||||||
|
var htmlWithNewLines = '<html><body>htmltext<br/><span class="b s i u"><b><i><s><u>newline</u></s></i></b></body></html>'
|
||||||
|
importrequest(htmlWithNewLines,importurl,"html")
|
||||||
|
helper.waitFor(function(){
|
||||||
|
return expect(getinnertext()).to.be('<span class="">htmltext</span>\n<span class="b i s u"><b><i><s><u>newline</u></s></i></b></span>\n<br>\n')
|
||||||
|
})
|
||||||
|
var results = exportfunc(helper.padChrome$.window.location.href)
|
||||||
|
expect(results[0][1]).to.be('htmltext<br><strong><em><s><u>newline</u></s></em></strong><br><br>')
|
||||||
|
expect(results[1][1]).to.be('htmltext\nnewline\n\n')
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
it("import a pad with bullets from html", function(done){
|
||||||
|
var importurl = helper.padChrome$.window.location.href+'/import'
|
||||||
|
var htmlWithBullets = '<html><body><ul class="list-bullet1"><li>bullet line 1</li><li>bullet line 2</li><ul class="list-bullet2"><li>bullet2 line 1</li><li>bullet2 line 2</li></ul></ul></body></html>'
|
||||||
|
importrequest(htmlWithBullets,importurl,"html")
|
||||||
|
helper.waitFor(function(){
|
||||||
|
return expect(getinnertext()).to.be('\
|
||||||
|
<ul class="list-bullet1"><li><span class="">bullet line 1</span></li></ul>\n\
|
||||||
|
<ul class="list-bullet1"><li><span class="">bullet line 2</span></li></ul>\n\
|
||||||
|
<ul class="list-bullet2"><li><span class="">bullet2 line 1</span></li></ul>\n\
|
||||||
|
<ul class="list-bullet2"><li><span class="">bullet2 line 2</span></li></ul>\n\
|
||||||
|
<br>\n')
|
||||||
|
})
|
||||||
|
var results = exportfunc(helper.padChrome$.window.location.href)
|
||||||
|
expect(results[0][1]).to.be('<ul class="bullet"><li>bullet line 1</li><li>bullet line 2</li><ul class="bullet"><li>bullet2 line 1</li><li>bullet2 line 2</li></ul></ul><br>')
|
||||||
|
expect(results[1][1]).to.be('\t* bullet line 1\n\t* bullet line 2\n\t\t* bullet2 line 1\n\t\t* bullet2 line 2\n\n')
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
it("import a pad with bullets and newlines from html", function(done){
|
||||||
|
var importurl = helper.padChrome$.window.location.href+'/import'
|
||||||
|
var htmlWithBullets = '<html><body><ul class="list-bullet1"><li>bullet line 1</li></ul><br/><ul class="list-bullet1"><li>bullet line 2</li><ul class="list-bullet2"><li>bullet2 line 1</li></ul></ul><br/><ul class="list-bullet1"><ul class="list-bullet2"><li>bullet2 line 2</li></ul></ul></body></html>'
|
||||||
|
importrequest(htmlWithBullets,importurl,"html")
|
||||||
|
helper.waitFor(function(){
|
||||||
|
return expect(getinnertext()).to.be('\
|
||||||
|
<ul class="list-bullet1"><li><span class="">bullet line 1</span></li></ul>\n\
|
||||||
|
<br>\n\
|
||||||
|
<ul class="list-bullet1"><li><span class="">bullet line 2</span></li></ul>\n\
|
||||||
|
<ul class="list-bullet2"><li><span class="">bullet2 line 1</span></li></ul>\n\
|
||||||
|
<br>\n\
|
||||||
|
<ul class="list-bullet2"><li><span class="">bullet2 line 2</span></li></ul>\n\
|
||||||
|
<br>\n')
|
||||||
|
})
|
||||||
|
var results = exportfunc(helper.padChrome$.window.location.href)
|
||||||
|
expect(results[0][1]).to.be('<ul class="bullet"><li>bullet line 1</li></ul><br><ul class="bullet"><li>bullet line 2</li><ul class="bullet"><li>bullet2 line 1</li></ul></ul><br><ul><ul class="bullet"><li>bullet2 line 2</li></ul></ul><br>')
|
||||||
|
expect(results[1][1]).to.be('\t* bullet line 1\n\n\t* bullet line 2\n\t\t* bullet2 line 1\n\n\t\t* bullet2 line 2\n\n')
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
it("import a pad with bullets and newlines and attributes from html", function(done){
|
||||||
|
var importurl = helper.padChrome$.window.location.href+'/import'
|
||||||
|
var htmlWithBullets = '<html><body><ul class="list-bullet1"><li>bullet line 1</li></ul><br/><ul class="list-bullet1"><li>bullet line 2</li><ul class="list-bullet2"><li>bullet2 line 1</li></ul></ul><br/><ul class="list-bullet1"><ul class="list-bullet2"><ul class="list-bullet3"><ul class="list-bullet4"><li><span class="b s i u"><b><i><s><u>bullet4 line 2 bisu</u></s></i></b></span></li><li><span class="b s "><b><s>bullet4 line 2 bs</s></b></span></li><li><span class="u"><u>bullet4 line 2 u</u></span><span class="u i s"><i><s><u>uis</u></s></i></span></li></ul></ul></ul></ul></body></html>'
|
||||||
|
importrequest(htmlWithBullets,importurl,"html")
|
||||||
|
helper.waitFor(function(){
|
||||||
|
return expect(getinnertext()).to.be('\
|
||||||
|
<ul class="list-bullet1"><li><span class="">bullet line 1</span></li></ul>\n\<br>\n\
|
||||||
|
<ul class="list-bullet1"><li><span class="">bullet line 2</span></li></ul>\n\
|
||||||
|
<ul class="list-bullet2"><li><span class="">bullet2 line 1</span></li></ul>\n<br>\n\
|
||||||
|
<ul class="list-bullet4"><li><span class="b i s u"><b><i><s><u>bullet4 line 2 bisu</u></s></i></b></span></li></ul>\n\
|
||||||
|
<ul class="list-bullet4"><li><span class="b s"><b><s>bullet4 line 2 bs</s></b></span></li></ul>\n\
|
||||||
|
<ul class="list-bullet4"><li><span class="u"><u>bullet4 line 2 u</u></span><span class="i s u"><i><s><u>uis</u></s></i></span></li></ul>\n\
|
||||||
|
<br>\n')
|
||||||
|
})
|
||||||
|
var results = exportfunc(helper.padChrome$.window.location.href)
|
||||||
|
expect(results[0][1]).to.be('<ul class="bullet"><li>bullet line 1</li></ul><br><ul class="bullet"><li>bullet line 2</li><ul class="bullet"><li>bullet2 line 1</li></ul></ul><br><ul><ul><ul><ul class="bullet"><li><strong><em><s><u>bullet4 line 2 bisu</u></s></em></strong></li><li><strong><s>bullet4 line 2 bs</s></strong></li><li><u>bullet4 line 2 u<em><s>uis</s></em></u></li></ul></ul></ul></ul><br>')
|
||||||
|
expect(results[1][1]).to.be('\t* bullet line 1\n\n\t* bullet line 2\n\t\t* bullet2 line 1\n\n\t\t\t\t* bullet4 line 2 bisu\n\t\t\t\t* bullet4 line 2 bs\n\t\t\t\t* bullet4 line 2 uuis\n\n')
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
it("import a pad with nested bullets from html", function(done){
|
||||||
|
var importurl = helper.padChrome$.window.location.href+'/import'
|
||||||
|
var htmlWithBullets = '<html><body><ul class="list-bullet1"><li>bullet line 1</li></ul><ul class="list-bullet1"><li>bullet line 2</li><ul class="list-bullet2"><li>bullet2 line 1</li></ul></ul><ul class="list-bullet1"><ul class="list-bullet2"><ul class="list-bullet3"><ul class="list-bullet4"><li>bullet4 line 2</li><li>bullet4 line 2</li><li>bullet4 line 2</li></ul><li>bullet3 line 1</li></ul></ul><li>bullet2 line 1</li></ul></body></html>'
|
||||||
|
importrequest(htmlWithBullets,importurl,"html")
|
||||||
|
var oldtext=getinnertext()
|
||||||
|
helper.waitFor(function(){
|
||||||
|
return oldtext != getinnertext()
|
||||||
|
// return expect(getinnertext()).to.be('\
|
||||||
|
//<ul class="list-bullet1"><li><span class="">bullet line 1</span></li></ul>\n\
|
||||||
|
//<ul class="list-bullet1"><li><span class="">bullet line 2</span></li></ul>\n\
|
||||||
|
//<ul class="list-bullet2"><li><span class="">bullet2 line 1</span></li></ul>\n\
|
||||||
|
//<ul class="list-bullet4"><li><span class="">bullet4 line 2</span></li></ul>\n\
|
||||||
|
//<ul class="list-bullet4"><li><span class="">bullet4 line 2</span></li></ul>\n\
|
||||||
|
//<ul class="list-bullet4"><li><span class="">bullet4 line 2</span></li></ul>\n\
|
||||||
|
//<br>\n')
|
||||||
|
})
|
||||||
|
|
||||||
|
var results = exportfunc(helper.padChrome$.window.location.href)
|
||||||
|
expect(results[0][1]).to.be('<ul class="bullet"><li>bullet line 1</li><li>bullet line 2</li><ul class="bullet"><li>bullet2 line 1</li><ul><ul class="bullet"><li>bullet4 line 2</li><li>bullet4 line 2</li><li>bullet4 line 2</li></ul><li>bullet3 line 1</li></ul></ul><li>bullet2 line 1</li></ul><br>')
|
||||||
|
expect(results[1][1]).to.be('\t* bullet line 1\n\t* bullet line 2\n\t\t* bullet2 line 1\n\t\t\t\t* bullet4 line 2\n\t\t\t\t* bullet4 line 2\n\t\t\t\t* bullet4 line 2\n\t\t\t* bullet3 line 1\n\t* bullet2 line 1\n\n')
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
it("import a pad with 8 levels of bullets and newlines and attributes from html", function(done){
|
||||||
|
var importurl = helper.padChrome$.window.location.href+'/import'
|
||||||
|
var htmlWithBullets = '<html><body><ul class="list-bullet1"><li>bullet line 1</li></ul><br/><ul class="list-bullet1"><li>bullet line 2</li><ul class="list-bullet2"><li>bullet2 line 1</li></ul></ul><br/><ul class="list-bullet1"><ul class="list-bullet2"><ul class="list-bullet3"><ul class="list-bullet4"><li><span class="b s i u"><b><i><s><u>bullet4 line 2 bisu</u></s></i></b></span></li><li><span class="b s "><b><s>bullet4 line 2 bs</s></b></span></li><li><span class="u"><u>bullet4 line 2 u</u></span><span class="u i s"><i><s><u>uis</u></s></i></span></li><ul class="list-bullet5"><ul class="list-bullet6"><ul class="list-bullet7"><ul class="list-bullet8"><li><span class="">foo</span></li><li><span class="b s"><b><s>foobar bs</b></s></span></li></ul></ul></ul></ul><ul class="list-bullet5"><li>foobar</li></ul></ul></ul></ul></body></html>'
|
||||||
|
importrequest(htmlWithBullets,importurl,"html")
|
||||||
|
helper.waitFor(function(){
|
||||||
|
return expect(getinnertext()).to.be('\
|
||||||
|
<ul class="list-bullet1"><li><span class="">bullet line 1</span></li></ul>\n\<br>\n\
|
||||||
|
<ul class="list-bullet1"><li><span class="">bullet line 2</span></li></ul>\n\
|
||||||
|
<ul class="list-bullet2"><li><span class="">bullet2 line 1</span></li></ul>\n<br>\n\
|
||||||
|
<ul class="list-bullet4"><li><span class="b i s u"><b><i><s><u>bullet4 line 2 bisu</u></s></i></b></span></li></ul>\n\
|
||||||
|
<ul class="list-bullet4"><li><span class="b s"><b><s>bullet4 line 2 bs</s></b></span></li></ul>\n\
|
||||||
|
<ul class="list-bullet4"><li><span class="u"><u>bullet4 line 2 u</u></span><span class="i s u"><i><s><u>uis</u></s></i></span></li></ul>\n\
|
||||||
|
<ul class="list-bullet8"><li><span class="">foo</span></li></ul>\n\
|
||||||
|
<ul class="list-bullet8"><li><span class="b s"><b><s>foobar bs</s></b></span></li></ul>\n\
|
||||||
|
<ul class="list-bullet5"><li><span class="">foobar</span></li></ul>\n\
|
||||||
|
<br>\n')
|
||||||
|
})
|
||||||
|
var results = exportfunc(helper.padChrome$.window.location.href)
|
||||||
|
expect(results[0][1]).to.be('<ul class="bullet"><li>bullet line 1</li></ul><br><ul class="bullet"><li>bullet line 2</li><ul class="bullet"><li>bullet2 line 1</li></ul></ul><br><ul><ul><ul><ul class="bullet"><li><strong><em><s><u>bullet4 line 2 bisu</u></s></em></strong></li><li><strong><s>bullet4 line 2 bs</s></strong></li><li><u>bullet4 line 2 u<em><s>uis</s></em></u></li><ul><ul><ul><ul class="bullet"><li>foo</li><li><strong><s>foobar bs</s></strong></li></ul></ul></ul><li>foobar</li></ul></ul></ul></ul></ul><br>')
|
||||||
|
expect(results[1][1]).to.be('\t* bullet line 1\n\n\t* bullet line 2\n\t\t* bullet2 line 1\n\n\t\t\t\t* bullet4 line 2 bisu\n\t\t\t\t* bullet4 line 2 bs\n\t\t\t\t* bullet4 line 2 uuis\n\t\t\t\t\t\t\t\t* foo\n\t\t\t\t\t\t\t\t* foobar bs\n\t\t\t\t\t* foobar\n\n')
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
|
||||||
|
xit("import a pad with ordered lists from html", function(done){
|
||||||
|
var importurl = helper.padChrome$.window.location.href+'/import'
|
||||||
|
var htmlWithBullets = '<html><body><ol class="list-number1" start="1"><li>number 1 line 1</li></ol><ol class="list-number1" start="2"><li>number 2 line 2</li></ol></body></html>'
|
||||||
|
importrequest(htmlWithBullets,importurl,"html")
|
||||||
|
-console.error(getinnertext())
|
||||||
|
expect(getinnertext()).to.be('\
|
||||||
|
<ol class="list-number1" start="1"><li><span class="">number 1 line 1</span></li></ol>\n\
|
||||||
|
<ol class="list-number1" start="2"><li><span class="">number 2 line 2</span></li></ol>\n\
|
||||||
|
<br>\n')
|
||||||
|
var results = exportfunc(helper.padChrome$.window.location.href)
|
||||||
|
expect(results[0][1]).to.be('<ol class="list-number1" start="1"><li>number 1 line 1</li></ol><ol class="list-number1" start="2"><li>number 2 line 2</li></ol>')
|
||||||
|
expect(results[1][1]).to.be('')
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
xit("import a pad with ordered lists and newlines from html", function(done){
|
||||||
|
var importurl = helper.padChrome$.window.location.href+'/import'
|
||||||
|
var htmlWithBullets = '<html><body><ol class="list-number1" start="1"><li>number 9 line 1</li></ol><br/><ol class="list-number1" start="2"><li>number 10 line 2</li><ol class="list-number2"><li>number 2 times line 1</li></ol></ol><br/><ol class="list-bullet1"><ol class="list-number2"><li>number 2 times line 2</li></ol></ol></body></html>'
|
||||||
|
importrequest(htmlWithBullets,importurl,"html")
|
||||||
|
expect(getinnertext()).to.be('\
|
||||||
|
<ol class="list-number1" start="1"><li><span class="">number 9 line 1</span></li></ol>\n\
|
||||||
|
<br>\n\
|
||||||
|
<ol class="list-number1" start="2"><li><span class="">number 10 line 2</span></li></ol>\n\
|
||||||
|
<ol class="list-number2"><li><span class="">number 2 times line 1</span></li></ol>\n\
|
||||||
|
<br>\n\
|
||||||
|
<ol class="list-number2"><li><span class="">number 2 times line 2</span></li></ol>\n\
|
||||||
|
<br>\n')
|
||||||
|
var results = exportfunc(helper.padChrome$.window.location.href)
|
||||||
|
console.error(results)
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
xit("import a pad with nested ordered lists and attributes and newlines from html", function(done){
|
||||||
|
var importurl = helper.padChrome$.window.location.href+'/import'
|
||||||
|
var htmlWithBullets = '<html><body><ol class="list-number1" start="1"><li><span class="b s i u"><b><i><s><u>bold strikethrough italics underline</u></s><i/></b></span> line <span class="b"><b>1bold</b></span></li></ol><br/><span class="i"><i><ol class="list-number1" start="2"><li>number 10 line 2</li><ol class="list-number2"><li>number 2 times line 1</li></ol></ol></i></span><br/><ol class="list-bullet1"><ol class="list-number2"><li>number 2 times line 2</li></ol></ol></body></html>'
|
||||||
|
importrequest(htmlWithBullets,importurl,"html")
|
||||||
|
expect(getinnertext()).to.be('\
|
||||||
|
<ol class="list-number1"><li><span class="b i s u"><b><i><s><u>bold strikethrough italics underline</u></s></i></b></span><span class=""> line </span><span class="b"><b>1bold</b></span></li></ol>\n\
|
||||||
|
<br>\n\
|
||||||
|
<ol class="list-number1"><li><span class="i"><i>number 10 line 2</i></span></li></ol>\n\
|
||||||
|
<ol class="list-number2"><li><span class="i"><i>number 2 times line 1</i></span></li></ol>\n\
|
||||||
|
<br>\n\
|
||||||
|
<ol class="list-number2"><li><span class="">number 2 times line 2</span></li></ol>\n\
|
||||||
|
<br>\n')
|
||||||
|
var results = exportfunc(helper.padChrome$.window.location.href)
|
||||||
|
console.error(results)
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
Loading…
Reference in a new issue