X-Git-Url: http://git.shiar.net/sheet.git/blobdiff_plain/c9e6cdf33c70b00f4dfe433e6a9f9e4234f46736..9ddf2e9a6173fcb1649ab9dd72ded3896195c83f:/writer.plp?ds=inline diff --git a/writer.plp b/writer.plp index 48ffd67..256a074 100644 --- a/writer.plp +++ b/writer.plp @@ -13,16 +13,9 @@ EOT use List::Util qw( pairs pairkeys ); my $db = eval { - my @dbinfo = ( - 'DBI:Pg:dbname=sheet;host=localhost', 'sheetadmin', 'fairuse', - ) or die "database not configured\n"; - require DBIx::Simple; - DBIx::Simple->new(@dbinfo[0..2], { - RaiseError => 1, - pg_enable_utf8 => 1, - }); + require Shiar_Sheet::DB; + Shiar_Sheet::DB->connect; } or Abort('Database error', 501, $@); -$db->abstract->{array_datatypes}++; my $user = eval { if (defined $post{username}) { @@ -78,6 +71,7 @@ my %lang = ( en => ["\N{REGIONAL INDICATOR SYMBOL LETTER G}\N{REGIONAL INDICATOR SYMBOL LETTER B}", 'english'], eo => ['★', 'esperanto'], ru => ["\N{REGIONAL INDICATOR SYMBOL LETTER R}\N{REGIONAL INDICATOR SYMBOL LETTER U}", 'русский'], + la => ["\N{PUSHPIN}", 'latin'], ); my @wordcols = pairkeys my %wordcol = ( @@ -105,8 +99,20 @@ my %wordcol = ( source => {-label => 'Image'}, thumb => {-label => 'Convert options', -multiple => 1}, ); -my ($find) = map {{id => $_}} $fields{id} || $Request || (); +if (my $search = $fields{q}) { + my %filter = (form => {ilike => '%'.$search.'%'}); + my $results = $db->select(word => '*', \%filter); + say '

Search

\n"; + exit; +} + +my ($find) = map {{id => $_}} $fields{id} || $Request || (); my $row; if ($find) { $row = $db->select(word => '*', $find)->hash @@ -167,6 +173,7 @@ elsif (defined $post{form}) {{ prio => undef, ); $subrow{wptitle} = $1 if $subrow{form} =~ s/\h*\[(.*)\]$//; # [Link] shorthand + $subrow{alt} = [split m{/}, $1] if $subrow{form} =~ s{/(\S.*)}{}; # /alternates shorthand $db->insert(word => \%subrow); delete $fields{$field}; } @@ -214,7 +221,7 @@ elsif (defined $post{form}) {{ 'convert', $imgpath, -delete => '1--1', -background => 'white', - -gravity => @cmds ? 'northwest' : 'center', + -gravity => defined $row->{thumb} ? 'northwest' : 'center', @cmds, -resize => "$xyres^", -extent => $xyres, '-strip', -quality => '60%', -interlace => 'plane', @@ -300,7 +307,7 @@ package Shiar_Sheet::FormRow { sub imagepath { my ($row, $col) = @_; return "data/word/org/$row->{id}.jpg" if $col eq 'source'; - return "data/word/en/$row->{form}.jpg" if $col eq 'thumb'; + return "data/word/en/$row->{id}.jpg" if $col eq 'thumb'; return; } }