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 🙏

© 2025 – Pkg Stats / Ryan Hefner

@happychef/algorithm

v1.2.10

Published

Restaurant and reservation algorithm utilities

Readme

@happychef/algorithm

Restaurant and reservation algorithm utilities for Happy Chef.

CI/CD Pipeline codecov npm version

Installation

npm install @happychef/algorithm

Features

  • Date & Time Availability: Check if specific dates and times are available for reservations
  • Timeblock Management: Get available timeblocks based on restaurant settings
  • Table Assignment: Automatically assign tables to reservations
  • Smart Filtering: Filter timeblocks based on max arrivals, max groups, and other constraints
  • Exception Handling: Support for restaurant opening hours exceptions and closures
  • Comprehensive Testing: 70+ unit tests ensuring reliability

Usage

const {
  isDateAvailable,
  isTimeAvailable,
  getAvailableTimeblocks,
  assignTablesIfPossible
} = require('@happychef/algorithm');

// Check if a date is available
const available = isDateAvailable(
  restaurantData,
  '2025-06-15',
  reservations,
  guests
);

// Get available timeblocks
const timeblocks = getAvailableTimeblocks(
  restaurantData,
  '2025-06-15',
  reservations,
  guests
);

// Check if specific time is available
const timeAvailable = isTimeAvailable(
  restaurantData,
  '2025-06-15',
  '12:00',
  reservations,
  guests
);

Development

Running Tests

# Run all tests
npm test

# Run tests in watch mode
npm run test:watch

# Run tests with coverage
npm run test:coverage

Test Coverage

The package includes comprehensive unit tests covering:

  • Helper functions (parseTime, getMealTypeByTime, etc.)
  • Date and time availability checks
  • Timeblock filtering
  • Restaurant data and exceptions handling
  • Table assignment logic
  • Filter functions (max arrivals, max groups)

All tests are automatically run on every push to the main branch via GitHub Actions.

CI/CD Pipeline

This package uses GitHub Actions for continuous integration and deployment:

  1. Automated Testing: Tests run on Node.js 18.x and 20.x
  2. Coverage Reports: Automatically uploaded to Codecov
  3. Automatic Publishing: When tests pass on main branch and version changes, package is automatically published to npm
  4. Git Tagging: Successful releases are automatically tagged

Setup Instructions

To enable automatic publishing:

  1. Create an NPM Token:

    • Go to npmjs.com
    • Navigate to Access Tokens
    • Generate a new "Automation" token
    • Copy the token
  2. Add NPM Token to GitHub Secrets:

    • Go to your GitHub repository
    • Navigate to Settings > Secrets and variables > Actions
    • Click "New repository secret"
    • Name: NPM_TOKEN
    • Value: Paste your NPM token
    • Click "Add secret"
  3. Optional: Add Codecov Token (for coverage reports):

    • Go to codecov.io
    • Add your repository
    • Copy the token
    • Add as CODECOV_TOKEN secret in GitHub
  4. Publish New Version:

    • Update version in package.json
    • Commit and push to main branch
    • GitHub Actions will automatically:
      • Run all tests
      • Publish to npm if tests pass
      • Create a git tag for the release

Contributing

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/amazing-feature)
  3. Write tests for your changes
  4. Ensure all tests pass (npm test)
  5. Commit your changes (git commit -m 'Add some amazing feature')
  6. Push to the branch (git push origin feature/amazing-feature)
  7. Open a Pull Request

License

MIT

Author

Happy Chef