Metadata
- Source
- C2LC-539
- Type
- New Feature
- Priority
- N/A
- Status
- Pull Request
- Resolution
- N/A
- Assignee
- Simon Bates
- Reporter
- Simon Bates
- Created
- 2021-10-28T14:09:21.588-0400 
- Updated
- 2024-04-30T10:29:50.355-0400 
- Versions
- N/A
- Fixed Versions
- N/A
- Component
- 
                        
                        - Coding Environment
 
Description
Comments
- 
                        Tony Atkins [RtF] commented 2021-11-04T08:56:03.470-0400 I did some research on this to see what options we have, based on our most recent discussion, in which we agreed that we only need to identify "mac" vs. "not mac", and change the alt/option wording in keyboard menus when the user is on a mac. The window.navigator object offers a "platform", which is available in Chrome, Firefox, and Safari, and which is consistently "MacIntel" for me. This suggests to me that we'd have to find a list of variations for M1 macs, older OS versions. There are lists out there already. Some of the variations suggest that we'd need to detect a list of: - Variations on desktop platforms, including recent versions of the OS and supported processor types.
- Variations on iOS devices and iOS versions.
- Variations used with the simulator (not hugely important, but useful for screen shots and testing). (The most recent simulator simply returns "iPad" and "iPhone", so maybe we can just use those).
 The window.navigator.userAgent property is also well supported, but would require picking the platform out strings like "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/15.0 Safari/605.1.15" using some kind of pattern. And there are specific plugins that mask the user agent. Chromium-derivatives offer a window.navigator.userAgentData property in which the user agent is presented as individual pieces of data. There, window.navigator.userAgentData.platform is better abstracted, simply "macOS". 
- 
                        Tony Atkins [RtF] commented 2021-11-04T09:16:00.622-0400 I also looked at react-device-detect, which already has definitions that let you detect a range of things, including mobile vs. desktop, specific browsers, and of course operating system. The approach seems good, but is probably overkill for what we want. 
- 
                        Tony Atkins [RtF] commented 2021-11-04T09:29:38.564-0400 We agreed to use window.navigator.platform for now. 
- 
                        Simon Bates commented 2024-04-30T10:29:50.355-0400 Moved to GitHub: https://github.com/codelearncreate/c2lc-coding-environment/issues/491