NAME

HTML::CalendarMonth - Perl extension for generating and manipulating HTML calendar months

SYNOPSIS

require HTML::CalendarMonth;
use     HTML::AsSubs;
$c = new HTML::CalendarMonth ( month => 3, year => 69 );
$c->item($c->year,$c->month)->attr(bgcolor => 'wheat');
$c->item($c->year,$c->month)->wrap_content(font({size => '+2'}));
print $c->as_HTML;

DESCRIPTION

HTML::CalendarMonth is a subclass of HTML::ElementTable. See HTML::ElementTable(3) for how that class works, for it affects this module on many levels. Like HTML::ElementTable, HTML::CalendarMonth behaves as if it were an HTML::ElementSuper, with methods added to easily manipulate the appearance of the HTML table containing the calendar. In addition to the row and column cell based methods provided in HTML::ElementTable, there are analogous methods based on items, or the symbols contained in the calendar cells. For instance, $c->item(15) returns the cell containing the 15th, and $c->item($c->year()) returns the cell containing the year. Groups of item cells can be manipulated as if they were single elements. For example, $c->daycol('Su') would affect all days in the same column as the 'Su' header.

The module includes support for 'week of the year' numbering, arbitrary 1st day of the week definitions, and aliasing so that you can express any element in any language HTML can handle.

PUBLIC METHODS

All arguments appearing in [brackets] are optional.

Constructor
new([attr1 => val1, attr2 => val2, ...]) HTML::CalendarMonth;

With no arguments, the constructor will return a calendar object representing the current month with a default appearance. The initial configuration of the calendar is controlled by special attributes. Non-calendar related attributes are passed along to HTML::ElementTable. Any non-table related attributes left after that are passed to HTML::Element while constructing the <table> tag.

Special Attributes for HTML::CalendarMonth

month      1-12, or Jan-Dec.  Default current.
year       Four digit representation.  Default current.
head_m     0 or 1.  Mode for month header display. Default 1.
head_y     0 or 1.  Mode for year header display. Default 1.
head_dow   0 or 1.  Mode for day-of-week header display. Default 1.
head_week  0 or 1.  Mode for week-of-year header display. Default 0.
week_begin 1..7. Specify first day of the week.  Days of the
           week  are numbered 1..7 
row_offset Row offset within the table containing the calendar.
col_offset Column offset within the table containing the calendar.
historic   0 or 1.  This option is ignored for dates that do not
           exceed the range of the built-in perl time functions.
           For dates that do exceed these ranges, this option
           specifies the default calculation method.  When set,
           if the 'cal' utility is available on your system, that
           will be used rather than Date::Calc. This is and issue
           since Date::Calc blindly extrapolates the Gregorian
           calendar, whereas 'cal' takes some of these quirks into
           account.  If 'cal' is not available on your system,
           this attribute is meaningless. Default 1.

See HTML::ElementTable(3) for the special attributes available to that class.

Item Query Methods

The following methods return lists of item symbols that are related in some way to the provided list of items. The returned items may then be used as arguments to the glob methods detailed further below. When these methods deal with 'rows' and 'columns', they are only concerned with the cells in the calendar -- not the cells that might be present in the surrounding table if you have extended it. If you have not set row or column offsets, or extended the span of the containing table, then these rows and columns are functionally equivalent to the table rows and columns.

row_items(row1, [row2, ...])

Returns all items in rows shared by the provided items.

col_items(col1, [col2, ...])

Returns all items in columns shared by the provided items.

daycol_items(col1, [col2, ...])

Same as col_items(), but the returned items are limited to those that are not header items (month, year, day-of-week).

row_of(item1, [item2, ...])

Returns the row numbers of rows containing the provided items.

col_of(item1, [item2, ...])

Returns the column numbers of columns containing the provided items.

lastday()

Returns the last day of the month.

dow1st()

Returns the column number for the first day of the month.

days()

Returns a list of all days of the month.

dayheaders()

Returns a list of all day headers (Su..Sa)

headers()

Returns a list of all headers (month, year, dayheaders)

items()

Returns a list of all items in the calendar.

first_col()

Returns the number of the first column of the calendar. This could be different from that of the surrounding table if the table was extended.

last_col()

Returns the number of the last column of the calendar. This could be different from that of the surrounding table if the table was extended.

first_row()

Returns the number of the first row of the calendar. This could be different from that of the surrounding table if offsets were made.

first_week_row()

Returns the number of the first row of the calendar containing day items (ie, the first week). This could vary depending on table offsets and header modes.

last_row()

Returns the number of the last row of the calendar. This could be different from that of the surrounding table if the table was extended.

Glob Methods

Glob methods return references that are functionally equivalent to an individual calendar cell. Mostly, they provide item based analogues to the glob methods provided in HTML::ElementTable. In methods dealing with rows, columns, and boxes, the globs include empty calendar cells (which would otherwise need to be accessed through native HTML::ElementTable methods). The row and column numbers returned by the item methods above are compatible with the grid based methods in HTML::ElementTable.

For details on how these globs work, check out HTML::ElementTable and HTML::ElementGlob.

item(item1, [item2, ...])

Returns all cells containing the provided items.

item_row(item1, [item2, ...])

Returns all cells in all rows occupied by the provided items.

item_col(item1, [item2, ...])

Returns all cells in all columns occupied by the provided items.

item_daycol(item1, [item2, ...])

Same as item_col(), except limits the cells to non header cells.

item_box(item1a, item1b, [item2a, item2b, ...])

Returns all cells in the boxes defined by the item pairs provided.

allheaders()

Returns all header cells.

alldays()

Returns all non header cells, including empty cells.

all()

Returns all cells in the calendar, including empty cells.

Transformation Methods

The following methods provide ways of translating between various symbolic values, coordinates, and representations.

coords_of(item)

Returns the row and column of the provided item, for use with the grid based methods in HTML::ElementTable.

item_at(row,column)

Returns the symbol of the item at the provided coordinates, for use with the item based methods of HTML::CalendarMonth.

monthname(monthnum)

Returns the name of the month number provided, where monthnum can be 1..12.

monthnum(monthname)

Returns the number (1..12) of the month name provided. Only a minimal case-insensitive match on the month name is necessary.

dayname(daynum)

Returns the name of the day of week header for a number of a day of the week, where daynum is 1..7.

daynum(dayname)

Returns the number of the day of the week given the symbolic name for that day (Su..Sa).

daytime(day)

Returns the number in seconds since the epoch for a given day. The day must be present in the current calendar.

REQUIRES

HTML::ElementTable

OPTIONAL

Date::Calc (only if you want week-of-year numbering)

AUTHOR

Matthew P. Sisk, <sisk@mojotoad.com>

COPYRIGHT

Copyright (c) 1998-2000 Matthew P. Sisk. All rights reserved. All wrongs revenged. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

ACKNOWLEDGEMENTS

Thanks to William R. Ward for some conceptual nudging. Thanks to Jarkko Hietaniemi for some suggestions on global calendar customs.

SEE ALSO

HTML::ElementTable(3), HTML::Element(3), perl(1)