docrev 0.9.18 → 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 (134) hide show
  1. package/.gitattributes +1 -1
  2. package/CHANGELOG.md +173 -149
  3. package/PLAN-tables-and-postprocess.md +850 -850
  4. package/README.md +431 -406
  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/build.d.ts +8 -0
  11. package/dist/lib/build.d.ts.map +1 -1
  12. package/dist/lib/build.js +62 -6
  13. package/dist/lib/build.js.map +1 -1
  14. package/dist/lib/commands/context.d.ts +1 -1
  15. package/dist/lib/commands/context.d.ts.map +1 -1
  16. package/dist/lib/commands/context.js +1 -1
  17. package/dist/lib/commands/context.js.map +1 -1
  18. package/dist/lib/commands/sections.js +7 -7
  19. package/dist/lib/commands/sections.js.map +1 -1
  20. package/dist/lib/commands/sync.d.ts.map +1 -1
  21. package/dist/lib/commands/sync.js +15 -14
  22. package/dist/lib/commands/sync.js.map +1 -1
  23. package/dist/lib/commands/utilities.js +164 -164
  24. package/dist/lib/commands/verify-anchors.js +6 -6
  25. package/dist/lib/commands/verify-anchors.js.map +1 -1
  26. package/dist/lib/commands/word-tools.js +8 -8
  27. package/dist/lib/grammar.js +3 -3
  28. package/dist/lib/macro-filter.lua +201 -0
  29. package/dist/lib/macros.d.ts +102 -0
  30. package/dist/lib/macros.d.ts.map +1 -0
  31. package/dist/lib/macros.js +218 -0
  32. package/dist/lib/macros.js.map +1 -0
  33. package/dist/lib/pdf-comments.js +44 -44
  34. package/dist/lib/plugins.js +57 -57
  35. package/dist/lib/pptx-color-filter.lua +37 -0
  36. package/dist/lib/pptx-themes.js +115 -115
  37. package/dist/lib/schema.d.ts.map +1 -1
  38. package/dist/lib/schema.js +34 -0
  39. package/dist/lib/schema.js.map +1 -1
  40. package/dist/lib/sections.d.ts +35 -0
  41. package/dist/lib/sections.d.ts.map +1 -1
  42. package/dist/lib/sections.js +81 -0
  43. package/dist/lib/sections.js.map +1 -1
  44. package/dist/lib/spelling.js +2 -2
  45. package/dist/lib/templates.js +387 -387
  46. package/dist/lib/themes.js +51 -51
  47. package/eslint.config.js +27 -27
  48. package/lib/anchor-match.ts +276 -276
  49. package/lib/annotations.ts +644 -644
  50. package/lib/build.ts +1766 -1694
  51. package/lib/citations.ts +160 -160
  52. package/lib/commands/build.ts +855 -855
  53. package/lib/commands/citations.ts +515 -515
  54. package/lib/commands/comments.ts +1050 -1050
  55. package/lib/commands/context.ts +176 -174
  56. package/lib/commands/core.ts +309 -309
  57. package/lib/commands/doi.ts +435 -435
  58. package/lib/commands/file-ops.ts +372 -372
  59. package/lib/commands/history.ts +320 -320
  60. package/lib/commands/index.ts +87 -87
  61. package/lib/commands/init.ts +259 -259
  62. package/lib/commands/merge-resolve.ts +378 -378
  63. package/lib/commands/preview.ts +178 -178
  64. package/lib/commands/project-info.ts +244 -244
  65. package/lib/commands/quality.ts +517 -517
  66. package/lib/commands/response.ts +454 -454
  67. package/lib/commands/section-boundaries.ts +82 -82
  68. package/lib/commands/sections.ts +451 -451
  69. package/lib/commands/sync.ts +709 -706
  70. package/lib/commands/text-ops.ts +449 -449
  71. package/lib/commands/utilities.ts +448 -448
  72. package/lib/commands/verify-anchors.ts +272 -272
  73. package/lib/commands/word-tools.ts +340 -340
  74. package/lib/comment-realign.ts +517 -517
  75. package/lib/config.ts +84 -84
  76. package/lib/crossref.ts +781 -781
  77. package/lib/csl.ts +191 -191
  78. package/lib/dependencies.ts +98 -98
  79. package/lib/diff-engine.ts +465 -465
  80. package/lib/doi-cache.ts +115 -115
  81. package/lib/doi.ts +897 -897
  82. package/lib/equations.ts +506 -506
  83. package/lib/errors.ts +346 -346
  84. package/lib/format.ts +541 -541
  85. package/lib/git.ts +326 -326
  86. package/lib/grammar.ts +303 -303
  87. package/lib/image-registry.ts +180 -180
  88. package/lib/import.ts +911 -911
  89. package/lib/journals.ts +543 -543
  90. package/lib/macro-filter.lua +201 -0
  91. package/lib/macros.ts +273 -0
  92. package/lib/merge.ts +633 -633
  93. package/lib/orcid.ts +144 -144
  94. package/lib/pdf-comments.ts +263 -263
  95. package/lib/pdf-import.ts +524 -524
  96. package/lib/plugins.ts +362 -362
  97. package/lib/postprocess.ts +188 -188
  98. package/lib/pptx-color-filter.lua +37 -37
  99. package/lib/pptx-template.ts +469 -469
  100. package/lib/pptx-themes.ts +483 -483
  101. package/lib/protect-restore.ts +520 -520
  102. package/lib/rate-limiter.ts +94 -94
  103. package/lib/response.ts +197 -197
  104. package/lib/restore-references.ts +240 -240
  105. package/lib/review.ts +327 -327
  106. package/lib/schema.ts +488 -454
  107. package/lib/scientific-words.ts +73 -73
  108. package/lib/sections.ts +425 -335
  109. package/lib/slides.ts +756 -756
  110. package/lib/spelling.ts +334 -334
  111. package/lib/templates.ts +526 -526
  112. package/lib/themes.ts +742 -742
  113. package/lib/trackchanges.ts +247 -247
  114. package/lib/tui.ts +450 -450
  115. package/lib/types.ts +550 -550
  116. package/lib/undo.ts +250 -250
  117. package/lib/utils.ts +69 -69
  118. package/lib/variables.ts +179 -179
  119. package/lib/word-extraction.ts +806 -806
  120. package/lib/word.ts +643 -643
  121. package/lib/wordcomments.ts +840 -840
  122. package/package.json +137 -137
  123. package/scripts/postbuild.js +47 -28
  124. package/skill/REFERENCE.md +539 -539
  125. package/skill/SKILL.md +295 -295
  126. package/tsconfig.json +26 -26
  127. package/types/index.d.ts +525 -525
  128. package/issues.md +0 -180
  129. package/site/assets/extra.css +0 -208
  130. package/site/commands.html +0 -926
  131. package/site/configuration.html +0 -469
  132. package/site/index.html +0 -288
  133. package/site/troubleshooting.html +0 -461
  134. package/site/workflow.html +0 -518
