
Product
Announcing Socket Fix 2.0
Socket Fix 2.0 brings targeted CVE remediation, smarter upgrade planning, and broader ecosystem support to help developers get to zero alerts.
@accesslint/voiceover
Advanced tools
A CLI and TypeScript interface for VoiceOver screen reader on macOS.
Use it to launch VoiceOver and log output to the command line, or write your own scripts to drive the screen reader.
$ npx @accesslint/voiceover
yarn add @accesslint/voiceover
or npm i @accesslint/voiceover
.
import { VoiceOver } from '@accesslint/voiceover';
const voiceOver = new VoiceOver();
await voiceOver.launch(); // start VoiceOver screen reader
voiceOver.tail(); // print last phrase on navigation
// perform actions using seek, rotor, and execute
await voiceOver.quit(); // stop VoiceOver
You can navigate to a specific phrase:
import { VoiceOver } from "@accesslint/voiceover";
const voiceOver = new VoiceOver({ log: true });
// open target application, e.g. with PlayWright
await voiceOver.launch();
await voiceOver.advance({
target: {
text: 'Example',
role: 'heading'
},
steps: 10
});
Save recordings of VoiceOver interactive sessions:
import { VoiceOver } from "@accesslint/voiceover";
import * as path from "path";
const voiceOver = new VoiceOver({ log: true });
voiceOver.record({ file: path.resolve(__dirname, 'recording.mov') });
// open target application, e.g. with PlayWright
await voiceOver.launch();
// peform interactions
In a realistic user scenario, someone could navigate the page by headings:
await voiceOver.rotor({ menu: 'Headings', find: 'my heading' }); // navigate directly to a heading using the web rotor
or by landmark:
await voiceOver.rotor({ menu: 'Landmarks', find: 'search' }); // navigate directly to a heading using the web rotor
$ open https://www.example.com -a Safari && npx @accesslint/voiceover
#=> Welcome to macOS. VoiceOver is on.
#=> Example Domain - Google Chrome Page has 1 link 1 heading 8 articles
$ open https://www.twitter.com -a Safari && npx @accesslint/voiceover | grep heading > headings.txt
FAQs
macOS VoiceOver Typescript interface and CLI
We found that @accesslint/voiceover demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Product
Socket Fix 2.0 brings targeted CVE remediation, smarter upgrade planning, and broader ecosystem support to help developers get to zero alerts.
Security News
Socket CEO Feross Aboukhadijeh joins Risky Business Weekly to unpack recent npm phishing attacks, their limited impact, and the risks if attackers get smarter.
Product
Socket’s new Tier 1 Reachability filters out up to 80% of irrelevant CVEs, so security teams can focus on the vulnerabilities that matter.