7 use Data::Dump qw(dump);
10 my $odt_file = 'contributions.odt';
12 my $xs = XML::Simple->new();
14 use OpenOffice::OODoc 2.101;
15 my $doc = odfDocument(file => $odt_file, create => 'text');
22 family => 'paragraph',
27 'fo:text-align' => 'justify'
33 #foreach my $file ( glob 'contributions/*.xml' ) {
36 open(my $fh, '<', 'contributions/all.xml');
43 foreach my $xml ( split(/\Q<?xml\E/, $xml) ) {
47 $xml = '<?xml' . $xml;
53 $abstract = $xs->XMLin( $xml, ForceArray => qw(PrimaryAuthor) );
55 warn "# abstract = ", dump($abstract);
57 my $id = $abstract->{'Id'}->[0] || die "no Id in ",dump($abstract);
58 warn "# $id abstract = ", dump($abstract);
60 foreach my $k (qw( ContributionType )) {
61 push @{ $stat->{$k}->{ $abstract->{$k}->[0] } }, $id;
64 if ( $abstract->{'ContributionType'}->[0] eq 'Symposium proposal' ) {
65 my $t = $abstract->{Title}->[0];
66 push @{ $stat->{_symposium}->{ $t } }, -$id;
69 if ( my $s = $abstract->{Symposium_title} ) {
71 push @{ $stat->{_symposium}->{$s} }, $id;
74 if ( exists $abstract->{PrimaryAuthor}->[0]->{FamilyName} ) {
75 $stat->{_order_by}->{$id} = $abstract->{PrimaryAuthor}->[0]->{FamilyName}->[0];
78 $abstracts->{ $id } = $abstract;
82 #warn "# stat = ",dump($stat);
87 my $abstract = $abstracts->{$id} || die "no $id in abstracts ",dump($abstracts);
89 my $t = $doc->appendParagraph(text => $abstract->{Title}->[0], style => 'Heading 1');
90 $doc->setPageBreak( $t, position => 'before', style => 'Heading 1');
92 foreach my $a ( @{ $abstract->{PrimaryAuthor} } ) {
93 $doc->appendParagraph(text => join(' ',
94 map { $a->{$_}->[0] } qw( FirstName FamilyName )
95 ), style => 'Heading 2');
96 $doc->appendParagraph(text => join(' ',
97 map { $a->{$_}->[0] } qw( Affiliation )
98 ), style => 'Heading 3');
99 push @{ $stat->{_Affiliation}->{ $a->{Affiliation}->[0] } }, $id;
102 # $doc->appendParagraph(text => $abstract->{Content}->[0], style => 'Abstract');
103 foreach my $p ( split(/[\n\r]+/, $abstract->{Content}->[0] ) ) {
104 $doc->appendParagraph(text => $p, style => 'Abstract');
107 $doc->appendParagraph(text => "\nTheme: " . $abstract->{Theme}->[0], style => 'Theme');
109 $doc->appendParagraph(text => "\nContributionType: " . $abstract->{ContributionType}->[0], style => 'Quotations');
111 $doc->appendParagraph(text => "\nID: " . $abstract->{Id}->[0], style => 'Abstract');
113 warn "# added $id to document\n";
116 #foreach my $id ( keys %$abstracts ) {
120 foreach my $symposium ( keys %{ $stat->{'_symposium'} } ) {
122 my $t = $doc->appendParagraph(text => $symposium, style => 'Title');
123 $doc->setPageBreak( $t, position => 'before', style => 'Title');
124 $doc->appendParagraph(text => 'Symposium', style => 'Subtitle');
126 my @symposium_ids = sort @{ $stat->{'_symposium'}->{$symposium} };
127 warn "## [$symposium] symposium_ids ", dump( @symposium_ids );
129 my $proposal_id = shift @symposium_ids;
130 if ( $proposal_id < 0 ) {
131 $proposal_id = abs( $proposal_id );
133 warn "ERROR: symposium [$symposium] doesn't have proposal!";
136 # @symposium_ids = sort { $stat->{_order_by}->{$a} cmp $stat->{_order_by}->{$b} } @symposium_ids;
137 @symposium_ids = sort @symposium_ids;
138 unshift @symposium_ids, $proposal_id;
140 $stat->{_order_symposium}->{$symposium} = [ @symposium_ids ];
142 foreach my $id ( @symposium_ids ) {
148 foreach my $type ( 'Oral presentation', 'Poster presentation' ) {
150 my $t = $doc->appendParagraph(text => $type, style => 'Title');
151 $doc->setPageBreak( $t, position => 'before', style => 'Title');
153 my @order = sort { lc $stat->{_order_by}->{$a} cmp lc $stat->{_order_by}->{$b} }
154 @{ $stat->{'ContributionType'}->{$type} };
156 $stat->{ '_order_' . $type } = [ @order ];
158 foreach my $id ( @order ) {
164 warn "# stat = ",dump($stat);
169 open(my $fh, '>', 'affiliation.csv');
170 foreach my $a ( sort keys %{ $stat->{_Affiliation} } ) {
171 print $fh '"',$a,'","',dump( $stat->{_Affiliation}->{$a} ), '"', "\n";
175 "Symposium proposal" => 12,
176 "Symposium abstract" => 52,
177 "Oral presentation" => 141,
178 "Poster presentation" => 71,