package/skill/SKILL.md CHANGED
@@ -1,295 +1,295 @@
1
- ---
2
- name: docrev
3
- description: "Document revision workflow tool (CLI: `rev`). Use when working with Word documents containing reviewer comments, importing track changes to markdown, replying to reviewer comments, building PDF/DOCX outputs, generating response letters, validating citations/DOIs, or any document revision task."
4
- ---
5
-
6
- # docrev - Document Revision Tool
7
-
8
- `rev` is a CLI tool for document workflows with Word ↔ Markdown round-trips.
9
-
10
- Works for any document that goes through Word-based review: scientific papers, contracts, reports, proposals, manuals.
11
-
12
- ## Content and Layout, Separated
13
-
14
- In Markdown, you focus on content. Write text, add citations with `[@key]`, insert equations with `$...$`, reference figures with `@fig:label`. No fiddling with fonts or styles.
15
-
16
- Layout is controlled in `rev.yaml`:
17
-
18
- ```yaml
19
- title: "My Document"
20
- docx:
21
- reference: template.docx
22
- ```
23
-
24
- Change the template, rebuild, and every document gets the new formatting.
25
-
26
- ## Core Workflow
27
-
28
- ### 1. Create or import a project
29
-
30
- ```bash
31
- rev new my-document # Start from scratch
32
- rev import manuscript.docx # Start from existing Word doc
33
- ```
34
-
35
- ### 2. Build and share
36
-
37
- ```bash
38
- rev build docx # Generate Word document
39
- ```
40
-
41
- Send to reviewers. They add comments and track changes in Word.
42
-
43
- ### 3. Import feedback
44
-
45
- ```bash
46
- rev sync reviewed.docx # Updates markdown with annotations
47
- rev sync # Auto-detect most recent .docx
48
- rev sync reviewed.docx --comments-only # Insert comments only; never modify prose
49
- rev verify-anchors reviewed.docx # Report which anchors still match current prose
50
- ```
51
-
52
- Use `--comments-only` when the markdown has been revised between sending the
53
- docx out and receiving it back. Without the flag, track changes from a stale
54
- draft would clobber newer edits. With it, only comments are imported, placed
55
- at fuzzy-matched anchors against the current prose. Run `rev verify-anchors`
56
- first to see which comments will land cleanly and which need manual placement.
57
-
58
- ### 4. View and address comments
59
-
60
- ```bash
61
- rev status # Project overview
62
- rev todo # List all pending comments
63
- rev next # Show next pending comment
64
- rev comments methods.md # List all comments with context
65
- ```
66
-
67
- ### 5. Reply to reviewer comments
68
-
69
- **Always use the non-interactive reply mode:**
70
-
71
- ```bash
72
- rev reply methods.md -n 1 -m "Added clarification about sampling methodology"
73
- rev reply results.md -n 3 -m "Updated figure to include 95% CI"
74
- ```
75
-
76
- Replies appear as: `{>>Reviewer: Original<<} {>>User: Reply<<}`
77
-
78
- ### 6. Resolve addressed comments
79
-
80
- ```bash
81
- rev resolve methods.md -n 1 # Mark comment #1 as resolved
82
- ```
83
-
84
- ### 7. Rebuild with comment threads
85
-
86
- ```bash
87
- rev build docx --dual # Produces clean + annotated versions
88
- rev build docx --show-changes # Single DOCX with visible track changes
89
- ```
90
-
91
- `--dual` produces:
92
- - `output/<title>.docx` — clean, for submission
93
- - `output/<title>_comments.docx` — comment threads as Word comments
94
-
95
- `--show-changes` produces a single audit DOCX where every accepted/rejected
96
- revision is rendered as a visible Word track change. Useful when a co-author
97
- wants to see what changed since the last shared version.
98
-
99
- Outputs land in `output/` by default; set `outputDir: null` in `rev.yaml`
100
- to keep them alongside `paper.md` (legacy layout). The basename is derived
101
- from `title:` unless overridden — set `output: { docx: foo.docx, pdf: foo.pdf }`
102
- in `rev.yaml` or pass `-o, --output <path>` on the CLI. See REFERENCE.md →
103
- "Choosing output filenames".
104
-
105
- For pandoc flags rev doesn't surface directly (Lua filters, custom variables,
106
- templates), use `--pandoc-arg` (repeatable) or `pandoc-args:` in `rev.yaml`
107
- (both top-level and per-format). Run with `--verbose` to see the exact pandoc
108
- invocation. See REFERENCE.md → "Passing custom pandoc args" for details.
109
-
110
- ### 8. Archive reviewer files
111
-
112
- ```bash
113
- rev archive # Move reviewer files to archive/
114
- ```
115
-
116
- ### 9. Generate response letter
117
-
118
- ```bash
119
- rev response # Generate point-by-point response letter
120
- ```
121
-
122
- ## Annotation Syntax (CriticMarkup)
123
-
124
- - `{++inserted text++}` - Additions
125
- - `{--deleted text--}` - Deletions
126
- - `{~~old~>new~~}` - Substitutions
127
- - `{>>Author: comment<<}` - Comments
128
- - `{>>Author: comment [RESOLVED]<<}` - Resolved comment
129
-
130
- ## Quick Commands
131
-
132
- | Task | Command |
133
- |------|---------|
134
- | Create project | `rev new my-project` |
135
- | Create LaTeX project | `rev new my-project --template latex` |
136
- | Import Word doc | `rev import manuscript.docx` |
137
- | Sync Word feedback | `rev sync reviewed.docx` |
138
- | Sync comments only (prose unchanged) | `rev sync reviewed.docx --comments-only` |
139
- | Verify anchors against current prose | `rev verify-anchors reviewed.docx` |
140
- | Sync PDF comments | `rev sync annotated.pdf` |
141
- | Extract PDF comments | `rev pdf-comments annotated.pdf` |
142
- | Extract with highlighted text | `rev pdf-comments file.pdf --with-text` |
143
- | Append PDF comments | `rev pdf-comments annotated.pdf --append methods.md` |
144
- | Project status | `rev status` |
145
- | Next pending | `rev next` |
146
- | List pending | `rev todo` |
147
- | Filter by author | `rev comments file.md --author "Reviewer 2"` |
148
- | Reply to all pending | `rev reply file.md --all -m "Addressed"` |
149
- | Accept all changes | `rev accept file.md -a` |
150
- | Build Word | `rev build docx` |
151
- | Build PDF | `rev build pdf` |
152
- | Build clean + annotated Word | `rev build docx --dual` |
153
- | Build clean + annotated PDF | `rev build pdf --dual` |
154
- | Build with visible track changes | `rev build docx --show-changes` |
155
- | Show contributors | `rev contributors` |
156
- | Lookup ORCID | `rev orcid 0000-0002-1825-0097` |
157
- | Archive reviewer files | `rev archive` |
158
- | Word count per section | `rev word-count` |
159
- | Project dashboard | `rev stats` |
160
- | Search all sections | `rev search "query"` |
161
- | Pre-submission check | `rev check` |
162
- | Validate citations | `rev citations` |
163
- | Check grammar/style | `rev grammar` |
164
- | Check spelling | `rev spelling` |
165
- | Open PDF preview | `rev preview pdf` |
166
- | Auto-rebuild on changes | `rev watch` |
167
- | Check for updates | `rev upgrade --check` |
168
-
169
- ## DOI Management
170
-
171
- ```bash
172
- rev doi check references.bib # Validate DOIs
173
- rev doi lookup references.bib # Find missing DOIs
174
- rev doi add 10.1234/example # Add citation from DOI
175
- ```
176
-
177
- ## Validation
178
-
179
- ```bash
180
- rev validate --journal nature # Check journal requirements
181
- rev validate --list # List 22 available journal profiles
182
- rev lint # Check broken refs, missing citations
183
- ```
184
-
185
- ## Cross-References
186
-
187
- Use in markdown files:
188
- - `@fig:label` - Figure reference (becomes "Figure 1" in Word)
189
- - `@tbl:label` - Table reference
190
- - `@eq:label` - Equation reference
191
- - `{#fig:label}` - Anchor for figures
192
-
193
- Insert a figure with the format-portable syntax (renders in both PDF and Word):
194
-
195
- ```markdown
196
- ![Caption text.](figures/foo.pdf){#fig:foo width=80%}
197
- ```
198
-
199
- Raw `\begin{figure}...\end{figure}` LaTeX blocks are PDF-only. For docx
200
- builds, `rev` auto-translates the common shape (single `\includegraphics`
201
- with optional `\caption{...}` and `\label{...}`) to the markdown form above
202
- so figures still render. Exotic blocks (`\subfloat`, `\rotatebox`, multiple
203
- `\includegraphics`) are left alone and warned about — convert them by hand
204
- or supply a custom Lua filter via `--pandoc-arg`. Opt out of auto-translate
205
- with `docx.translateRawFigures: false` in `rev.yaml`.
206
-
207
- ## Template Variables
208
-
209
- Available in section files (processed during build):
210
- - `{{date}}` - Current date (YYYY-MM-DD)
211
- - `{{date:MMMM D, YYYY}}` - Custom format
212
- - `{{title}}` - Document title
213
- - `{{author}}` - First author
214
- - `{{word_count}}` - Total word count
215
-
216
- ## Project Structure
217
-
218
- ```
219
- my-document/
220
- ├── rev.yaml # Project config
221
- ├── introduction.md # Section files with annotations
222
- ├── methods.md
223
- ├── results.md
224
- ├── discussion.md
225
- ├── references.bib # Bibliography
226
- ├── figures/ # Images
227
- ├── paper.md # Combined sections (auto-generated)
228
- └── output/ # Built artefacts
229
- ├── my-document.docx
230
- └── my-document.pdf
231
- ```
232
-
233
- Set `outputDir: null` in `rev.yaml` to write outputs alongside `paper.md`
234
- instead.
235
-
236
- ## PDF Comment Workflow
237
-
238
- For reviewers who annotate PDFs instead of Word documents:
239
-
240
- ### 1. Extract comments from PDF
241
-
242
- ```bash
243
- rev pdf-comments annotated.pdf # Display all comments
244
- rev pdf-comments annotated.pdf --by-author # Group by reviewer
245
- rev pdf-comments annotated.pdf --json # Output as JSON
246
- ```
247
-
248
- ### 2. Import into markdown
249
-
250
- ```bash
251
- rev sync annotated.pdf # Auto-import to sections
252
- rev pdf-comments annotated.pdf --append methods.md # Append to specific file
253
- ```
254
-
255
- ### 3. Build PDF with margin notes
256
-
257
- ```bash
258
- rev build pdf --dual
259
- ```
260
-
261
- Produces:
262
- - `paper.pdf` — clean version for submission
263
- - `paper_comments.pdf` — comments rendered as LaTeX margin notes
264
-
265
- **Supported PDF Annotations:**
266
- - Sticky notes, text boxes, highlights, underlines, strikethrough, squiggly
267
-
268
- ## When Helping Users
269
-
270
- 1. **Setup**: Ensure `rev config user "Name"` is set for replies
271
- 2. **Sync phase**: Run `rev sync` to get feedback (works with both Word and PDF)
272
- 3. **Review phase**: Use `rev todo` and `rev next` to navigate comments, `rev reply` to respond
273
- 4. **Accept phase**: Use `rev accept -a` or `rev review` to handle track changes
274
- 5. **Build phase**: Run `rev build docx --dual` or `rev build pdf --dual` for annotated versions
275
- 6. **Archive phase**: Run `rev archive` to move reviewer files
276
- 7. **Validation phase**: Run `rev check` before submission
277
- 8. **Response letter**: Use `rev response` to generate point-by-point responses
278
-
279
- ## Critical: Ask Questions When Unsure
280
-
281
- When addressing reviewer comments or editing documents:
282
-
283
- - **Never guess methods or numbers** - If a comment asks for clarification about methodology, sample sizes, statistical parameters, dates, or any quantitative information, ASK the user rather than inventing values
284
- - **Placeholders are acceptable** - Use `[???]` or `[TODO: specify X]` when information is missing rather than fabricating data
285
- - **Search online for references** - When comments request citations, use web search to find appropriate references rather than guessing
286
- - **Clarify ambiguous requests** - If a reviewer comment could be interpreted multiple ways, ask the user which interpretation they prefer
287
- - **Verify existing values** - When editing numbers that already exist in the document, confirm changes with the user if there's any doubt
288
-
289
- Example scenarios requiring user input:
290
- - "Add a reference for this claim" → Search online OR ask user for specific citation
291
- - "Clarify the sample size" → Ask user for the correct number
292
- - "Specify the statistical test used" → Ask user which test was actually used
293
- - "Add the date of data collection" → Ask user for the actual date
294
-
295
- For complete command reference, see [REFERENCE.md](REFERENCE.md).
1
+ ---
2
+ name: docrev
3
+ description: "Document revision workflow tool (CLI: `rev`). Use when working with Word documents containing reviewer comments, importing track changes to markdown, replying to reviewer comments, building PDF/DOCX outputs, generating response letters, validating citations/DOIs, or any document revision task."
4
+ ---
5
+
6
+ # docrev - Document Revision Tool
7
+
8
+ `rev` is a CLI tool for document workflows with Word ↔ Markdown round-trips.
9
+
10
+ Works for any document that goes through Word-based review: scientific papers, contracts, reports, proposals, manuals.
11
+
12
+ ## Content and Layout, Separated
13
+
14
+ In Markdown, you focus on content. Write text, add citations with `[@key]`, insert equations with `$...$`, reference figures with `@fig:label`. No fiddling with fonts or styles.
15
+
16
+ Layout is controlled in `rev.yaml`:
17
+
18
+ ```yaml
19
+ title: "My Document"
20
+ docx:
21
+ reference: template.docx
22
+ ```
23
+
24
+ Change the template, rebuild, and every document gets the new formatting.
25
+
26
+ ## Core Workflow
27
+
28
+ ### 1. Create or import a project
29
+
30
+ ```bash
31
+ rev new my-document # Start from scratch
32
+ rev import manuscript.docx # Start from existing Word doc
33
+ ```
34
+
35
+ ### 2. Build and share
36
+
37
+ ```bash
38
+ rev build docx # Generate Word document
39
+ ```
40
+
41
+ Send to reviewers. They add comments and track changes in Word.
42
+
43
+ ### 3. Import feedback
44
+
45
+ ```bash
46
+ rev sync reviewed.docx # Updates markdown with annotations
47
+ rev sync # Auto-detect most recent .docx
48
+ rev sync reviewed.docx --comments-only # Insert comments only; never modify prose
49
+ rev verify-anchors reviewed.docx # Report which anchors still match current prose
50
+ ```
51
+
52
+ Use `--comments-only` when the markdown has been revised between sending the
53
+ docx out and receiving it back. Without the flag, track changes from a stale
54
+ draft would clobber newer edits. With it, only comments are imported, placed
55
+ at fuzzy-matched anchors against the current prose. Run `rev verify-anchors`
56
+ first to see which comments will land cleanly and which need manual placement.
57
+
58
+ ### 4. View and address comments
59
+
60
+ ```bash
61
+ rev status # Project overview
62
+ rev todo # List all pending comments
63
+ rev next # Show next pending comment
64
+ rev comments methods.md # List all comments with context
65
+ ```
66
+
67
+ ### 5. Reply to reviewer comments
68
+
69
+ **Always use the non-interactive reply mode:**
70
+
71
+ ```bash
72
+ rev reply methods.md -n 1 -m "Added clarification about sampling methodology"
73
+ rev reply results.md -n 3 -m "Updated figure to include 95% CI"
74
+ ```
75
+
76
+ Replies appear as: `{>>Reviewer: Original<<} {>>User: Reply<<}`
77
+
78
+ ### 6. Resolve addressed comments
79
+
80
+ ```bash
81
+ rev resolve methods.md -n 1 # Mark comment #1 as resolved
82
+ ```
83
+
84
+ ### 7. Rebuild with comment threads
85
+
86
+ ```bash
87
+ rev build docx --dual # Produces clean + annotated versions
88
+ rev build docx --show-changes # Single DOCX with visible track changes
89
+ ```
90
+
91
+ `--dual` produces:
92
+ - `output/<title>.docx` — clean, for submission
93
+ - `output/<title>_comments.docx` — comment threads as Word comments
94
+
95
+ `--show-changes` produces a single audit DOCX where every accepted/rejected
96
+ revision is rendered as a visible Word track change. Useful when a co-author
97
+ wants to see what changed since the last shared version.
98
+
99
+ Outputs land in `output/` by default; set `outputDir: null` in `rev.yaml`
100
+ to keep them alongside `paper.md` (legacy layout). The basename is derived
101
+ from `title:` unless overridden — set `output: { docx: foo.docx, pdf: foo.pdf }`
102
+ in `rev.yaml` or pass `-o, --output <path>` on the CLI. See REFERENCE.md →
103
+ "Choosing output filenames".
104
+
105
+ For pandoc flags rev doesn't surface directly (Lua filters, custom variables,
106
+ templates), use `--pandoc-arg` (repeatable) or `pandoc-args:` in `rev.yaml`
107
+ (both top-level and per-format). Run with `--verbose` to see the exact pandoc
108
+ invocation. See REFERENCE.md → "Passing custom pandoc args" for details.
109
+
110
+ ### 8. Archive reviewer files
111
+
112
+ ```bash
113
+ rev archive # Move reviewer files to archive/
114
+ ```
115
+
116
+ ### 9. Generate response letter
117
+
118
+ ```bash
119
+ rev response # Generate point-by-point response letter
120
+ ```
121
+
122
+ ## Annotation Syntax (CriticMarkup)
123
+
124
+ - `{++inserted text++}` - Additions
125
+ - `{--deleted text--}` - Deletions
126
+ - `{~~old~>new~~}` - Substitutions
127
+ - `{>>Author: comment<<}` - Comments
128
+ - `{>>Author: comment [RESOLVED]<<}` - Resolved comment
129
+
130
+ ## Quick Commands
131
+
132
+ | Task | Command |
133
+ |------|---------|
134
+ | Create project | `rev new my-project` |
135
+ | Create LaTeX project | `rev new my-project --template latex` |
136
+ | Import Word doc | `rev import manuscript.docx` |
137
+ | Sync Word feedback | `rev sync reviewed.docx` |
138
+ | Sync comments only (prose unchanged) | `rev sync reviewed.docx --comments-only` |
139
+ | Verify anchors against current prose | `rev verify-anchors reviewed.docx` |
140
+ | Sync PDF comments | `rev sync annotated.pdf` |
141
+ | Extract PDF comments | `rev pdf-comments annotated.pdf` |
142
+ | Extract with highlighted text | `rev pdf-comments file.pdf --with-text` |
143
+ | Append PDF comments | `rev pdf-comments annotated.pdf --append methods.md` |
144
+ | Project status | `rev status` |
145
+ | Next pending | `rev next` |
146
+ | List pending | `rev todo` |
147
+ | Filter by author | `rev comments file.md --author "Reviewer 2"` |
148
+ | Reply to all pending | `rev reply file.md --all -m "Addressed"` |
149
+ | Accept all changes | `rev accept file.md -a` |
150
+ | Build Word | `rev build docx` |
151
+ | Build PDF | `rev build pdf` |
152
+ | Build clean + annotated Word | `rev build docx --dual` |
153
+ | Build clean + annotated PDF | `rev build pdf --dual` |
154
+ | Build with visible track changes | `rev build docx --show-changes` |
155
+ | Show contributors | `rev contributors` |
156
+ | Lookup ORCID | `rev orcid 0000-0002-1825-0097` |
157
+ | Archive reviewer files | `rev archive` |
158
+ | Word count per section | `rev word-count` |
159
+ | Project dashboard | `rev stats` |
160
+ | Search all sections | `rev search "query"` |
161
+ | Pre-submission check | `rev check` |
162
+ | Validate citations | `rev citations` |
163
+ | Check grammar/style | `rev grammar` |
164
+ | Check spelling | `rev spelling` |
165
+ | Open PDF preview | `rev preview pdf` |
166
+ | Auto-rebuild on changes | `rev watch` |
167
+ | Check for updates | `rev upgrade --check` |
168
+
169
+ ## DOI Management
170
+
171
+ ```bash
172
+ rev doi check references.bib # Validate DOIs
173
+ rev doi lookup references.bib # Find missing DOIs
174
+ rev doi add 10.1234/example # Add citation from DOI
175
+ ```
176
+
177
+ ## Validation
178
+
179
+ ```bash
180
+ rev validate --journal nature # Check journal requirements
181
+ rev validate --list # List 22 available journal profiles
182
+ rev lint # Check broken refs, missing citations
183
+ ```
184
+
185
+ ## Cross-References
186
+
187
+ Use in markdown files:
188
+ - `@fig:label` - Figure reference (becomes "Figure 1" in Word)
189
+ - `@tbl:label` - Table reference
190
+ - `@eq:label` - Equation reference
191
+ - `{#fig:label}` - Anchor for figures
192
+
193
+ Insert a figure with the format-portable syntax (renders in both PDF and Word):
194
+
195
+ ```markdown
196
+ ![Caption text.](figures/foo.pdf){#fig:foo width=80%}
197
+ ```
198
+
199
+ Raw `\begin{figure}...\end{figure}` LaTeX blocks are PDF-only. For docx
200
+ builds, `rev` auto-translates the common shape (single `\includegraphics`
201
+ with optional `\caption{...}` and `\label{...}`) to the markdown form above
202
+ so figures still render. Exotic blocks (`\subfloat`, `\rotatebox`, multiple
203
+ `\includegraphics`) are left alone and warned about — convert them by hand
204
+ or supply a custom Lua filter via `--pandoc-arg`. Opt out of auto-translate
205
+ with `docx.translateRawFigures: false` in `rev.yaml`.
206
+
207
+ ## Template Variables
208
+
209
+ Available in section files (processed during build):
210
+ - `{{date}}` - Current date (YYYY-MM-DD)
211
+ - `{{date:MMMM D, YYYY}}` - Custom format
212
+ - `{{title}}` - Document title
213
+ - `{{author}}` - First author
214
+ - `{{word_count}}` - Total word count
215
+
216
+ ## Project Structure
217
+
218
+ ```
219
+ my-document/
220
+ ├── rev.yaml # Project config
221
+ ├── introduction.md # Section files with annotations
222
+ ├── methods.md
223
+ ├── results.md
224
+ ├── discussion.md
225
+ ├── references.bib # Bibliography
226
+ ├── figures/ # Images
227
+ ├── paper.md # Combined sections (auto-generated)
228
+ └── output/ # Built artefacts
229
+ ├── my-document.docx
230
+ └── my-document.pdf
231
+ ```
232
+
233
+ Set `outputDir: null` in `rev.yaml` to write outputs alongside `paper.md`
234
+ instead.
235
+
236
+ ## PDF Comment Workflow
237
+
238
+ For reviewers who annotate PDFs instead of Word documents:
239
+
240
+ ### 1. Extract comments from PDF
241
+
242
+ ```bash
243
+ rev pdf-comments annotated.pdf # Display all comments
244
+ rev pdf-comments annotated.pdf --by-author # Group by reviewer
245
+ rev pdf-comments annotated.pdf --json # Output as JSON
246
+ ```
247
+
248
+ ### 2. Import into markdown
249
+
250
+ ```bash
251
+ rev sync annotated.pdf # Auto-import to sections
252
+ rev pdf-comments annotated.pdf --append methods.md # Append to specific file
253
+ ```
254
+
255
+ ### 3. Build PDF with margin notes
256
+
257
+ ```bash
258
+ rev build pdf --dual
259
+ ```
260
+
261
+ Produces:
262
+ - `paper.pdf` — clean version for submission
263
+ - `paper_comments.pdf` — comments rendered as LaTeX margin notes
264
+
265
+ **Supported PDF Annotations:**
266
+ - Sticky notes, text boxes, highlights, underlines, strikethrough, squiggly
267
+
268
+ ## When Helping Users
269
+
270
+ 1. **Setup**: Ensure `rev config user "Name"` is set for replies
271
+ 2. **Sync phase**: Run `rev sync` to get feedback (works with both Word and PDF)
272
+ 3. **Review phase**: Use `rev todo` and `rev next` to navigate comments, `rev reply` to respond
273
+ 4. **Accept phase**: Use `rev accept -a` or `rev review` to handle track changes
274
+ 5. **Build phase**: Run `rev build docx --dual` or `rev build pdf --dual` for annotated versions
275
+ 6. **Archive phase**: Run `rev archive` to move reviewer files
276
+ 7. **Validation phase**: Run `rev check` before submission
277
+ 8. **Response letter**: Use `rev response` to generate point-by-point responses
278
+
279
+ ## Critical: Ask Questions When Unsure
280
+
281
+ When addressing reviewer comments or editing documents:
282
+
283
+ - **Never guess methods or numbers** - If a comment asks for clarification about methodology, sample sizes, statistical parameters, dates, or any quantitative information, ASK the user rather than inventing values
284
+ - **Placeholders are acceptable** - Use `[???]` or `[TODO: specify X]` when information is missing rather than fabricating data
285
+ - **Search online for references** - When comments request citations, use web search to find appropriate references rather than guessing
286
+ - **Clarify ambiguous requests** - If a reviewer comment could be interpreted multiple ways, ask the user which interpretation they prefer
287
+ - **Verify existing values** - When editing numbers that already exist in the document, confirm changes with the user if there's any doubt
288
+
289
+ Example scenarios requiring user input:
290
+ - "Add a reference for this claim" → Search online OR ask user for specific citation
291
+ - "Clarify the sample size" → Ask user for the correct number
292
+ - "Specify the statistical test used" → Ask user which test was actually used
293
+ - "Add the date of data collection" → Ask user for the actual date
294
+
295
+ For complete command reference, see [REFERENCE.md](REFERENCE.md).
package/tsconfig.json CHANGED
@@ -1,26 +1,26 @@
1
- {
2
- "compilerOptions": {
3
- "target": "ES2022",
4
- "module": "NodeNext",
5
- "moduleResolution": "NodeNext",
6
- "lib": ["ES2022"],
7
- "outDir": "./dist",
8
- "rootDir": ".",
9
- "declaration": true,
10
- "declarationMap": true,
11
- "sourceMap": true,
12
- "strict": true,
13
- "noImplicitAny": true,
14
- "strictNullChecks": true,
15
- "noImplicitReturns": true,
16
- "noUncheckedIndexedAccess": false,
17
- "esModuleInterop": true,
18
- "skipLibCheck": true,
19
- "forceConsistentCasingInFileNames": true,
20
- "resolveJsonModule": true,
21
- "allowJs": true,
22
- "checkJs": false
23
- },
24
- "include": ["lib/**/*", "bin/**/*"],
25
- "exclude": ["node_modules", "dist", "test"]
26
- }
1
+ {
2
+ "compilerOptions": {
3
+ "target": "ES2022",
4
+ "module": "NodeNext",
5
+ "moduleResolution": "NodeNext",
6
+ "lib": ["ES2022"],
7
+ "outDir": "./dist",
8
+ "rootDir": ".",
9
+ "declaration": true,
10
+ "declarationMap": true,
11
+ "sourceMap": true,
12
+ "strict": true,
13
+ "noImplicitAny": true,
14
+ "strictNullChecks": true,
15
+ "noImplicitReturns": true,
16
+ "noUncheckedIndexedAccess": false,
17
+ "esModuleInterop": true,
18
+ "skipLibCheck": true,
19
+ "forceConsistentCasingInFileNames": true,
20
+ "resolveJsonModule": true,
21
+ "allowJs": true,
22
+ "checkJs": false
23
+ },
24
+ "include": ["lib/**/*", "bin/**/*"],
25
+ "exclude": ["node_modules", "dist", "test"]
26
+ }