Implement dragging import/export of URLs

This commit is contained in:
Matthias Neeracher 2011-08-21 21:35:04 +02:00
parent b1a1104361
commit 9b42529dc3
5 changed files with 44 additions and 17 deletions

View File

@ -8,6 +8,8 @@
#import "MAColorForURL.h" #import "MAColorForURL.h"
#import <QTKit/QTKit.h>
@implementation MAColorForURL @implementation MAColorForURL
+ (Class)transformedValueClass + (Class)transformedValueClass
@ -22,7 +24,8 @@
- (id)transformedValue:(id)value - (id)transformedValue:(id)value
{ {
if ([[NSFileManager defaultManager] fileExistsAtPath:value]) NSURL * mediaURL = [NSURL URLWithString:value];
if ([QTMovie canInitWithURL:mediaURL])
return [NSColor blackColor]; return [NSColor blackColor];
else else
return [NSColor redColor]; return [NSColor redColor];

View File

@ -94,8 +94,9 @@ static const char * kMADocWindowObserver = "MADocWindowObserver";
// Current movie changed // Current movie changed
// //
if (MAMedia * currentMedia = [self currentMedia]) { if (MAMedia * currentMedia = [self currentMedia]) {
currentMovie = [[QTMovie alloc] initWithFile:[currentMedia media] error:nil]; NSURL * mediaURL = [NSURL URLWithString:[currentMedia media]];
currentMovieTitle = [currentMedia name]; currentMovie = [[QTMovie alloc] initWithURL:mediaURL error:nil];
currentMovieTitle = [currentMedia name];
} else { } else {
currentMovie = nil; currentMovie = nil;
currentMovieTitle = @""; currentMovieTitle = @"";

View File

@ -42,7 +42,7 @@
- (MAMedia *)addMediaURL:(NSURL *)url name:(NSString *)name date:(NSDate *)date - (MAMedia *)addMediaURL:(NSURL *)url name:(NSString *)name date:(NSDate *)date
{ {
NSString * path = [url path]; NSString * path = [url absoluteString];
NSNumber * size; NSNumber * size;
[url getResourceValue:&size forKey:NSURLFileSizeKey error:nil]; [url getResourceValue:&size forKey:NSURLFileSizeKey error:nil];
int64_t fileSize = [size longLongValue]; int64_t fileSize = [size longLongValue];

View File

@ -41,10 +41,13 @@
- (NSArray *)writableTypesForPasteboard:(NSPasteboard *)pasteboard - (NSArray *)writableTypesForPasteboard:(NSPasteboard *)pasteboard
{ {
if (![contents count] || [[contents objectAtIndex:0] class] != [MAMedia class]) MAMedia * media;
if (![contents count] || [(media = [contents objectAtIndex:0]) class] != [MAMedia class])
return [NSArray arrayWithObjects:kMADragType, kUTTypeUTF8PlainText, nil]; return [NSArray arrayWithObjects:kMADragType, kUTTypeUTF8PlainText, nil];
else if ([[NSURL URLWithString:[media media]] isFileURL])
return [NSArray arrayWithObjects:kMADragType, kUTTypeFileURL, nil];
else else
return [NSArray arrayWithObjects:kMADragType, NSFilenamesPboardType, nil]; return [NSArray arrayWithObjects:kMADragType, kUTTypeURL, nil];
} }
- (NSPasteboardWritingOptions)writingOptionsForType:(NSString *)type pasteboard:(NSPasteboard *)pasteboard - (NSPasteboardWritingOptions)writingOptionsForType:(NSString *)type pasteboard:(NSPasteboard *)pasteboard
@ -61,11 +64,8 @@
for (id obj in contents) for (id obj in contents)
[stringBuffer appendFormat:@"%@\n", [obj exportText]]; [stringBuffer appendFormat:@"%@\n", [obj exportText]];
return stringBuffer; return stringBuffer;
} else if ([type isEqual:NSFilenamesPboardType]) { } else if ([type isEqual:(NSString *)kUTTypeURL] || [type isEqual:(NSString *)kUTTypeFileURL]) {
NSMutableArray * urls = [NSMutableArray array]; return [contents count]>0 ? [[contents objectAtIndex:0] media] : nil;
for (MAMedia * obj in contents)
[urls addObject:[NSURL fileURLWithPath:[obj media]]];
return urls;
} }
return nil; return nil;
} }
@ -76,8 +76,9 @@
- (void)registerOurDragTypes - (void)registerOurDragTypes
{ {
[mediaTable setDraggingSourceOperationMask:NSDragOperationCopy forLocal:NO];
[mediaTable registerForDraggedTypes: [mediaTable registerForDraggedTypes:
[NSArray arrayWithObjects:kMADragType,NSFilenamesPboardType, nil]]; [NSArray arrayWithObjects:kMADragType, NSFilenamesPboardType, kUTTypeURL, nil]];
[annotationTable setDraggingSourceOperationMask:NSDragOperationEvery forLocal:NO]; [annotationTable setDraggingSourceOperationMask:NSDragOperationEvery forLocal:NO];
[annotationTable setVerticalMotionCanBeginDrag:NO]; [annotationTable setVerticalMotionCanBeginDrag:NO];
@ -110,7 +111,8 @@
if (tableView == [info draggingSource]) if (tableView == [info draggingSource])
return NSDragOperationNone; return NSDragOperationNone;
NSPasteboard * pb = [info draggingPasteboard]; NSPasteboard * pb = [info draggingPasteboard];
if (id drag = [pb propertyListForType:kMADragType]) { id drag;
if ((drag = [pb propertyListForType:kMADragType])) {
// //
// We don't allow media drops in annotation table // We don't allow media drops in annotation table
// //
@ -128,6 +130,16 @@
} }
} }
return NSDragOperationCopy; return NSDragOperationCopy;
} else if (tableView == mediaTable) {
if ((drag = [pb propertyListForType:NSFilenamesPboardType])) {
[tableView setDropRow:row dropOperation:NSTableViewDropAbove];
return NSDragOperationLink;
} else if ((drag = [pb stringForType:(NSString *)kUTTypeURL])
|| (drag = [pb stringForType:(NSString *)kUTTypeFileURL])
) {
[tableView setDropRow:row dropOperation:NSTableViewDropAbove];
return NSDragOperationLink;
}
} }
return NSDragOperationNone; return NSDragOperationNone;
} }
@ -146,9 +158,20 @@
media = [allMedia objectAtIndex:row]; media = [allMedia objectAtIndex:row];
} }
if (id drag = [pb propertyListForType:kMADragType]) id drag;
if ((drag = [pb propertyListForType:kMADragType])) {
for (id obj in (NSArray *)[drag longValue]) for (id obj in (NSArray *)[drag longValue])
[obj copyToDocument:doc withMedia:media]; [obj copyToDocument:doc withMedia:media];
} else if ((drag = [pb propertyListForType:NSFilenamesPboardType])) {
NSMutableArray * urls = [NSMutableArray array];
for (NSString * path in drag)
[urls addObject:[NSURL fileURLWithPath:path]];
[self addMedia:urls];
} else if ((drag = [pb stringForType:(NSString *)kUTTypeURL])
|| (drag = [pb stringForType:(NSString *)kUTTypeFileURL])
) {
[self addMedia:[NSArray arrayWithObject:[NSURL URLWithString:drag]]];
}
return YES; return YES;
} }

View File

@ -20,7 +20,7 @@
- (MAMedia *)copyToDocument:(MADocument *)doc withMedia:(MAMedia *)m - (MAMedia *)copyToDocument:(MADocument *)doc withMedia:(MAMedia *)m
{ {
MAMedia * media = [doc addMediaURL:[NSURL fileURLWithPath:self.media] MAMedia * media = [doc addMediaURL:[NSURL URLWithString:self.media]
name:self.name name:self.name
date:[NSDate dateWithTimeIntervalSinceReferenceDate:self.date]]; date:[NSDate dateWithTimeIntervalSinceReferenceDate:self.date]];
media.notes = self.notes; media.notes = self.notes;