# Copyright (C) 2007-13  Stephane Galland <[email protected]>
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; see the file COPYING.  If not, write to
# the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA.

=pod

=head1 NAME

AutoLaTeX::GUI::AbstractTranslatorPanel - An abstract user interface

=head1 DESCRIPTION

AutoLaTeX::GUI::AbstractTranslatorPanel is a Perl module, which permits to
display a panel that manages AutoLaTeX translators.

=head1 METHOD DESCRIPTIONS

This section contains only the methods in AbstractTranslatorPanel.pm itself.

=over

=cut

package AutoLaTeX::GUI::AbstractTranslatorPanel;

@ISA = qw( AutoLaTeX::GUI::WidgetUtil );
@EXPORT = qw();
@EXPORT_OK = qw();

require 5.014;
use strict;
use utf8;
use vars qw(@ISA @EXPORT @EXPORT_OK $VERSION);
use Exporter;

use AutoLaTeX::GUI::WidgetUtil;
use AutoLaTeX::Core::Util;
use AutoLaTeX::Core::IntUtils;
use AutoLaTeX::Core::Translator;
use AutoLaTeX::Core::Config;

#------------------------------------------------------
#
# Global vars
#
#------------------------------------------------------

# Version number
my $VERSION = "7.0" ;

=pod

=item * initializeTranslatorPanel()

Initializing the panel content before displaying.

This method read the list of the translators and
fill the attribute C<{'DATA'}{'translators'}>.

=cut
sub initializeTranslatorPanel() : method {
       my $self = shift;

       my %translators = $self->readTranslatorList();
       $self->attr('TRANSLATORS') = \%translators;
}

=pod

=item * readTranslatorList()

Replies the hastable that describes the translators

=cut
sub readTranslatorList() : method {
       my $self = shift;

       my $systemConfig = $self->attr('CONFIGURATIONS','SYSTEM') || {};
       my $userConfig = $self->attr('CONFIGURATIONS','USER') || {};
       my $projectConfig = $self->attr('CONFIGURATIONS','PROJECT') || {};
       my $config = $self->attr('CONFIGURATIONS','FULL') || {};

       my %translators = getTranslatorList(%{$config});

       setInclusionFlags(%translators,
               %{$systemConfig},
               %{$userConfig},
               %{$projectConfig});

       return %translators;
}


=pod

=item * applyInclusionsInConfiguration(\%$)

Put the translator inclusion flags into the specified configuration.
Replies if a changed was applied in the configuration

=over 4

=item the configuration data structure

=item the configuration level

=back

=cut
sub applyInclusionsInConfiguration(\%$) {
       my $self = shift;
       my $hasChanged = 0;
       my $allTrans = $self->attr('TRANSLATORS');
       while (my ($transName,$data) = each(%{$allTrans})) {
               if (defined($data->{'included'}{$_[1]})) {
                       my $val = cfgToBoolean($data->{'included'}{$_[1]});
                       $hasChanged = ($hasChanged)||(!$_[0]->{"$transName.include module"})||($_[0]->{"$transName.include module"} ne $val);
                       $_[0]->{"$transName.include module"} = $val;
               }
       }
       printDbg(_T("No change detected")) unless ($hasChanged);
       return $hasChanged;
}

=pod

=item * savePanelContent()

Save the content of this panel.

=cut
sub savePanelContent() : method {
       my $self = shift;
       my %configuration;

       # System level
       if ($self->isAdminUser()) {
               printDbg(_T("Saving system configuration about translators"));
               printDbgIndent();
               %configuration = readOnlySystemConfiguration(1);
               if ($self->applyInclusionsInConfiguration(\%configuration,'system')) {
                       writeConfigFile(getSystemConfigFilename(), %configuration);
               }
               printDbgUnindent();
       }

       # User level
       printDbg(_T("Saving user configuration about translators"));
       printDbgIndent();
       %configuration = readOnlyUserConfiguration(1);
       if ($self->applyInclusionsInConfiguration(\%configuration,'user')) {
               writeConfigFile(getUserConfigFilename(), %configuration);
       }
       printDbgUnindent();

       # Project level
       if ($self->hasProject()) {
               printDbg(_T("Saving project configuration about translators"));
               printDbgIndent();
               %configuration = %{readOnlyProjectConfiguration($self->attr('CONFIGURATIONS','PROJECT','__private__','input.project directory'))};
               if ($self->applyInclusionsInConfiguration(\%configuration,'project')) {
                       writeConfigFile(getProjectConfigFilename(), %configuration);
               }
               printDbgUnindent();
       }
}

1;
__END__

=back

=head1 COPYRIGHT

(c) Copyright 2007-13 Stephane Galland E<lt>[email protected]<gt>, under GPL.

=head1 AUTHORS

=over

=item *

Conceived and initially developed by Stéphane Galland E<lt>[email protected]<gt>.

=back

=head1 SEE ALSO

L<autolatex>