The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
=head1 NAME

Net::Songkick::Venue - Models a venue in the Songkick API

=cut

package Net::Songkick::Venue;

use strict;
use warnings;

use Moose;

use Net::Songkick::MetroArea;

has $_ => (
    is => 'ro',
    isa => 'Str',
) for qw[uri lat id lng displayName];

has metro_area => (
    is => 'ro',
    isa => 'Net::Songkick::MetroArea',
);

=head1 METHODS

=head2 Net::Songkick::Venue->new_from_xml

Creates a new Net::Songkick::Venue object from an XML::Element object that
has been created from an <venue> ... </venue> element in the XML returned
from a Songkick API request.

=cut

sub new_from_xml {
    my $class = shift;
    my ($xml) = @_;

    my $self = {};

    foreach (qw[uri lat id lng displayName]) {
        $self->{$_} = $xml->findvalue("\@$_");
    }

    $self->{metro_area} =
        Net::Songkick::MetroArea->new_from_xml(
            ($xml->findnodes('metroArea'))[0]
        );

    return $class->new($self);
}

=head1 AUTHOR

Dave Cross <dave@mag-sol.com>

=head1 SEE ALSO

perl(1), L<http://www.songkick.com/>, L<http://developer.songkick.com/>

=head1 COPYRIGHT AND LICENSE

Copyright (C) 2010, Magnum Solutions Ltd.  All Rights Reserved.

This script is free software; you can redistribute it and/or modify it
under the same terms as Perl itself. 

=cut

1;