* Palettes/2Controls/GormButtonAttributesInspector.m (ok:), (revert:): adopt methods to be usable for objects with prototype. This inspector can be called in "Prototype" mode.

This commit is contained in:
Sergii Stoian 2020-01-05 03:17:37 +02:00
parent cdb2814a8a
commit 6722945719

View file

@ -134,19 +134,26 @@ NSString *rtString = nil;
- (void) ok: (id) sender
{
id obj = object;
if ([object respondsToSelector: @selector(prototype)])
{
obj = [object prototype];
}
if (sender == alignMatrix)
{
[(NSButton *)object setAlignment: (NSTextAlignment)[[sender selectedCell] tag]];
[(NSButton *)obj setAlignment: (NSTextAlignment)[[sender selectedCell] tag]];
}
else if (sender == iconMatrix)
{
[(NSButton *)object setImagePosition:
[(NSButton *)obj setImagePosition:
(NSCellImagePosition)[[sender selectedCell] tag]];
}
else if (sender == keyForm)
{
[keyEquiv selectItemAtIndex: 0]; // if the user does his own thing, select the default...
[object setKeyEquivalent: [[sender cellAtIndex: 0] stringValue]];
// if the user does his own thing, select the default...
[keyEquiv selectItemAtIndex: 0];
[obj setKeyEquivalent: [[sender cellAtIndex: 0] stringValue]];
}
else if (sender == keyEquiv)
{
@ -155,56 +162,56 @@ NSString *rtString = nil;
{
case 0: // none
{
[object setKeyEquivalent: nil];
[obj setKeyEquivalent: nil];
}
break;
case 1: // return
{
[object setKeyEquivalent: @"\r"];
[obj setKeyEquivalent: @"\r"];
[[keyForm cellAtIndex: 0] setStringValue: @"\\r"];
}
break;
case 2: // delete
{
[object setKeyEquivalent: @"\b"];
[obj setKeyEquivalent: @"\b"];
[[keyForm cellAtIndex: 0] setStringValue: @"\\b"];
}
break;
case 3: // escape
{
[object setKeyEquivalent: @"\E"];
[obj setKeyEquivalent: @"\E"];
[[keyForm cellAtIndex: 0] setStringValue: @"\\E"];
}
break;
case 4: // tab
{
[object setKeyEquivalent: @"\t"];
[obj setKeyEquivalent: @"\t"];
[[keyForm cellAtIndex: 0] setStringValue: @"\\t"];
}
break;
case 5: // up
{
[object setKeyEquivalent: upString];
[obj setKeyEquivalent: upString];
}
break;
case 6: // down
{
[object setKeyEquivalent: dnString];
[obj setKeyEquivalent: dnString];
}
break;
case 7: // left
{
[object setKeyEquivalent: ltString];
[obj setKeyEquivalent: ltString];
}
break;
case 8: // right
{
[object setKeyEquivalent: rtString];
[obj setKeyEquivalent: rtString];
}
break;
default: // should never happen..
{
[object setKeyEquivalent: nil];
[obj setKeyEquivalent: nil];
NSLog(@"This shouldn't happen.");
}
break;
@ -215,148 +222,168 @@ NSString *rtString = nil;
BOOL flag;
flag = ([[sender cellAtRow: 0 column: 0] state] == NSOnState) ? YES : NO;
[object setBordered: flag]; flag = ([[sender cellAtRow: 1 column: 0] state] == NSOnState) ? YES : NO;
[object setContinuous: flag];
[obj setBordered: flag];
flag = ([[sender cellAtRow: 1 column: 0] state] == NSOnState) ? YES : NO;
[obj setContinuous: flag];
flag = ([[sender cellAtRow: 2 column: 0] state] == NSOnState) ? YES : NO;
[object setEnabled: flag];
[obj setEnabled: flag];
[object setState: [[sender cellAtRow: 3 column: 0] state]];
[obj setState: [[sender cellAtRow: 3 column: 0] state]];
flag = ([[sender cellAtRow: 4 column: 0] state] == NSOnState) ? YES : NO;
[object setTransparent: flag];
[obj setTransparent: flag];
}
else if (sender == tagForm)
{
[(NSButton *)object setTag: [[sender cellAtIndex: 0] intValue]];
[(NSButton *)obj setTag: [[sender cellAtIndex: 0] intValue]];
}
else if (sender == titleForm)
{
NSString *string;
NSImage *image;
[object setTitle: [[sender cellAtIndex: 0] stringValue]];
[object setAlternateTitle: [[sender cellAtIndex: 1] stringValue]];
[obj setTitle: [[sender cellAtIndex: 0] stringValue]];
[obj setAlternateTitle: [[sender cellAtIndex: 1] stringValue]];
string = [[sender cellAtIndex: 2] stringValue];
if ([string length] > 0)
{
image = [NSImage imageNamed: string];
[object setImage: image];
[obj setImage: image];
}
string = [[sender cellAtIndex: 3] stringValue];
if ([string length] > 0)
{
image = [NSImage imageNamed: string];
[object setAlternateImage: image];
[obj setAlternateImage: image];
}
}
else if (sender == typeButton)
{
[object setButtonType: [[sender selectedItem] tag]];
[obj setButtonType: [[sender selectedItem] tag]];
}
else if (sender == bezelButton)
{
[object setBezelStyle: [[sender selectedItem] tag]];
[obj setBezelStyle: [[sender selectedItem] tag]];
}
else if ([sender isKindOfClass: [NSMenuItem class]] )
{
/*
* In old NSPopUpButton implementation we do receive
* the selected menu item here. Not the PopUpbutton 'typeButton'
* FIXME: Ideally we should also test if the menu item belongs
* to the 'type button' control. How to do that?
*/
[(NSButton *)object setButtonType: [sender tag]];
* In old NSPopUpButton implementation we do receive
* the selected menu item here. Not the PopUpbutton 'typeButton'
* FIXME: Ideally we should also test if the menu item belongs
* to the 'type button' control. How to do that?
*/
[(NSButton *)obj setButtonType: [sender tag]];
}
else if (sender == altMod)
{
if([altMod state] == NSOnState)
if ([altMod state] == NSOnState)
{
[object setKeyEquivalentModifierMask: [object keyEquivalentModifierMask] | NSAlternateKeyMask];
[obj setKeyEquivalentModifierMask:
[obj keyEquivalentModifierMask] | NSAlternateKeyMask];
}
else
{
[object setKeyEquivalentModifierMask: [object keyEquivalentModifierMask] & ~NSAlternateKeyMask];
[obj setKeyEquivalentModifierMask:
[obj keyEquivalentModifierMask] & ~NSAlternateKeyMask];
}
}
else if (sender == ctrlMod)
{
if([ctrlMod state] == NSOnState)
if ([ctrlMod state] == NSOnState)
{
[object setKeyEquivalentModifierMask: [object keyEquivalentModifierMask] | NSControlKeyMask];
[obj setKeyEquivalentModifierMask:
[obj keyEquivalentModifierMask] | NSControlKeyMask];
}
else
{
[object setKeyEquivalentModifierMask: [object keyEquivalentModifierMask] & ~NSControlKeyMask];
[obj setKeyEquivalentModifierMask:
[obj keyEquivalentModifierMask] & ~NSControlKeyMask];
}
}
else if (sender == shiftMod)
{
if([shiftMod state] == NSOnState)
if ([shiftMod state] == NSOnState)
{
[object setKeyEquivalentModifierMask: [object keyEquivalentModifierMask] | NSShiftKeyMask];
[obj setKeyEquivalentModifierMask:
[obj keyEquivalentModifierMask] | NSShiftKeyMask];
}
else
{
[object setKeyEquivalentModifierMask: [object keyEquivalentModifierMask] & ~NSShiftKeyMask];
[obj setKeyEquivalentModifierMask:
[obj keyEquivalentModifierMask] & ~NSShiftKeyMask];
}
}
else if (sender == cmdMod)
{
if([cmdMod state] == NSOnState)
if ([cmdMod state] == NSOnState)
{
[object setKeyEquivalentModifierMask: [object keyEquivalentModifierMask] | NSCommandKeyMask];
[obj setKeyEquivalentModifierMask:
[obj keyEquivalentModifierMask] | NSCommandKeyMask];
}
else
{
[object setKeyEquivalentModifierMask: [object keyEquivalentModifierMask] & ~NSCommandKeyMask];
[obj setKeyEquivalentModifierMask:
[obj keyEquivalentModifierMask] & ~NSCommandKeyMask];
}
}
if ([object respondsToSelector: @selector(prototype)])
{
[object setPrototype: obj];
}
[super ok: sender];
}
-(void) revert: (id)sender
{
NSImage *image;
id obj = object;
if ([object respondsToSelector: @selector(prototype)])
{
obj = [object prototype];
}
if(sender != nil)
{
NSString *key = VSTR([object keyEquivalent]);
unsigned int flags = [object keyEquivalentModifierMask];
NSString *key = VSTR([obj keyEquivalent]);
unsigned int flags = [obj keyEquivalentModifierMask];
[alignMatrix selectCellWithTag: [object alignment]];
[iconMatrix selectCellWithTag: [object imagePosition]];
[alignMatrix selectCellWithTag: [obj alignment]];
[iconMatrix selectCellWithTag: [obj imagePosition]];
[[keyForm cellAtIndex: 0] setStringValue: key];
if([key isEqualToString: @"\r"])
if ([key isEqualToString: @"\r"])
{
[keyEquiv selectItemAtIndex: 1];
}
else if([key isEqualToString: @"\b"])
else if ([key isEqualToString: @"\b"])
{
[keyEquiv selectItemAtIndex: 2];
}
else if([key isEqualToString: @"\E"])
else if ([key isEqualToString: @"\E"])
{
[keyEquiv selectItemAtIndex: 3];
}
else if([key isEqualToString: @"\t"])
else if ([key isEqualToString: @"\t"])
{
[keyEquiv selectItemAtIndex: 4];
}
else if([key isEqualToString: upString])
else if ([key isEqualToString: upString])
{
[keyEquiv selectItemAtIndex: 5];
}
else if([key isEqualToString: dnString])
else if ([key isEqualToString: dnString])
{
[keyEquiv selectItemAtIndex: 6];
}
else if([key isEqualToString: ltString])
else if ([key isEqualToString: ltString])
{
[keyEquiv selectItemAtIndex: 7];
}
else if([key isEqualToString: rtString])
else if ([key isEqualToString: rtString])
{
[keyEquiv selectItemAtIndex: 8];
}
@ -366,23 +393,23 @@ NSString *rtString = nil;
}
[optionMatrix deselectAllCells];
if ([object isBordered])
[optionMatrix selectCellAtRow: 0 column: 0];
if ([object isContinuous])
[optionMatrix selectCellAtRow: 1 column: 0];
if ([object isEnabled])
[optionMatrix selectCellAtRow: 2 column: 0];
if ([object state] == NSOnState)
[optionMatrix selectCellAtRow: 3 column: 0];
if ([object isTransparent])
[optionMatrix selectCellAtRow: 4 column: 0];
if ([obj isBordered])
[optionMatrix selectCellAtRow: 0 column: 0];
if ([obj isContinuous])
[optionMatrix selectCellAtRow: 1 column: 0];
if ([obj isEnabled])
[optionMatrix selectCellAtRow: 2 column: 0];
if ([obj state] == NSOnState)
[optionMatrix selectCellAtRow: 3 column: 0];
if ([obj isTransparent])
[optionMatrix selectCellAtRow: 4 column: 0];
[[tagForm cellAtIndex: 0] setIntValue: [(NSButton *)obj tag]];
[[tagForm cellAtIndex: 0] setIntValue: [(NSButton *)object tag]];
[[titleForm cellAtIndex: 0] setStringValue: VSTR([obj title])];
[[titleForm cellAtIndex: 1] setStringValue: VSTR([obj alternateTitle])];
[[titleForm cellAtIndex: 0] setStringValue: VSTR([object title])];
[[titleForm cellAtIndex: 1] setStringValue: VSTR([object alternateTitle])];
image = [object image];
image = [obj image];
if (image != nil)
{
[[titleForm cellAtIndex: 2] setStringValue: VSTR([image name])];
@ -392,7 +419,7 @@ NSString *rtString = nil;
[[titleForm cellAtIndex: 2] setStringValue: @""];
}
image = [object alternateImage];
image = [obj alternateImage];
if (image != nil)
{
[[titleForm cellAtIndex: 3] setStringValue: VSTR([image name])];
@ -426,10 +453,10 @@ NSString *rtString = nil;
[typeButton selectItemAtIndex:
[typeButton indexOfItemWithTag:
[self buttonTypeForObject: object]]];
[self buttonTypeForObject: obj]]];
[bezelButton selectItemAtIndex:
[bezelButton indexOfItemWithTag: [object bezelStyle]]];
[bezelButton indexOfItemWithTag: [obj bezelStyle]]];
}
}