WireArray::findRandomTimed() method

Find a quantity of random elements from this WireArray based on a timed interval (or user provided seed).

If no $seed is provided, today's date (day) is used to seed the random number generator, so you can use this function to rotate items on a daily basis.

Idea and implementation provided by mindplay.dk

Example

// Get same 3 random items per day
$randomItems = $items->findRandomTimed(3);

// Get same 3 random items per hour
$randomItems = $items->findRandomTimed('YmdH'); 

Usage

// basic usage
$items = $wireArray->findRandomTimed(int $num);

// usage with all arguments
$items = $wireArray->findRandomTimed(int $num, $seed = 'Ymd');

Arguments

NameType(s)Description
numint

The amount of items to extract from the given list

seed (optional)int, string

Optionally provide one of the following:

  • A PHP date() format string.
  • A number used to see the random number generator.
  • The default is the PHP date format "Ymd" which makes it randomize once daily.

Return value

See Also


WireArray methods and properties

API reference based on ProcessWire core version 3.0.236

Latest news

  • ProcessWire Weekly #550
    In the 550th issue of ProcessWire Weekly we're going to check out the latest core updates, introduce a new third party module called PagefileMetadata, and more. Read on!
    Weekly.pw / 23 November 2024
  • Custom Fields Module
    This week we look at a new ProFields module named Custom Fields. This module provides a way to rapidly build out ProcessWire fields that contain any number of subfields/properties within them.
    Blog / 30 August 2024
  • Subscribe to weekly ProcessWire news

“Indeed, if ProcessWire can be considered as a CMS in its own right, it also offers all the advantages of a CMF (Content Management Framework). Unlike other solutions, the programmer is not forced to follow the proposed model and can integrate his/her ways of doing things.” —Guy Verville, Spiria Digital Inc.