Storing expanded state part I
This commit is contained in:
@@ -321,14 +321,14 @@
|
||||
<rect key="frame" x="1" y="0.0" width="318" height="306"/>
|
||||
<autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
|
||||
<subviews>
|
||||
<outlineView verticalHuggingPriority="750" allowsExpansionToolTips="YES" columnAutoresizingStyle="firstColumnOnly" alternatingRowBackgroundColors="YES" autosaveColumns="NO" headerView="sii-NE-JkJ" indentationPerLevel="16" outlineTableColumn="Lb1-9n-wlc" id="hKk-G1-1po">
|
||||
<outlineView verticalHuggingPriority="750" allowsExpansionToolTips="YES" columnAutoresizingStyle="firstColumnOnly" alternatingRowBackgroundColors="YES" columnResizing="NO" autosaveColumns="NO" autosaveName="" rowSizeStyle="automatic" headerView="sii-NE-JkJ" viewBased="YES" indentationPerLevel="16" outlineTableColumn="Lb1-9n-wlc" id="hKk-G1-1po">
|
||||
<rect key="frame" x="0.0" y="0.0" width="318" height="283"/>
|
||||
<autoresizingMask key="autoresizingMask"/>
|
||||
<size key="intercellSpacing" width="3" height="2"/>
|
||||
<color key="backgroundColor" name="controlBackgroundColor" catalog="System" colorSpace="catalog"/>
|
||||
<color key="gridColor" name="gridColor" catalog="System" colorSpace="catalog"/>
|
||||
<tableColumns>
|
||||
<tableColumn identifier="" width="252.5" minWidth="40" maxWidth="1000" id="Lb1-9n-wlc">
|
||||
<tableColumn identifier="cellFeedConfigName" width="262" minWidth="40" maxWidth="1000" id="Lb1-9n-wlc">
|
||||
<tableHeaderCell key="headerCell" lineBreakMode="truncatingTail" borderStyle="border" title="Name">
|
||||
<font key="font" metaFont="smallSystem"/>
|
||||
<color key="textColor" name="headerTextColor" catalog="System" colorSpace="catalog"/>
|
||||
@@ -340,16 +340,39 @@
|
||||
<color key="backgroundColor" name="controlBackgroundColor" catalog="System" colorSpace="catalog"/>
|
||||
</textFieldCell>
|
||||
<tableColumnResizingMask key="resizingMask" resizeWithTable="YES"/>
|
||||
<prototypeCellViews>
|
||||
<tableCellView identifier="cellFeedConfigName" id="USO-Q1-NDq" userLabel="cellView">
|
||||
<rect key="frame" x="1" y="1" width="262" height="17"/>
|
||||
<autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
|
||||
<subviews>
|
||||
<imageView horizontalHuggingPriority="251" verticalHuggingPriority="251" fixedFrame="YES" translatesAutoresizingMaskIntoConstraints="NO" id="Z4d-cK-DSP" userLabel="img">
|
||||
<rect key="frame" x="0.0" y="0.0" width="17" height="17"/>
|
||||
<autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMinY="YES"/>
|
||||
<imageCell key="cell" refusesFirstResponder="YES" alignment="left" imageScaling="proportionallyDown" image="NSActionTemplate" id="qWz-Xe-Me7"/>
|
||||
</imageView>
|
||||
<textField verticalHuggingPriority="750" horizontalCompressionResistancePriority="250" fixedFrame="YES" allowsExpansionToolTips="YES" translatesAutoresizingMaskIntoConstraints="NO" id="9aj-WF-3MF" userLabel="str">
|
||||
<rect key="frame" x="23" y="0.0" width="239" height="17"/>
|
||||
<autoresizingMask key="autoresizingMask" widthSizable="YES" flexibleMinY="YES"/>
|
||||
<textFieldCell key="cell" lineBreakMode="truncatingTail" sendsActionOnEndEditing="YES" title="Feed Title" id="Vp6-Ny-4XI">
|
||||
<font key="font" metaFont="system"/>
|
||||
<color key="textColor" name="controlTextColor" catalog="System" colorSpace="catalog"/>
|
||||
<color key="backgroundColor" name="controlColor" catalog="System" colorSpace="catalog"/>
|
||||
<connections>
|
||||
<binding destination="USO-Q1-NDq" name="value" keyPath="objectValue.name" id="Ojs-Mi-qdl"/>
|
||||
</connections>
|
||||
</textFieldCell>
|
||||
</textField>
|
||||
</subviews>
|
||||
<connections>
|
||||
<outlet property="textField" destination="9aj-WF-3MF" id="I4F-yK-Is7"/>
|
||||
</connections>
|
||||
</tableCellView>
|
||||
</prototypeCellViews>
|
||||
<connections>
|
||||
<binding destination="1oZ-Uo-mIu" name="value" keyPath="arrangedObjects.name" id="Lgo-HL-51z">
|
||||
<dictionary key="options">
|
||||
<bool key="NSConditionallySetsEditable" value="YES"/>
|
||||
<string key="NSNullPlaceholder">TUUP</string>
|
||||
</dictionary>
|
||||
</binding>
|
||||
<binding destination="1oZ-Uo-mIu" name="value" keyPath="arrangedObjects" id="YFe-9D-GmJ"/>
|
||||
</connections>
|
||||
</tableColumn>
|
||||
<tableColumn identifier="" width="59.5" minWidth="40" maxWidth="1000" id="8st-OH-BXG">
|
||||
<tableColumn identifier="cellFeedConfigRefresh" width="50" minWidth="40" maxWidth="1000" id="8st-OH-BXG">
|
||||
<tableHeaderCell key="headerCell" lineBreakMode="truncatingTail" borderStyle="border" title="Refresh">
|
||||
<font key="font" metaFont="smallSystem"/>
|
||||
<color key="textColor" name="headerTextColor" catalog="System" colorSpace="catalog"/>
|
||||
@@ -360,13 +383,37 @@
|
||||
<color key="textColor" name="controlTextColor" catalog="System" colorSpace="catalog"/>
|
||||
<color key="backgroundColor" name="controlBackgroundColor" catalog="System" colorSpace="catalog"/>
|
||||
</textFieldCell>
|
||||
<prototypeCellViews>
|
||||
<tableCellView identifier="cellFeedConfigRefresh" id="tSf-op-fUB" userLabel="cellView">
|
||||
<rect key="frame" x="266" y="1" width="50" height="17"/>
|
||||
<autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
|
||||
<subviews>
|
||||
<textField verticalHuggingPriority="750" horizontalCompressionResistancePriority="250" fixedFrame="YES" allowsExpansionToolTips="YES" translatesAutoresizingMaskIntoConstraints="NO" id="RZ4-Kn-HYa" userLabel="str">
|
||||
<rect key="frame" x="0.0" y="0.0" width="50" height="17"/>
|
||||
<autoresizingMask key="autoresizingMask" widthSizable="YES" flexibleMinY="YES"/>
|
||||
<textFieldCell key="cell" lineBreakMode="truncatingTail" sendsActionOnEndEditing="YES" alignment="right" title="21042s" id="pIo-Xo-bMN">
|
||||
<font key="font" metaFont="system"/>
|
||||
<color key="textColor" name="controlTextColor" catalog="System" colorSpace="catalog"/>
|
||||
<color key="backgroundColor" name="controlColor" catalog="System" colorSpace="catalog"/>
|
||||
<connections>
|
||||
<binding destination="tSf-op-fUB" name="value" keyPath="objectValue.refresh" id="Eqe-4f-Qns"/>
|
||||
</connections>
|
||||
</textFieldCell>
|
||||
</textField>
|
||||
</subviews>
|
||||
<connections>
|
||||
<outlet property="textField" destination="RZ4-Kn-HYa" id="FHL-bL-MN2"/>
|
||||
</connections>
|
||||
</tableCellView>
|
||||
</prototypeCellViews>
|
||||
<connections>
|
||||
<binding destination="1oZ-Uo-mIu" name="value" keyPath="arrangedObjects.refresh" id="R51-fy-Ufu"/>
|
||||
<binding destination="1oZ-Uo-mIu" name="value" keyPath="arrangedObjects" id="Xuf-hB-h9d"/>
|
||||
</connections>
|
||||
</tableColumn>
|
||||
</tableColumns>
|
||||
<connections>
|
||||
<outlet property="dataSource" destination="1oZ-Uo-mIu" id="sch-o5-yEm"/>
|
||||
<outlet property="delegate" destination="1oZ-Uo-mIu" id="ZkV-Zy-rDc"/>
|
||||
</connections>
|
||||
</outlineView>
|
||||
</subviews>
|
||||
@@ -444,6 +491,7 @@
|
||||
<userDefaultsController representsSharedInstance="YES" id="K8S-BW-Na6"/>
|
||||
</objects>
|
||||
<resources>
|
||||
<image name="NSActionTemplate" width="14" height="14"/>
|
||||
<image name="NSAddTemplate" width="11" height="11"/>
|
||||
<image name="NSBookmarksTemplate" width="17" height="18"/>
|
||||
<image name="NSPathTemplate" width="16" height="10"/>
|
||||
|
||||
@@ -32,6 +32,7 @@
|
||||
@property (weak) IBOutlet NSMenuItem *openUnreadItem;
|
||||
|
||||
@property (strong) NSArray<NSTreeNode*> *currentlyDraggedNodes;
|
||||
@property (strong) NSMutableSet<NSIndexPath*> *expandedItems;
|
||||
@end
|
||||
|
||||
@implementation NewsController
|
||||
@@ -41,11 +42,41 @@ static NSString *dragNodeType = @"baRSS-feed-type";
|
||||
|
||||
- (void)awakeFromNib {
|
||||
[super awakeFromNib];
|
||||
self.expandedItems = [NSMutableSet set];
|
||||
NSArray *storedExpansions = [[NSUserDefaults standardUserDefaults] arrayForKey:@"pups"];
|
||||
NSLog(@"%lu", storedExpansions.count);
|
||||
for (NSString *str in storedExpansions) {
|
||||
if (str.length == 0)
|
||||
continue;
|
||||
NSIndexPath *path = [NSIndexPath new];
|
||||
for (NSString *idx in [str componentsSeparatedByString:@","]) {
|
||||
path = [path indexPathByAddingIndex:(NSUInteger)[idx integerValue]];
|
||||
}
|
||||
NSLog(@"%@", path);
|
||||
}
|
||||
NSLog(@"%@", self.arrangedObjects.childNodes);
|
||||
// [self.expandedItems bind:NSContentArrayBinding toObject:[NSUserDefaultsController sharedUserDefaultsController] withKeyPath:@"values.pups" options:nil];
|
||||
// [self.expandedItems addObject:[self indexPathToString:[NSIndexPath indexPathWithIndex:4]]];
|
||||
// self.expandedItems = [NSMutableSet set];
|
||||
// [self.expandedItems bind:@"values" toObject:[NSUserDefaults standardUserDefaults]
|
||||
// withKeyPath:@"extensio" options:@{ NSContinuouslyUpdatesValueBindingOption : @YES,
|
||||
// NSRaisesForNotApplicableKeysBindingOption : @YES
|
||||
// }];
|
||||
// [self.expandedItems addObject:[NSIndexPath indexPathWithIndex:4]];
|
||||
|
||||
|
||||
|
||||
// Set the outline view to accept the custom drag type AbstractTreeNodeType...
|
||||
[self.outlineView registerForDraggedTypes:[NSArray arrayWithObject:dragNodeType]];
|
||||
[self setSortDescriptors:[NSArray arrayWithObject:[NSSortDescriptor sortDescriptorWithKey:@"sortIndex" ascending:YES]]];
|
||||
}
|
||||
|
||||
|
||||
- (NSView *)outlineView:(NSOutlineView *)outlineView viewForTableColumn:(NSTableColumn *)tableColumn item:(id)item {
|
||||
// this delegate method is only here to set owner to null and prohibit repeated awakeFromNib calls
|
||||
return [self.outlineView makeViewWithIdentifier:tableColumn.identifier owner:nil];
|
||||
}
|
||||
|
||||
- (IBAction)pauseUpdates:(NSMenuItem *)sender {
|
||||
NSLog(@"pause");
|
||||
}
|
||||
@@ -149,6 +180,67 @@ static NSString *dragNodeType = @"baRSS-feed-type";
|
||||
}
|
||||
}
|
||||
|
||||
- (NSString*)indexPathToString:(NSIndexPath*)path {
|
||||
NSMutableString *mStr = [NSMutableString string];
|
||||
for (NSUInteger i = 0; i < path.length; i++) {
|
||||
[mStr appendFormat:@",%lu", [path indexAtPosition:i]];
|
||||
}
|
||||
if (mStr.length < 1) return mStr;
|
||||
return [mStr substringFromIndex:1];
|
||||
}
|
||||
|
||||
- (NSArray*)indexPathToNumberArray:(NSIndexPath*)path {
|
||||
NSUInteger *idcs = malloc(sizeof(NSUInteger) * path.length);
|
||||
[path getIndexes:idcs];
|
||||
NSMutableArray *arr = [[NSMutableArray alloc] initWithCapacity:path.length];
|
||||
for (NSUInteger i = 0; i < path.length; i++) {
|
||||
[arr addObject:[NSNumber numberWithUnsignedInteger:[path indexAtPosition:i]]];
|
||||
}
|
||||
free(idcs);
|
||||
return arr;
|
||||
}
|
||||
|
||||
- (id)outlineView:(NSOutlineView *)outlineView itemForPersistentObject:(id)object {
|
||||
NSIndexPath *path = [NSIndexPath new];
|
||||
for (NSNumber *num in object) {
|
||||
path = [path indexPathByAddingIndex:[num unsignedIntegerValue]];
|
||||
}
|
||||
NSLog(@"%@", [self arrangedObjects]);
|
||||
[((AppDelegate*)[NSApp delegate]) persistentContainer];
|
||||
NSTreeNode *node = [[self arrangedObjects] descendantNodeAtIndexPath:path];
|
||||
return node;
|
||||
}
|
||||
|
||||
- (id)outlineView:(NSOutlineView *)outlineView persistentObjectForItem:(id)item {
|
||||
NSUInteger len = [item indexPath].length;
|
||||
NSUInteger *idcs = malloc(sizeof(NSUInteger) * len);
|
||||
[[item indexPath] getIndexes:idcs];
|
||||
NSMutableArray *arr = [[NSMutableArray alloc] initWithCapacity:len];
|
||||
for (NSUInteger i = 0; i < len; i++) {
|
||||
[arr addObject:[NSNumber numberWithUnsignedInteger:[[item indexPath] indexAtPosition:i]]];
|
||||
}
|
||||
free(idcs);
|
||||
return arr;
|
||||
}
|
||||
|
||||
#pragma mark - Store and reload exanded items
|
||||
|
||||
- (void)loadExpandedItems {
|
||||
|
||||
}
|
||||
|
||||
- (BOOL)outlineView:(NSOutlineView *)outlineView shouldExpandItem:(id)item {
|
||||
[self.expandedItems addObject:[item indexPath]];
|
||||
return YES;
|
||||
}
|
||||
|
||||
- (BOOL)outlineView:(NSOutlineView *)outlineView shouldCollapseItem:(id)item {
|
||||
[self.expandedItems removeObject:[item indexPath]];
|
||||
// [self.outlineView isExpandable:]
|
||||
// [self.outlineView expandItem:]
|
||||
return YES;
|
||||
}
|
||||
|
||||
#pragma mark - Dragging Support, Data Source Delegate
|
||||
|
||||
- (BOOL)outlineView:(NSOutlineView *)outlineView writeItems:(NSArray *)items toPasteboard:(NSPasteboard *)pboard {
|
||||
|
||||
Reference in New Issue
Block a user