mirror of
https://github.com/MacPass/MacPass.git
synced 2025-12-14 03:32:40 +00:00
fixed view redrawing and animations
MPGradientView not correctly redraws dirty rects added rough idea for Search bar (Select what to search) fixed animations for status bar updated open panel to just allow .kdb and .kdbx files auto-coallapsing outline view on startup added rough scotch for entry edit view
This commit is contained in:
@@ -260,8 +260,8 @@
|
||||
isa = PBXFrameworksBuildPhase;
|
||||
buildActionMask = 2147483647;
|
||||
files = (
|
||||
4C8FECC816D57E3200BF26CF /* QuartzCore.framework in Frameworks */,
|
||||
4CAD748E15B88AC100104512 /* libz.dylib in Frameworks */,
|
||||
4C8FECC816D57E3200BF26CF /* QuartzCore.framework in Frameworks */,
|
||||
4CAD748C15B889B700104512 /* Security.framework in Frameworks */,
|
||||
4C77E36715B84A240093A587 /* Cocoa.framework in Frameworks */,
|
||||
);
|
||||
@@ -273,15 +273,15 @@
|
||||
4C06398C15B980480004DE27 /* Views */ = {
|
||||
isa = PBXGroup;
|
||||
children = (
|
||||
4C25D58616CF0FAA00F6806C /* EntryView.xib */,
|
||||
4CF5D49516D5B6E900CB78BD /* EntryEditView.xib */,
|
||||
4C77E37B15B84A240093A587 /* MainMenu.xib */,
|
||||
4CA0B2EC15BCADAC00654E32 /* SettingsWindow.xib */,
|
||||
4CA0B2EF15BCADC800654E32 /* GeneralSettings.xib */,
|
||||
4C77E37B15B84A240093A587 /* MainMenu.xib */,
|
||||
4CD884B615BD47080042BBF8 /* MainWindow.xib */,
|
||||
4C61EA0416D2FFE200AC519E /* OutlineView.xib */,
|
||||
4CA0B2EC15BCADAC00654E32 /* SettingsWindow.xib */,
|
||||
4C6B0E8B16C9B99B00A9ED23 /* PasswordInputView.xib */,
|
||||
4C25D58416CF0F8800F6806C /* WelcomeView.xib */,
|
||||
4C25D58616CF0FAA00F6806C /* EntryView.xib */,
|
||||
4C61EA0416D2FFE200AC519E /* OutlineView.xib */,
|
||||
4C69A73816D589DF00EC1B1A /* MPGradientView.h */,
|
||||
4C69A73916D589DF00EC1B1A /* MPGradientView.m */,
|
||||
);
|
||||
@@ -871,7 +871,7 @@
|
||||
GCC_PRECOMPILE_PREFIX_HEADER = YES;
|
||||
GCC_PREFIX_HEADER = "MacPass/MacPass-Prefix.pch";
|
||||
INFOPLIST_FILE = "MacPass/MacPass-Info.plist";
|
||||
MACOSX_DEPLOYMENT_TARGET = 10.8;
|
||||
MACOSX_DEPLOYMENT_TARGET = 10.7;
|
||||
PRODUCT_NAME = "$(TARGET_NAME)";
|
||||
WRAPPER_EXTENSION = app;
|
||||
};
|
||||
@@ -884,7 +884,7 @@
|
||||
GCC_PRECOMPILE_PREFIX_HEADER = YES;
|
||||
GCC_PREFIX_HEADER = "MacPass/MacPass-Prefix.pch";
|
||||
INFOPLIST_FILE = "MacPass/MacPass-Info.plist";
|
||||
MACOSX_DEPLOYMENT_TARGET = 10.8;
|
||||
MACOSX_DEPLOYMENT_TARGET = 10.7;
|
||||
PRODUCT_NAME = "$(TARGET_NAME)";
|
||||
WRAPPER_EXTENSION = app;
|
||||
};
|
||||
|
||||
@@ -60,7 +60,6 @@
|
||||
<string key="NSFrame">{{13, 10}, {482, 597}}</string>
|
||||
<reference key="NSSuperview" ref="1005"/>
|
||||
<reference key="NSWindow"/>
|
||||
<reference key="NSNextKeyView" ref="709543686"/>
|
||||
<string key="NSReuseIdentifierKey">_NS:9</string>
|
||||
<array class="NSMutableArray" key="NSTabViewItems">
|
||||
<object class="NSTabViewItem" id="66471917">
|
||||
@@ -678,7 +677,6 @@ AQABAAEAAQAB//+dkAEA//+PgAAE//+dkAEI//+dkAEMUERUAFBTVABQV1QAUFBUAAAAAAEAAAABA</b
|
||||
<string key="NSFrame">{{382, 10}, {69, 32}}</string>
|
||||
<reference key="NSSuperview" ref="709543686"/>
|
||||
<reference key="NSWindow"/>
|
||||
<reference key="NSNextKeyView"/>
|
||||
<string key="NSReuseIdentifierKey">_NS:9</string>
|
||||
<bool key="NSEnabled">YES</bool>
|
||||
<object class="NSButtonCell" key="NSCell" id="1017592733">
|
||||
@@ -740,7 +738,6 @@ AQABAAEAAQAB//+dkAEA//+PgAAE//+dkAEI//+dkAEMUERUAFBTVABQV1QAUFBUAAAAAAEAAAABA</b
|
||||
<int key="NSvFlags">256</int>
|
||||
<array class="NSMutableArray" key="NSSubviews"/>
|
||||
<string key="NSFrame">{{10, 33}, {462, 551}}</string>
|
||||
<reference key="NSNextKeyView"/>
|
||||
<string key="NSReuseIdentifierKey">_NS:28</string>
|
||||
</object>
|
||||
<string key="NSLabel">Advanced</string>
|
||||
@@ -765,7 +762,7 @@ AQABAAEAAQAB//+dkAEA//+PgAAE//+dkAEI//+dkAEMUERUAFBTVABQV1QAUFBUAAAAAAEAAAABA</b
|
||||
<string key="NSClassName">NSView</string>
|
||||
</object>
|
||||
<object class="NSImageView" id="491721175">
|
||||
<reference key="NSNextResponder"/>
|
||||
<nil key="NSNextResponder"/>
|
||||
<int key="NSvFlags">268</int>
|
||||
<set class="NSMutableSet" key="NSDragTypes">
|
||||
<string>Apple PDF pasteboard type</string>
|
||||
@@ -776,7 +773,6 @@ AQABAAEAAQAB//+dkAEA//+PgAAE//+dkAEI//+dkAEMUERUAFBTVABQV1QAUFBUAAAAAAEAAAABA</b
|
||||
<string>NeXT TIFF v4.0 pasteboard type</string>
|
||||
</set>
|
||||
<string key="NSFrameSize">{54, 54}</string>
|
||||
<reference key="NSSuperview"/>
|
||||
<string key="NSReuseIdentifierKey">_NS:9</string>
|
||||
<bool key="NSEnabled">YES</bool>
|
||||
<object class="NSImageCell" key="NSCell" id="26384283">
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -13,6 +13,10 @@
|
||||
#import "MPIconHelper.h"
|
||||
#import "KdbGroup+MPAdditions.h"
|
||||
|
||||
#import <QuartzCore/QuartzCore.h>
|
||||
|
||||
#define STATUS_BAR_ANIMATION_TIME 0.2
|
||||
|
||||
NSString *const MPEntryTableUserNameColumnIdentifier = @"MPUserNameColumnIdentifier";
|
||||
NSString *const MPEntryTableTitleColumnIdentifier = @"MPTitleColumnIdentifier";
|
||||
NSString *const MPEntryTablePasswordColumnIdentifier = @"MPPasswordColumnIdentifier";
|
||||
@@ -28,11 +32,17 @@ NSString *const _MPTAbleSecurCellView = @"PasswordCell";
|
||||
@property (retain) NSArray *filteredEntries;
|
||||
@property (assign) IBOutlet NSTableView *entryTable;
|
||||
@property (assign) IBOutlet NSView *statusBar;
|
||||
@property (assign) IBOutlet NSTextField *searchLabelTextField;
|
||||
@property (assign) BOOL isStatusBarVisible;
|
||||
@property (retain) IBOutlet NSLayoutConstraint *statusBarToTop;
|
||||
@property (retain) IBOutlet NSLayoutConstraint *tableToTop;
|
||||
|
||||
|
||||
- (BOOL)hasActiveFilter;
|
||||
- (BOOL)hasFilter;
|
||||
- (void)updateFilter;
|
||||
- (void)didChangeGroupSelectionInOutlineView:(NSNotification *)notification;
|
||||
- (void)showStatusBarAnimated:(BOOL)animate;
|
||||
- (void)hideStatusBarAnimated:(BOOL)animate;
|
||||
|
||||
@end
|
||||
|
||||
@@ -46,6 +56,7 @@ NSString *const _MPTAbleSecurCellView = @"PasswordCell";
|
||||
- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil {
|
||||
self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
|
||||
if(self) {
|
||||
_isStatusBarVisible = YES;
|
||||
_entryArrayController = [[NSArrayController alloc] init];
|
||||
[[NSNotificationCenter defaultCenter] addObserver:self
|
||||
selector:@selector(didChangeGroupSelectionInOutlineView:)
|
||||
@@ -57,8 +68,11 @@ NSString *const _MPTAbleSecurCellView = @"PasswordCell";
|
||||
|
||||
- (void)didLoadView {
|
||||
|
||||
[self.view setWantsLayer:YES];
|
||||
[self hideStatusBarAnimated:NO];
|
||||
[[self.searchLabelTextField cell] setBackgroundStyle:NSBackgroundStyleRaised];
|
||||
[self.entryTable setDelegate:self];
|
||||
|
||||
|
||||
NSTableColumn *parentColumn = [self.entryTable tableColumns][0];
|
||||
NSTableColumn *titleColumn = [self.entryTable tableColumns][1];
|
||||
NSTableColumn *userNameColumn = [self.entryTable tableColumns][2];
|
||||
@@ -83,7 +97,7 @@ NSString *const _MPTAbleSecurCellView = @"PasswordCell";
|
||||
|
||||
- (NSView *)tableView:(NSTableView *)tableView viewForTableColumn:(NSTableColumn *)tableColumn row:(NSInteger)row {
|
||||
KdbEntry *entry = [self.entryArrayController arrangedObjects][row];
|
||||
|
||||
|
||||
const BOOL isTitleColumn = [[tableColumn identifier] isEqualToString:MPEntryTableTitleColumnIdentifier];
|
||||
const BOOL isGroupColumn = [[tableColumn identifier] isEqualToString:MPEntryTableParentColumnIdentifier];
|
||||
const BOOL isPasswordColum = [[tableColumn identifier] isEqualToString:MPEntryTablePasswordColumnIdentifier];
|
||||
@@ -103,7 +117,7 @@ NSString *const _MPTAbleSecurCellView = @"PasswordCell";
|
||||
}
|
||||
|
||||
if( isPasswordColum ) {
|
||||
view = [tableView makeViewWithIdentifier:_MPTAbleSecurCellView owner:self];
|
||||
view = [tableView makeViewWithIdentifier:_MPTAbleSecurCellView owner:self];
|
||||
[[view textField] setStringValue:entry.password];
|
||||
return view;
|
||||
}
|
||||
@@ -119,15 +133,9 @@ NSString *const _MPTAbleSecurCellView = @"PasswordCell";
|
||||
|
||||
#pragma mark Notifications
|
||||
- (void)didChangeGroupSelectionInOutlineView:(NSNotification *)notification {
|
||||
/*
|
||||
If we have an active search, do not mess with the content
|
||||
*/
|
||||
if([self hasActiveFilter]) {
|
||||
return;
|
||||
}
|
||||
else {
|
||||
[[self.entryTable tableColumnWithIdentifier:MPEntryTableParentColumnIdentifier] setHidden:YES];
|
||||
}
|
||||
|
||||
self.filter = @""; // will update the reast automatically
|
||||
|
||||
MPOutlineViewDelegate *delegate = [notification object];
|
||||
KdbGroup *group = delegate.selectedGroup;
|
||||
if(group) {
|
||||
@@ -140,7 +148,7 @@ NSString *const _MPTAbleSecurCellView = @"PasswordCell";
|
||||
|
||||
#pragma mark Filtering
|
||||
|
||||
- (BOOL)hasActiveFilter {
|
||||
- (BOOL)hasFilter {
|
||||
return ([self.filter length] > 0);
|
||||
}
|
||||
|
||||
@@ -154,21 +162,16 @@ NSString *const _MPTAbleSecurCellView = @"PasswordCell";
|
||||
|
||||
- (void)updateFilter {
|
||||
MPDatabaseDocument *openDatabase = [MPDatabaseController defaultController].database;
|
||||
if(openDatabase) {
|
||||
if(openDatabase && [self hasFilter]) {
|
||||
[self showStatusBarAnimated:YES];
|
||||
|
||||
/*
|
||||
Search in the background
|
||||
*/
|
||||
dispatch_queue_t backgroundQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
|
||||
dispatch_async(backgroundQueue, ^{
|
||||
if([self.filter length] == 0) {
|
||||
self.filteredEntries = [openDatabase.root childEntries];
|
||||
}
|
||||
else {
|
||||
NSPredicate *filterPredicate = [NSPredicate predicateWithFormat:@"SELF.title CONTAINS[cd] %@", self.filter];
|
||||
self.filteredEntries = [[openDatabase.root childEntries] filteredArrayUsingPredicate:filterPredicate];
|
||||
}
|
||||
dispatch_async(dispatch_get_main_queue(), ^{
|
||||
|
||||
NSPredicate *filterPredicate = [NSPredicate predicateWithFormat:@"SELF.title CONTAINS[cd] %@", self.filter];
|
||||
self.filteredEntries = [[openDatabase.root childEntries] filteredArrayUsingPredicate:filterPredicate];
|
||||
|
||||
dispatch_sync(dispatch_get_main_queue(), ^{
|
||||
[self.entryArrayController setContent:self.filteredEntries];
|
||||
[[self.entryTable tableColumnWithIdentifier:MPEntryTableParentColumnIdentifier] setHidden:NO];
|
||||
});
|
||||
@@ -177,6 +180,53 @@ NSString *const _MPTAbleSecurCellView = @"PasswordCell";
|
||||
else {
|
||||
[self.entryArrayController setContent:nil];
|
||||
self.filteredEntries = nil;
|
||||
[[self.entryTable tableColumnWithIdentifier:MPEntryTableParentColumnIdentifier] setHidden:YES];
|
||||
[self hideStatusBarAnimated:YES];
|
||||
}
|
||||
}
|
||||
|
||||
#pragma mark Animation
|
||||
|
||||
- (void)showStatusBarAnimated:(BOOL)animate {
|
||||
|
||||
if(self.isStatusBarVisible) {
|
||||
return; // nothign to to
|
||||
}
|
||||
self.isStatusBarVisible = YES;
|
||||
self.statusBarToTop.constant = 0;
|
||||
self.tableToTop.constant = [self.statusBar frame].size.height;
|
||||
|
||||
if(animate) {
|
||||
[NSAnimationContext runAnimationGroup:^(NSAnimationContext* context) {
|
||||
context.duration = STATUS_BAR_ANIMATION_TIME;
|
||||
context.allowsImplicitAnimation = YES;
|
||||
[self.view layoutSubtreeIfNeeded];
|
||||
} completionHandler:nil] ;
|
||||
}
|
||||
else {
|
||||
[self.view layoutSubtreeIfNeeded];
|
||||
}
|
||||
}
|
||||
|
||||
- (void)hideStatusBarAnimated:(BOOL)animate {
|
||||
|
||||
if(!self.isStatusBarVisible) {
|
||||
return; // nothing to do;
|
||||
}
|
||||
|
||||
self.isStatusBarVisible = NO;
|
||||
self.statusBarToTop.constant = -[self.statusBar frame].size.height;
|
||||
self.tableToTop.constant = -1;
|
||||
|
||||
if(animate) {
|
||||
[NSAnimationContext runAnimationGroup:^(NSAnimationContext* context) {
|
||||
context.duration = STATUS_BAR_ANIMATION_TIME;
|
||||
context.allowsImplicitAnimation = YES;
|
||||
[self.view layoutSubtreeIfNeeded];
|
||||
} completionHandler:nil] ;
|
||||
}
|
||||
else {
|
||||
[self.view layoutSubtreeIfNeeded];
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -20,7 +20,6 @@
|
||||
|
||||
@implementation MPGradientView
|
||||
|
||||
|
||||
- (id)initWithFrame:(NSRect)frameRect {
|
||||
NSColor *activeTop = [NSColor colorWithCalibratedWhite:0.85 alpha:1];
|
||||
NSColor *activeBottom = [NSColor colorWithCalibratedWhite:0.7 alpha:1];
|
||||
@@ -40,12 +39,17 @@
|
||||
return self;
|
||||
}
|
||||
|
||||
#pragma mark Drawing
|
||||
|
||||
- (void)drawRect:(NSRect)dirtyRect {
|
||||
/*
|
||||
We draw a Gradient, so make sure we always redraw the full view
|
||||
*/
|
||||
NSGradient *gradient = self.isRenderedActive ? self.activeGradient : self.inactiveGradient;
|
||||
[gradient drawInRect:dirtyRect angle:90];
|
||||
[gradient drawInRect:self.bounds angle:90];
|
||||
}
|
||||
|
||||
#pragma mark State Refresh
|
||||
- (void)_registerWindow:(NSWindow *)newWindow {
|
||||
if([self window]) {
|
||||
[[NSNotificationCenter defaultCenter] removeObserver:self name:NSWindowDidBecomeKeyNotification object:[self window]];
|
||||
@@ -55,7 +59,6 @@
|
||||
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(refreshActiveState) name:NSWindowDidBecomeKeyNotification object:newWindow];
|
||||
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(refreshActiveState) name:NSWindowDidResignKeyNotification object:newWindow];
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
- (void)viewWillMoveToWindow:(NSWindow *)newWindow {
|
||||
@@ -67,6 +70,7 @@
|
||||
self.isRenderedActive = [[self window] isKeyWindow];
|
||||
}
|
||||
|
||||
# pragma mark Custom Properties
|
||||
- (void)setIsRenderedActive:(BOOL)isRenderedActive {
|
||||
if(_isRenderedActive != isRenderedActive) {
|
||||
_isRenderedActive = isRenderedActive;
|
||||
|
||||
@@ -16,12 +16,12 @@
|
||||
|
||||
@interface MPMainWindowController ()
|
||||
|
||||
|
||||
@property (assign) IBOutlet NSView *outlineView;
|
||||
@property (assign) IBOutlet NSSplitView *splitView;
|
||||
@property (assign) IBOutlet NSView *contentView;
|
||||
|
||||
@property (retain) IBOutlet NSView *welcomeView;
|
||||
@property (assign) IBOutlet NSTextField *welcomeText;
|
||||
@property (retain) NSToolbar *toolbar;
|
||||
|
||||
@property (retain) MPPasswordInputController *passwordInputController;
|
||||
@@ -31,6 +31,9 @@
|
||||
@property (retain) MPToolbarDelegate *toolbarDelegate;
|
||||
@property (retain) MPMainWindowSplitViewDelegate *splitViewDelegate;
|
||||
|
||||
- (void)collapseOutlineView;
|
||||
- (void)expandOutlineView;
|
||||
|
||||
@end
|
||||
|
||||
@implementation MPMainWindowController
|
||||
@@ -58,9 +61,14 @@
|
||||
[super dealloc];
|
||||
}
|
||||
|
||||
#pragma mark View Handling
|
||||
|
||||
- (void)windowDidLoad
|
||||
{
|
||||
[super windowDidLoad];
|
||||
|
||||
[[self.welcomeText cell] setBackgroundStyle:NSBackgroundStyleRaised];
|
||||
|
||||
const CGFloat minimumWindowWidth = MPMainWindowSplitViewDelegateMinimumContentWidth + MPMainWindowSplitViewDelegateMinimumOutlineWidth + [self.splitView dividerThickness];
|
||||
[self.window setMinSize:NSMakeSize( minimumWindowWidth, 400)];
|
||||
|
||||
@@ -72,13 +80,13 @@
|
||||
[self.splitView setDelegate:self.splitViewDelegate];
|
||||
|
||||
NSRect frame = [self.outlineView frame];
|
||||
// frame.size.height -= 1;
|
||||
// frame.origin.y = 10;
|
||||
[self.outlineViewController.view setFrame:frame];
|
||||
[self.outlineViewController.view setAutoresizingMask:NSViewWidthSizable | NSViewHeightSizable];
|
||||
[self.splitView replaceSubview:self.outlineView with:[self.outlineViewController view]];
|
||||
[self.splitView adjustSubviews];
|
||||
|
||||
[self setContentViewController:nil];
|
||||
[self collapseOutlineView];
|
||||
}
|
||||
|
||||
- (void)setContentViewController:(MPViewController *)viewController {
|
||||
@@ -113,6 +121,21 @@
|
||||
[self.window makeFirstResponder:[viewController reconmendedFirstResponder]];
|
||||
}
|
||||
|
||||
- (void)collapseOutlineView {
|
||||
NSView *outlineView = [self.splitView subviews][0];
|
||||
if(![outlineView isHidden]) {
|
||||
[self.splitView setPosition:0 ofDividerAtIndex:0];
|
||||
}
|
||||
}
|
||||
|
||||
- (void)expandOutlineView {
|
||||
NSView *outlineView = [self.splitView subviews][0];
|
||||
if([outlineView isHidden]) {
|
||||
[self.splitView setPosition:MPMainWindowSplitViewDelegateMinimumOutlineWidth ofDividerAtIndex:0];
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
#pragma mark Actions
|
||||
|
||||
- (void)performFindPanelAction:(id)sender {
|
||||
@@ -124,7 +147,7 @@
|
||||
}
|
||||
|
||||
- (void)openDocument:(id)sender {
|
||||
|
||||
|
||||
if(!self.passwordInputController) {
|
||||
self.passwordInputController = [[[MPPasswordInputController alloc] init] autorelease];
|
||||
}
|
||||
@@ -134,6 +157,7 @@
|
||||
[openPanel setCanChooseFiles:YES];
|
||||
[openPanel setCanCreateDirectories:NO];
|
||||
[openPanel setAllowsMultipleSelection:NO];
|
||||
[openPanel setAllowedFileTypes:@[ @"kdbx", @"kdb"]];
|
||||
[openPanel beginSheetModalForWindow:self.window completionHandler:^(NSInteger result){
|
||||
if(result == NSFileHandlingPanelOKButton) {
|
||||
NSURL *file = [[openPanel URLs] lastObject];
|
||||
@@ -155,10 +179,13 @@
|
||||
}
|
||||
|
||||
- (void)showEntries {
|
||||
[self expandOutlineView];
|
||||
if(!self.entryViewController) {
|
||||
_entryViewController = [[MPEntryViewController alloc] init];
|
||||
}
|
||||
[self setContentViewController:self.entryViewController];
|
||||
}
|
||||
|
||||
- (IBAction)changedFileType:(id)sender {
|
||||
}
|
||||
@end
|
||||
|
||||
@@ -21,7 +21,7 @@
|
||||
<key>CFBundleSignature</key>
|
||||
<string>????</string>
|
||||
<key>CFBundleVersion</key>
|
||||
<string>15D</string>
|
||||
<string>1C8</string>
|
||||
<key>LSMinimumSystemVersion</key>
|
||||
<string>${MACOSX_DEPLOYMENT_TARGET}</string>
|
||||
<key>NSHumanReadableCopyright</key>
|
||||
|
||||
@@ -41,17 +41,10 @@
|
||||
<object class="NSTextField" id="86698766">
|
||||
<reference key="NSNextResponder" ref="1005"/>
|
||||
<int key="NSvFlags">268</int>
|
||||
<string key="NSFrame">{{210, 211}, {177, 34}}</string>
|
||||
<string key="NSFrame">{{223, 214}, {152, 29}}</string>
|
||||
<reference key="NSSuperview" ref="1005"/>
|
||||
<reference key="NSWindow"/>
|
||||
<reference key="NSNextKeyView"/>
|
||||
<object class="NSShadow" key="NSViewShadow">
|
||||
<double key="NSShadowVert">1</double>
|
||||
<object class="NSColor" key="NSShadowColor" id="214915299">
|
||||
<int key="NSColorSpace">1</int>
|
||||
<bytes key="NSRGB">MSAxIDEAA</bytes>
|
||||
</object>
|
||||
</object>
|
||||
<string key="NSReuseIdentifierKey">_NS:1535</string>
|
||||
<bool key="NSEnabled">YES</bool>
|
||||
<object class="NSTextFieldCell" key="NSCell" id="726130946">
|
||||
@@ -60,7 +53,7 @@
|
||||
<string key="NSContents">No Database</string>
|
||||
<object class="NSFont" key="NSSupport">
|
||||
<string key="NSName">LucidaGrande</string>
|
||||
<double key="NSSize">28</double>
|
||||
<double key="NSSize">24</double>
|
||||
<int key="NSfFlags">16</int>
|
||||
</object>
|
||||
<string key="NSCellIdentifier">_NS:1535</string>
|
||||
@@ -91,7 +84,6 @@
|
||||
<reference key="NSSuperview"/>
|
||||
<reference key="NSWindow"/>
|
||||
<reference key="NSNextKeyView" ref="86698766"/>
|
||||
<bool key="NSViewIsLayerTreeHost">YES</bool>
|
||||
<string key="NSClassName">NSView</string>
|
||||
</object>
|
||||
</array>
|
||||
@@ -105,6 +97,14 @@
|
||||
</object>
|
||||
<int key="connectionID">12</int>
|
||||
</object>
|
||||
<object class="IBConnectionRecord">
|
||||
<object class="IBOutletConnection" key="connection">
|
||||
<string key="label">welcomeText</string>
|
||||
<reference key="source" ref="1001"/>
|
||||
<reference key="destination" ref="86698766"/>
|
||||
</object>
|
||||
<int key="connectionID">17</int>
|
||||
</object>
|
||||
</array>
|
||||
<object class="IBMutableOrderedSet" key="objectRecords">
|
||||
<array key="orderedObjects">
|
||||
@@ -136,27 +136,11 @@
|
||||
<int key="objectID">1</int>
|
||||
<reference key="object" ref="1005"/>
|
||||
<array class="NSMutableArray" key="children">
|
||||
<object class="IBNSLayoutConstraint" id="400794400">
|
||||
<reference key="firstItem" ref="1005"/>
|
||||
<int key="firstAttribute">10</int>
|
||||
<int key="relation">0</int>
|
||||
<reference key="secondItem" ref="86698766"/>
|
||||
<int key="secondAttribute">10</int>
|
||||
<float key="multiplier">1</float>
|
||||
<object class="IBLayoutConstant" key="constant">
|
||||
<double key="value">0.0</double>
|
||||
</object>
|
||||
<float key="priority">1000</float>
|
||||
<reference key="containingView" ref="1005"/>
|
||||
<int key="scoringType">9</int>
|
||||
<float key="scoringTypeFloat">40</float>
|
||||
<int key="contentType">2</int>
|
||||
</object>
|
||||
<object class="IBNSLayoutConstraint" id="121551590">
|
||||
<reference key="firstItem" ref="1005"/>
|
||||
<object class="IBNSLayoutConstraint" id="7631442">
|
||||
<reference key="firstItem" ref="86698766"/>
|
||||
<int key="firstAttribute">9</int>
|
||||
<int key="relation">0</int>
|
||||
<reference key="secondItem" ref="86698766"/>
|
||||
<reference key="secondItem" ref="1005"/>
|
||||
<int key="secondAttribute">9</int>
|
||||
<float key="multiplier">1</float>
|
||||
<object class="IBLayoutConstant" key="constant">
|
||||
@@ -164,8 +148,24 @@
|
||||
</object>
|
||||
<float key="priority">1000</float>
|
||||
<reference key="containingView" ref="1005"/>
|
||||
<int key="scoringType">9</int>
|
||||
<float key="scoringTypeFloat">40</float>
|
||||
<int key="scoringType">5</int>
|
||||
<float key="scoringTypeFloat">22</float>
|
||||
<int key="contentType">2</int>
|
||||
</object>
|
||||
<object class="IBNSLayoutConstraint" id="790404227">
|
||||
<reference key="firstItem" ref="86698766"/>
|
||||
<int key="firstAttribute">10</int>
|
||||
<int key="relation">0</int>
|
||||
<reference key="secondItem" ref="1005"/>
|
||||
<int key="secondAttribute">10</int>
|
||||
<float key="multiplier">1</float>
|
||||
<object class="IBLayoutConstant" key="constant">
|
||||
<double key="value">0.0</double>
|
||||
</object>
|
||||
<float key="priority">1000</float>
|
||||
<reference key="containingView" ref="1005"/>
|
||||
<int key="scoringType">5</int>
|
||||
<float key="scoringTypeFloat">22</float>
|
||||
<int key="contentType">2</int>
|
||||
</object>
|
||||
<reference ref="86698766"/>
|
||||
@@ -186,13 +186,13 @@
|
||||
<reference key="parent" ref="86698766"/>
|
||||
</object>
|
||||
<object class="IBObjectRecord">
|
||||
<int key="objectID">10</int>
|
||||
<reference key="object" ref="121551590"/>
|
||||
<int key="objectID">21</int>
|
||||
<reference key="object" ref="790404227"/>
|
||||
<reference key="parent" ref="1005"/>
|
||||
</object>
|
||||
<object class="IBObjectRecord">
|
||||
<int key="objectID">11</int>
|
||||
<reference key="object" ref="400794400"/>
|
||||
<int key="objectID">22</int>
|
||||
<reference key="object" ref="7631442"/>
|
||||
<reference key="parent" ref="1005"/>
|
||||
</object>
|
||||
</array>
|
||||
@@ -202,46 +202,39 @@
|
||||
<string key="-2.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||
<string key="-3.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||
<array class="NSMutableArray" key="1.IBNSViewMetadataConstraints">
|
||||
<reference ref="121551590"/>
|
||||
<reference ref="400794400"/>
|
||||
<reference ref="790404227"/>
|
||||
<reference ref="7631442"/>
|
||||
</array>
|
||||
<string key="1.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||
<string key="10.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||
<string key="11.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||
<boolean value="NO" key="2.IBNSViewMetadataTranslatesAutoresizingMaskIntoConstraints"/>
|
||||
<string key="2.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||
<reference key="2.IBViewIntegration.shadowColor" ref="214915299"/>
|
||||
<real value="0.0" key="2.IBViewIntegration.shadowBlurRadius"/>
|
||||
<object class="NSColor" key="2.IBViewIntegration.shadowColor">
|
||||
<int key="NSColorSpace">1</int>
|
||||
<bytes key="NSRGB">MSAxIDEAA</bytes>
|
||||
</object>
|
||||
<real value="1" key="2.IBViewIntegration.shadowOffsetHeight"/>
|
||||
<real value="0.0" key="2.IBViewIntegration.shadowOffsetWidth"/>
|
||||
<string key="21.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||
<string key="22.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||
<string key="3.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||
</dictionary>
|
||||
<dictionary class="NSMutableDictionary" key="unlocalizedProperties"/>
|
||||
<nil key="activeLocalization"/>
|
||||
<dictionary class="NSMutableDictionary" key="localizations"/>
|
||||
<nil key="sourceID"/>
|
||||
<int key="maxID">12</int>
|
||||
<int key="maxID">22</int>
|
||||
</object>
|
||||
<object class="IBClassDescriber" key="IBDocument.Classes">
|
||||
<array class="NSMutableArray" key="referencedPartialClassDescriptions">
|
||||
<object class="IBPartialClassDescription">
|
||||
<string key="className">MPMainWindowController</string>
|
||||
<string key="superclassName">NSWindowController</string>
|
||||
<object class="NSMutableDictionary" key="actions">
|
||||
<string key="NS.key.0">usePassword:</string>
|
||||
<string key="NS.object.0">id</string>
|
||||
</object>
|
||||
<object class="NSMutableDictionary" key="actionInfosByName">
|
||||
<string key="NS.key.0">usePassword:</string>
|
||||
<object class="IBActionInfo" key="NS.object.0">
|
||||
<string key="name">usePassword:</string>
|
||||
<string key="candidateClassName">id</string>
|
||||
</object>
|
||||
</object>
|
||||
<dictionary class="NSMutableDictionary" key="outlets">
|
||||
<string key="contentView">NSView</string>
|
||||
<string key="keyPathControl">NSPathControl</string>
|
||||
<string key="outlineView">NSOutlineView</string>
|
||||
<string key="passwordTextField">NSTextField</string>
|
||||
<string key="passwordView">NSView</string>
|
||||
<string key="outlineView">NSView</string>
|
||||
<string key="splitView">NSSplitView</string>
|
||||
<string key="welcomeText">NSTextField</string>
|
||||
<string key="welcomeView">NSView</string>
|
||||
</dictionary>
|
||||
<dictionary class="NSMutableDictionary" key="toOneOutletInfosByName">
|
||||
@@ -249,22 +242,18 @@
|
||||
<string key="name">contentView</string>
|
||||
<string key="candidateClassName">NSView</string>
|
||||
</object>
|
||||
<object class="IBToOneOutletInfo" key="keyPathControl">
|
||||
<string key="name">keyPathControl</string>
|
||||
<string key="candidateClassName">NSPathControl</string>
|
||||
</object>
|
||||
<object class="IBToOneOutletInfo" key="outlineView">
|
||||
<string key="name">outlineView</string>
|
||||
<string key="candidateClassName">NSOutlineView</string>
|
||||
</object>
|
||||
<object class="IBToOneOutletInfo" key="passwordTextField">
|
||||
<string key="name">passwordTextField</string>
|
||||
<string key="candidateClassName">NSTextField</string>
|
||||
</object>
|
||||
<object class="IBToOneOutletInfo" key="passwordView">
|
||||
<string key="name">passwordView</string>
|
||||
<string key="candidateClassName">NSView</string>
|
||||
</object>
|
||||
<object class="IBToOneOutletInfo" key="splitView">
|
||||
<string key="name">splitView</string>
|
||||
<string key="candidateClassName">NSSplitView</string>
|
||||
</object>
|
||||
<object class="IBToOneOutletInfo" key="welcomeText">
|
||||
<string key="name">welcomeText</string>
|
||||
<string key="candidateClassName">NSTextField</string>
|
||||
</object>
|
||||
<object class="IBToOneOutletInfo" key="welcomeView">
|
||||
<string key="name">welcomeView</string>
|
||||
<string key="candidateClassName">NSView</string>
|
||||
|
||||
Reference in New Issue
Block a user