mirror of
https://github.com/Toxblh/MTMR.git
synced 2026-01-10 17:08:39 +00:00
191 lines
5.7 KiB
Swift
191 lines
5.7 KiB
Swift
//
|
|
// TouchBarItems.swift
|
|
// MTMR
|
|
//
|
|
// Created by Anton Palgunov on 18/03/2018.
|
|
// Copyright © 2018 Anton Palgunov. All rights reserved.
|
|
//
|
|
|
|
import Cocoa
|
|
|
|
class CustomButtonTouchBarItem: NSCustomTouchBarItem, NSGestureRecognizerDelegate {
|
|
var tapClosure: (() -> Void)?
|
|
var longTapClosure: (() -> Void)?
|
|
|
|
private var button: NSButton!
|
|
private var singleClick: HapticClickGestureRecognizer!
|
|
private var longClick: NSPressGestureRecognizer!
|
|
|
|
init(identifier: NSTouchBarItem.Identifier, title: String) {
|
|
attributedTitle = title.defaultTouchbarAttributedString
|
|
|
|
super.init(identifier: identifier)
|
|
button = CustomHeightButton(title: title, target: nil, action: nil)
|
|
|
|
longClick = NSPressGestureRecognizer(target: self, action: #selector(handleGestureLong))
|
|
longClick.allowedTouchTypes = .direct
|
|
longClick.delegate = self
|
|
|
|
singleClick = HapticClickGestureRecognizer(target: self, action: #selector(handleGestureSingle))
|
|
singleClick.allowedTouchTypes = .direct
|
|
singleClick.delegate = self
|
|
|
|
reinstallButton()
|
|
button.attributedTitle = attributedTitle
|
|
}
|
|
|
|
required init?(coder _: NSCoder) {
|
|
fatalError("init(coder:) has not been implemented")
|
|
}
|
|
|
|
var isBordered: Bool = true {
|
|
didSet {
|
|
reinstallButton()
|
|
}
|
|
}
|
|
|
|
var backgroundColor: NSColor? {
|
|
didSet {
|
|
reinstallButton()
|
|
}
|
|
}
|
|
|
|
var title: String {
|
|
get {
|
|
return attributedTitle.string
|
|
}
|
|
set {
|
|
attributedTitle = newValue.defaultTouchbarAttributedString
|
|
}
|
|
}
|
|
|
|
var attributedTitle: NSAttributedString {
|
|
didSet {
|
|
button?.imagePosition = attributedTitle.length > 0 ? .imageLeading : .imageOnly
|
|
button?.attributedTitle = attributedTitle
|
|
}
|
|
}
|
|
|
|
var image: NSImage? {
|
|
didSet {
|
|
button.image = image
|
|
}
|
|
}
|
|
|
|
private func reinstallButton() {
|
|
let title = button.attributedTitle
|
|
let image = button.image
|
|
let cell = CustomButtonCell(parentItem: self)
|
|
button.cell = cell
|
|
if let color = backgroundColor {
|
|
cell.isBordered = true
|
|
button.bezelColor = color
|
|
cell.backgroundColor = color
|
|
} else {
|
|
button.isBordered = isBordered
|
|
button.bezelStyle = isBordered ? .rounded : .inline
|
|
}
|
|
button.imageScaling = .scaleProportionallyDown
|
|
button.imageHugsTitle = true
|
|
button.attributedTitle = title
|
|
button?.imagePosition = title.length > 0 ? .imageLeading : .imageOnly
|
|
button.image = image
|
|
view = button
|
|
|
|
view.addGestureRecognizer(longClick)
|
|
view.addGestureRecognizer(singleClick)
|
|
}
|
|
|
|
func gestureRecognizer(_ gestureRecognizer: NSGestureRecognizer, shouldRequireFailureOf otherGestureRecognizer: NSGestureRecognizer) -> Bool {
|
|
if gestureRecognizer == singleClick && otherGestureRecognizer == longClick {
|
|
return false
|
|
}
|
|
return true
|
|
}
|
|
|
|
@objc func handleGestureSingle(gr: NSClickGestureRecognizer) {
|
|
switch gr.state {
|
|
case .ended:
|
|
tapClosure?()
|
|
break
|
|
default:
|
|
break
|
|
}
|
|
}
|
|
|
|
@objc func handleGestureLong(gr: NSPressGestureRecognizer) {
|
|
switch gr.state {
|
|
case .began:
|
|
if let closure = self.longTapClosure {
|
|
HapticFeedback.shared.tap(strong: 2)
|
|
closure()
|
|
} else if let closure = self.tapClosure {
|
|
HapticFeedback.shared.tap(strong: 6)
|
|
closure()
|
|
print("long click")
|
|
}
|
|
break
|
|
default:
|
|
break
|
|
}
|
|
}
|
|
}
|
|
|
|
class CustomHeightButton: NSButton {
|
|
override var intrinsicContentSize: NSSize {
|
|
var size = super.intrinsicContentSize
|
|
size.height = 30
|
|
return size
|
|
}
|
|
}
|
|
|
|
class CustomButtonCell: NSButtonCell {
|
|
weak var parentItem: CustomButtonTouchBarItem?
|
|
|
|
init(parentItem: CustomButtonTouchBarItem) {
|
|
super.init(textCell: "")
|
|
self.parentItem = parentItem
|
|
}
|
|
|
|
override func highlight(_ flag: Bool, withFrame cellFrame: NSRect, in controlView: NSView) {
|
|
super.highlight(flag, withFrame: cellFrame, in: controlView)
|
|
if !isBordered {
|
|
if flag {
|
|
setAttributedTitle(attributedTitle, withColor: .lightGray)
|
|
} else if let parentItem = self.parentItem {
|
|
attributedTitle = parentItem.attributedTitle
|
|
}
|
|
}
|
|
}
|
|
|
|
required init(coder _: NSCoder) {
|
|
fatalError("init(coder:) has not been implemented")
|
|
}
|
|
|
|
func setAttributedTitle(_ title: NSAttributedString, withColor color: NSColor) {
|
|
let attrTitle = NSMutableAttributedString(attributedString: title)
|
|
attrTitle.addAttributes([.foregroundColor: color], range: NSRange(location: 0, length: attrTitle.length))
|
|
attributedTitle = attrTitle
|
|
}
|
|
}
|
|
|
|
class HapticClickGestureRecognizer: NSClickGestureRecognizer {
|
|
override func touchesBegan(with event: NSEvent) {
|
|
HapticFeedback.shared.tap(strong: 2)
|
|
super.touchesBegan(with: event)
|
|
}
|
|
|
|
override func touchesEnded(with event: NSEvent) {
|
|
HapticFeedback.shared.tap(strong: 1)
|
|
super.touchesEnded(with: event)
|
|
}
|
|
}
|
|
|
|
extension String {
|
|
var defaultTouchbarAttributedString: NSAttributedString {
|
|
let attrTitle = NSMutableAttributedString(string: self, attributes: [.foregroundColor: NSColor.white, .font: NSFont.systemFont(ofSize: 15, weight: .regular), .baselineOffset: 1])
|
|
attrTitle.setAlignment(.center, range: NSRange(location: 0, length: count))
|
|
return attrTitle
|
|
}
|
|
}
|