hovancik / stretchly

The break time reminder app
https://hovancik.net/stretchly
BSD 2-Clause "Simplified" License
4.51k stars 436 forks source link

[Bug]: Idle time detection on M1-based Mac seems not to work #1210

Closed jamesholland-uk closed 4 months ago

jamesholland-uk commented 1 year ago

Version

Known issues

Existing issues

What operating system are you using?

macOS

Operating System Version

macOS Monterey 12.6

Reproduction steps

  1. Use Stretchly on a daily basis on an M1-based Mac, with the "Monitor system idle time" option enabled
  2. Do something else in the room, leaving the Mac idle
  3. See the breaks continuing to appear on the screen whilst you are not using the Mac keyboard or mouse ... Reproduces how often: Continually

Expected Behavior

Whilst the Mac is idle, the breaks should not continue.

Actual Behavior

Whilst the Mac is idle, the breaks continue.

Relevant log output

Today's logfile. I left the room completely from approximately 09:15 to 10:05 so the Mac should have been idle.

[2022-10-05 00:29:45.039] [info]  System: resume or unlock
[2022-10-05 00:31:23.786] [info]  System: suspend or lock
[2022-10-05 00:31:23.792] [info]  Stretchly: not pausing for suspendOrLock because paused already
[2022-10-05 01:00:03.598] [info]  System: resume or unlock
[2022-10-05 01:00:04.730] [info]  System: suspend or lock
[2022-10-05 01:00:04.745] [info]  Stretchly: not pausing for suspendOrLock because paused already
[2022-10-05 06:11:24.752] [info]  Stretchly: resuming breaks
[2022-10-05 06:46:16.892] [info]  Stretchly: showing Mini Break notification
[2022-10-05 07:00:05.761] [info]  System: resume or unlock
[2022-10-05 07:00:05.769] [warn]  Stretchly: Mini Break already running, not starting Mini Break
[2022-10-05 07:00:08.181] [info]  Stretchly: showing window 1 of 1
[2022-10-05 07:00:08.182] [info]  Stretchly: starting Mini Break
[2022-10-05 07:00:28.188] [info]  Stretchly: finishing Mini Break (shouldPlanNext: true)
[2022-10-05 07:05:07.478] [info]  Stretchly: pausing breaks because of idle time
[2022-10-05 07:07:33.673] [info]  System: suspend or lock
[2022-10-05 07:07:33.681] [info]  Stretchly: not pausing for suspendOrLock because paused already
[2022-10-05 08:29:25.701] [info]  System: resume or unlock
[2022-10-05 08:29:26.757] [info]  Stretchly: resuming breaks after idle time
[2022-10-05 08:30:39.151] [info]  System: suspend or lock
[2022-10-05 08:30:39.160] [info]  Stretchly: pausing breaks for 1ms
[2022-10-05 09:02:52.891] [info]  System: resume or unlock
[2022-10-05 09:02:52.900] [info]  Stretchly: resuming breaks
[2022-10-05 09:04:57.367] [info]  System: suspend or lock
[2022-10-05 09:04:57.372] [info]  Stretchly: pausing breaks for 1ms
[2022-10-05 09:06:28.298] [info]  System: resume or unlock
[2022-10-05 09:06:28.452] [info]  Stretchly: resuming breaks
[2022-10-05 09:06:36.745] [info]  System: resume or unlock
[2022-10-05 09:36:18.433] [info]  Stretchly: showing Mini Break notification
[2022-10-05 09:36:28.508] [info]  Stretchly: not showing on more Monitors as it is disabled.
[2022-10-05 09:36:30.051] [info]  Stretchly: showing window 1 of 2
[2022-10-05 09:36:30.052] [info]  Stretchly: starting Mini Break
[2022-10-05 09:36:36.188] [info]  Stretchly: postponing Mini Break
[2022-10-05 09:38:26.184] [info]  Stretchly: showing Mini Break notification
[2022-10-05 09:38:36.238] [info]  Stretchly: not showing on more Monitors as it is disabled.
[2022-10-05 09:38:37.796] [info]  Stretchly: showing window 1 of 2
[2022-10-05 09:38:37.797] [info]  Stretchly: starting Mini Break
[2022-10-05 09:38:39.805] [info]  Stretchly: finishing Mini Break (shouldPlanNext: true)
[2022-10-05 10:08:29.834] [info]  Stretchly: showing Mini Break notification
[2022-10-05 10:08:39.915] [info]  Stretchly: not showing on more Monitors as it is disabled.
[2022-10-05 10:08:41.396] [info]  Stretchly: showing window 1 of 2
[2022-10-05 10:08:41.397] [info]  Stretchly: starting Mini Break
[2022-10-05 10:09:01.407] [info]  Stretchly: finishing Mini Break (shouldPlanNext: true)
[2022-10-05 10:38:31.447] [info]  Stretchly: showing Long Break notification
[2022-10-05 10:39:01.519] [info]  Stretchly: not showing on more Monitors as it is disabled.
[2022-10-05 10:39:03.079] [info]  Stretchly: showing window 1 of 2
[2022-10-05 10:39:03.080] [info]  Stretchly: starting Long Break
[2022-10-05 10:39:56.217] [info]  Stretchly: postponing Long Break
[2022-10-05 10:44:26.210] [info]  Stretchly: showing Long Break notification
[2022-10-05 10:44:56.263] [info]  Stretchly: not showing on more Monitors as it is disabled.
[2022-10-05 10:44:57.939] [info]  Stretchly: showing window 1 of 2
[2022-10-05 10:44:57.940] [info]  Stretchly: starting Long Break
[2022-10-05 10:44:58.989] [info]  Stretchly: finishing Long Break (shouldPlanNext: true)

