package RequestForm::Validate::Ajax;
use Dancer2;
use LIMS::Local::Utils;
use RequestForm::Class; # provides Moo, Local::MooX::Types & LIMS::Local::Debug::p
prefix '/ajax';
# nhs number ajax validation ('get' returns a string, 'post' returns json):
any [ qw(get post) ] => '/validate_nhs_number' => sub {
my $var = params->{nhs_number}; # p $var;
my $is_valid = LIMS::Local::Utils::check_nhsno($var) ? 'OK' : 'invalid';
# web form jquery $.ajax function sends a 'post' request, alternative is $.get
if (request->is_post) {
my $json = to_json({ result => $is_valid });
return $json;
}
else { return $is_valid }
};
# bsn.AutoSuggest.jQuery method, returns json:
get '/autosuggest_location' => sub {
my $ref_src = param 'ref_src'; # warn $ref_src;
return unless $ref_src && length $ref_src >= 3;
# my $db = var 'db'; p $db; # no access to RequestForm vars ??
my $ctr = session->read('centre'); # p $ctr;
my $db = RequestForm::DB->new(dbname => $ctr);
my $locations = $db->get_referral_sources($ref_src); # p $sources;
# manipulate $locations to provide keys for AJAX caller:
my @results = map {
{
id => $_->{id},
value => $_->{display_name},
info => $_->{organisation_code},
}
} @$locations;
my $json = to_json({ results => \@results }); # p $json;
return $json;
};
1;