2017 © Pedro Peláez
 

craft-plugin store-hours

This plugin adds a new “Store Hours” field type to Craft, for collecting the opening and closing hours of a business for each day of the week.

image

craftcms/store-hours

This plugin adds a new “Store Hours” field type to Craft, for collecting the opening and closing hours of a business for each day of the week.

  • Saturday, July 28, 2018
  • by brandonkelly
  • Repository
  • 4 Watchers
  • 52 Stars
  • 931 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 6 Forks
  • 0 Open issues
  • 12 Versions
  • 28 % Grown

The README.md

Store Hours for Craft CMS

This plugin adds a new “Store Hours” field type to Craft, for collecting the opening and closing hours (or any other time slots) of an organization for each day of the week., (*1)

Requirements

This plugin requires Craft CMS 5.0 or later., (*2)

Installation

You can install this plugin from the Plugin Store or with Composer., (*3)

From the Plugin Store

Go to the Plugin Store in your project’s Control Panel and search for “Store Hours”. Then press Install in its modal window., (*4)

With Composer

Open your terminal and run the following commands:, (*5)

# go to the project directory
cd /path/to/my-project.test

# tell Composer to load the plugin
composer require craftcms/store-hours

# tell Craft to install the plugin
php craft plugin/install store-hours

Customizing Time Slots

Store Hours fields have a setting called “Time Slots” that lets you customize the time columns that will be visible in the field inputs. By default there will be two time slots, “Opening Time” and “Closing Time”, but you can customize those however you like., (*6)

A Time Slots field setting with “Open”, “Close”, “Second Open”, and “Second Close” slots defined, (*7)

Each row you add here will end up adding a new column to the field inputs., (*8)

A Store Hours field with four custom time slots, (*9)

Templating

You can loop through your Store Hours fields to access info for each day of the week (starting with Sunday):, (*10)

<h3>Opening Hours</h3>
<dl>
  {% for day in entry.<FieldHandle> %}
    <dt>{{ day.name }}</dt>
    <dd>
      {% if day.isBlank %}
        Closed
      {% else %}
        {{ day.open|time }} - {{ day.close|time }}
      {% endif %}
    </dd>
  {% endfor %}
</dl>

The exact time format that will be used when outputting times with the |time filter depends on the current application locale. See the Craft documentation for details on how it can be customized., (*11)

Showing a Single Day’s Hours

You can get the hours for a single day using the following methods:, (*12)

Method Day
getSun() Sunday
getMon() Monday
getTue() Tuesday
getWed() Wednesday
getThu() Thursday
getFri() Friday
getSat() Saturday
getYesterday() Yesterday
getToday() Today
getTomorrow() Tomorrow
<h3>Today’s Hours</h3>
{% set today = entry.<FieldHandle>.today %}
{% if today.isBlank %}
  <p>Sorry, we’re closed today.</p>
  {% set tomorrow = entry.<FieldHandle>.tomorrow %}
  {% if not tomorrow.isBlank %}
    <p>We’ll be back open tomorrow at {{ tomorrow.open|time }}.</p>
  {% endif %}
{% else %}
  <p>We’re open from {{ today.open|time }} to {{ today.close|time }} today.</p>
{% endif %}

Showing a Custom Day Range

To only show certain days of the week (e.g only Monday through Friday), use the getRange() field method. Pass two integers in to represent the start and end days of the range, using this mapping:, (*13)

