mirror of https://github.com/procxx/kepka.git
show in finder done, open with custom dialog started for mac
This commit is contained in:
parent
196b412d1f
commit
2b61046a75
|
@ -314,6 +314,7 @@ lng_context_copy_image: "Copy Image";
|
||||||
lng_context_close_image: "Close Image";
|
lng_context_close_image: "Close Image";
|
||||||
lng_context_cancel_download: "Cancel Download";
|
lng_context_cancel_download: "Cancel Download";
|
||||||
lng_context_show_in_folder: "Show in Folder";
|
lng_context_show_in_folder: "Show in Folder";
|
||||||
|
lng_context_show_in_finder: "Show in Finder";
|
||||||
lng_context_open_video: "Open Video";
|
lng_context_open_video: "Open Video";
|
||||||
lng_context_save_video: "Save Video As...";
|
lng_context_save_video: "Save Video As...";
|
||||||
lng_context_open_audio: "Open Audio";
|
lng_context_open_audio: "Open Audio";
|
||||||
|
|
|
@ -1768,7 +1768,8 @@ void HistoryVideo::draw(QPainter &p, const HistoryItem *parent, const QString &t
|
||||||
p.fillRect(0, _height, width, st::msgShadow, shadow->b);
|
p.fillRect(0, _height, width, st::msgShadow, shadow->b);
|
||||||
|
|
||||||
if (_thumbw) {
|
if (_thumbw) {
|
||||||
p.drawPixmap(QPoint(st::mediaPadding.left(), st::mediaPadding.top()), data->thumb->pix(_thumbw), QRect(_thumbx, _thumby, st::mediaThumbSize, st::mediaThumbSize));
|
int32 rf(cIntRetinaFactor());
|
||||||
|
p.drawPixmap(QPoint(st::mediaPadding.left(), st::mediaPadding.top()), data->thumb->pix(_thumbw), QRect(_thumbx * rf, _thumby * rf, st::mediaThumbSize * rf, st::mediaThumbSize * rf));
|
||||||
} else {
|
} else {
|
||||||
p.drawPixmap(QPoint(st::mediaPadding.left(), st::mediaPadding.top()), App::sprite(), (out ? st::mediaDocOutImg : st::mediaDocInImg));
|
p.drawPixmap(QPoint(st::mediaPadding.left(), st::mediaPadding.top()), App::sprite(), (out ? st::mediaDocOutImg : st::mediaDocInImg));
|
||||||
}
|
}
|
||||||
|
|
|
@ -636,7 +636,7 @@ void HistoryList::showContextMenu(QContextMenuEvent *e, bool showFromTouch) {
|
||||||
_menu->addAction(lang(lng_context_cancel_download), this, SLOT(cancelContextDownload()))->setEnabled(true);
|
_menu->addAction(lang(lng_context_cancel_download), this, SLOT(cancelContextDownload()))->setEnabled(true);
|
||||||
} else {
|
} else {
|
||||||
if ((lnkVideo && !lnkVideo->video()->already(true).isEmpty()) || (lnkAudio && !lnkAudio->audio()->already(true).isEmpty()) || (lnkDocument && !lnkDocument->document()->already(true).isEmpty())) {
|
if ((lnkVideo && !lnkVideo->video()->already(true).isEmpty()) || (lnkAudio && !lnkAudio->audio()->already(true).isEmpty()) || (lnkDocument && !lnkDocument->document()->already(true).isEmpty())) {
|
||||||
_menu->addAction(lang(lng_context_show_in_folder), this, SLOT(showContextInFolder()))->setEnabled(true);
|
_menu->addAction(lang(cPlatform() == dbipMac ? lng_context_show_in_finder : lng_context_show_in_folder), this, SLOT(showContextInFolder()))->setEnabled(true);
|
||||||
}
|
}
|
||||||
_menu->addAction(lang(lnkVideo ? lng_context_open_video : (lnkAudio ? lng_context_open_audio : lng_context_open_document)), this, SLOT(openContextFile()))->setEnabled(true);
|
_menu->addAction(lang(lnkVideo ? lng_context_open_video : (lnkAudio ? lng_context_open_audio : lng_context_open_document)), this, SLOT(openContextFile()))->setEnabled(true);
|
||||||
_menu->addAction(lang(lnkVideo ? lng_context_save_video : (lnkAudio ? lng_context_save_audio : lng_context_save_document)), this, SLOT(saveContextFile()))->setEnabled(true);
|
_menu->addAction(lang(lnkVideo ? lng_context_save_video : (lnkAudio ? lng_context_save_audio : lng_context_save_document)), this, SLOT(saveContextFile()))->setEnabled(true);
|
||||||
|
|
|
@ -71,7 +71,7 @@ void debugLogWrite(const char *file, int32 line, const QString &v) {
|
||||||
OutputDebugString(reinterpret_cast<const wchar_t *>(msg.utf16()));
|
OutputDebugString(reinterpret_cast<const wchar_t *>(msg.utf16()));
|
||||||
#endif
|
#endif
|
||||||
#ifdef Q_OS_MAC
|
#ifdef Q_OS_MAC
|
||||||
_outputDebugString(msg.toUtf8().constData());
|
objc_outputDebugString(msg.toUtf8().constData());
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -130,7 +130,7 @@ posInited(false), trayIcon(0), trayIconMenu(0), icon256(qsl(":/gui/art/iconround
|
||||||
}
|
}
|
||||||
|
|
||||||
void PsMainWindow::psIdleTimeout() {
|
void PsMainWindow::psIdleTimeout() {
|
||||||
int64 idleTime = _idleTime();
|
int64 idleTime = objc_idleTime();
|
||||||
if (idleTime >= 0) {
|
if (idleTime >= 0) {
|
||||||
if (idleTime <= IdleMsecs) {
|
if (idleTime <= IdleMsecs) {
|
||||||
psIdle = false;
|
psIdle = false;
|
||||||
|
@ -147,7 +147,7 @@ bool PsMainWindow::psIsOnline(int state) const {
|
||||||
} else if (!isVisible()) {
|
} else if (!isVisible()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
int64 idleTime = _idleTime();
|
int64 idleTime = objc_idleTime();
|
||||||
LOG(("App Info: idle time %1").arg(idleTime));
|
LOG(("App Info: idle time %1").arg(idleTime));
|
||||||
if (idleTime >= 0) {
|
if (idleTime >= 0) {
|
||||||
if (idleTime > IdleMsecs) {
|
if (idleTime > IdleMsecs) {
|
||||||
|
@ -1624,26 +1624,11 @@ void psPostprocessFile(const QString &name) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void psOpenFile(const QString &name, bool openWith) {
|
void psOpenFile(const QString &name, bool openWith) {
|
||||||
/*std::wstring wname = QDir::toNativeSeparators(name).toStdWString();
|
objc_openFile(name.toUtf8().constData(), openWith);
|
||||||
|
|
||||||
if (openWith && useOpenAs) {
|
|
||||||
if (shOpenWithDialog) {
|
|
||||||
OPENASINFO info;
|
|
||||||
info.oaifInFlags = OAIF_ALLOW_REGISTRATION | OAIF_REGISTER_EXT | OAIF_EXEC;
|
|
||||||
info.pcszClass = NULL;
|
|
||||||
info.pcszFile = wname.c_str();
|
|
||||||
shOpenWithDialog(0, &info);
|
|
||||||
} else {
|
|
||||||
openAs_RunDLL(0, 0, wname.c_str(), SW_SHOWNORMAL);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
ShellExecute(0, L"open", wname.c_str(), 0, 0, SW_SHOWNORMAL);
|
|
||||||
}*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void psShowInFolder(const QString &name) {
|
void psShowInFolder(const QString &name) {
|
||||||
//QString nameEscaped = QDir::toNativeSeparators(name).replace('"', qsl("\"\""));
|
objc_showInFinder(name.toUtf8().constData(), QFileInfo(name).absolutePath().toUtf8().constData());
|
||||||
//ShellExecute(0, 0, qsl("explorer").toStdWString().c_str(), (qsl("/select,") + nameEscaped).toStdWString().c_str(), 0, SW_SHOWNORMAL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void psExecUpdater() {
|
void psExecUpdater() {
|
||||||
|
|
|
@ -48,6 +48,9 @@ public:
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
void _debugShowAlert(const char *utf8str);
|
void objc_debugShowAlert(const char *utf8str);
|
||||||
void _outputDebugString(const char *utf8str);
|
void objc_outputDebugString(const char *utf8str);
|
||||||
int64 _idleTime();
|
int64 objc_idleTime();
|
||||||
|
|
||||||
|
void objc_showInFinder(const char *utf8file, const char *utf8path);
|
||||||
|
void objc_openFile(const char *utf8file, bool openwith);
|
||||||
|
|
|
@ -18,9 +18,9 @@ Copyright (c) 2014 John Preston, https://tdesktop.com
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#include "pspecific_mac_p.h"
|
#include "pspecific_mac_p.h"
|
||||||
|
|
||||||
#include <AppKit/AppKit.h>
|
|
||||||
#include <Cocoa/Cocoa.h>
|
#include <Cocoa/Cocoa.h>
|
||||||
#include <IOKit/IOKitLib.h>
|
#include <IOKit/IOKitLib.h>
|
||||||
|
#include <CoreFoundation/CFURL.h>
|
||||||
|
|
||||||
@interface ObserverHelper : NSObject {
|
@interface ObserverHelper : NSObject {
|
||||||
}
|
}
|
||||||
|
@ -201,7 +201,7 @@ void PsMacWindowPrivate::clearNotifies(unsigned long long peer) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void _debugShowAlert(const char *utf8str) {
|
void objc_debugShowAlert(const char *utf8str) {
|
||||||
NSString *text = [[NSString alloc] initWithUTF8String: utf8str];
|
NSString *text = [[NSString alloc] initWithUTF8String: utf8str];
|
||||||
NSAlert *alert = [NSAlert alertWithMessageText:@"Debug Message" defaultButton:@"OK" alternateButton:nil otherButton:nil informativeTextWithFormat:@"%@", text];
|
NSAlert *alert = [NSAlert alertWithMessageText:@"Debug Message" defaultButton:@"OK" alternateButton:nil otherButton:nil informativeTextWithFormat:@"%@", text];
|
||||||
[alert runModal];
|
[alert runModal];
|
||||||
|
@ -209,7 +209,7 @@ void _debugShowAlert(const char *utf8str) {
|
||||||
[text release];
|
[text release];
|
||||||
}
|
}
|
||||||
|
|
||||||
void _outputDebugString(const char *utf8str) {
|
void objc_outputDebugString(const char *utf8str) {
|
||||||
NSString *text = [[NSString alloc] initWithUTF8String:utf8str];
|
NSString *text = [[NSString alloc] initWithUTF8String:utf8str];
|
||||||
NSLog(@"%@", text);
|
NSLog(@"%@", text);
|
||||||
[text release];
|
[text release];
|
||||||
|
@ -219,7 +219,7 @@ PsMacWindowPrivate::~PsMacWindowPrivate() {
|
||||||
delete data;
|
delete data;
|
||||||
}
|
}
|
||||||
|
|
||||||
int64 _idleTime() { // taken from https://github.com/trueinteractions/tint/issues/53
|
int64 objc_idleTime() { // taken from https://github.com/trueinteractions/tint/issues/53
|
||||||
CFMutableDictionaryRef properties = 0;
|
CFMutableDictionaryRef properties = 0;
|
||||||
CFTypeRef obj;
|
CFTypeRef obj;
|
||||||
mach_port_t masterPort;
|
mach_port_t masterPort;
|
||||||
|
@ -268,3 +268,106 @@ int64 _idleTime() { // taken from https://github.com/trueinteractions/tint/issue
|
||||||
IOObjectRelease(iter);
|
IOObjectRelease(iter);
|
||||||
return (result == err) ? -1 : int64(result);
|
return (result == err) ? -1 : int64(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void objc_showInFinder(const char *utf8file, const char *utf8path) {
|
||||||
|
NSString *file = [[NSString alloc] initWithUTF8String:utf8file], *path = [[NSString alloc] initWithUTF8String:utf8path];
|
||||||
|
[[NSWorkspace sharedWorkspace] selectFile:file inFileViewerRootedAtPath:path];
|
||||||
|
[file release];
|
||||||
|
[path release];
|
||||||
|
}
|
||||||
|
|
||||||
|
@interface NSURL(CompareUrls)
|
||||||
|
|
||||||
|
- (BOOL) isEquivalent:(NSURL *)aURL;
|
||||||
|
|
||||||
|
@end
|
||||||
|
|
||||||
|
@implementation NSURL(CompareUrls)
|
||||||
|
|
||||||
|
- (BOOL) isEquivalent:(NSURL *)aURL {
|
||||||
|
if ([self isEqual:aURL]) return YES;
|
||||||
|
if ([[self scheme] caseInsensitiveCompare:[aURL scheme]] != NSOrderedSame) return NO;
|
||||||
|
if ([[self host] caseInsensitiveCompare:[aURL host]] != NSOrderedSame) return NO;
|
||||||
|
if ([[self path] compare:[aURL path]] != NSOrderedSame) return NO;
|
||||||
|
if ([[self port] compare:[aURL port]] != NSOrderedSame) return NO;
|
||||||
|
if ([[self query] compare:[aURL query]] != NSOrderedSame) return NO;
|
||||||
|
return YES;
|
||||||
|
}
|
||||||
|
|
||||||
|
@end
|
||||||
|
|
||||||
|
@interface ChooseApplicationDelegate : NSObject<NSOpenSavePanelDelegate> {
|
||||||
|
}
|
||||||
|
|
||||||
|
- (id) init:(NSArray *)recommendedApps;
|
||||||
|
- (BOOL) panel:(id)sender shouldEnableURL:(NSURL *)url;
|
||||||
|
- (void) dealloc;
|
||||||
|
|
||||||
|
@end
|
||||||
|
|
||||||
|
@implementation ChooseApplicationDelegate {
|
||||||
|
BOOL onlyRecommended;
|
||||||
|
NSArray *apps;
|
||||||
|
}
|
||||||
|
|
||||||
|
- (id) init:(NSArray *)recommendedApps {
|
||||||
|
if (self = [super init]) {
|
||||||
|
onlyRecommended = YES;
|
||||||
|
apps = recommendedApps;
|
||||||
|
}
|
||||||
|
return self;
|
||||||
|
}
|
||||||
|
|
||||||
|
- (BOOL) panel:(id)sender shouldEnableURL:(NSURL *)url {
|
||||||
|
NSNumber *isDirectory;
|
||||||
|
if ([url getResourceValue:&isDirectory forKey:NSURLIsDirectoryKey error:nil] && isDirectory != nil && [isDirectory boolValue]) {
|
||||||
|
if (onlyRecommended) {
|
||||||
|
CFStringRef ext = CFURLCopyPathExtension((CFURLRef)url);
|
||||||
|
NSNumber *isPackage;
|
||||||
|
if ([url getResourceValue:&isPackage forKey:NSURLIsPackageKey error:nil] && isPackage != nil && [isPackage boolValue]) {
|
||||||
|
if (apps) {
|
||||||
|
for (id app in apps) {
|
||||||
|
if ([(NSURL*)app isEquivalent:url]) {
|
||||||
|
return YES;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return NO;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return YES;
|
||||||
|
}
|
||||||
|
return NO;
|
||||||
|
}
|
||||||
|
|
||||||
|
- (void) dealloc {
|
||||||
|
if (apps) {
|
||||||
|
[apps release];
|
||||||
|
}
|
||||||
|
[super dealloc];
|
||||||
|
}
|
||||||
|
|
||||||
|
@end
|
||||||
|
|
||||||
|
void objc_openFile(const char *utf8file, bool openwith) {
|
||||||
|
NSString *file = [[NSString alloc] initWithUTF8String:utf8file];
|
||||||
|
if (openwith || [[NSWorkspace sharedWorkspace] openFile:file] == NO) {
|
||||||
|
NSURL *url = [NSURL fileURLWithPath:file];
|
||||||
|
NSArray *apps = (NSArray*)LSCopyApplicationURLsForURL(CFURLRef(url), kLSRolesAll);
|
||||||
|
|
||||||
|
ChooseApplicationDelegate *delegate = [[ChooseApplicationDelegate alloc] init:apps];
|
||||||
|
NSOpenPanel *openPanel = [NSOpenPanel openPanel];
|
||||||
|
|
||||||
|
[openPanel setCanChooseDirectories:NO];
|
||||||
|
[openPanel setCanChooseFiles:YES];
|
||||||
|
[openPanel setAllowsMultipleSelection:NO];
|
||||||
|
[openPanel setDelegate:delegate];
|
||||||
|
[openPanel setTitle:@"Choose Application"];
|
||||||
|
[openPanel setMessage:@"Choose an application to open the document \"blabla.png\"."];
|
||||||
|
if ([openPanel runModal] == NSOKButton) {
|
||||||
|
NSArray *result = [openPanel URLs];
|
||||||
|
}
|
||||||
|
[delegate release];
|
||||||
|
}
|
||||||
|
[file release];
|
||||||
|
}
|
||||||
|
|
|
@ -59,7 +59,6 @@ TitleWidget::TitleWidget(Window *window)
|
||||||
, _maximize(this, window)
|
, _maximize(this, window)
|
||||||
, _restore(this, window)
|
, _restore(this, window)
|
||||||
, _close(this, window)
|
, _close(this, window)
|
||||||
, availWidth(460)
|
|
||||||
, lastMaximized(!(window->windowState() & Qt::WindowMaximized))
|
, lastMaximized(!(window->windowState() & Qt::WindowMaximized))
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
|
@ -84,8 +84,6 @@ private:
|
||||||
RestoreBtn _restore;
|
RestoreBtn _restore;
|
||||||
CloseBtn _close;
|
CloseBtn _close;
|
||||||
|
|
||||||
int32 availWidth;
|
|
||||||
|
|
||||||
bool lastMaximized;
|
bool lastMaximized;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue