diff options
Diffstat (limited to 'perl-install/install/gtk.pm')
| -rw-r--r-- | perl-install/install/gtk.pm | 235 | 
1 files changed, 114 insertions, 121 deletions
| diff --git a/perl-install/install/gtk.pm b/perl-install/install/gtk.pm index 877f62596..f878e42d9 100644 --- a/perl-install/install/gtk.pm +++ b/perl-install/install/gtk.pm @@ -1,18 +1,20 @@ -package install::gtk; # $Id$ +package install::gtk;  use diagnostics;  use strict; -use ugtk2; -use mygtk2; +use ugtk3; +use mygtk3;  use common;  use lang;  use devices; +use detect_devices;  #-#####################################################################################  #-INTERN CONSTANT  #-##################################################################################### +# FIXME: either drop 'doc' option or convert this to CSS!  #- if we're running for the doc team, we want screenshots with  #- a good B&W contrast: we'll override values of our theme  my $theme_overriding_for_doc = q(style "galaxy-default" @@ -52,69 +54,65 @@ widget "*logo*" style "background-logo"  );  #------------------------------------------------------------------------------ -sub load_rc { +sub load_css {      my ($o, $name) = @_;      my $f = $name; -    -r $name or $f = find { -r $_ } map { "$_/themes-$name.rc" } ("share", $ENV{SHARE_PATH}, dirname(__FILE__) . '/..'); +    -r $name or $f = find { -r $_ } map { "$_/themes-$name.css" } ("share", $ENV{SHARE_PATH}, dirname(__FILE__) . '/..');      if ($f) { -	Gtk2::Rc->parse_string($o->{doc} ? $theme_overriding_for_doc : scalar cat_($f)); +	my $pl = Gtk3::CssProvider->new; +	$pl->load_from_data($o->{doc} ? $theme_overriding_for_doc : scalar cat_($f)); +	Gtk3::StyleContext::add_provider_for_screen(Gtk3::Gdk::Screen::get_default(), $pl, Gtk3::STYLE_PROVIDER_PRIORITY_APPLICATION);     } - -    if ($::move) { -        #- override selection color since we will not do inverse-video on the text when it's images -	Gtk2::Rc->parse_string(q( -style "galaxy-default" -{ -    base[ACTIVE]      = "#CECECE" -    base[SELECTED]    = "#CECECE" -    text[ACTIVE]      = "#000000" -    text[PRELIGHT]    = "#000000" -    text[SELECTED]    = "#000000" -} -)); -    }  }  #------------------------------------------------------------------------------  sub load_font {      my ($o) = @_; -    if (lang::text_direction_rtl()) { -	Gtk2::Widget->set_default_direction('rtl');  +    if (defined($::WizardWindow) && lang::text_direction_rtl()) { +	Gtk3::Widget::set_default_direction('rtl');  	my ($x, $y) = $::WizardWindow->get_position;  	my ($width) = $::WizardWindow->get_size;  	$::WizardWindow->move($::rootwidth - $width - $x, $y);      } -    Gtk2::Rc->parse_string(q( -style "default-font"  -{ -   font_name = ") . lang::l2pango_font($o->{locale}{lang}) . q(" -} -widget "*" style "default-font" - +    my $font = lang::l2pango_font($o->{locale}{lang}); +    my $s = qq(gtk-font-name = $font); +    my $pl = Gtk3::CssProvider->new; +    $pl->load_from_data(sprintf("GtkWindow { %s }", lang::l2css_font($o->{locale}{lang}))); +    Gtk3::StyleContext::add_provider_for_screen(Gtk3::Gdk::Screen::get_default(), $pl, Gtk3::STYLE_PROVIDER_PRIORITY_APPLICATION); +    # FIXME: this should be done in /mnt too for forked app such as gurpmi{,.addmedia} (mga#67): +    output("/.config/gtk-3.0/settings.ini", qq([Settings] +$s  ));  }  #------------------------------------------------------------------------------  sub default_theme {      my ($o) = @_; -    $::move ? '' :      $o->{simple_themes} || $o->{vga16} ? 'blue' : 'galaxy';  } +my $root_window; +  sub install_theme {      my ($o) = @_; -    load_rc($o, $o->{theme} ||= default_theme($o)); +    load_css($o, $o->{theme} ||= default_theme($o));      load_font($o); -    if (!$::move) { -	my $win = gtknew('Window', widget_name => 'background'); -	$win->realize; -	mygtk2::set_root_window_background_with_gc($win->style->bg_gc('normal')); -    } +    my $win = gtknew('Window', widget_name => 'background', title => 'root window'); +    $win->set_type_hint('desktop'); # for matchbox window manager +    $win->realize; +    $root_window = $win; +} + +sub create_step_box { +    gtknew('HBox', spacing => 0, children => [ +        @_, +        0, gtknew('Alignment', width => 24), +    ]);  }  #------------------------------------------------------------------------------ @@ -122,34 +120,52 @@ my %steps;  sub create_steps_window {      my ($o) = @_; -    return if $::stepswidth == 0; -      $o->{steps_window} and $o->{steps_window}->destroy;      $steps{$_} ||= gtknew('Pixbuf', file => "steps_$_") foreach qw(on off done); +      my $category = sub {  -	gtknew('HBox', children_tight => [  -	    gtknew('Label', text_markup => '<b><u>' . $_[0] . '</u></b>', widget_name => 'Step-categories') -	]); +	create_step_box( +	    1, gtknew('Label_Right', text_markup => '<b>' . uc($_[0]) . '</b>', widget_name => 'Step-categories'), +	);      }; -    my @l = $category->(N("Installation")); +    my @l = ( +        $category->(N("Installation")) +    );      foreach (grep { !eval $o->{steps}{$_}{hidden} } @{$o->{orderedSteps}}) { -	if ($_ eq 'setRootPassword') { +	if ($_ eq 'setRootPassword_addUser') {  	    push @l, '', $category->(N("Configuration"));  	}  	my $img = gtknew('Image', file => 'steps_off.png');  	$steps{steps}{$_}{img} = $img; -	$steps{steps}{$_}{raw_text} = translate($o->{steps}{$_}{text}); -	push @l, gtknew('HBox', spacing => 7, children_tight => [ '', '', $img, $steps{steps}{$_}{text} = gtknew('Label', text => $steps{steps}{$_}{raw_text}) ]); +	push @l, create_step_box( +            1, $steps{steps}{$_}{text} = gtknew('Label_Right', text => translate($o->{steps}{$_}{text})), +            0, gtknew('Alignment', width => 6), +            0, $img, +        );      } -    my $offset = 20; -    $o->{steps_window} = -      gtknew('Window', width => ($::stepswidth - $offset), widget_name => 'Steps', -	     position => [ lang::text_direction_rtl() ? $::rootwidth - $::stepswidth : $offset, 150 ], -	     child => gtknew('VBox', spacing => 6, children_tight => \@l)); -    $o->{steps_window}->show; +    my $offset = 10; +    $o->{steps_widget} = +      gtknew('MDV_Notebook', widget_name => 'Steps', children => [ +          # 145 is the vertical offset in order to be below the actual logo: +          [ gtknew('VBox', spacing => 6, width => ($::stepswidth - $offset), children_tight => \@l), 0, 145 ] +      ]); + +    $root_window->add( +        $o->{steps_window} =  +          gtknew('HBox', +                 children => +                   [ +                       if_($::stepswidth != 0, 0, $o->{steps_widget}), +                       1, gtknew('Label', width => -1, height => -1), +                   ], +             ) +    ); + +    $root_window->set_position('GTK_WIN_POS_CENTER_ALWAYS'); +    $root_window->show_all;  }  sub update_steps_position { @@ -159,43 +175,30 @@ sub update_steps_position {      foreach (@{$o->{orderedSteps}}) {  	exists $steps{steps}{$_} or next;  	if ($o->{steps}{$_}{entered} && !$o->{steps}{$_}{done}) { -	    $steps{steps}{$_}{img}->set_from_pixbuf($steps{on}); -	    $steps{steps}{$_}{text}->set_markup('<b><i>' . $steps{steps}{$_}{raw_text} . '</i></b>'); -	    if ($last_step) { -             $steps{steps}{$last_step}{img}->set_from_pixbuf($steps{done}); -             $steps{steps}{$last_step}{text}->set_markup('<b>' . $steps{steps}{$last_step}{raw_text} . '</b>'); -         } +            # we need to flush the X queue since else we got a temporary Y position of -1 when switching locales: +            mygtk3::flush(); #- for auto_installs which never go through the Gtk3 main loop +            $o->{steps_widget}->move_selection($steps{steps}{$_}{text}); + +            if ($last_step) { +                $steps{steps}{$last_step}{img}->set_from_pixbuf($steps{done}); +            }  	    return;  	} -	$last_step = $_; +        $last_step = $_;      } -    mygtk2::flush(); #- for auto_installs which never go through the Gtk2 main loop -} - -#------------------------------------------------------------------------------ -sub create_logo_window { -    my ($o) = @_; - -    return if $::logowidth == 0 || $::move; - -    mygtk2::may_destroy($o->{logo_window}); - -    my $file = $o->{meta_class} eq 'firewall' ? "logo-mandriva-Firewall.png" : "logo-mandriva.png"; - -    $o->{logo_window} = -      gtknew('Window',  -	     width => $::logowidth, height => $::logoheight,  -	     widget_name => 'logo', -	     child => gtknew('Image', file => $file), -	 ); -    $o->{logo_window}->show; +    mygtk3::flush(); #- for auto_installs which never go through the Gtk3 main loop  }  #------------------------------------------------------------------------------  sub init_gtk {      my ($o) = @_; -    symlink("/tmp/stage2/etc/$_", "/etc/$_") foreach qw(gtk-2.0 pango fonts); +    symlink("/tmp/stage2/etc/$_", "/etc/$_") foreach qw(gtk-3.0 pango fonts); + +    # Custom _global_ CSS: +    mkdir_p("/.config/gtk-3.0");  # TODO/FIXME: set ENV{HOME} ? +    # FIXME: this should be done in /mnt too for forked app such as gurpmi{,.addmedia} (mga#67): +    symlinkf('/usr/lib/libDrakX/gtk.css', '/.config/gtk-3.0/gtk.css');      if ($o->{vga16}) {          #- inactivate antialias in VGA16 because it makes fonts look worse @@ -208,19 +211,19 @@ q(<fontconfig>          $ENV{FONTCONFIG_FILE} = '/tmp/fonts.conf';      } -    Gtk2->init; -    Gtk2->set_locale; +    Gtk3->init; +    c::init_setlocale();  }  #------------------------------------------------------------------------------  sub init_sizes {      my ($o) = @_; -    ($::rootwidth,  $::rootheight)    = (Gtk2::Gdk->screen_width, Gtk2::Gdk->screen_height); -    $::stepswidth = $::rootwidth <= 640 ? 0 : 200 if !$::move; -    ($::logowidth, $::logoheight) = $::rootwidth <= 640 ? (0, 0) : (800, 75); -    ($o->{windowwidth}, $o->{windowheight}) = ($::rootwidth - $::stepswidth, $::rootheight - $::helpheight - $::logoheight); -    ($::real_windowwidth, $::real_windowheight) = (576, 418); -    $::move and $o->{windowwidth} -= 100; +    ($::rootwidth,  $::rootheight)    = (Gtk3::Gdk::Screen::width, Gtk3::Gdk::Screen::height); +    $::stepswidth = $::rootwidth <= 640 ? 0 : 196; +    ($o->{windowwidth}, $o->{windowheight}) = ($::rootwidth - $::stepswidth, $::rootheight); +    # Adapt the window size to available screen width and height. +    $::real_windowwidth = $::rootwidth > 800 ? 800 : 576; +    $::real_windowheight = $::rootheight > 600 ? 633 : 465;  }  sub handle_unsafe_mouse { @@ -238,49 +241,39 @@ sub handle_unsafe_mouse {  sub special_shortcuts {      my (undef, $event) = @_; -    my $d = ${{ $Gtk2::Gdk::Keysyms{F2} => 'screenshot', $Gtk2::Gdk::Keysyms{Home} => 'restart' }}{$event->keyval}; +    my $d = ${{ Gtk3::Gdk::KEY_F2 => 'screenshot', Gtk3::Gdk::KEY_Home => 'restart' }}{$event->keyval};      if ($d eq 'screenshot') { +	# FIXME: should handle the fact it doesn't work when chrooted by urpmi during transaction:  	install::any::take_screenshot($::o);      } elsif ($d eq 'restart' && member('control-mask', @{$event->state}) && member('mod1-mask', @{$event->state})) {  	log::l("restarting install"); -	ugtk2->exit(0x35); +	ugtk3->exit(0x35);      }      0;  }  #------------------------------------------------------------------------------  sub createXconf { -    my ($file, $mouse_type, $mouse_dev, $_wacom_dev, $Driver) = @_; - -    symlinkf(devices::make($mouse_dev), "/dev/mouse") if $mouse_dev ne 'none'; - -    #- needed for imlib to start on 8-bit depth visual. -    symlink("/tmp/stage2/etc/imrc", "/etc/imrc"); -    symlink("/tmp/stage2/etc/im_palette.pal", "/etc/im_palette.pal"); +    my ($file, $Driver) = @_;      #- remove "error opening security policy file" warning      symlink("/tmp/stage2/etc/X11", "/etc/X11"); -if ($Driver) { -     output($file, sprintf(<<'END', ($::globetrotter ? "" : 'Option "XkbDisable"'), $mouse_type, $Driver, $Driver eq 'fbdev' ? '"default"' : '"800x600" "640x480"')); -Section "Files" -   FontPath   "/usr/share/fonts:unscaled" +    return if !$Driver; + +     # grub2-efi init framebuffer in 1024x768, we must stay in sync or loading fails +     my $resolution = $Driver eq 'fbdev' ? is_uefi() ? '"1024x768"' : '"default"' : '"800x600" "640x480"'; +     # efi framebuffer wants 24 bit +     my $depth = is_uefi() ? '24' : '16'; +     output($file, qq(Section "ServerFlags"  EndSection -Section "InputDevice" -    Identifier "Keyboard" -    Driver "keyboard" -    %s -    Option "XkbModel" "pc105" -    Option "XkbLayout" "" +Section "Module" +      Disable "glx"  EndSection -Section "InputDevice" -    Identifier "Mouse" -    Driver "mouse" -    Option "Protocol" "%s" -    Option "Device" "/dev/mouse" -    Option "ZAxisMapping" "4 5" +Section "Files" +   FontPath   "/usr/share/fonts:unscaled"  EndSection  Section "Monitor" @@ -291,29 +284,29 @@ EndSection  Section "Device"      Identifier  "device" -    Driver      "%s" +    Driver      "$Driver"  EndSection  Section "Screen"      Identifier "screen"      Device "device"      Monitor "monitor" -    DefaultColorDepth 16 +    DefaultColorDepth $depth      Subsection "Display" -        Depth 16 -        Modes %s +        Depth $depth +        Modes $resolution      EndSubsection  EndSection  Section "ServerLayout" +    Option "BlankTime"   "0" +    Option "StandbyTime" "0" +    Option "SuspendTime" "0" +    Option "OffTime"     "0"      Identifier "layout"      Screen "screen" -    InputDevice "Mouse" "CorePointer" -    InputDevice "Keyboard" "CoreKeyboard"  EndSection - -END - } +));  }  1; | 
