docrev 0.10.0 → 0.10.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (126) hide show
  1. package/.gitattributes +1 -1
  2. package/CHANGELOG.md +173 -164
  3. package/PLAN-tables-and-postprocess.md +850 -850
  4. package/README.md +431 -431
  5. package/bin/rev.js +11 -11
  6. package/bin/rev.ts +145 -145
  7. package/completions/rev.bash +127 -127
  8. package/completions/rev.ps1 +210 -210
  9. package/completions/rev.zsh +207 -207
  10. package/dist/lib/anchor-match.d.ts +1 -1
  11. package/dist/lib/anchor-match.d.ts.map +1 -1
  12. package/dist/lib/anchor-match.js +17 -47
  13. package/dist/lib/anchor-match.js.map +1 -1
  14. package/dist/lib/build.js +4 -4
  15. package/dist/lib/commands/context.d.ts +1 -1
  16. package/dist/lib/commands/context.d.ts.map +1 -1
  17. package/dist/lib/commands/context.js +1 -1
  18. package/dist/lib/commands/context.js.map +1 -1
  19. package/dist/lib/commands/sections.js +7 -7
  20. package/dist/lib/commands/sections.js.map +1 -1
  21. package/dist/lib/commands/sync.d.ts.map +1 -1
  22. package/dist/lib/commands/sync.js +15 -14
  23. package/dist/lib/commands/sync.js.map +1 -1
  24. package/dist/lib/commands/utilities.js +164 -164
  25. package/dist/lib/commands/verify-anchors.js +6 -6
  26. package/dist/lib/commands/verify-anchors.js.map +1 -1
  27. package/dist/lib/commands/word-tools.js +8 -8
  28. package/dist/lib/grammar.js +3 -3
  29. package/dist/lib/macro-filter.lua +201 -201
  30. package/dist/lib/pdf-comments.js +44 -44
  31. package/dist/lib/plugins.js +57 -57
  32. package/dist/lib/pptx-color-filter.lua +37 -37
  33. package/dist/lib/pptx-themes.js +115 -115
  34. package/dist/lib/sections.d.ts +35 -0
  35. package/dist/lib/sections.d.ts.map +1 -1
  36. package/dist/lib/sections.js +81 -0
  37. package/dist/lib/sections.js.map +1 -1
  38. package/dist/lib/spelling.js +2 -2
  39. package/dist/lib/templates.js +387 -387
  40. package/dist/lib/themes.js +51 -51
  41. package/docs-src/build.py +113 -113
  42. package/docs-src/extra.css +208 -208
  43. package/docs-src/md-to-html.lua +6 -6
  44. package/docs-src/template.html +116 -116
  45. package/eslint.config.js +27 -27
  46. package/lib/anchor-match.ts +276 -308
  47. package/lib/annotations.ts +644 -644
  48. package/lib/build.ts +1766 -1766
  49. package/lib/citations.ts +160 -160
  50. package/lib/commands/build.ts +855 -855
  51. package/lib/commands/citations.ts +515 -515
  52. package/lib/commands/comments.ts +1050 -1050
  53. package/lib/commands/context.ts +176 -174
  54. package/lib/commands/core.ts +309 -309
  55. package/lib/commands/doi.ts +435 -435
  56. package/lib/commands/file-ops.ts +372 -372
  57. package/lib/commands/history.ts +320 -320
  58. package/lib/commands/index.ts +87 -87
  59. package/lib/commands/init.ts +259 -259
  60. package/lib/commands/merge-resolve.ts +378 -378
  61. package/lib/commands/preview.ts +178 -178
  62. package/lib/commands/project-info.ts +244 -244
  63. package/lib/commands/quality.ts +517 -517
  64. package/lib/commands/response.ts +454 -454
  65. package/lib/commands/section-boundaries.ts +82 -82
  66. package/lib/commands/sections.ts +451 -451
  67. package/lib/commands/sync.ts +709 -706
  68. package/lib/commands/text-ops.ts +449 -449
  69. package/lib/commands/utilities.ts +448 -448
  70. package/lib/commands/verify-anchors.ts +272 -272
  71. package/lib/commands/word-tools.ts +340 -340
  72. package/lib/comment-realign.ts +517 -517
  73. package/lib/config.ts +84 -84
  74. package/lib/crossref.ts +781 -781
  75. package/lib/csl.ts +191 -191
  76. package/lib/dependencies.ts +98 -98
  77. package/lib/diff-engine.ts +465 -465
  78. package/lib/doi-cache.ts +115 -115
  79. package/lib/doi.ts +897 -897
  80. package/lib/equations.ts +506 -506
  81. package/lib/errors.ts +346 -346
  82. package/lib/format.ts +541 -541
  83. package/lib/git.ts +326 -326
  84. package/lib/grammar.ts +303 -303
  85. package/lib/image-registry.ts +180 -180
  86. package/lib/import.ts +911 -911
  87. package/lib/journals.ts +543 -543
  88. package/lib/macro-filter.lua +201 -201
  89. package/lib/macros.ts +273 -273
  90. package/lib/merge.ts +633 -633
  91. package/lib/orcid.ts +144 -144
  92. package/lib/pdf-comments.ts +263 -263
  93. package/lib/pdf-import.ts +524 -524
  94. package/lib/plugins.ts +362 -362
  95. package/lib/postprocess.ts +188 -188
  96. package/lib/pptx-color-filter.lua +37 -37
  97. package/lib/pptx-template.ts +469 -469
  98. package/lib/pptx-themes.ts +483 -483
  99. package/lib/protect-restore.ts +520 -520
  100. package/lib/rate-limiter.ts +94 -94
  101. package/lib/response.ts +197 -197
  102. package/lib/restore-references.ts +240 -240
  103. package/lib/review.ts +327 -327
  104. package/lib/schema.ts +488 -488
  105. package/lib/scientific-words.ts +73 -73
  106. package/lib/sections.ts +425 -335
  107. package/lib/slides.ts +756 -756
  108. package/lib/spelling.ts +334 -334
  109. package/lib/templates.ts +526 -526
  110. package/lib/themes.ts +742 -742
  111. package/lib/trackchanges.ts +247 -247
  112. package/lib/tui.ts +450 -450
  113. package/lib/types.ts +550 -550
  114. package/lib/undo.ts +250 -250
  115. package/lib/utils.ts +69 -69
  116. package/lib/variables.ts +179 -179
  117. package/lib/word-extraction.ts +806 -806
  118. package/lib/word.ts +643 -643
  119. package/lib/wordcomments.ts +840 -840
  120. package/mkdocs.yml +64 -64
  121. package/package.json +137 -137
  122. package/scripts/postbuild.js +47 -47
  123. package/skill/REFERENCE.md +539 -539
  124. package/skill/SKILL.md +295 -295
  125. package/tsconfig.json +26 -26
  126. package/types/index.d.ts +525 -525
