colored-boxes.lyx: new example file for the tcolorbox.module

- also improve the tcolorbox.module

This is a fileformat change - only to be able to revert the new styles defined in the module.
This commit is contained in:
Uwe Stöhr 2015-10-19 07:10:09 +02:00
parent 86325e50d0
commit ce933b1e14
8 changed files with 7327 additions and 22 deletions

View File

@ -11,6 +11,13 @@ adjustments are made to tex2lyx and bugs are fixed in lyx2lyx.
----------------------- -----------------------
2015-10-19 Uwe Stöhr <uwestoehr@web.de>
* Format incremented to 498
tcolorbox module improvements:
- 5 new custom box insets
- new subtitle inset
- new raster box inset
2015-07-16 Georg Baum <Georg.Baum@post.rwth-aachen.de> 2015-07-16 Georg Baum <Georg.Baum@post.rwth-aachen.de>
* Format incremented to 497 * Format incremented to 497
The boundingBox parameter of InsetExternal uses units now The boundingBox parameter of InsetExternal uses units now

View File

@ -309,6 +309,7 @@ dist_examples_DATA = \
examples/biblioExample.bib \ examples/biblioExample.bib \
examples/chess-article.lyx \ examples/chess-article.lyx \
examples/chessgame.lyx \ examples/chessgame.lyx \
examples/colored-boxes.lyx \
examples/docbook_article.lyx \ examples/docbook_article.lyx \
examples/europeCV.lyx \ examples/europeCV.lyx \
examples/europassCV.lyx \ examples/europassCV.lyx \

File diff suppressed because it is too large Load Diff

View File

@ -1,9 +1,10 @@
#\DeclareLyXModule[tcolorbox.sty]{Fancy Colored Boxes} #\DeclareLyXModule[tcolorbox.sty,environ.sty,etoolbox.sty,pgf.sty]{Fancy Colored Boxes}
#DescriptionBegin #DescriptionBegin
#Adds custom insets that support colored boxes via the tcolorbox package. #Adds custom insets that support colored boxes via the tcolorbox package.
#See the tcolorbox documentation for details. #See the tcolorbox documentation for details.
#DescriptionEnd #DescriptionEnd
#Authors: Jürgen Spitzmüller #Author: Jürgen Spitzmüller
# Uwe Stöhr <uwestoehr@lyx.org>
Format 54 Format 54
@ -17,36 +18,39 @@ InsetLayout Flex:Color_Box
Argument 1 Argument 1
LabelString "Color Box Options" LabelString "Color Box Options"
Tooltip "Insert the color box options here (see tcolorbox manual)" Tooltip "Insert the color box options here (see tcolorbox manual)"
PassThruChars "\[]{}"
EndArgument EndArgument
ResetsFont true ResetsFont true
End End
InsetLayout Flex:Dynamic_Color_Box InsetLayout Flex:Dynamic_Color_Box
LyXType custom CopyStyle Flex:Color_Box
Decoration classic
LabelString "Color Box (Dynamic)"
LatexType command LatexType command
LabelString "Color Box (Dynamic)"
LatexName tcbox LatexName tcbox
Requires tcolorbox
Argument 1
LabelString "Color Box Options"
Tooltip "Insert the color box options here (see tcolorbox manual)"
EndArgument
ResetsFont true
End End
InsetLayout Flex:Fit_Color_Box InsetLayout Flex:Fit_Color_Box
LyXType custom CopyStyle Flex:Dynamic_Color_Box
Decoration classic
LabelString "Color Box (Fit Contents)" LabelString "Color Box (Fit Contents)"
LatexType command
LatexName tcboxfit LatexName tcboxfit
Requires tcolorbox End
InsetLayout Flex:Raster_Color_Box
CopyStyle Flex:Color_Box
LabelString "Raster Color Box"
LatexName tcbraster
End
InsetLayout Flex:Subtitle
CopyStyle Flex:Dynamic_Color_Box
LatexName tcbsubtitle
LabelString "Subtitle"
Argument 1 Argument 1
LabelString "Color Box Options" LabelString "Subtitle Options"
Tooltip "Insert the color box options here (see tcolorbox manual)" ToolTip "Insert the options here"
PassThruChars "\[]{}"
EndArgument EndArgument
ResetsFont true
End End
Style Color_Box_Separator Style Color_Box_Separator
@ -111,3 +115,72 @@ Style Color_Box_Setup
Spellcheck 0 Spellcheck 0
End End
Style New_Color_Box_Type
CopyStyle Color_Box_Setup
LatexName newtcolorbox
LabelString "New Color Box Type"
Font
Family roman
EndFont
LabelFont
Color green
EndFont
Argument 1
LabelString "New Box Options"
Tooltip "Options for the new box type (optional)"
PassThruChars "\[]{}"
EndArgument
Argument 2
LabelString "Name"
Tooltip "Name of the new box type"
Mandatory 1
AutoInsert 1
EndArgument
Argument 3
LabelString "Arguments"
Tooltip "Number of arguments (remove this inset if none!)"
Requires 4
EndArgument
Argument 4
LabelString "Default Value"
Tooltip "Default value for argument (keep empty!)"
Requires 3
EndArgument
End
# define 5 different box environments that can be customized by the user
InsetLayout Flex:Custom_Color_Box_1
CopyStyle Flex:Color_Box
LabelString "Custom Color Box 1"
LatexName cBoxA
Argument 2
LabelString "More Color Box Options"
Tooltip "Insert more color box options here"
Mandatory 1
EndArgument
End
InsetLayout Flex:Custom_Color_Box_2
CopyStyle Flex:Custom_Color_Box_1
LabelString "Custom Color Box 2"
LatexName cBoxB
End
InsetLayout Flex:Custom_Color_Box_3
CopyStyle Flex:Custom_Color_Box_1
LabelString "Custom Color Box 3"
LatexName cBoxC
End
InsetLayout Flex:Custom_Color_Box_4
CopyStyle Flex:Custom_Color_Box_1
LabelString "Custom Color Box 4"
LatexName cBoxD
End
InsetLayout Flex:Custom_Color_Box_5
CopyStyle Flex:Custom_Color_Box_1
LabelString "Custom Color Box 5"
LatexName cBoxE
End