Preferences

{
    "microbreakDuration": 20000,
    "microbreakInterval": 1800000,
    "breakDuration": 300000,
    "breakInterval": 2,
    "breakNotification": true,
    "microbreakNotification": true,
    "breakNotificationInterval": 30000,
    "microbreakNotificationInterval": 10000,
    "microbreak": true,
    "break": true,
    "microbreakStrictMode": false,
    "breakStrictMode": false,
    "morningHour": 6,
    "microbreakPostpone": true,
    "breakPostpone": true,
    "microbreakPostponeTime": 120000,
    "breakPostponeTime": 300000,
    "microbreakPostponesLimit": 1,
    "microbreakPostponableDurationPercent": 30,
    "breakPostponesLimit": 1,
    "breakPostponableDurationPercent": 30,
    "mainColor": "#1D1F21",
    "transparentMode": false,
    "opacity": 0.9,
    "audio": "crystal-glass",
    "volume": 1,
    "fullscreen": false,
    "ideas": true,
    "naturalBreaks": true,
    "naturalBreaksInactivityResetTime": 300000,
    "allScreens": false,
    "useIdeasFromSettings": false,
    "language": "en",
    "notifyNewVersion": true,
    "isFirstRun": false,
    "posLatitude": 0,
    "posLongitude": 0,
    "useMonochromeTrayIcon": true,
    "useMonochromeInvertedTrayIcon": false,
    "silentNotifications": true,
    "monitorDnd": true,
    "microbreakStartSoundPlaying": false,
    "breakStartSoundPlaying": false,
    "themeSource": "system",
    "endBreakShortcut": "CmdOrCtrl+X",
    "breakWindowWidth": 0.85,
    "breakWindowHeight": 0.85,
    "checkNewVersion": true,
    "breakIdeas": [
        {
            "data": [
                "Not alone",
                "Do you find it hard to take a break alone? Try to do it with a co-worker. Aside from making it easier to stick to breaks, you will have a chance to get to know them better. Taking breaks together increases productivity."
            ],
            "enabled": true
        },
        {
            "data": [
                "Step away",
                "Do you ever notice how your brain can figure things out by itself? All it takes is to step away from the computer and take a break to think about something totally unrelated."
            ],
            "enabled": true
        },
        {
            "data": [
                "Microbreaks",
                "Rest is a key component in ensuring the performance of the musculoskeletal system. Frequent breaks can decrease the duration of a task and help lower the exposure to ergonomic injury risk."
            ],
            "enabled": true
        },
        {
            "data": [
                "Meditation",
                "Research studies suggest that mindfulness-based exercises help decrease anxiety, depression, stress, and pain, and help improve general health, mental health, and quality of life. Not sure how to start? There are numerous apps to help you out."
            ],
            "enabled": true
        },
        {
            "data": [
                "Blink",
                "Looking at screens for a long time causes you to blink less, thus exposing your eyes to the air. Blink rapidly for a few seconds to refresh the tear film and clear dust from the eye surface."
            ],
            "enabled": true
        },
        {
            "data": [
                "Ergonomics",
                "Improper height and angle of the keyboard, mouse, monitor or working surface can cause health problems. Take some time to read about desk ergonomics."
            ],
            "enabled": true
        },
        {
            "data": [
                "Move",
                "There are a lot of ways you can exercise within your office. Try marching in place or doing desk push-ups."
            ],
            "enabled": true
        },
        {
            "data": [
                "Change",
                "Do you have a stability ball or standing work desk? Consider replacing your desk chair with them for a while."
            ],
            "enabled": true
        },
        {
            "data": [
                "Notice",
                "Are you daydreaming or having trouble focusing? It is a sign that you need to take a break."
            ],
            "enabled": true
        },
        {
            "data": [
                "Tech",
                "How about taking a no-tech walk?"
            ],
            "enabled": true
        },
        {
            "data": [
                "Metabolism",
                "Emerging research shows that sitting for long periods of time contributes to risk of metabolic syndrome, heart attack and stroke risk and overall death risk, among others. Taking regular walking breaks can help your circulation, working to counteract some of those problems."
            ],
            "enabled": true
        },
        {
            "data": [
                "Active Meetings",
                "How about moving meetings from the conference room to the concourse? Walking not only burns calories but it may even foster a sense of collaboration."
            ],
            "enabled": true
        },
        {
            "data": [
                "Fruit",
                "Take your time and eat some fruit. Slowly. Notice the flavor, the texture, the freshness."
            ],
            "enabled": true
        },
        {
            "data": [
                "Bathrooms",
                "Walk to the farthest bathroom in the worksite facility when going to the restroom."
            ],
            "enabled": true
        },
        {
            "data": [
                "Coffee break",
                "Going on coffee break? Consider doing a 5-minute walk every time you go for one."
            ],
            "enabled": true
        },
        {
            "data": [
                "Colleagues",
                "Do not email or message office colleagues, walk to their desks to communicate with them."
            ],
            "enabled": true
        },
        {
            "data": [
                "Learning",
                "In a study of healthy volunteers, NIH researchers found that taking short breaks, early and often, may help our brains learn new skills."
            ],
            "enabled": true
        },
        {
            "data": [
                "Exercise",
                "Evidence suggests small amounts of regular exercise can bring dramatic health benefits, including measurably reducing stress."
            ],
            "enabled": true
        },
        {
            "data": [
                "Repeat",
                "Have you found your stretch-ly-routine? Do not forget to repeat it for more than once to better fight effects of prolonged sitting."
            ],
            "enabled": true
        },
        {
            "data": [
                "Wrist and forearm",
                "Extend your arms with the palms facing towards you, then slowly rotate the hands four times clockwise, then four times counter-clockwise."
            ],
            "enabled": true
        },
        {
            "data": [
                "Back stretching",
                "Join your hands behind your head, then lift them together up above your head ending with your palms facing upward."
            ],
            "enabled": true
        },
        {
            "data": [
                "Mobilize",
                "For every thirty minutes of stagnation, you should have at least one minute of stimulation."
            ],
            "enabled": true
        },
        {
            "data": [
                "7 Minute Workout",
                "This workout packs in a full-body exercise routine in a fraction of the time. But as with any exercise, be careful. There are numerous apps to get you started."
            ],
            "enabled": true
        },
        {
            "data": [
                "Pulse",
                " Raise your pulse rate to 120 beats per minute for 20 straight minutes four or five times a week doing anything you enjoy. Regularly raising your heart rate results in improved cardiovascular health."
            ],
            "enabled": true
        },
        {
            "data": [
                "Take the stairs ",
                "Studies have shown that stair climbing, which is considered vigorous-intensity physical activity, burns more calories per minute than jogging."
            ],
            "enabled": true
        },
        {
            "data": [
                "Make art",
                "Art therapy is known to have great mental health benefits, especially when it comes to stress management. How about writing a quick poem, taking a picture or painting something small?"
            ],
            "enabled": true
        },
        {
            "data": [
                "Declutter",
                "A clean space helps your focus at work and is often linked to positive emotions like happiness."
            ],
            "enabled": true
        },
        {
            "data": [
                "Lunch outside",
                "Nature is linked to positive emotions and decreased stress and anxiety. Whenever possible, try to take your daily lunch break outside, surrounded by some greenery."
            ],
            "enabled": true
        },
        {
            "data": [
                "Public transport",
                "If you use public transport regularly, you can stand instead of sitting. If it is possible, try to replace as many of your daily trips as possible with walking or cycling."
            ],
            "enabled": true
        },
        {
            "data": [
                "Yawning",
                "Yawning can be really helpful, as it produces tears to help moisten and lubricate the eyes."
            ],
            "enabled": true
        },
        {
            "data": [
                "Focus change",
                "Hold one finger close to the eye and focus on it. Slowly move the finger away, focus far into the distance and then back to the finger. Bring the finger back and focus on something far away."
            ],
            "enabled": true
        },
        {
            "data": [
                "Palming",
                "While seated, brace elbows on the desk and close to the desk edge. Let your weight fall forward and cup hands over eyes. Close your eyes and inhale slowly through nose and hold for few seconds. Continue deep breathing."
            ],
            "enabled": true
        },
        {
            "data": [
                "Hand squeezes",
                "Squeeze a pair of balled-up socks or a soft rubber ball, hold for 5 seconds. Repeat whole process few times."
            ],
            "enabled": true
        },
        {
            "data": [
                "Slow Breathing",
                "Emerging research suggests potential for use of controlled slow breathing techniques as a means of optimising physiological parameters that appear to be associated with health and longevity."
            ],
            "enabled": true
        }
    ],
    "microbreakIdeas": [
        {
            "data": "Go grab a glass of water.",
            "enabled": true
        },
        {
            "data": "Slowly look all the way left, then right.",
            "enabled": true
        },
        {
            "data": "Slowly look all the way up, then down.",
            "enabled": true
        },
        {
            "data": "Close your eyes and take few deep breaths.",
            "enabled": true
        },
        {
            "data": "Close your eyes and relax.",
            "enabled": true
        },
        {
            "data": "Stretch your legs.",
            "enabled": true
        },
        {
            "data": "Stretch your arms.",
            "enabled": true
        },
        {
            "data": "Is your sitting posture correct?",
            "enabled": true
        },
        {
            "data": "Slowly turn head to side and hold for 10 seconds.",
            "enabled": true
        },
        {
            "data": "Slowly tilt head to side and hold for 5-10 seconds.",
            "enabled": true
        },
        {
            "data": "Stand from your chair and stretch.",
            "enabled": true
        },
        {
            "data": "Refocus your eyes on an object at least 20 meters away.",
            "enabled": true
        },
        {
            "data": "Take a moment to think about something you appreciate.",
            "enabled": true
        },
        {
            "data": "Take a moment to smile at being alive.",
            "enabled": true
        },
        {
            "data": "A truly ergonomic workstation is one that you regularly push away from.",
            "enabled": true
        },
        {
            "data": "Close your eyes and count your breaths.",
            "enabled": true
        },
        {
            "data": "Close your eyes and name the things you hear.",
            "enabled": true
        },
        {
            "data": "Place your fingertips on your shoulders. Roll your shoulders forward for 10 seconds, then backward.",
            "enabled": true
        },
        {
            "data": "Raise your right arm, stretch it over your head to the left, and hold for 10 seconds. Repeat on the other side.",
            "enabled": true
        },
        {
            "data": "With your right hand, grab each finger of your left hand in turn and squeeze. Repeat on the other side.",
            "enabled": true
        },
        {
            "data": "Stand up and do a lunge. Hold for 10 seconds, then do the other leg.",
            "enabled": true
        },
        {
            "data": "Close your eyes and simply notice whatever arises in current moment, without judgement.",
            "enabled": true
        },
        {
            "data": "Focus every 20 minutes for 20 seconds on an object at 20 feet distance.",
            "enabled": true
        },
        {
            "data": "If you need help, ask for it.",
            "enabled": true
        },
        {
            "data": "Do one thing at a time.",
            "enabled": true
        },
        {
            "data": "Is your attention spent wisely?",
            "enabled": true
        },
        {
            "data": "Change your sitting posture.",
            "enabled": true
        },
        {
            "data": "Expose your eyes to natural light.",
            "enabled": true
        },
        {
            "data": "With your eyes closed, slowly and gently raise your eyes to the ceiling and back down to the floor.",
            "enabled": true
        },
        {
            "data": "With your eyes closed, slowly and gently move your eyes to the left, then slowly to the right.",
            "enabled": true
        },
        {
            "data": "Shake your hands out to get some relief.",
            "enabled": true
        },
        {
            "data": "One at a time, touch the tip of each finger to the tip of your thumb so they make an O-shape.",
            "enabled": true
        },
        {
            "data": "Make a fist and then slide your fingers up until they point toward the ceiling, like you're telling someone to stop.",
            "enabled": true
        },
        {
            "data": "Make a fist and then fan your fingers out and stretch them as far as you can.",
            "enabled": true
        },
        {
            "data": "Sit tall, arms hanging at your sides, and slowly rotate neck in one direction in a large circle.",
            "enabled": true
        },
        {
            "data": "Stand tall and slowly tilt your head toward the shoulder using the same hand until you feel a strech.",
            "enabled": true
        },
        {
            "data": "Stand tall with your arms by your side. Squeeze your shoulder blades together and hold.",
            "enabled": true
        },
        {
            "data": "Stand tall with your arms raised along your shoulders. Move hands slightly behind your back, hold for a second and return.",
            "enabled": true
        }
    ],
    "showBreaksAsRegularWindows": false,
    "appExclusions": [],
    "appExclusionsCheckInterval": 1000,
    "pauseForSuspendOrLock": true,
    "pauseBreaksShortcut": "",
    "resumeBreaksShortcut": "",
    "screen": "primary",
    "timeToBreakInTray": false,
    "currentTimeInBreaks": false
}

