5 % my $prefix = $opt{'prefix'} || '';
6 % my $disabled = $opt{'disabled'} || '';
7 % my $empty = $opt{'empty_option'} || '';
8 % my $start_year = $opt{'start_year'};
9 % my $end_year = $opt{'end_year'} || '2037';
12 % if ( $opt{'show_month_abbr'} ) {
13 % @mon = qw(Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec);
15 % @mon = ( ( map "0$_", 1 .. 9 ), 10 .. 12 ),
18 % my $date = $opt{'selected_date'} || '';
19 % $date = '' if $date eq '-';
20 % #$date ||= '01-2000' unless $empty;
22 % my $mon = $opt{'selected_mon'} || 0;
23 % my $year = $opt{'selected_year'} || 0;
25 % if ( $date =~ /^(\d{4})-(\d{1,2})-\d{1,2}$/ ) { #PostgreSQL date format
26 % ( $mon, $year ) = ( $2, $1 );
27 % } elsif ( $date =~ /^(\d{1,2})-(\d{1,2}-)?(\d{4}$)/ ) {
28 % ( $mon, $year ) = ( $1, $3 );
30 % die "unrecognized expiration date format: $date";
34 % unless ( $start_year ) {
36 % $start_year = $t[5] + 1900;
38 % $start_year = $year if $start_year > $year && $year > 0;
43 <SELECT NAME="<% $prefix %>_month" SIZE="1" <% $disabled%>>
45 <% $empty ? '<OPTION VALUE="">' : '' %>
46 % foreach ( 1 .. 12 ) {
48 <OPTION<% $_ == $mon ? ' SELECTED' : '' %> VALUE="<% $_ %>"><% $mon[$_-1] %>
52 </SELECT>/<SELECT NAME="<% $prefix %>_year" SIZE="1" <% $disabled%>>
54 <% $empty ? '<OPTION VALUE="">' : '' %>
55 % for ( $start_year .. $end_year ) {
57 <OPTION<% $_ == $year ? ' SELECTED' : '' %> VALUE="<% $_ %>"><% $_ %>