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

application.ui.imports.ImportBrailleView Maven / Gradle / Ivy

package application.ui.imports;

import java.io.File;
import java.io.IOException;
import java.util.Map;
import java.util.logging.Level;
import java.util.logging.Logger;

import application.l10n.Messages;
import javafx.fxml.FXMLLoader;
import javafx.scene.Parent;
import javafx.scene.Scene;
import javafx.scene.input.KeyCode;
import javafx.scene.input.KeyEvent;
import javafx.stage.Stage;

/**
 * Provides a dialog that imports formatted braille.
 * @author Joel Håkansson
 */
public class ImportBrailleView extends Stage {
	private static final Logger logger = Logger.getLogger(ImportBrailleView.class.getCanonicalName());
	private ImportBrailleController controller;

	/**
	 * Creates a new import dialog with the specified file.
	 * @param path the file path
	 */
	public ImportBrailleView(File path) {
		try {
			FXMLLoader loader = new FXMLLoader(this.getClass().getResource("ImportBraille.fxml"), Messages.getBundle());
			Parent root = loader.load();
			controller = loader.getController();
			Scene scene = new Scene(root);
	    	setScene(scene);
			scene.addEventHandler(KeyEvent.KEY_PRESSED, ev->{
				if (ev.getCode()==KeyCode.ESCAPE) {
					controller.closeWindow();
				}
			});
	    	setResizable(false);
	    	controller.setFile(path);
		} catch (IOException e) {
			logger.log(Level.WARNING, "Failed to load view", e);
		}
		setTitle(Messages.TITLE_IMPORT_BRAILLE_OPTIONS_DIALOG.localize());
	}
	
	/**
	 * Gets the options set by the user when operating the dialog.
	 * @return returns the options set or null if the dialog was cancelled
	 */
	public Map getOptions() {
		return controller.getOptions();
	}

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy