blob: dd32001b9ef6a7a1e9ff8e929b76265ae27200c7 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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 org.apache.directory.studio.valueeditors.adtime;
import java.util.Calendar;
import org.apache.directory.studio.common.ui.widgets.BaseWidgetUtils;
import org.apache.directory.studio.valueeditors.ValueEditorsActivator;
import org.apache.directory.studio.valueeditors.ValueEditorsConstants;
import org.eclipse.jface.dialogs.Dialog;
import org.eclipse.swt.SWT;
import org.eclipse.swt.events.ModifyEvent;
import org.eclipse.swt.events.ModifyListener;
import org.eclipse.swt.events.SelectionAdapter;
import org.eclipse.swt.events.SelectionEvent;
import org.eclipse.swt.events.SelectionListener;
import org.eclipse.swt.events.VerifyEvent;
import org.eclipse.swt.events.VerifyListener;
import org.eclipse.swt.layout.GridData;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Control;
import org.eclipse.swt.widgets.DateTime;
import org.eclipse.swt.widgets.Label;
import org.eclipse.swt.widgets.Shell;
import org.eclipse.swt.widgets.Spinner;
import org.eclipse.swt.widgets.Text;
/**
* This class provides a dialog to edit an Active Directory Date & Time value.
*
* @author <a href="mailto:dev@directory.apache.org">Apache Directory Project</a>
*/
public class ActiveDirectoryTimeValueDialog extends Dialog
{
/** The value */
private long value;
//
// UI Fields
//
// Time
private Spinner hoursSpinner;
private Spinner minutesSpinner;
private Spinner secondsSpinner;
// Date
private DateTime dateCalendar;
// Raw value
private Text rawValueText;
//
// Listeners
//
/**
* The modify listener of the hours field.
*/
private ModifyListener hoursModifyListener = new ModifyListener()
{
public void modifyText( ModifyEvent e )
{
updateValueFromNonRawFields();
removeListeners();
updateRawFields();
addListeners();
}
};
/**
* The modify listener of the minutes field.
*/
private ModifyListener minutesModifyListener = new ModifyListener()
{
public void modifyText( ModifyEvent e )
{
updateValueFromNonRawFields();
removeListeners();
updateRawFields();
addListeners();
}
};
/**
* The modify listener of the seconds field.
*/
private ModifyListener secondsModifyListener = new ModifyListener()
{
public void modifyText( ModifyEvent e )
{
updateValueFromNonRawFields();
removeListeners();
updateRawFields();
addListeners();
}
};
/**
* The selection listener of the calendar.
*/
private SelectionListener dateSelectionListener = new SelectionAdapter()
{
public void widgetSelected( SelectionEvent e )
{
updateValueFromNonRawFields();
removeListeners();
updateRawFields();
addListeners();
}
};
/**
* The modify listener of the raw field.
*/
private ModifyListener rawValueModifyListener = new ModifyListener()
{
public void modifyText( ModifyEvent e )
{
try
{
value = Long.parseLong( rawValueText.getText() );
removeListeners();
updateNonRawFields();
addListeners();
}
catch ( NumberFormatException e1 )
{
return;
}
}
};
private VerifyListener rawValueVerifyListener = new VerifyListener()
{
public void verifyText( VerifyEvent e )
{
// Prevent the user from entering anything but an integer
if ( !e.text.matches( "(-)?([0-9])*" ) ) //$NON-NLS-1$
{
e.doit = false;
}
}
};
/**
* Creates a new instance of ActiveDirectoryTimeValueDialog.
*
* @param parentShell
* the parent shell
* @param value
* the initial value
*/
public ActiveDirectoryTimeValueDialog( Shell parentShell, long value )
{
this( parentShell );
this.value = value;
}
/**
* Creates a new instance of ActiveDirectoryTimeValueDialog.
*
* @param parentShell
* the parent shell
* @param value
* the initial value
*/
public ActiveDirectoryTimeValueDialog( Shell parentShell )
{
super( parentShell );
super.setShellStyle( super.getShellStyle() | SWT.RESIZE );
this.value = ActiveDirectoryTimeUtils.convertToActiveDirectoryTime( Calendar.getInstance() );
}
/**
* {@inheritDoc}
*/
protected void configureShell( Shell shell )
{
super.configureShell( shell );
shell.setText( Messages.getString( "ActiveDirectoryTimeValueDialog.DateAndTimeEditor" ) ); //$NON-NLS-1$
shell.setImage( ValueEditorsActivator.getDefault().getImage( ValueEditorsConstants.IMG_GENERALIZEDTIMEEDITOR ) );
}
/**
* {@inheritDoc}
*/
protected Control createDialogArea( Composite parent )
{
// Main composites
Composite composite = ( Composite ) super.createDialogArea( parent );
Composite dualComposite = BaseWidgetUtils.createColumnContainer( composite, 2, 1 );
// Creating dialog areas
createTimeDialogArea( dualComposite );
createDateDialogArea( dualComposite );
createRawValueDialogArea( dualComposite );
// Initializing with initial value
initWithInitialValue();
// Adding listeners
addListeners();
applyDialogFont( composite );
return composite;
}
/**
* Creates the "Time" dialog area.
*
* @param parent
* the parent composite
*/
private void createTimeDialogArea( Composite parent )
{
// Label
Label timeLabel = new Label( parent, SWT.NONE );
timeLabel.setText( Messages.getString( "ActiveDirectoryTimeValueDialog.Time" ) ); //$NON-NLS-1$
Composite rightComposite = BaseWidgetUtils.createColumnContainer( parent, 5, 1 );
// Hours
hoursSpinner = new Spinner( rightComposite, SWT.BORDER );
hoursSpinner.setMinimum( 0 );
hoursSpinner.setMaximum( 23 );
hoursSpinner.setTextLimit( 2 );
hoursSpinner.setLayoutData( new GridData( SWT.LEFT, SWT.CENTER, false, false ) );
Label label1 = BaseWidgetUtils.createLabel( rightComposite, ":", 1 ); //$NON-NLS-1$
label1.setLayoutData( new GridData( SWT.CENTER, SWT.CENTER, true, false ) );
// Minutes
minutesSpinner = new Spinner( rightComposite, SWT.BORDER );
minutesSpinner.setMinimum( 0 );
minutesSpinner.setMaximum( 59 );
minutesSpinner.setTextLimit( 2 );
minutesSpinner.setLayoutData( new GridData( SWT.CENTER, SWT.CENTER, false, false ) );
Label label2 = BaseWidgetUtils.createLabel( rightComposite, ":", 1 ); //$NON-NLS-1$
label2.setLayoutData( new GridData( SWT.CENTER, SWT.CENTER, true, false ) );
// Seconds
secondsSpinner = new Spinner( rightComposite, SWT.BORDER );
secondsSpinner.setMinimum( 0 );
secondsSpinner.setMaximum( 59 );
secondsSpinner.setTextLimit( 2 );
secondsSpinner.setLayoutData( new GridData( SWT.RIGHT, SWT.CENTER, false, false ) );
}
/**
* Creates the "Date" dialog area.
*
* @param parent
* the parent composite
*/
private void createDateDialogArea( Composite parent )
{
// Label
Label dateLabel = BaseWidgetUtils.createLabel( parent,
Messages.getString( "ActiveDirectoryTimeValueDialog.Date" ), 1 ); //$NON-NLS-1$
dateLabel.setLayoutData( new GridData( SWT.NONE, SWT.TOP, false, false ) );
Composite rightComposite = BaseWidgetUtils.createColumnContainer( parent, 1, 1 );
// Calendar
dateCalendar = new DateTime( rightComposite, SWT.CALENDAR | SWT.BORDER );
dateCalendar.setLayoutData( new GridData( SWT.FILL, SWT.CENTER, true, false ) );
}
/**
* Creates the "Raw value" dialog area.
*
* @param parent
* the parent composite
*/
private void createRawValueDialogArea( Composite parent )
{
// Separator
Label separatorLabel = new Label( parent, SWT.SEPARATOR | SWT.HORIZONTAL );
separatorLabel.setLayoutData( new GridData( SWT.FILL, SWT.CENTER, true, false, 2, 1 ) );
// Label
BaseWidgetUtils.createLabel( parent, Messages.getString( "ActiveDirectoryTimeValueDialog.RawValue" ), 1 ); //$NON-NLS-1$
// Text
rawValueText = BaseWidgetUtils.createText( parent, "", 1 ); //$NON-NLS-1$
}
/**
* Initializes the UI with the value.
*/
private void initWithInitialValue()
{
updateNonRawFields();
updateRawFields();
}
/**
* Update the non-raw UI fields.
*/
private void updateNonRawFields()
{
// Getting the calendar
Calendar calendar = getCalendarFromValue();
// Time
hoursSpinner.setSelection( calendar.get( Calendar.HOUR_OF_DAY ) );
minutesSpinner.setSelection( calendar.get( Calendar.MINUTE ) );
secondsSpinner.setSelection( calendar.get( Calendar.SECOND ) );
// Date
dateCalendar.setDate( calendar.get( Calendar.YEAR ), calendar.get( Calendar.MONTH ), calendar
.get( Calendar.DAY_OF_MONTH ) );
}
/**
* Update the raw UI fields.
*/
private void updateRawFields()
{
// Raw value
rawValueText.setText( "" + value ); //$NON-NLS-1$
}
/**
* Adds the listeners to the UI fields.
*/
private void addListeners()
{
// Hours
hoursSpinner.addModifyListener( hoursModifyListener );
// Minutes
minutesSpinner.addModifyListener( minutesModifyListener );
// Seconds
secondsSpinner.addModifyListener( secondsModifyListener );
// Calendar
dateCalendar.addSelectionListener( dateSelectionListener );
// Raw value
rawValueText.addModifyListener( rawValueModifyListener );
rawValueText.addVerifyListener( rawValueVerifyListener );
}
/**
* Removes the listeners from the UI fields.
*/
private void removeListeners()
{
// Hours
hoursSpinner.removeModifyListener( hoursModifyListener );
// Minutes
minutesSpinner.removeModifyListener( minutesModifyListener );
// Seconds
secondsSpinner.removeModifyListener( secondsModifyListener );
// Calendar
dateCalendar.removeSelectionListener( dateSelectionListener );
// Raw value
rawValueText.removeModifyListener( rawValueModifyListener );
rawValueText.removeVerifyListener( rawValueVerifyListener );
}
/**
* Updates the value using the non raw fields.
*/
private void updateValueFromNonRawFields()
{
// Getting the calendar
Calendar calendar = getCalendarFromValue();
// Time
calendar.set( Calendar.HOUR_OF_DAY, hoursSpinner.getSelection() );
calendar.set( Calendar.MINUTE, minutesSpinner.getSelection() );
calendar.set( Calendar.SECOND, secondsSpinner.getSelection() );
// Date
calendar.set( Calendar.YEAR, dateCalendar.getYear() );
calendar.set( Calendar.MONTH, dateCalendar.getMonth() );
calendar.set( Calendar.DAY_OF_MONTH, dateCalendar.getDay() );
value = ActiveDirectoryTimeUtils.convertToActiveDirectoryTime( calendar );
}
/**
* Gets a calendar from the current value.
*
* @return a calendar corresponding to the current value
*/
private Calendar getCalendarFromValue()
{
return ActiveDirectoryTimeUtils.convertToCalendar( value );
}
/**
* Gets the value.
*
* @return
* the value
*/
public long getValue()
{
return value;
}
}