All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.izforge.izpack.panels.defaulttarget.DefaultTargetPanel Maven / Gradle / Ivy

There is a newer version: 5.2.2
Show newest version
/*
 * IzPack - Copyright 2001-2008 Julien Ponge, All Rights Reserved.
 *
 * http://izpack.org/
 * http://developer.berlios.de/projects/izpack/
 *
 * Copyright 2004 Klaus Bartz
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.izforge.izpack.panels.defaulttarget;

import com.izforge.izpack.api.adaptator.IXMLElement;
import com.izforge.izpack.api.data.Panel;
import com.izforge.izpack.api.resource.Resources;
import com.izforge.izpack.gui.log.Log;
import com.izforge.izpack.installer.automation.PanelAutomation;
import com.izforge.izpack.installer.data.GUIInstallData;
import com.izforge.izpack.installer.gui.InstallerFrame;
import com.izforge.izpack.installer.util.InstallPathHelper;
import com.izforge.izpack.panels.path.PathInputPanel;

import static com.izforge.izpack.panels.target.TargetPanel.PANEL_NAME;

/**
 * The target directory selection panel.
 * TODO - not clear why this class needs to extend PathInputPanel as it uses none of its methods
 *
 * @author Julien Ponge
 * @author Jeff Gordon
 */
public class DefaultTargetPanel extends PathInputPanel
{

    private static final long serialVersionUID = 3256443616359329170L;
    private PanelAutomation defaultTargetPanelAutomationHelper;

    /**
     * The constructor.
     *
     * @param panel       the panel meta-data
     * @param parent      the parent window
     * @param installData the installation data
     * @param resources   the resources
     * @param log         the log
     */
    public DefaultTargetPanel(Panel panel, InstallerFrame parent, GUIInstallData installData, Resources resources,
                              Log log)
    {
        super(panel, PANEL_NAME, parent, installData, resources, log);
        this.defaultTargetPanelAutomationHelper = new DefaultTargetPanelAutomationHelper();
    }

    /**
     * Called when the panel becomes active.
     */
    @Override
    public void panelActivate()
    {
        String path = InstallPathHelper.getPath(installData);
        installData.setInstallPath(path);
        parent.skipPanel();
    }

    /**
     * Indicates whether the panel has been validated or not.
     *
     * @return Whether the panel has been validated or not.
     */
    @Override
    public boolean isValidated()
    {
        return (true);
    }

    @Override
    public void createInstallationRecord(IXMLElement rootElement)
    {
        defaultTargetPanelAutomationHelper.createInstallationRecord(this.installData, rootElement);
    }

    @Override
    public String getSummaryBody()
    {
        return (this.installData.getInstallPath());
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy