npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

daheeahn-expo-stt

v0.0.4

Published

Unofficial Speech To Text module for Expo which supports iOS and Android

Downloads

18

Readme

expo-stt

Sequence Diagram

Below is a sequence diagram explaining how each module, including SpeechRecognizer, works.

Sequence Diagram

And below is the mermaid code to create the above diagram.


sequenceDiagram
    participant User
    participant ExpoSttModule
    participant SpeechRecognizer
    participant ReactNative as React Native Module

    User->>ExpoSttModule: startSpeech()
    ExpoSttModule->>SpeechRecognizer: createSpeechRecognizer()
    ExpoSttModule->>SpeechRecognizer: startListening()
    SpeechRecognizer-->>ExpoSttModule: onReadyForSpeech

    User->>SpeechRecognizer: User starts speaking
    SpeechRecognizer-->>ExpoSttModule: onBeginningOfSpeech
    ExpoSttModule->>ReactNative: sendEvent(onSpeechStart)

    User->>SpeechRecognizer: User finishes speaking
    SpeechRecognizer-->>ExpoSttModule: onEndOfSpeech
    ExpoSttModule->>ReactNative: sendEvent(onSpeechEnd)

    SpeechRecognizer-->>ExpoSttModule: onResults
    ExpoSttModule->>ReactNative: sendEvent(onSpeechResult)

    alt SpeechRecognizer encounters an error
        SpeechRecognizer-->>ExpoSttModule: onError
        ExpoSttModule->>ReactNative: sendEvent(onSpeechError)
    end

Demo

Demo speech to text

Add the package to your npm dependencies

npm install expo-stt
or
yarn add expo-stt

Remember, this module doesn't support Expo Go. So for Expo project, you will need to generates native code (Bare React Native project can skip this step)

npx expo prebuild --clean

Configure for iOS (Bare React Native project only)

Run npx pod-install after installing the npm package.

Add missing permissions for iOS

Add following key to plugins of app.json in Expo project This is an optional, just use in case you want to customize the permission string

  "plugins": [
    [
      "expo-stt",
      {
        "microphonePermission": "Allow $(PRODUCT_NAME) to access your microphone",
        "speechRecognitionPermission": "Allow $(PRODUCT_NAME) to access your speech recognition"
      }
    ]
  ]

For Bare React Native project, you need to add these key to Info.plist in ios directory

  <key>NSMicrophoneUsageDescription</key>
  <string>Allow $(PRODUCT_NAME) to access your microphone</string>
  <key>NSSpeechRecognitionUsageDescription</key>
  <string>Allow $(PRODUCT_NAME) to access your speech recognition</string>

Usage

Register some listeners

  import * as ExpoStt from 'expo-stt';

  useEffect(() => {
    const onSpeechStart = ExpoStt.addOnSpeechStartListener(() => {
      setSpokenText("");
      setError(undefined);
      setRecognizing(true);
    });

    const onSpeechResult = ExpoStt.addOnSpeechResultListener(({ value }) => {
      setSpokenText(value.join());
    });

    const onSpeechError = ExpoStt.addOnSpeechErrorListener(({ cause }) => {
      setError(cause);
      setRecognizing(false);
    });

    const onSpeechEnd = ExpoStt.addOnSpeechEndListener(() => {
      setRecognizing(false);
    });

    return () => {
      onSpeechStart.remove();
      onSpeechResult.remove();
      onSpeechError.remove();
      onSpeechEnd.remove();
    };
  }, []);

There are some functions available to call such as:

  • ExpoStt.startSpeech()
  • ExpoStt.stopSpeech()
  • ExpoStt.destroySpeech()
  • ExpoStt.requestRecognitionPermission()
  • ExpoStt.checkRecognitionPermission()

Take a look into example/App.tsx for completed example

Contributing

Contributions are very welcome! Please refer to guidelines described in the contributing guide.