-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathnotebookStyles.wl
101 lines (96 loc) · 2.41 KB
/
notebookStyles.wl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
(* ::Package:: *)
processSheet//Clear
processSheet[{nb_NotebookObject, {implements_NotebookObject, ___}}]:=implements;
processSheet[_]:=Nothing;
getSheet//Clear;
getSheet[nb_NotebookObject]:=
processSheet@Lookup[NotebookInformation[nb], "StyleDefinitions", {}];
getSheet[e_]:=e;
getStyleSheetChain[nb_NotebookObject]:=
Rest@
Module[{s=<||>},
FixedPointList[
getSheet,
Replace[Lookup[NotebookInformation[nb], "StyleDefinitions", {}],
{
{n_NotebookObject}:>n,
{n_NotebookObject, {i_, ___}}:>i
}
]
]
]
mergeStyles[styles_]:=
Merge[
{
styles
},
If[AnyTrue[#, ListQ[#]&&OptionQ[#]&],
Merge[Flatten@#, Last],
Last@#
]&
];
mergeStyleSet[styles_]:=
Merge[
Normal/@styles,
mergeStyles
];
getStyleChain[nbs:{__NotebookObject}]:=
Module[
{
cells=Cells/@nbs,
names,
ops
},
ops=ConstantArray[<||>, Length@nbs];
MapIndexed[
Replace[
#,
{
Cell[StyleData[name:_String|All, env:_String|None:None], o___?OptionQ]:>
Set[
ops[[#2[[1]], Key@If[env===None, name, {name, env}] ]],
Merge[
{
Normal@Replace[
ops[[#2[[1]], Key@If[env===None, name, {name, env}]]],
Except[_Association]:><||>
],
o
},
Last
]
],
c:Cell[
StyleData[
name:_String|All, env:_String|None:None,
StyleDefinitions->StyleData[parent_]
],
o___?OptionQ
]:>
With[
{
inherited=
mergeStyles@
Flatten@List@Lookup[ops[[;;#2[[1]]-1]], Key@parent, <||>]
},
Set[
ops[[#2[[1]],Key@If[env===None, name, {name, env}] ]],
Merge[
{
Replace[
ops[[#2[[1]], Key@If[env===None, name, {name, env}]]],
Except[_Association]-><||>
],
o
},
Last
]
]
]
},
1
]&,
NotebookRead/@cells
];
mergeStyleSet@ops
]