@@ -1,208 +1,208 @@
1
- /* ── Base ──────────────────────────────────────────────── */
2
- html, body {
3
- height: 100%;
4
- }
5
-
6
- body {
7
- background-color: #F5F6F8;
8
- color: #3E3F3A;
9
- display: flex;
10
- flex-direction: column;
11
- min-height: 100vh;
12
- padding-top: 4rem;
13
- font-family: "Roboto", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
14
- }
15
-
16
- .container { flex: 1; }
17
- footer { margin-top: auto; }
18
-
19
- /* ── Navbar (pkgdown-style subtle tint, not bg-primary) ── */
20
- .navbar {
21
- background: color-mix(in oklab, color-mix(in oklab, var(--bs-body-bg) 95%, var(--bs-primary)) 95%, var(--bs-body-color));
22
- border-bottom: 1px solid #DFD7CA;
23
- line-height: initial;
24
- }
25
-
26
- .navbar .nav-link.active {
27
- font-weight: 600;
28
- color: var(--bs-primary) !important;
29
- }
30
-
31
- /* ── Links ─────────────────────────────────────────────── */
32
- a { color: #325D88; }
33
- a:hover { color: #1E3D5C; }
34
-
35
- /* ── Headings ──────────────────────────────────────────── */
36
- h1 { font-size: 2rem; font-weight: 600; margin-bottom: 1rem; }
37
- h2 {
38
- font-size: 1.4rem; font-weight: 600;
39
- margin-top: 2rem; margin-bottom: .65rem;
40
- padding-bottom: .3rem;
41
- border-bottom: 1px solid #DFD7CA;
42
- }
43
- h3 { font-size: 1.1rem; font-weight: 600; margin-top: 1.5rem; }
44
- h4 { font-size: 1rem; font-weight: 600; margin-top: 1.2rem; }
45
-
46
- /* ── Code ──────────────────────────────────────────────── */
47
- pre, div.sourceCode {
48
- background-color: #EEEEED;
49
- border: 1px solid #DFD7CA;
50
- border-radius: .375rem;
51
- padding: .9rem 1.1rem;
52
- font-size: .85rem;
53
- overflow-x: auto;
54
- margin: 1em 0;
55
- }
56
-
57
- code {
58
- background-color: #EEEEED;
59
- color: #3E3F3A;
60
- border-radius: .25rem;
61
- padding: .1em .35em;
62
- font-size: .875em;
63
- }
64
-
65
- pre code, div.sourceCode code {
66
- background: none;
67
- padding: 0;
68
- border-radius: 0;
69
- font-size: inherit;
70
- color: inherit;
71
- }
72
-
73
- div.sourceCode { padding: 0; }
74
- div.sourceCode pre { border: none; margin: 0; }
75
-
76
- /* ── Tables ────────────────────────────────────────────── */
77
- table {
78
- width: 100%;
79
- border-collapse: collapse;
80
- margin: 1em 0;
81
- font-size: .9rem;
82
- }
83
-
84
- thead th {
85
- background-color: #DFD7CA;
86
- color: #3E3F3A;
87
- font-weight: 600;
88
- padding: .5rem .75rem;
89
- border-bottom: 2px solid #c8c0b4;
90
- text-align: left;
91
- }
92
-
93
- td, th { padding: .4rem .75rem; border-bottom: 1px solid #e8e2d8; }
94
- tbody tr:hover { background-color: rgba(223,215,202,.2); }
95
-
96
- /* ── TOC sidebar ───────────────────────────────────────── */
97
- aside#toc, aside .toc, aside nav.toc { font-size: .875rem; }
98
-
99
- aside h2.h6 {
100
- text-transform: uppercase;
101
- font-size: .68rem;
102
- letter-spacing: .07em;
103
- color: #6c757d;
104
- font-weight: 600;
105
- margin-bottom: .5rem;
106
- border: none;
107
- padding: 0;
108
- }
109
-
110
- aside .toc, aside #TOC {
111
- position: sticky;
112
- top: 5rem;
113
- max-height: calc(100vh - 6rem);
114
- overflow-y: auto;
115
- }
116
-
117
- aside ul {
118
- list-style: none;
119
- padding-left: .9rem;
120
- margin: 0;
121
- }
122
- aside > nav > .toc > ul,
123
- aside .toc > ul { padding-left: 0; }
124
-
125
- aside li { margin: .1rem 0; }
126
-
127
- aside a {
128
- color: #6c757d;
129
- text-decoration: none;
130
- display: block;
131
- line-height: 1.55;
132
- }
133
- aside a:hover { color: #325D88; }
134
-
135
- /* ── Home page cards ───────────────────────────────────── */
136
- .doc-card {
137
- border: 1px solid #DFD7CA;
138
- border-radius: .375rem;
139
- padding: 1.1rem 1.25rem;
140
- height: 100%;
141
- background: #fff;
142
- transition: border-color .15s, box-shadow .15s;
143
- }
144
- .doc-card:hover {
145
- border-color: #325D88;
146
- box-shadow: 0 2px 8px rgba(50,93,136,.1);
147
- }
148
- .doc-card h5 { font-size: 1rem; font-weight: 600; margin-bottom: .4rem; }
149
- .doc-card p { font-size: .875rem; color: #6c757d; margin-bottom: .6rem; }
150
- .doc-card a.stretched-link::after { z-index: 1; }
151
-
152
- /* ── Badges row ────────────────────────────────────────── */
153
- .badge-row { margin-bottom: 1rem; line-height: 2; }
154
- .badge-row img { margin-right: .25rem; }
155
-
156
- /* ── ── ── DARK MODE ── ── ── ──────────────────────────── */
157
-
158
- [data-bs-theme="dark"] body { background-color: #343739; color: #DFD7CA; }
159
-
160
- [data-bs-theme="dark"] .navbar {
161
- background: color-mix(in oklab, color-mix(in oklab, #343739 92%, var(--bs-primary)) 95%, #DFD7CA);
162
- border-bottom-color: #495057;
163
- }
164
-
165
- [data-bs-theme="dark"] a { color: #7ba8d0; }
166
- [data-bs-theme="dark"] a:hover { color: #a5c4e8; }
167
-
168
- [data-bs-theme="dark"] .navbar .nav-link.active { color: #7ba8d0 !important; }
169
-
170
- [data-bs-theme="dark"] h1,
171
- [data-bs-theme="dark"] h2,
172
- [data-bs-theme="dark"] h3,
173
- [data-bs-theme="dark"] h4 { color: #DFD7CA; }
174
-
175
- [data-bs-theme="dark"] h2 { border-color: #495057; }
176
-
177
- [data-bs-theme="dark"] pre,
178
- [data-bs-theme="dark"] div.sourceCode {
179
- background-color: #2C2F31;
180
- border-color: #495057;
181
- color: #DFD7CA;
182
- }
183
-
184
- [data-bs-theme="dark"] code {
185
- background-color: #2C2F31;
186
- color: #DFD7CA;
187
- }
188
-
189
- [data-bs-theme="dark"] div.sourceCode span[class] { color: #DFD7CA !important; }
190
-
191
- [data-bs-theme="dark"] thead th {
192
- background-color: #3d4043;
193
- color: #DFD7CA;
194
- border-color: #495057;
195
- }
196
- [data-bs-theme="dark"] td,
197
- [data-bs-theme="dark"] th { border-color: #3d4043; }
198
- [data-bs-theme="dark"] tbody tr:hover { background-color: rgba(73,80,87,.3); }
199
-
200
- [data-bs-theme="dark"] aside a { color: #8e9499; }
201
- [data-bs-theme="dark"] aside a:hover { color: #7ba8d0; }
202
-
203
- [data-bs-theme="dark"] .doc-card {
204
- background: #2C2F31;
205
- border-color: #495057;
206
- }
207
- [data-bs-theme="dark"] .doc-card:hover { border-color: #7ba8d0; }
208
- [data-bs-theme="dark"] .doc-card p { color: #8e9499; }
1
+ /* ── Base ──────────────────────────────────────────────── */
2
+ html, body {
3
+ height: 100%;
4
+ }
5
+
6
+ body {
7
+ background-color: #F5F6F8;
8
+ color: #3E3F3A;
9
+ display: flex;
10
+ flex-direction: column;
11
+ min-height: 100vh;
12
+ padding-top: 4rem;
13
+ font-family: "Roboto", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
14
+ }
15
+
16
+ .container { flex: 1; }
17
+ footer { margin-top: auto; }
18
+
19
+ /* ── Navbar (pkgdown-style subtle tint, not bg-primary) ── */
20
+ .navbar {
21
+ background: color-mix(in oklab, color-mix(in oklab, var(--bs-body-bg) 95%, var(--bs-primary)) 95%, var(--bs-body-color));
22
+ border-bottom: 1px solid #DFD7CA;
23
+ line-height: initial;
24
+ }
25
+
26
+ .navbar .nav-link.active {
27
+ font-weight: 600;
28
+ color: var(--bs-primary) !important;
29
+ }
30
+
31
+ /* ── Links ─────────────────────────────────────────────── */
32
+ a { color: #325D88; }
33
+ a:hover { color: #1E3D5C; }
34
+
35
+ /* ── Headings ──────────────────────────────────────────── */
36
+ h1 { font-size: 2rem; font-weight: 600; margin-bottom: 1rem; }
37
+ h2 {
38
+ font-size: 1.4rem; font-weight: 600;
39
+ margin-top: 2rem; margin-bottom: .65rem;
40
+ padding-bottom: .3rem;
41
+ border-bottom: 1px solid #DFD7CA;
42
+ }
43
+ h3 { font-size: 1.1rem; font-weight: 600; margin-top: 1.5rem; }
44
+ h4 { font-size: 1rem; font-weight: 600; margin-top: 1.2rem; }
45
+
46
+ /* ── Code ──────────────────────────────────────────────── */
47
+ pre, div.sourceCode {
48
+ background-color: #EEEEED;
49
+ border: 1px solid #DFD7CA;
50
+ border-radius: .375rem;
51
+ padding: .9rem 1.1rem;
52
+ font-size: .85rem;
53
+ overflow-x: auto;
54
+ margin: 1em 0;
55
+ }
56
+
57
+ code {
58
+ background-color: #EEEEED;
59
+ color: #3E3F3A;
60
+ border-radius: .25rem;
61
+ padding: .1em .35em;
62
+ font-size: .875em;
63
+ }
64
+
65
+ pre code, div.sourceCode code {
66
+ background: none;
67
+ padding: 0;
68
+ border-radius: 0;
69
+ font-size: inherit;
70
+ color: inherit;
71
+ }
72
+
73
+ div.sourceCode { padding: 0; }
74
+ div.sourceCode pre { border: none; margin: 0; }
75
+
76
+ /* ── Tables ────────────────────────────────────────────── */
77
+ table {
78
+ width: 100%;
79
+ border-collapse: collapse;
80
+ margin: 1em 0;
81
+ font-size: .9rem;
82
+ }
83
+
84
+ thead th {
85
+ background-color: #DFD7CA;
86
+ color: #3E3F3A;
87
+ font-weight: 600;
88
+ padding: .5rem .75rem;
89
+ border-bottom: 2px solid #c8c0b4;
90
+ text-align: left;
91
+ }
92
+
93
+ td, th { padding: .4rem .75rem; border-bottom: 1px solid #e8e2d8; }
94
+ tbody tr:hover { background-color: rgba(223,215,202,.2); }
95
+
96
+ /* ── TOC sidebar ───────────────────────────────────────── */
97
+ aside#toc, aside .toc, aside nav.toc { font-size: .875rem; }
98
+
99
+ aside h2.h6 {
100
+ text-transform: uppercase;
101
+ font-size: .68rem;
102
+ letter-spacing: .07em;
103
+ color: #6c757d;
104
+ font-weight: 600;
105
+ margin-bottom: .5rem;
106
+ border: none;
107
+ padding: 0;
108
+ }
109
+
110
+ aside .toc, aside #TOC {
111
+ position: sticky;
112
+ top: 5rem;
113
+ max-height: calc(100vh - 6rem);
114
+ overflow-y: auto;
115
+ }
116
+
117
+ aside ul {
118
+ list-style: none;
119
+ padding-left: .9rem;
120
+ margin: 0;
121
+ }
122
+ aside > nav > .toc > ul,
123
+ aside .toc > ul { padding-left: 0; }
124
+
125
+ aside li { margin: .1rem 0; }
126
+
127
+ aside a {
128
+ color: #6c757d;
129
+ text-decoration: none;
130
+ display: block;
131
+ line-height: 1.55;
132
+ }
133
+ aside a:hover { color: #325D88; }
134
+
135
+ /* ── Home page cards ───────────────────────────────────── */
136
+ .doc-card {
137
+ border: 1px solid #DFD7CA;
138
+ border-radius: .375rem;
139
+ padding: 1.1rem 1.25rem;
140
+ height: 100%;
141
+ background: #fff;
142
+ transition: border-color .15s, box-shadow .15s;
143
+ }
144
+ .doc-card:hover {
145
+ border-color: #325D88;
146
+ box-shadow: 0 2px 8px rgba(50,93,136,.1);
147
+ }
148
+ .doc-card h5 { font-size: 1rem; font-weight: 600; margin-bottom: .4rem; }
149
+ .doc-card p { font-size: .875rem; color: #6c757d; margin-bottom: .6rem; }
150
+ .doc-card a.stretched-link::after { z-index: 1; }
151
+
152
+ /* ── Badges row ────────────────────────────────────────── */
153
+ .badge-row { margin-bottom: 1rem; line-height: 2; }
154
+ .badge-row img { margin-right: .25rem; }
155
+
156
+ /* ── ── ── DARK MODE ── ── ── ──────────────────────────── */
157
+
158
+ [data-bs-theme="dark"] body { background-color: #343739; color: #DFD7CA; }
159
+
160
+ [data-bs-theme="dark"] .navbar {
161
+ background: color-mix(in oklab, color-mix(in oklab, #343739 92%, var(--bs-primary)) 95%, #DFD7CA);
162
+ border-bottom-color: #495057;
163
+ }
164
+
165
+ [data-bs-theme="dark"] a { color: #7ba8d0; }
166
+ [data-bs-theme="dark"] a:hover { color: #a5c4e8; }
167
+
168
+ [data-bs-theme="dark"] .navbar .nav-link.active { color: #7ba8d0 !important; }
169
+
170
+ [data-bs-theme="dark"] h1,
171
+ [data-bs-theme="dark"] h2,
172
+ [data-bs-theme="dark"] h3,
173
+ [data-bs-theme="dark"] h4 { color: #DFD7CA; }
174
+
175
+ [data-bs-theme="dark"] h2 { border-color: #495057; }
176
+
177
+ [data-bs-theme="dark"] pre,
178
+ [data-bs-theme="dark"] div.sourceCode {
179
+ background-color: #2C2F31;
180
+ border-color: #495057;
181
+ color: #DFD7CA;
182
+ }
183
+
184
+ [data-bs-theme="dark"] code {
185
+ background-color: #2C2F31;
186
+ color: #DFD7CA;
187
+ }
188
+
189
+ [data-bs-theme="dark"] div.sourceCode span[class] { color: #DFD7CA !important; }
190
+
191
+ [data-bs-theme="dark"] thead th {
192
+ background-color: #3d4043;
193
+ color: #DFD7CA;
194
+ border-color: #495057;
195
+ }
196
+ [data-bs-theme="dark"] td,
197
+ [data-bs-theme="dark"] th { border-color: #3d4043; }
198
+ [data-bs-theme="dark"] tbody tr:hover { background-color: rgba(73,80,87,.3); }
199
+
200
+ [data-bs-theme="dark"] aside a { color: #8e9499; }
201
+ [data-bs-theme="dark"] aside a:hover { color: #7ba8d0; }
202
+
203
+ [data-bs-theme="dark"] .doc-card {
204
+ background: #2C2F31;
205
+ border-color: #495057;
206
+ }
207
+ [data-bs-theme="dark"] .doc-card:hover { border-color: #7ba8d0; }
208
+ [data-bs-theme="dark"] .doc-card p { color: #8e9499; }
@@ -1,6 +1,6 @@
1
- -- Rewrite .md links to .html in pandoc output
2
- function Link(el)
3
- el.target = el.target:gsub("%.md$", ".html")
4
- el.target = el.target:gsub("%.md#", ".html#")
5
- return el
6
- end
1
+ -- Rewrite .md links to .html in pandoc output
2
+ function Link(el)
3
+ el.target = el.target:gsub("%.md$", ".html")
4
+ el.target = el.target:gsub("%.md#", ".html#")
5
+ return el
6
+ end