Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
erp5
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
alecs_myu
erp5
Commits
e5e277e2
Commit
e5e277e2
authored
Feb 07, 2012
by
Rafael Monnerat
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Unify Javascript for Book/Chapter Render
parent
06f75d6e
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
353 additions
and
293 deletions
+353
-293
bt5/erp5_run_my_doc/SkinTemplateItem/portal_skins/erp5_run_my_doc/WebPage_viewAsBook.xml
...eItem/portal_skins/erp5_run_my_doc/WebPage_viewAsBook.xml
+1
-2
bt5/erp5_run_my_doc/SkinTemplateItem/portal_skins/erp5_run_my_doc/WebPage_viewAsChapter.xml
...em/portal_skins/erp5_run_my_doc/WebPage_viewAsChapter.xml
+2
-2
bt5/erp5_run_my_doc/SkinTemplateItem/portal_skins/erp5_run_my_doc/chapter_converter.js.xml
...tem/portal_skins/erp5_run_my_doc/chapter_converter.js.xml
+0
-288
bt5/erp5_run_my_doc/SkinTemplateItem/portal_skins/erp5_run_my_doc/html5_book.js.xml
...mplateItem/portal_skins/erp5_run_my_doc/html5_book.js.xml
+349
-0
bt5/erp5_run_my_doc/bt/revision
bt5/erp5_run_my_doc/bt/revision
+1
-1
No files found.
bt5/erp5_run_my_doc/SkinTemplateItem/portal_skins/erp5_run_my_doc/WebPage_viewAsBook.xml
View file @
e5e277e2
...
@@ -45,8 +45,7 @@
...
@@ -45,8 +45,7 @@
<link
rel=
"stylesheet"
type=
"text/css"
tal:attributes=
"href string:${portal_url}/boom.css"
>
\n
<link
rel=
"stylesheet"
type=
"text/css"
tal:attributes=
"href string:${portal_url}/boom.css"
>
\n
<script
type=
"text/javascript"
tal:attributes=
"src string:${portal_url}/jquery/core/jquery.js"
></script>
\n
<script
type=
"text/javascript"
tal:attributes=
"src string:${portal_url}/jquery/core/jquery.js"
></script>
\n
<script
type=
"text/javascript"
tal:attributes=
"src string:${portal_url}/jquery/ui/js/jquery-ui.js"
></script>
\n
<script
type=
"text/javascript"
tal:attributes=
"src string:${portal_url}/jquery/ui/js/jquery-ui.js"
></script>
\n
<script
type=
"text/javascript"
tal:attributes=
"src string:${portal_url}/book_converter.js"
></script>
\n
<script
type=
"text/javascript"
tal:attributes=
"src string:${portal_url}/html5_book.js"
></script>
\n
<script
type=
"text/javascript"
tal:attributes=
"src string:${portal_url}/chapter_converter.js"
></script>
\n
</tal:block>
\n
</tal:block>
\n
<script
type=
"text/javascript"
>
\n
<script
type=
"text/javascript"
>
\n
$(document).ready(function(){\n
$(document).ready(function(){\n
...
...
bt5/erp5_run_my_doc/SkinTemplateItem/portal_skins/erp5_run_my_doc/WebPage_viewAsChapter.xml
View file @
e5e277e2
...
@@ -39,13 +39,13 @@
...
@@ -39,13 +39,13 @@
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
\n
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
\n
<html
xmlns=
"http://www.w3.org/1999/xhtml"
>
\n
<html
xmlns=
"http://www.w3.org/1999/xhtml"
>
\n
<head>
\n
<head>
\n
<meta
http-equiv=
"Content-Type"
content=
"text/html; charset=utf-8"
/>
\n
<meta
http-equiv=
"Content-Type"
content=
"text/html; charset=utf-8"
/>
\n
<tal:block
tal:define=
"site_root python: here.getWebSiteValue() or here.getPortalObject();\n
<tal:block
tal:define=
"site_root python: here.getWebSiteValue() or here.getPortalObject();\n
portal_url python: site_root.absolute_url();"
>
\n
portal_url python: site_root.absolute_url();"
>
\n
<link
rel=
"stylesheet"
type=
"text/css"
tal:attributes=
"href string:${portal_url}/boom.css"
>
\n
<link
rel=
"stylesheet"
type=
"text/css"
tal:attributes=
"href string:${portal_url}/boom.css"
>
\n
<script
type=
"text/javascript"
tal:attributes=
"src string:${portal_url}/jquery/core/jquery.js"
></script>
\n
<script
type=
"text/javascript"
tal:attributes=
"src string:${portal_url}/jquery/core/jquery.js"
></script>
\n
<script
type=
"text/javascript"
tal:attributes=
"src string:${portal_url}/jquery/ui/js/jquery-ui.js"
></script>
\n
<script
type=
"text/javascript"
tal:attributes=
"src string:${portal_url}/jquery/ui/js/jquery-ui.js"
></script>
\n
<script
type=
"text/javascript"
tal:attributes=
"src string:${portal_url}/
chapter_converter
.js"
></script>
\n
<script
type=
"text/javascript"
tal:attributes=
"src string:${portal_url}/
html5_book
.js"
></script>
\n
</tal:block>
\n
</tal:block>
\n
<script
type=
"text/javascript"
>
\n
<script
type=
"text/javascript"
>
\n
$(document).ready(function(){\n
$(document).ready(function(){\n
...
...
bt5/erp5_run_my_doc/SkinTemplateItem/portal_skins/erp5_run_my_doc/chapter_converter.js.xml
deleted
100644 → 0
View file @
06f75d6e
<?xml version="1.0"?>
<ZopeData>
<record
id=
"1"
aka=
"AAAAAAAAAAE="
>
<pickle>
<global
name=
"DTMLDocument"
module=
"OFS.DTMLDocument"
/>
</pickle>
<pickle>
<dictionary>
<item>
<key>
<string>
_Cacheable__manager_id
</string>
</key>
<value>
<string>
http_cache
</string>
</value>
</item>
<item>
<key>
<string>
__name__
</string>
</key>
<value>
<string>
chapter_converter.js
</string>
</value>
</item>
<item>
<key>
<string>
_vars
</string>
</key>
<value>
<dictionary/>
</value>
</item>
<item>
<key>
<string>
globals
</string>
</key>
<value>
<dictionary/>
</value>
</item>
<item>
<key>
<string>
raw
</string>
</key>
<value>
<string
encoding=
"cdata"
>
<![CDATA[
/*\n
Copyright (c) 2011 Nexedi SARL and Contributors. All Rights Reserved.\n
\n
This program is Free Software; you can redistribute it and/or\n
modify it under the terms of the GNU General Public License\n
as published by the Free Software Foundation; either version 2\n
of the License, or (at your option) any later version.\n
\n
This program is distributed in the hope that it will be useful,\n
but WITHOUT ANY WARRANTY; without even the implied warranty of\n
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n
GNU General Public License for more details.\n
\n
You should have received a copy of the GNU General Public License\n
along with this program; if not, write to the Free Software\n
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n
*/\n
var textContent, testPageHTML, body;\n
function cleanForPrince(){\n
var temp = $(\'iframe\', parent.document).contents().children().clone();\n
$(\'script\', temp).remove();\n
$(\'style, meta:not([name=author])\', temp).remove();\n
$(\'head\', temp).prepend($(\'<meta>
\').attr(\'http-equiv\',\'content-type\').attr(\'content\', \'text/html; charset=utf-8\'));\n
var images = $(\'img\', temp);\n
n = images.length;\n
for(var i = 0; i
< n
;
i++){\n
var
img =
images.eq(i);\n
var
src =
img.attr(\'src\').split(\'?format\')[0].split(\'/\');\n
var
extension =
img.attr(\'type\');\n
if(
extension =
=
undefined)\n
extension =
"png"
;\n
else\n
extension =
extension.split(\'/\')[1].split(\'+\')[0];\n
img.attr(\'src\',src[src.length
-
1]
+
\'.\'
+
extension);\n
}\n
var
text =
temp.html();\n
var
result =
""
,
tagName =
""
,
c =
""
,
chr =
""
;\n
var
n =
text.length;\n
if
(
text =
=
null)
{\n
return
false;\n
}\n
var
tag =
false,
tagNameParsing =
false;\n
for(var
i =
0;
i
<
n;
i++){\n
chr =
text[i];\n
c =
chr.toLowerCase();\n
if(
c =
=
\'<\'
&&
tag =
=
false){\n
tag =
true;\n
tagNameParsing =
true;\n
}\n
else
if(tag){\n
if(
c =
=
\'
\')\n
tagNameParsing =
false;\n
else
if(
c =
=
\'
>
\'){\n
tagNameParsing = false;\n
tag = false;\n
if(tagName == \'img\')\n
result += \'/\';\n
tagName = \'\';\n
}\n
else if(tagNameParsing){\n
if(c == \'i\'
&&
tagName == \'\')\n
tagName += c;\n
else if(c == \'m\'
&&
tagName == \'i\')\n
tagName += c;\n
else if(c == \'g\'
&&
tagName == \'im\')\n
tagName += c;\n
}\n
}\n
result += chr;\n
}\n
$(\'textarea[name=field_book_text_content]\', parent.document).val(\'
<html>
\\n\' + result + \'\\n
</html>
\');\n
return false;\n
}\n
\n
function changeTag(element, tag){\n
var tag = $(\'
<
\' + tag + \'>\').html(element.html());\n
element.after(tag);\n
element.remove();\n
return tag;\n
}\n
\n
function parseList(text){\n
return text.replace("[","").replace("]","").replace(/\'/g,"").replace(/,/g,", ");\n
}\n
\n
function generateTblContent(title, id, className){\n
return $(\'
<li>
\').addClass(className).append($(\'
<a>
\').attr(\'href\',\'#\' + id).text(title));\n
}\n
\n
function generateToCLine(){\n
return generateTblContent("Table of Contents", \'toc-h-1\', \'frontmatter\');\n
}\n
\n
function generateFMLine(title, id){\n
return generateTblContent(title, \'frontmatter-h-\' + id, \'frontmatter\');\n
}\n
\n
function generateEMLine(title, id){\n
return generateTblContent(title, \'endmatter-h-\' + id, \'endmatter\');\n
}\n
\n
function generatePartLine(title, id){\n
return generateTblContent(title,\'part-h-\' + id, \'part\');\n
}\n
\n
function addLinksToChapters(chapterContainer, id){\n
var chapters = chapterContainer.children();\n
var n = chapters.length;\n
for(var i = 0; i
< n
;
i++){\n
var
chap =
chapters.eq(i);\n
chap.addClass(\'chapter\');\n
$(\'a\',
chap).attr(\'href\',
\'#chapter-h-\'
+
id
+
\'-\'
+
(i+1));\n
}\n
return
chapterContainer;\n
}\n
\n
function
addToC(txt){\n
var
ul =
$(\'<ul
>
\').addClass(\'toc\');\n
var beginning = true;\n
var counter = 1, partCounter = 1;\n
$(\'body\').prepend($(\'
<div>
\').addClass(\'toc\').attr(\'id\',\'toc-h-1\').append(ul));\n
ul.html(txt);\n
ul.append(generateToCLine());\n
var headers = $(\'h1\', ul);\n
var n = headers.length;\n
for(var i = 0; i
< n
;
i++){\n
var
hdr =
headers.eq(i);\n
var
j =
hdr.index()
+
1;\n
var
chapterList =
ul.children().eq(j)[0];\n
if(
chapterList =
=
undefined
||
chapterList.tagName.toUpperCase()
==
"UL"){\n
beginning =
false;\n
ul.append(generatePartLine(hdr.text(),
partCounter).append(addLinksToChapters($(chapterList),
partCounter)));\n
partCounter++;\n
counter =
1;\n
}\n
else{\n
if(beginning)\n
ul.append(generateFMLine(hdr.text(),
counter));\n
else\n
ul.append(generateEMLine(hdr.text(),
counter));\n
counter++;\n
}\n
}\n
$(\'
>
h1\', ul).remove();\n
}\n
\n
function fetchTextInfo(hasToC, txt){\n
$.get(\'TestPage_getDetail\', function(details, status, xhr){\n
details = details.split(\'\\n\');\n
var title = details[0], shortTitle = details[1], description = details[2], authors = parseList(details[3]);\n
var year = details[4].split(\'/\')[0];\n
var titleObj = $(\'title\');\n
if(titleObj.length > 0)\n
titleObj.text(title);\n
else\n
$(\'head\').append($(\'
<title>
\').text(title));\n
$(\'head\').prepend($(\'
<meta>
\').attr(\'name\',\'author\').attr(\'content\', authors));\n
titleObj = $(\'
<h1>
\').text(title);\n
var subtitle = $(\'
<h2>
\').text(description);\n
var edition = $(\'
<h3>
\').text(shortTitle);\n
\n
//Add Table of Contents\n
if(hasToC)\n
addToC(txt);\n
//Add imprint\n
$(\'body\').prepend($(\'
<div>
\').addClass(\'imprint\').append($(\'
<p>
\').text("Copyright \\u00A9 " + year + \' \' + authors)));\n
//Add Title Page\n
$(\'body\').prepend($(\'
<div>
\').addClass(\'titlepage\').append(titleObj.clone().addClass(\'no-toc\')).append(subtitle.clone().addClass(\'no-toc\')).append(edition.clone().addClass(\'no-toc\')).append($(\'
<p>
\').addClass(\'no-toc\').text(authors)));\n
//Add Front Cover\n
$(\'body\').prepend($(\'
<div>
\').addClass(\'frontcover\').append($(\'
<img>
\').attr(\'src\',\'canvas?format=\')).append(titleObj).append(subtitle).append(edition));\n
if(hasToC)\n
cleanForPrince();\n
});\n
}\n
\n
function convertChapter(link, container, first, isChapter, chapterCounter, partCounter){\n
$(function() {\n
//Getting the html content\n
$.get(link, function(data, textStatus, jqXHR){\n
var chapterContainer = $(\'
<div>
\').addClass(\'chapter\').attr(\'id\', \'chapter-h-\' + partCounter + \'-\' + chapterCounter).html(data);\n
link = link.replace("index_html?format=html","");\n
var sections = $(\'section\', chapterContainer);\n
$(\'base,meta,link,title\', chapterContainer).remove();\n
changeTag($(\'footer\', chapterContainer), \'p\');\n
var n = sections.length;\n
for(var i = 0; i
< n
;
i++){\n
element =
changeTag(sections.eq(i),
\'div\');\n
var
images =
$(\'
>
img, details > img\', element);\n
var otherImages = $(\'img:not(> img, details > img)\', element);\n
var p = images.length;\n
for(var j = 0; j
< p
;
j++){\n
var
img =
images[j];\n
var
div =
$(\'<div
>
\');\n
var caption = $(\'
<p>
\').addClass(\'caption\');\n
if((/^http/).test($(img).attr(\'src\')) == false) {\n
$(img).attr(\'src\', link + $(img).attr(\'src\'));\n
}\n
$(img).before(div);\n
var imgToAppend = $(img);\n
var imgWidth = $(img).attr(\'width\');\n
if( imgWidth == undefined || imgWidth == \'\')\n
imgToAppend.attr(\'width\',\'90%\');\n
div.addClass(\'figure\').append(caption).append($(\'
<p>
\').addClass(\'art\').append(imgToAppend));\n
caption.text($(img).attr(\'title\'));\n
}\n
var p = otherImages.length;\n
for(var j = 0; j
< p
;
j++){\n
var
img =
otherImages[j];\n
if((/^http/).test($(img).attr(\'src\'))
==
false)
{\n
$(img).attr(\'src\',
link
+
$(img).attr(\'src\'));\n
}\n
}\n
if(first
&&
i =
=
0)\n
element.attr(\'style\',\'counter-reset:
page
1;\');\n
else
if(i
!=
0){\n
var
headers =
$(\':header\',
element);\n
var
j =
0,
p =
headers.length;\n
for(
j =
0;
j
<
p;
j++){\n
var
hdr =
headers[j];\n
changeTag($(hdr),
\'H\'
+
(parseInt(hdr.tagName.split(\'H\')[1])
+
1));\n
}\n
}\n
var
details =
$(\'details\',
element);\n
details.before(details.html());\n
details.remove();\n
element.addClass(\'section\');\n
}\n
//Why
using
this
instead
of
load?
because
using
load
causes
errors
when
the
images
are
loaded,
and
the
process
won\'t
reach
the
end
in
certain
cases\n
//Moreover,
since
we
load
also
descriptions,
it\'s
better
to
do
it
this
way
so
that
the
user
doesn\'t
see
the
trick\n
chapterContainer.append($(\'div.section\',
chapterContainer));\n
\n
$(\'test\',
chapterContainer).remove();\n
//If
it\'s
a
chapter
and
not
the
introduction
or
an
appendix
for
instance\n
if(isChapter){\n
container.append(chapterContainer);\n
cleanForPrince();\n
}\n
else\n
container.append(chapterContainer.children());\n
if(container[0].tagName.toUpperCase()
==
\'BODY\'){\n
fetchTextInfo(false,
\'\');\n
}\n
});\n
});\n
}
]]
></string>
</value>
</item>
<item>
<key>
<string>
title
</string>
</key>
<value>
<string></string>
</value>
</item>
</dictionary>
</pickle>
</record>
</ZopeData>
bt5/erp5_run_my_doc/SkinTemplateItem/portal_skins/erp5_run_my_doc/
book_converter
.js.xml
→
bt5/erp5_run_my_doc/SkinTemplateItem/portal_skins/erp5_run_my_doc/
html5_book
.js.xml
View file @
e5e277e2
...
@@ -12,7 +12,7 @@
...
@@ -12,7 +12,7 @@
</item>
</item>
<item>
<item>
<key>
<string>
__name__
</string>
</key>
<key>
<string>
__name__
</string>
</key>
<value>
<string>
book_converter
.js
</string>
</value>
<value>
<string>
html5_book
.js
</string>
</value>
</item>
</item>
<item>
<item>
<key>
<string>
_vars
</string>
</key>
<key>
<string>
_vars
</string>
</key>
...
@@ -47,8 +47,238 @@ You should have received a copy of the GNU General Public License\n
...
@@ -47,8 +47,238 @@ You should have received a copy of the GNU General Public License\n
along with this program; if not, write to the Free Software\n
along with this program; if not, write to the Free Software\n
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n
*/\n
*/\n
var textContent, testPageHTML, body;\n
\n
function cleanForPrince(){\n
var temp = $(\'iframe\', parent.document).contents().children().clone();\n
$(\'script\', temp).remove();\n
$(\'style, meta:not([name=author])\', temp).remove();\n
$(\'head\', temp).prepend($(\'<meta>
\').attr(\'http-equiv\',\'content-type\').attr(\'content\', \'text/html; charset=utf-8\'));\n
var images = $(\'img\', temp);\n
n = images.length;\n
for(var i = 0; i
< n
;
i++){\n
var
img =
images.eq(i);\n
var
src =
img.attr(\'src\').split(\'?format\')[0].split(\'/\');\n
var
extension =
img.attr(\'type\');\n
if(
extension =
=
undefined)\n
extension =
"png"
;\n
else\n
extension =
extension.split(\'/\')[1].split(\'+\')[0];\n
img.attr(\'src\',src[src.length
-
1]
+
\'.\'
+
extension);\n
}\n
var
text =
temp.html();\n
var
result =
""
,
tagName =
""
,
c =
""
,
chr =
""
;\n
var
n =
text.length;\n
if
(
text =
=
null)
{\n
return
false;\n
}\n
var
tag =
false,
tagNameParsing =
false;\n
for(var
i =
0;
i
<
n;
i++){\n
chr =
text[i];\n
c =
chr.toLowerCase();\n
if(
c =
=
\'<\'
&&
tag =
=
false){\n
tag =
true;\n
tagNameParsing =
true;\n
}\n
else
if(tag){\n
if(
c =
=
\'
\')\n
tagNameParsing =
false;\n
else
if(
c =
=
\'
>
\'){\n
tagNameParsing = false;\n
tag = false;\n
if(tagName == \'img\')\n
result += \'/\';\n
tagName = \'\';\n
}\n
else if(tagNameParsing){\n
if(c == \'i\'
&&
tagName == \'\')\n
tagName += c;\n
else if(c == \'m\'
&&
tagName == \'i\')\n
tagName += c;\n
else if(c == \'g\'
&&
tagName == \'im\')\n
tagName += c;\n
}\n
}\n
result += chr;\n
}\n
$(\'textarea[name=field_book_text_content]\', parent.document).val(\'
<html>
\\n\' + result + \'\\n
</html>
\');\n
return false;\n
}\n
\n
function changeTag(element, tag){\n
var tag = $(\'
<
\' + tag + \'>\').html(element.html());\n
element.after(tag);\n
element.remove();\n
return tag;\n
}\n
\n
function parseList(text){\n
return text.replace("[","").replace("]","").replace(/\'/g,"").replace(/,/g,", ");\n
}\n
\n
function generateTblContent(title, id, className){\n
return $(\'
<li>
\').addClass(className).append($(\'
<a>
\').attr(\'href\',\'#\' + id).text(title));\n
}\n
\n
function generateToCLine(){\n
return generateTblContent("Table of Contents", \'toc-h-1\', \'frontmatter\');\n
}\n
\n
function generateFMLine(title, id){\n
return generateTblContent(title, \'frontmatter-h-\' + id, \'frontmatter\');\n
}\n
\n
function generateEMLine(title, id){\n
return generateTblContent(title, \'endmatter-h-\' + id, \'endmatter\');\n
}\n
\n
function generatePartLine(title, id){\n
return generateTblContent(title,\'part-h-\' + id, \'part\');\n
}\n
\n
function addLinksToChapters(chapterContainer, id){\n
var chapters = chapterContainer.children();\n
var n = chapters.length;\n
for(var i = 0; i
< n
;
i++){\n
var
chap =
chapters.eq(i);\n
chap.addClass(\'chapter\');\n
$(\'a\',
chap).attr(\'href\',
\'#chapter-h-\'
+
id
+
\'-\'
+
(i+1));\n
}\n
return
chapterContainer;\n
}\n
\n
function
addToC(txt){\n
//
Add
to
table
of
Contents\n
var
ul =
$(\'<ul
>
\').addClass(\'toc\');\n
var beginning = true;\n
var counter = 1, partCounter = 1;\n
$(\'body\').prepend($(\'
<div>
\').addClass(\'toc\').attr(\'id\',\'toc-h-1\').append(ul));\n
ul.html(txt);\n
ul.append(generateToCLine());\n
var headers = $(\'h1\', ul);\n
var n = headers.length;\n
for(var i = 0; i
< n
;
i++){\n
var
hdr =
headers.eq(i);\n
var
j =
hdr.index()
+
1;\n
var
chapterList =
ul.children().eq(j)[0];\n
if(
chapterList =
=
undefined
||
chapterList.tagName.toUpperCase()
==
"UL"){\n
beginning =
false;\n
ul.append(generatePartLine(hdr.text(),
partCounter).append(addLinksToChapters($(chapterList),
partCounter)));\n
partCounter++;\n
counter =
1;\n
}\n
else{\n
if(beginning)\n
ul.append(generateFMLine(hdr.text(),
counter));\n
else\n
ul.append(generateEMLine(hdr.text(),
counter));\n
counter++;\n
}\n
}\n
$(\'
>
h1\', ul).remove();\n
}\n
\n
function fetchTextInfo(hasToC, txt){\n
$.get(\'TestPage_getDetail\', function(details, status, xhr){\n
details = details.split(\'\\n\');\n
var title = details[0], shortTitle = details[1], description = details[2], authors = parseList(details[3]);\n
var year = details[4].split(\'/\')[0];\n
var titleObj = $(\'title\');\n
if(titleObj.length > 0)\n
titleObj.text(title);\n
else\n
$(\'head\').append($(\'
<title>
\').text(title));\n
$(\'head\').prepend($(\'
<meta>
\').attr(\'name\',\'author\').attr(\'content\', authors));\n
titleObj = $(\'
<h1>
\').text(title);\n
var subtitle = $(\'
<h2>
\').text(description);\n
var edition = $(\'
<h3>
\').text(shortTitle);\n
\n
//Add Table of Contents\n
if(hasToC)\n
addToC(txt);\n
//Add imprint\n
$(\'body\').prepend($(\'
<div>
\').addClass(\'imprint\').append($(\'
<p>
\').text("Copyright \\u00A9 " + year + \' \' + authors)));\n
//Add Title Page\n
$(\'body\').prepend($(\'
<div>
\').addClass(\'titlepage\').append(titleObj.clone().addClass(\'no-toc\')).append(subtitle.clone().addClass(\'no-toc\')).append(edition.clone().addClass(\'no-toc\')).append($(\'
<p>
\').addClass(\'no-toc\').text(authors)));\n
//Add Front Cover\n
$(\'body\').prepend($(\'
<div>
\').addClass(\'frontcover\').append($(\'
<img>
\').attr(\'src\',\'canvas?format=\')).append(titleObj).append(subtitle).append(edition));\n
if(hasToC)\n
cleanForPrince();\n
});\n
}\n
\n
function convertChapter(link, container, first, isChapter, chapterCounter, partCounter){\n
$(function() {\n
//Getting the html content\n
$.get(link, function(data, textStatus, jqXHR){\n
var chapterContainer = $(\'
<div>
\').addClass(\'chapter\').attr(\'id\', \'chapter-h-\' + partCounter + \'-\' + chapterCounter).html(data);\n
link = link.replace("index_html?format=html","");\n
$(\'test\', chapterContainer).remove();\n
var sections = $(\'section\', chapterContainer);\n
$(\'base,meta,link,title\', chapterContainer).remove();\n
changeTag($(\'footer\', chapterContainer), \'p\');\n
var n = sections.length;\n
for(var i = 0; i
< n
;
i++){\n
element =
changeTag(sections.eq(i),
\'div\');\n
var
images =
$(\'
>
img, details > img\', element);\n
var otherImages = $(\'img:not(> img, details > img)\', element);\n
var p = images.length;\n
for(var j = 0; j
< p
;
j++){\n
var
img =
images[j];\n
var
div =
$(\'<div
>
\');\n
var caption = $(\'
<p>
\').addClass(\'caption\');\n
if((/^http/).test($(img).attr(\'src\')) == false) {\n
$(img).attr(\'src\', link + $(img).attr(\'src\'));\n
}\n
$(img).before(div);\n
var imgToAppend = $(img);\n
var imgWidth = $(img).attr(\'width\');\n
if( imgWidth == undefined || imgWidth == \'\')\n
imgToAppend.attr(\'width\',\'90%\');\n
div.addClass(\'figure\').append(caption).append($(\'
<p>
\').addClass(\'art\').append(imgToAppend));\n
caption.text($(img).attr(\'title\'));\n
}\n
var p = otherImages.length;\n
for(var j = 0; j
< p
;
j++){\n
var
img =
otherImages[j];\n
if((/^http/).test($(img).attr(\'src\'))
==
false)
{\n
$(img).attr(\'src\',
link
+
$(img).attr(\'src\'));\n
}\n
}\n
if(first
&&
i =
=
0)\n
element.attr(\'style\',\'counter-reset:
page
1;\');\n
else
if(i
!=
0){\n
var
headers =
$(\':header\',
element);\n
var
j =
0,
p =
headers.length;\n
for(
j =
0;
j
<
p;
j++){\n
var
hdr =
headers[j];\n
changeTag($(hdr),
\'H\'
+
(parseInt(hdr.tagName.split(\'H\')[1])
+
1));\n
}\n
}\n
var
details =
$(\'details\',
element);\n
details.before(details.html());\n
details.remove();\n
element.addClass(\'section\');\n
}\n
//Why
using
this
instead
of
load?
because
using
load
causes
errors
when
the
images
are
loaded,
and
the
process
won\'t
reach
the
end
in
certain
cases\n
//Moreover,
since
we
load
also
descriptions,
it\'s
better
to
do
it
this
way
so
that
the
user
doesn\'t
see
the
trick\n
chapterContainer.append($(\'div.section\',
chapterContainer));\n
\n
$(\'test\',
chapterContainer).remove();\n
//If
it\'s
a
chapter
and
not
the
introduction
or
an
appendix
for
instance\n
if(isChapter){\n
container.append(chapterContainer);\n
cleanForPrince();\n
}\n
else\n
container.append(chapterContainer.children());\n
if(container[0].tagName.toUpperCase()
==
\'BODY\'){\n
fetchTextInfo(false,
\'\');\n
}\n
});\n
});\n
}\n
\n
\n
var body;\n
function
convertBook(linkToBook,
container){\n
function
convertBook(linkToBook,
container){\n
$(function()
{\n
$(function()
{\n
//Getting
the
html
content\n
//Getting
the
html
content\n
...
@@ -104,7 +334,8 @@ function convertBook(linkToBook, container){\n
...
@@ -104,7 +334,8 @@ function convertBook(linkToBook, container){\n
fetchTextInfo(true, data);\n
fetchTextInfo(true, data);\n
});\n
});\n
});\n
});\n
}
}\n
]]>
</string>
</value>
]]>
</string>
</value>
</item>
</item>
...
...
bt5/erp5_run_my_doc/bt/revision
View file @
e5e277e2
3
3
3
4
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment