Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/mooerslab/writing-progress-2024-25

Track words written and time spent on writing projects in 2024 and 2025.
https://github.com/mooerslab/writing-progress-2024-25

accountability career-management excel getting-things-done google-sheets libre-office open-office project-management scientific-writing self-motivation time-management time-power writing-project-management

Last synced: 20 days ago
JSON representation

Track words written and time spent on writing projects in 2024 and 2025.

Awesome Lists containing this project

README

        

![Version](https://img.shields.io/static/v1?label=writing-progress-2024-25&message=0.5.1&color=brightcolor)
[![License: MIT](https://img.shields.io/badge/License-MIT-blue.svg)](https://opensource.org/licenses/MIT)

# Track progress on writing projects with bar plots and heatmaps

## Format
Google Sheets workbook exported to Excel or ODT workbook files.
Either can be imported back into Google Sheets.
I recommend using Google Sheets for faster access to enter daily progress.
Store the link to the workbook in a bookmark, or better yet, in a local index.html file for fast access from your browser.
You can also store the link in a voice command; see the [quick start](#note) section below.

## The problem addressed

Managing multiple writing projects is a significant unsolved problem in academic writing and time management.
Most academics have to make progress on two or more writing projects per day.
The overhead for doing so consumes mental bandwidth.
Most books on academic writing skip over this problem because they do not have a good solution for this problem.
I designed the above spreadsheets to address this problem.

Most writing guides suggest tracking the total effort expended on writing per day in terms of minutes spent, word count, or both.
Word count tends to plateau early when writing academic papers and grant applications, so tracking time is more important.
The spreadsheets support tracking both.
The workbook tracks at the project level so that you can monitor the distribution of your effort.
You can use it well or poorly, like any tool. Good luck!

## Synopsis
The above Open Office Document (writing-progress-2024-25.ods) can be imported into Google Sheets, where it was created.
You can also open this document in Libre Office or Open Office for offline use.
The Excel version writing-progress-2024-25.xlsx can be run in Microsoft Excel.
Either document can be imported into your Google Drive account for faster access as a Google Sheets document.
I store a link to the Google Sheet document in my web browser for instant access.

After spending 10-30 minutes customizing the workbook for your current and planned writing projects, you should be set to track your writing progress by project for 2024 and 2025.
It should take no more than a minute a day to make the entries and to check on your monthly progress displayed as bar plots in the right margin, as shown below.
The sums in the bar plot are taken across all projects.
To check your effort on a particular project, open its project sheet and sum over columns F for minutes and G for words.

Version 0.5 contains a column on the left side of the min_day and word_day sheets with the difference between the cumulative monthly total and the cumulative monthly goal.
A negative value means that you are behind.

Python scripts are included for remotely accessing the min_day and word_day sheets and displaying a summary as a horizontal bar plot or a heatmap with matplotlib.
I mapped this to three-letter aliases for rapid access.

## Quick start: add today's progress for Project 18

1. Open the file.
2. Select Project sheet `18`.
3. Enter minutes spent on project 18 in column F and the current day's row.
4. Enter the number of words written on Project 18 in column G and the current day's row.

You are finished!! It is that fast and easy!!!

### Note:

If you use Voice In Plus, you can map the voice command `open sheet 18` to the code` >` to use your voice to open Project 18's Google Sheet for updating.
You can create multiple aliases for the same web page that do not include the project number so that you can still open up the appropriate sheet without remembering the project number.

I use the command `open project 18` to open the project's website on Overleaf.

You can do something similar with Serenade, Talon Voice, or the built-in Voice Control software on the Mac.

## Checking progress

1. Open sheet min_day. Scroll to the right margin. Inspect the bar graph for the current month. The gray bars are the cumulative goals; the orange bars are the cumulative progress.
2. Repeat with sheet word_day.

## Customization

1. Edit the sheet tabs to change the project names. This will break the formula in the corresponding column of the min_day and word_day sheets. Edit the formulas as needed.
2. Edit the column names in sheets `min_day` and `word_day` to refer to the changed project name.
3. [Optional] The goals can be reset to align with your objectives.

## Adding an eleventh project

1. Create a new project sheet by duplicating an old one and edit to customize it.
2. Insert a new project column in the `min_day` and `word_day` sheets and edit the column name to refer to the new project name.
3. Add the formula summation formula in row 733 of the new column else the Python scripts below will not work.
4. [Optional. Read to the end.] Edit the formula in the Daily Total column (column E) `min_day` and `word_day` to include the new column in the range of columns so that the progress on this project gets counted. Note that this formula will be automatically updated if you insert the new column at an interior site among the project columns.

## Observations

1. Limit the tracking to the projects you are committed to finishing in the next two years. The purpose of this tool is to sustain your commitment to finishing these projects, not necessarily to document your effort. You can use a writing log for that purpose (see [Writing Log templates](https://github.com/MooersLab#writing-log-for-planning-manuscripts)).
2. To save space, name the sheets using integers. Map the project number to the project name in the project sheet.
3. The optimal column width for the project columns on the `min_day` and `word_da`y' sheets is 45 points when using four-digit project numbers.
4. Up to 30 projects can be viewed simultaneously without scrolling horizontally. You could always move some of the rightmost project columns on `min_day` and `word_day` sheet to the right of the bar plots to keep the bar plots in view without needing to scroll to the right or you can zoom out further.

**You are now ready for the next two years!!!!** :)

# Upgrades
## Version 0.5.1
- Minor edits of the readme.
- Added funding.

## Version 0.5

- Column inserted in the min_day and word_day sheets to record the difference between the cumulative monthly total and the monthly cumulative goal. A positive value means you are ahead of your goal, and a negative value means you are behind your goal. Glancing at this column might be faster and more informative than scrolling to the right to see the bar plots.

## Version 0.4

- Sum formula added to row 733 at the bottom of the columns for the projects in sheets `min_day` and `words_day`.
The minutes were converted to hours in these sums.

- Scripts provided to plot cumulative words and time spent by the project as bar plots (gs2hbarm.py and gs2hbarw.py) or by day as heatmaps (gs2hmw.py and gs2hmm.py) by extracting the data from the workbook on Google Sheets. You must provide authorization for access to your Google Drive and your Google Sheets. See the Read-the-docs for [gspread](https://docs.gspread.org/en/latest/oauth2.html). Take care to update the script file if rename the workbook.

- I map these scripts to the following three-letter bash aliases (`hbh`, `hbw`, `hmm`, and `hmw`) so that I can generate these plots on the fly from the prompt in the terminal. `mp312` is a bash alias to Python3.12 from MacPorts: `/opt/local/bin/python3.12`.

```bash
# barplots
alias hbh='mp312 ~/gs2hbarm.py && echo "Horizontal bar plot of hours spent per project since January 1, 2024."'
alias hbw='mp312 ~/gs2hbarw.py && echo "Horizontal bar plot of words written per project since January 1, 2024."'

# heatmaps.
alias hmm='mp312 ~/gs2hmm.py && echo "Heat map of minutes spent per day since January 1, 2024."'
alias hmw='mp312 ~/gs2hmw.py && echo "Heat map of words spent per day since January 1, 2024."'
```

Here is the heatmap on September 7, 2024. It was made with alias hmj to show effort on journal articles only. It is reading data from a sqlite time tracking database that I started in May 2022. This display shows repeating temporal variation due to teaching and NIH grant reviewer service.

# Long form version of the README.md

More details are found [here](https://github.com/MooersLab/writingProgess2023/edit/main/README.md)

# Related links

## Related projects of possible interest

- [Writing Log template in LaTeX](https://github.com/MooersLab/writingLogTemplate). This is the favored format. LaTeX beginners can easily use this document on Overleaf without any configuration.
- [Writing log template in Org-mode](https://github.com/MooersLab/writingLogTemplateInOrg) Has all of the features of the LaTeX variant. Favored by many Emacs users. Org-mode is a powerful analog of markdown that can interpret LaTeX code blocks. It is vastly more capable than markdown. It even supports literate programming.
- [Writing log template in reStructuredText](https://github.com/MooersLab/writing-log-rst) reStructuredText is used by programmers for documentation.
- [Writing log template in Markdown](https://github.com/MooersLab/writing-log-md) Markdown variant. Read and rendered to PDF by most good text editors.
- [Writing log template in ODT](https://github.com/MooersLab/writing-log-odt) ODT can be read by Open Office, LibreOffice, and MS Word.
- [Writing log template in DOCX for MS Word](https://github.com/MooersLab/writing-log-docx) MS Word variant. Probably the least suitable format for this task.
- [Voice computing-related repos](https://github.com/MooersLab#voice-computing)
- [LaTeX manuscript template](https://github.com/MooersLab/manuscriptInLaTeX/edit/main/README.md)
- [Org-mode manuscript template](https://github.com/MooersLab/manuscriptInOrg/edit/main/README.md)
- [Slideshow template in LaTeX](https://github.com/MooersLab/slideshowTemplateLaTeX)
- [Annotated bibliography Template in LaTeX](https://github.com/MooersLab/annotatedBibliography)
- [Diary for 2024 in LaTeX](https://github.com/MooersLab/diary2024inLaTeX)
- [latex-emacs profile](https://github.com/MooersLab/latex-emacs)
- [default Emacs profile](https://github.com/MooersLab/configorg)
- [snippets for latex-mode in Emacs](https://github.com/MooersLab/snippet-latex-mode)
- [Quizzes about Emacs to improve recall of keybindings](https://github.com/MooersLab/qemacs)
- [Slides from talk about GhostText, Data Science Workshop, July 2022](https://github.com/MooersLab/DSW22ghosttext)
- [Video link to talk about GhostText, Data Science Workshop, July 2022](https://mediasite.ouhsc.edu/Mediasite/Channel/python/watch/4da0872f028c4255ae12935655e911321d)
- [Slideshow about using LaTeX in Emacs, Berlin Emacs Meetup, 31 August 2022](https://github.com/MooersLab/BerlinEmacsAugust2022)
- [The writer's crede](https://github.com/MooersLab/thewriterslaw)

## Sources of funding

- NIH: R01 CA242845
- NIH: R01 AI088011
- NIH: P30 CA225520 (PI: R. Mannel)
- NIH: P20 GM103640 and P30 GM145423 (PI: A. West)