Additional information

This used to work on my previous Intel-based Mac, I believe it has broken since moving to M1-based Mac.

I want to disable the postponement feature, but I can't because the timing of breaks does not match up with my active time at the Mac.

Code of Conduct

hovancik commented 1 year ago

Sorry, but I don't have m1 to check on :(

It would be great if someone could check whether getSystemIdleTime from electron is working correctly on mac m1 https://www.electronjs.org/de/docs/latest/api/power-monitor#powermonitorgetsystemidletime.

Also, maybe some app is making the system not being "idle"? I noticed such a behavior in the past with some music players and such

jamesholland-uk commented 1 year ago

Thanks @hovancik. If there is an easy way for me to check any of this for you on my M1 machine, let me know.

hovancik commented 1 year ago

You could try running this repo: https://github.com/electron/electron-quick-start and edit the code to print powerMonitor.getSystemIdleTime() every few seconds. When you think your system is on idle, you can check what does the electron (and therefore stretchly) thinks.

jamesholland-uk commented 1 year ago

I tried and failed for an hour or so, seems my Javascript is not very good, sorry!

hovancik commented 1 year ago

No worries, this things sometimes get fixed with new versions of Electron, so let's see

rlue commented 5 months ago

I am on an M1 Mac Mini. I have confirmed that powerMonitor.getSystemIdleTime() works in Electron (and so the upstream tag can be removed from this issue, and/or this issue may be closed):

$ git clone https://github.com/electron/electron-quick-start
$ cd electron-quick-start
$ sed -i "s/\( } = require('electron')\)/, powerMonitor\1/" main.js
$ sed -i 's/^}$/\n  setInterval(() => console.log(powerMonitor.getSystemIdleTime()), 1000)\n&/' main.js
$ npm install
$ npm start

> electron-quick-start@1.0.0 start
> electron .

1
2
3
4
5
6
7
8
9
10
11
0   # <-- when I move the mouse