Number Day
0 Sunday
1 Monday
2 Tuesday
3 Wednesday
4 Thursday
5 Friday
6 Saturday
{# Only show Monday-Friday #}
{% set range = entry.<FieldHandle>.getRange(1, 5) %}

{% for day in range %}
    {# ... #}
{% endfor %}

Showing Grouped Ranges

You can show consolidated list of hours, such as:, (*14)

11am – 6pm Mon – Fri\ 11am – 5pm Sat – Sun, (*15)

To do that, use the getGroupedRanges() field method, which is similar to getRange(), except the resulting days are grouped by their time slots., (*16)

<ul>
  {% for group in entry.<FieldHandle>.getGroupedRanges(1) %}
    {% set first = group|first %}
    {% set last = group|last %}
    {% if first.open and first.close %}
      <li>
        <strong>
          {{ first.open|date('g:sa')|replace(':00', '') }}&hairsp;–&hairsp;{{ first.close|date('g:sa')|replace(':00', '') }}
        </strong>
        {% if first != last %}
          {{ first.getName('medium') }}&hairsp;–&hairsp;{{ last.getName('medium') }}
        {% else %}
          {{ first.getName('medium') }}
        {% endif %}
      {% endif %}
    </li>  
  {% endfor %}
</ul>

Changing the Week Start Day

You can use the getRange() field method to return the full list of days with a different week start day. For example, if you want Monday to be the first day of the week, do this:, (*17)

{# Show all days with Monday first #}
{% set range = entry.<FieldHandle>.getRange(1, 0) %}

{% for day in range %}
  {# ... #}
{% endfor %}

As a shortcut, you can also skip passing the end day when you want to do this:, (*18)

{# Show all days with Monday first #}
{% set range = entry.<FieldHandle>.getRange(1) %}

{% for day in range %}
  {# ... #}
{% endfor %}

Determining Whether All Slots are Blank

You can quickly find out whether all the time slots in a day were left blank using the getIsBlank() (isBlank) field method:, (*19)

<h3>Opening Hours</h3>
<dl>
  {% for day in entry.<FieldHandle> %}
    <dt>{{ day.name }}</dt>
    <dd>
      {% if day.isBlank %}
        Closed
      {% else %}
        {{ day.open|time }} - {{ day.close|time }}
      {% endif %}
    </dd>
  {% endfor %}
</dl>

The Versions

28/07 2018

v2.x-dev

2.9999999.9999999.9999999-dev

This plugin adds a new “Store Hours” field type to Craft, for collecting the opening and closing hours of a business for each day of the week.

  Sources   Download

MIT

The Requires

 

json yii2 html cms store craftcms hours

19/07 2018

2.1.0.1

2.1.0.1

This plugin adds a new “Store Hours” field type to Craft, for collecting the opening and closing hours of a business for each day of the week.

  Sources   Download

MIT

The Requires

 

json yii2 html cms store craftcms hours

19/07 2018

2.1.0

2.1.0.0

This plugin adds a new “Store Hours” field type to Craft, for collecting the opening and closing hours of a business for each day of the week.

  Sources   Download

MIT

The Requires

 

json yii2 html cms store craftcms hours

01/05 2018

dev-feature/isOpen

dev-feature/isOpen

This plugin adds a new “Store Hours” field type to Craft, for collecting the opening and closing hours of a business for each day of the week.

  Sources   Download

MIT

The Requires

 

json yii2 html cms store craftcms hours

17/04 2018

dev-feature/time-slots

dev-feature/time-slots

This plugin adds a new “Store Hours” field type to Craft, for collecting the opening and closing hours of a business for each day of the week.

  Sources   Download

MIT

The Requires

 

json yii2 html cms store craftcms hours

05/12 2017

2.0.6

2.0.6.0

This plugin adds a new “Store Hours” field type to Craft, for collecting the opening and closing hours of a business for each day of the week.

  Sources   Download

MIT

The Requires

 

json yii2 html cms store craftcms hours

09/11 2017

2.0.5

2.0.5.0

This plugin adds a new “Store Hours” field type to Craft, for collecting the opening and closing hours of a business for each day of the week.

  Sources   Download

MIT

The Requires

 

json yii2 html cms store craftcms hours

07/07 2017

2.0.4

2.0.4.0

This plugin adds a new “Store Hours” field type to Craft, for collecting the opening and closing hours of a business for each day of the week.

  Sources   Download

MIT

The Requires

 

json yii2 html cms store craftcms hours

15/05 2017

2.0.3

2.0.3.0

This plugin adds a new “Store Hours” field type to Craft, for collecting the opening and closing hours of a business for each day of the week.

  Sources   Download

MIT

The Requires

 

json yii2 html cms store craftcms hours

15/05 2017

2.0.2

2.0.2.0

This plugin adds a new “Store Hours” field type to Craft, for collecting the opening and closing hours of a business for each day of the week.

  Sources   Download

MIT

The Requires

 

json yii2 html cms store craftcms hours

15/05 2017

2.0.1

2.0.1.0

This plugin adds a new “Store Hours” field type to Craft, for collecting the opening and closing hours of a business for each day of the week.

  Sources   Download

MIT

The Requires

 

json yii2 html cms store craftcms hours

11/05 2017

2.0.0

2.0.0.0

This plugin adds a new “Store Hours” field type to Craft, for collecting the opening and closing hours of a business for each day of the week.

  Sources   Download

MIT

The Requires

 

json yii2 html cms store craftcms hours