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

@xexiu/astro-speech

v0.2.9

Published

HTML, CSS and a bit of javascript made with Custom Elements astro-speech for Astro.

Downloads

21

Readme

🚀 astro-speech

NPM Downloads PRs Welcome Astro TypeScript ESLint

HELLO there 👋

HTML, CSS and a bit of javascript made with Custom Elements article speech for astro. Uses API from browsers. Compatible with web/mobile, responsive, HTML, SEO friendly. Lighthouse score 100%. Uses Custom Elements for a better optimization: customElements.define('xe-article-speech', ArticleSpeech);


Forking and giving a star will contribute to my motivation in making components for astro (react, react-native, etc...) that are purely HTML, CSS, SEO friendly and responsive :) (almost all components :P).


DEMO: Astro Article Specch This product is actively mantained. Any PR, issues or whatever concern, please visit the Github repository https://github.com/xexiu/astro-components.

Tutorials Roadmap

  • Web2: JavaScript, HTML, CSS, Node.js, Python (MLL, AI), React, NextJS React Native and more.
  • Web3: Blockchain, WEB3, dApps, smart contracts and more.

📦 Installation

  • Using bun:
bun i @xexiu/astro-speech
  • Using npm:
npm i @xexiu/astro-speech

🔁 API

interface Props {
  classes?: string; // Optional
  title: string; // Optional
  text: string; // Requiered
  btnClasses?: string; // Optional
  btnText?: any; // Optional
}

🛠 Usage in astro (client)

---
// more personal/code imports
import AstroSpeech from '@xexiu/astro-speech';
---

<div class="container">
    <p class="get-me">Whatever text to listen...</p>
</div>

<AstroSpeech
    text={document.querySelector('.get-me').textContent}
    btnText="Listen to article"
/>

🛠 Usage in astro (Server)

---
// more personal/code imports
import AstroSpeech from '@xexiu/astro-speech';

const blogs = {
   latest: [
      {
         id: 'post-3.md',
         slug: 'post-3',
         body:
        '\n' +
        'TEST3\n' +
        '\n' +
        'Nisi duis ex aliqua eu officia eiusmod duis magna pariatur. Irure laborum qui aliqua nulla esse cillum laborum aliquip nulla elit. Id id Lorem duis irure cillum culpa. Nulla sint et aliqua velit do. Nulla sit sit proident consectetur enim ullamco aliqua in reprehenderit ullamco officia.\n' +
        '\n' +
        '## Kinda Sus\n' +
        '\n' +
        '  ![Pica](/src/images/pic_ts.jpeg)\n' +
        '\n' +
        '  Ad ipsum velit sint enim exercitation mollit consequat elit mollit qui commodo aute. Laboris culpa voluptate aliquip incididunt duis. Cupidatat aliquip et sunt aute fugiat cupidatat irure voluptate. Occaecat officia et sunt.\n' +
        '\n' +
        '  ```js\n' +
        '  test()\n' +
        '  ```\n' +
        '\n' +
        '  Officia tempor voluptate enim consequat cillum aute fugiat cupidatat incididunt magna labore in commodo. Eiusmod nostrud non deserunt. Incididunt excepteur pariatur magna. Proident aute ad in velit labore enim sit cillum ad mollit proident et qui. Esse sunt ullamco ullamco ipsum enim eu esse id eu exercitation laboris magna Lorem. Anim nostrud officia anim velit do exercitation labore mollit excepteur excepteur ex.\n' +
        '\n' +
        '## Is anyone reading these?\n' +
        '\n' +
        '  Ipsum adipisicing exercitation dolor pariatur labore qui. Culpa cupidatat ea elit eiusmod tempor ea qui dolor Lorem laborum adipisicing. Ad ea laboris qui cupidatat deserunt culpa. Nulla ex velit adipisicing proident fugiat deserunt sunt eu adipisicing sint incididunt quis qui. Nulla fugiat labore duis ullamco reprehenderit excepteur laboris tempor ullamco aliquip laborum aliqua. Est tempor nisi magna ut elit pariatur commodo.\n' +
        '\n' +
        '  Labore commodo do incididunt amet ad et exercitation magna veniam veniam aute laboris excepteur occaecat Lorem. Fugiat in magna commodo magna nulla eu. Fugiat nulla aliqua sunt duis enim irure aliquip fugiat aliqua Lorem ad tempor incididunt proident incididunt. Labore fugiat tempor esse cillum voluptate culpa anim sunt consequat. Ipsum minim nostrud laborum sit aliquip duis officia consequat est. Fugiat mollit elit nulla. Sit minim est elit labore. Sunt eu pariatur pariatur ut deserunt nulla labore in non sit tempor voluptate ex.\n' +
        '\n' +
        '  ![alt text](/src/images/hero-img.png "alt title")\n' +
        ''
      }
   ]
};
---

<div class="container">
    <p class="get-me">Whatever text...</p>
</div>

<AstroSpeech
    text={blogs.latest[0].body}
    btnText="Listen to article"
/>

 ¡Chao pescao! 👋 🐠