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

ios-chat

v1.2.1

Published

Style chat ui like Apple's iOS

Downloads

12

Readme

ios-chat

demo

Small Library to show chat UI as iOS style

You can easily style your chatbot or chat system with "ios-chat"

currently, all the library's functions only works at browser (not support SSR)


Contents


Setup

using npm

  npm install ios-chat
  import { addRoomListener, answerChat } from "ios-chat";

using script

  <!-- esm module -->
  <script src="https://unpkg.com/ios-chat/dist/esm/index.js"></script>

  <!-- umd module -->
  <script src="https://unpkg.com/ios-chat/dist/umd/index.js"></script>
<ios-chat room-id="example"></ios-chat>

<script>
  Chat.addRoomListener("example", (msg) => {
    // ...
  });
</script>

Basic Concepts

ios-chat is just using Web Components API, so you can attach everywhere inside of body with predefined tag name, <ios-chat>

attributes

  1. room-id: string (required)

    Chat room ID, it is necessary to use API since the library configured chat room with room-id

    ⭐️important note - all chat rooms can be handled after the tag is attached at DOM. Literally, The functions below will work after the tags are added inside of body tag.

  2. dark: boolean (optional)

    The attribute for setting dark mode

    if it is true, dark mode appeared

    default value is false

  3. textonly: boolean (optional)

    The attribute for setting input mode

    if it is true, the sender can only send string messages

    default value is false

example on html

<ios-chat room-id="chat" dark="true"></ios-chat>

<!-- only string sending -->
<ios-chat room-id="chat" dark="true" textonly></ios-chat>

Precautions

  1. answer and sender UI

    Don't be confused while using answerChat( ) and sendChat( )

  1. all images and audio are created with URL.createObjectURL( );

    so all of them are just temporary data, if you want to know how to save data to server or other storage, check next js + ios-chat

  2. <ios-chat> has z-index a maximal of 10

API

functions

sendChat (async)

async function sendChat(roomId: string, info: SendInfo);
  • if chat room is blocked, throw error

  • send chat message to room, check SendInfo

  • it return Promise that has same duration with message animation duration

    so if you don't want to override animation, wait this Promise

answerChat (async)

async function answerChat(roomId: string, info: SendInfo);
  • if chat room is blocked, throw error

  • answer chat message to room, check SendInfo

  • it return Promise that has same duration with message animation duration

    so if you don't want to override animation, wait this Promise

startAnswerLoading

function startAnswerLoading(roomId: string);
  • if chat room is blocked, throw error

  • start loading for room

  • the blocked value will be true

endAnswerLoading (async)

async function endAnswerLoading(roomId: string);
  • end loading for room

  • the blocked value will be false

isBlocked

function isBlocked(roomId: string): boolean;
  • return status, as boolean, for roomId

getMessages

function getMessages(roomId: string): ChatMessage[];
  • get all message list from chat room

initChat

function initChat(roomId: string, messages: ChatMessage[]);
// e.g
initChat("example", messages);
  • init room with message list

    this won't show message animation

addRoomListener

function addRoomListener(roomId: string, callback: ListenerCallback): string;

// e.g
const listenerId = addRoomListener("example", (msg: ChatMessage) => {
  if (msg.type === "text")
    alert(msg.content)
});
  • with this function, you can listen recent message(type ChatMessage) from chat room

  • the function get recent message except loading type message (message from startAnswerLoading)

  • the function return listener id which will use at removeRoomListener

removeRoomListener

function removeRoomListener(roomId: string, listenerId: string);

// e.g
removeRoomListener("example", listenerId);

types

ChatMessage

type ChatMessage = {
  type: ChatMessageType; // 'text' | 'img' |'audio' | "loading"
  role: Role; // 'sender' | 'receiver'
  id: string;
  createdDatetime: number;
  content: string;
  origin?: string; // room-id string
};
  • if one chat room send message to other room, the origin will be stored.

SendInfo

type SendInfo = {
  type: ChatMessageType; // 'text' | 'img' |'audio' | "loading"
  content: string;
  origin?: string;
}

Examples

next js + ios-chat

vanilla JS + ios-chat

Issues