View File

@ -85,7 +85,7 @@ format_relation = [("0_06", [200], minor_versions("0.6" , 4)),
("1_6", list(range(277,346)), minor_versions("1.6" , 10)), ("1_6", list(range(277,346)), minor_versions("1.6" , 10)),
("2_0", list(range(346,414)), minor_versions("2.0" , 8)), ("2_0", list(range(346,414)), minor_versions("2.0" , 8)),
("2_1", list(range(414,475)), minor_versions("2.1" , 0)), ("2_1", list(range(414,475)), minor_versions("2.1" , 0)),
("2_2", list(range(475,498)), minor_versions("2.2" , 0)) ("2_2", list(range(475,499)), minor_versions("2.2" , 0))
] ]
#################################################################### ####################################################################

View File

@ -39,6 +39,65 @@ from parser_tools import find_token, find_token_backwards, find_re, \
find_end_of_inset, find_end_of_layout, find_nonempty_line, \ find_end_of_inset, find_end_of_layout, find_nonempty_line, \
get_containing_layout, get_value, check_token get_containing_layout, get_value, check_token
####################################################################
# Private helper functions
def revert_Argument_to_TeX_brace(document, line, endline, n, nmax, environment, opt, nolastopt):
'''
Reverts an InsetArgument to TeX-code
usage:
revert_Argument_to_TeX_brace(document, LineOfBegin, LineOfEnd, StartArgument, EndArgument, isEnvironment, isOpt, notLastOpt)
LineOfBegin is the line of the \begin_layout or \begin_inset statement
LineOfEnd is the line of the \end_layout or \end_inset statement, if "0" is given, the end of the file is used instead
StartArgument is the number of the first argument that needs to be converted
EndArgument is the number of the last argument that needs to be converted or the last defined one
isEnvironment must be true, if the layout is for a LaTeX environment
isOpt must be true, if the argument is an optional one
notLastOpt must be true if the argument is mandatory and followed by optional ones
'''
lineArg = 0
wasOpt = False
while lineArg != -1 and n < nmax + 1:
lineArg = find_token(document.body, "\\begin_inset Argument " + str(n), line)
if lineArg > endline and endline != 0:
return wasOpt
if lineArg != -1:
beginPlain = find_token(document.body, "\\begin_layout Plain Layout", lineArg)
# we have to assure that no other inset is in the Argument
beginInset = find_token(document.body, "\\begin_inset", beginPlain)
endInset = find_token(document.body, "\\end_inset", beginPlain)
k = beginPlain + 1
l = k
while beginInset < endInset and beginInset != -1:
beginInset = find_token(document.body, "\\begin_inset", k)
endInset = find_token(document.body, "\\end_inset", l)
k = beginInset + 1
l = endInset + 1
if environment == False:
if opt == False:
if nolastopt == False:
document.body[endInset - 2 : endInset + 1] = put_cmd_in_ert("}{")
else:
document.body[endInset - 2 : endInset + 1] = put_cmd_in_ert("}")
del(document.body[lineArg : beginPlain + 1])
wasOpt = False
else:
document.body[endInset - 2 : endInset + 1] = put_cmd_in_ert("]")
document.body[lineArg : beginPlain + 1] = put_cmd_in_ert("[")
wasOpt = True
else:
if opt == False:
document.body[endInset - 2 : endInset + 1] = put_cmd_in_ert("}")
document.body[lineArg : beginPlain + 1] = put_cmd_in_ert("{")
wasOpt = False
else:
document.body[endInset - 2 : endInset + 1] = put_cmd_in_ert("]")
document.body[lineArg : beginPlain + 1] = put_cmd_in_ert("[")
wasOpt = True
n += 1
return wasOpt
############################################################################### ###############################################################################
### ###
### Conversion and reversion routines ### Conversion and reversion routines
@ -1566,6 +1625,193 @@ def revert_external_bbox(document):
convert_revert_external_bbox(document, False) convert_revert_external_bbox(document, False)
def revert_tcolorbox_1(document):
" Reverts the Flex:Subtitle inset of tcolorbox to TeX-code "
i = -1
while True:
i = find_token(document.header, "tcolorbox", i)
if i == -1:
break
else:
flex = 0
flexEnd = -1
flex = find_token(document.body, "\\begin_inset Flex Subtitle", flex)
if flex == -1:
return flexEnd
flexEnd = find_end_of_inset(document.body, flex)
wasOpt = revert_Argument_to_TeX_brace(document, flex, flexEnd, 1, 1, False, True, False)
revert_Argument_to_TeX_brace(document, flex, 0, 2, 2, False, False, False)
flexEnd = find_end_of_inset(document.body, flex)
if wasOpt == True:
document.body[flex + 0 : flex + 4] = put_cmd_in_ert("\\tcbsubtitle")
else:
document.body[flex + 0 : flex + 4] = put_cmd_in_ert("\\tcbsubtitle{")
document.body[flexEnd + 4 : flexEnd + 7] = put_cmd_in_ert("}")
flex += 1
def revert_tcolorbox_2(document):
" Reverts the Flex:Raster_Color_Box inset of tcolorbox to TeX-code "
i = -1
while True:
i = find_token(document.header, "tcolorbox", i)
if i == -1:
break
else:
flex = 0
flexEnd = -1
flex = find_token(document.body, "\\begin_inset Flex Raster Color Box", flex)
if flex == -1:
return flexEnd
flexEnd = find_end_of_inset(document.body, flex)
revert_Argument_to_TeX_brace(document, flex, flexEnd, 1, 1, True, True, False)
flexEnd = find_end_of_inset(document.body, flex)
document.body[flex + 0 : flex + 4] = put_cmd_in_ert("\\begin{tcbraster}")
document.body[flexEnd + 4 : flexEnd + 7] = put_cmd_in_ert("\\end{tcbraster}")
flex += 1
def revert_tcolorbox_3(document):
" Reverts the Flex:Custom_Color_Box_1 inset of tcolorbox to TeX-code "
i = -1
while True:
i = find_token(document.header, "tcolorbox", i)
if i == -1:
break
else:
flex = 0
flexEnd = -1
flex = find_token(document.body, "\\begin_inset Flex Custom Color Box 1", flex)
if flex == -1:
return flexEnd
flexEnd = find_end_of_inset(document.body, flex)
revert_Argument_to_TeX_brace(document, flex, flexEnd, 1, 1, True, True, False)
revert_Argument_to_TeX_brace(document, flex, 0, 2, 2, True, False, False)
flexEnd = find_end_of_inset(document.body, flex)
document.body[flex + 0 : flex + 4] = put_cmd_in_ert("\\begin{cBoxA}")
document.body[flexEnd + 4 : flexEnd + 7] = put_cmd_in_ert("{}\\end{cBoxA}")
flex += 1
def revert_tcolorbox_4(document):
" Reverts the Flex:Custom_Color_Box_2 inset of tcolorbox to TeX-code "
i = -1
while True:
i = find_token(document.header, "tcolorbox", i)
if i == -1:
break
else:
flex = 0
flexEnd = -1
flex = find_token(document.body, "\\begin_inset Flex Custom Color Box 2", flex)
if flex == -1:
return flexEnd
flexEnd = find_end_of_inset(document.body, flex)
revert_Argument_to_TeX_brace(document, flex, flexEnd, 1, 1, True, True, False)
revert_Argument_to_TeX_brace(document, flex, 0, 2, 2, True, False, False)
flexEnd = find_end_of_inset(document.body, flex)
document.body[flex + 0 : flex + 4] = put_cmd_in_ert("\\begin{cBoxB}")
document.body[flexEnd + 4 : flexEnd + 7] = put_cmd_in_ert("{}\\end{cBoxB}")
flex += 1
def revert_tcolorbox_5(document):
" Reverts the Flex:Custom_Color_Box_3 inset of tcolorbox to TeX-code "
i = -1
while True:
i = find_token(document.header, "tcolorbox", i)
if i == -1:
break
else:
flex = 0
flexEnd = -1
flex = find_token(document.body, "\\begin_inset Flex Custom Color Box 3", flex)
if flex == -1:
return flexEnd
flexEnd = find_end_of_inset(document.body, flex)
revert_Argument_to_TeX_brace(document, flex, flexEnd, 1, 1, True, True, False)
revert_Argument_to_TeX_brace(document, flex, 0, 2, 2, True, False, False)
flexEnd = find_end_of_inset(document.body, flex)
document.body[flex + 0 : flex + 4] = put_cmd_in_ert("\\begin{cBoxC}")
document.body[flexEnd + 4 : flexEnd + 7] = put_cmd_in_ert("{}\\end{cBoxC}")
flex += 1
def revert_tcolorbox_6(document):
" Reverts the Flex:Custom_Color_Box_4 inset of tcolorbox to TeX-code "
i = -1
while True:
i = find_token(document.header, "tcolorbox", i)
if i == -1:
break
else:
flex = 0
flexEnd = -1
flex = find_token(document.body, "\\begin_inset Flex Custom Color Box 4", flex)
if flex == -1:
return flexEnd
flexEnd = find_end_of_inset(document.body, flex)
revert_Argument_to_TeX_brace(document, flex, flexEnd, 1, 1, True, True, False)
revert_Argument_to_TeX_brace(document, flex, 0, 2, 2, True, False, False)
flexEnd = find_end_of_inset(document.body, flex)
document.body[flex + 0 : flex + 4] = put_cmd_in_ert("\\begin{cBoxD}")
document.body[flexEnd + 4 : flexEnd + 7] = put_cmd_in_ert("{}\\end{cBoxD}")
flex += 1
def revert_tcolorbox_7(document):
" Reverts the Flex:Custom_Color_Box_5 inset of tcolorbox to TeX-code "
i = -1
while True:
i = find_token(document.header, "tcolorbox", i)
if i == -1:
break
else:
flex = 0
flexEnd = -1
flex = find_token(document.body, "\\begin_inset Flex Custom Color Box 5", flex)
if flex == -1:
return flexEnd
flexEnd = find_end_of_inset(document.body, flex)
revert_Argument_to_TeX_brace(document, flex, flexEnd, 1, 1, True, True, False)
revert_Argument_to_TeX_brace(document, flex, 0, 2, 2, True, False, False)
flexEnd = find_end_of_inset(document.body, flex)
document.body[flex + 0 : flex + 4] = put_cmd_in_ert("\\begin{cBoxE}")
document.body[flexEnd + 4 : flexEnd + 7] = put_cmd_in_ert("{}\\end{cBoxE}")
flex += 1
def revert_tcolorbox_8(document):
" Reverts the layout New Color Box Type of tcolorbox to TeX-code "
i = 0
j = 0
k = 0
while True:
if i != -1:
i = find_token(document.body, "\\begin_layout New Color Box Type", i)
if i != -1:
j = find_end_of_layout(document.body, i)
wasOpt = revert_Argument_to_TeX_brace(document, i, j, 1, 1, False, True, False)
revert_Argument_to_TeX_brace(document, i, 0, 2, 2, False, False, True)
revert_Argument_to_TeX_brace(document, i, 0, 3, 4, False, True, False)
document.body[i] = document.body[i].replace("\\begin_layout New Color Box Type", "\\begin_layout Standard")
if wasOpt == True:
document.body[i + 1 : i + 1] = put_cmd_in_ert("\\newtcolorbox")
else:
document.body[i + 1 : i + 1] = put_cmd_in_ert("\\newtcolorbox{")
k = find_end_of_inset(document.body, j)
k = find_token(document.body, "\\end_inset", k + 1)
k = find_token(document.body, "\\end_inset", k + 1)
if wasOpt == True:
k = find_token(document.body, "\\end_inset", k + 1)
document.body[k + 2 : j + 2] = put_cmd_in_ert("{")
j = find_token(document.body, "\\begin_layout Standard", j + 1)
document.body[j - 2 : j - 2] = put_cmd_in_ert("}")
i += 1
if i == -1:
return
## ##
# Conversion hub # Conversion hub
# #
@ -1597,10 +1843,14 @@ convert = [
[494, []], [494, []],
[495, [convert_subref]], [495, [convert_subref]],
[496, [convert_nounzip]], [496, [convert_nounzip]],
[497, [convert_external_bbox]] [497, [convert_external_bbox]],
[498, []]
] ]
revert = [ revert = [
[497, [revert_tcolorbox_1, revert_tcolorbox_2,
revert_tcolorbox_3, revert_tcolorbox_4, revert_tcolorbox_5,
revert_tcolorbox_6, revert_tcolorbox_7, revert_tcolorbox_8]],
[496, [revert_external_bbox]], [496, [revert_external_bbox]],
[495, []], # nothing to do since the noUnzip parameter was optional [495, []], # nothing to do since the noUnzip parameter was optional
[494, [revert_subref]], [494, [revert_subref]],

View File

@ -606,6 +606,7 @@ Menuset
Menu "examples" Menu "examples"
Item "Beamer Presentations|B" "help-open beamer" Item "Beamer Presentations|B" "help-open beamer"
Item "Braille|a" "help-open Braille" Item "Braille|a" "help-open Braille"
Item "Colored boxes|C" "help-open colored-boxes"
Item "Feynman-diagram|F" "help-open FeynmanDiagrams" Item "Feynman-diagram|F" "help-open FeynmanDiagrams"
Item "Knitr|K" "help-open knitr" Item "Knitr|K" "help-open knitr"
Item "LilyPond|P" "help-open lilypond" Item "LilyPond|P" "help-open lilypond"

View File

@ -32,8 +32,8 @@ extern char const * const lyx_version_info;
// Do not remove the comment below, so we get merge conflict in // Do not remove the comment below, so we get merge conflict in
// independent branches. Instead add your own. // independent branches. Instead add your own.
#define LYX_FORMAT_LYX 497 // gb: bounding box of external insets supports units #define LYX_FORMAT_LYX 498 // uwestoehr: tcolorbox module improvements
#define LYX_FORMAT_TEX2LYX 497 #define LYX_FORMAT_TEX2LYX 498
#if LYX_FORMAT_TEX2LYX != LYX_FORMAT_LYX #if LYX_FORMAT_TEX2LYX != LYX_FORMAT_LYX
#ifndef _MSC_VER #ifndef _MSC_VER