vue-occasions

1.1.1 • Public • Published

vue-occasions

Tags your HTML’s body element with a class and data attribute reflecting today’s occasion or holiday. You can then style that element with CSS or implement some JavaScript behaviour. For example, you could show special versions of your site’s logo on different holidays or trigger a holiday-specific modal.

Version MIT License Minified Size

Table of Contents

Installation

npm

npm install vue-occasions --save

Yarn

yarn add vue-occasions

Import vue-occasions into your project:

import VueOccasions from "vue-occasions"

Install the plugin in your application:

createApp(App)
  .use(VueOccasions)
  .mount("#app")

On May the 4th, this will result in:

<body class="star-wars" data-occasion="star-wars">

Now you can leverage CSS and JavaScript as you wish in celebration of Star Wars Day.

Options

Custom occasions

You can add your own occasions by supplying a JSON object during initialization:

createApp(App)
  .use(VueOccasions, {
    occasions: {
      "Feb 27":"birthday"
    }
  })
  .mount("#app")

Note: if an occasion already exists for the date you provide, your custom occasion will be given priority.

Date

To simulate an occasion without having to time travel, pass in a relevant date with your initialization:

createApp(App)
  .use(VueOccasions, {date: "Apr 01"})
  .mount("#app")

This is intended for testing purposes only. Be sure to remove the date override once you have completed testing.

Log occasions

To log all available occasions to the console, provide the log option:

createApp(App)
  .use(VueOccasions, {log: true})
  .mount("#app")

onOccasion callback

When vue-occasions adds its attributes to your body tag, it will also execute code inside the onOccasion callback block.

createApp(App)
  .use(VueOccasions, {
    onOccasion: () => {
      // add your callback code here
    }
  })
  .mount("#app")

Extras

Special dates

Four special date functions are available: nthDay(), lastWeekday(), weekdayAfter() and weekdayBefore(). Use these as follows:

The first Monday of February:

{
  "_nthDay(1,Mon,Feb)":"happy-day"
}

The last Monday of May:

{
  "_lastWeekday(Mon,May)":"memorial"
}

The Tuesday after June 14:

{
  "_weekdayAfter(Tue,Jun,14)":"knitting-group"
}

The Tuesday before February 27:

{
  "_weekdayBefore(Tue,Feb,27)":"slappy-day"
}

Don’t miss those double-quotes.

Current occasion

You can retrieve the current occasion that is attached to your element with:

document.querySelector("body").getAttribute("data-occasion")

Examples

Star Wars Day

Let’s trigger a JavaScript alert when simulating May 4th:

createApp(App)
  .use(VueOccasions, {
    date: "May 04",
    onOccasion: () => {
      if (document.querySelector("body").getAttribute("data-occasion") === "star-wars") {
        alert("May the Fourth be with you.")
      }
    }
  })
  .mount("#app")

Book club

A book club meets on the last Friday of every other month. On those Fridays, their website displays a reminder badge.

Their initialization looks like this:

createApp(App)
  .use(VueOccasions, {
    occasions: {
      "_lastWeekday(Fri,Jan)":"book-club-meeting",
      "_lastWeekday(Fri,Mar)":"book-club-meeting",
      "_lastWeekday(Fri,May)":"book-club-meeting",
      "_lastWeekday(Fri,Jul)":"book-club-meeting",
      "_lastWeekday(Fri,Sep)":"book-club-meeting",
      "_lastWeekday(Fri,Nov)":"book-club-meeting"
    }
  })
  .mount("#app")

In their CSS, they have:

#meeting-tonight {
  display: none;
}
body.book-club-meeting #meeting-tonight {
  display: block;
}

Notes

Occasion name format

Since occasion names are used for CSS classes, they must follow the syntax rules. The occasions provided (occasions.json) use hyphenated names.

Date format

Names of months and weekdays must be their first three letters, title cased. Eg: Jan, Feb, Mon and Tue.

Days must be two digits, so some need leading zeroes. Eg: 08, 09, 10, 11, etc.

Changelog

Apr 7, 2023 v1.0.4

  • Core functionality
  • Test suite

Apr 8, 2023 v1.1.1

  • Add log option to log available occasions to console

License

The MIT License

Package Sidebar

Install

npm i vue-occasions

Weekly Downloads

6

Version

1.1.1

License

MIT

Unpacked Size

20.2 kB

Total Files

6

Last publish

Collaborators

  • speasley