STTextView

0.0.19

TextKit2 text view without NSTextView baggage
krzyzanowskim/STTextView

What's New

2022-07-21T11:23:39Z

STTextView

The goal of this project is to build NSTextView replacement component utilizing TextKit2. Because reasons.

The component is developed to serve Swift Studio needs. (ST prefix stands for "Swift sTudio" because SS is not good prefix since 1939)

Screen Shot 2022-05-21 at 11 44 25

TextKit2 was announced during WWDC 2021 as a TextKit replacement for text layout and whatnot. Apple announced that NSTextView, the view component specialized for text editing, will adopt TextKit2 and provide support along TextKit1 bits. As I started to learn more about NSTextView + TextKit2, I realized as of today (Feb 2022), neither NSTextView is fully functional, nor TextKit2 classes are fully functional. Along the way, I reported several bug reports to Apple requested DTS (support tickets). Eventually, I've got blocked by specific bugs that pushed me to start this project.

Bug Reports List

List of issues I reported to Apple so far:

  • FB9856587: TextKit2 unexpected additional line fragment for last line
  • FB9925766: NSTextSelectionNavigation.deletionRanges only works at the end of the word
  • FB9925647: NSTextLayoutManager.replaceContents(in range: with attributedString:) is documented but is not part of the public API
  • FB9907261: NSTextElementProvider.replaceContents(in:with:) does not replace content as documented
  • FB9692714: Rendering attributes does not draw properly
  • FB9886911: NSTextView can't properly layout and display long lines (this one is nasty since it causes the view "jump" whenever text attribute updates)
  • FB9713415: NSTextView drawInsertionPoint(in:color:turnedOn) is never called
  • FB9971054: NSLayoutManager.enumerateCaretOffsetsInLineFragment ignores starting location
  • FB9971054: NSTextView assert on selection when setup with TextKit2
  • FB9743449, FB10019859: NSTextContentStorage.textElements(for:) returns no element, while enumerateTextElements does return elements

... I'm aware that the list of issues is not complete.

Integration

Swift Package Manager:

dependencies: [
    .package(url: "https://github.com/krzyzanowskim/STTextView")
]

Use

let textView = STTextView()

let paragraph = NSParagraphStyle.default.mutableCopy() as! NSMutableParagraphStyle
paragraph.lineHeightMultiple = 1.1
paragraph.defaultTabInterval = 28

textView.defaultParagraphStyle = paragraph
textView.font = NSFont.monospacedSystemFont(ofSize: 14, weight: .regular)
textView.textColor = .textColor
textView.string = "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aenean ornare lobortis sem a vulputate."
textView.addAttributes([.foregroundColor: NSColor.red], range: NSRange(location: 10, length: 5))
textView.widthTracksTextView = true
textView.highlightSelectedLine = true
textView.lineNumbersVisible = true
textView.delegate = self

let scrollView = NSScrollView()
scrollView.documentView = textView

// Line numbers
scrollView.verticalRulerView = STLineNumberRulerView(textView: textView, scrollView: scrollView)
scrollView.rulersVisible = true

Suggestions or Feedback

I'd love to hear from you! Get in touch via twitter @krzyzanowskim, or a pull request.

License

Commercial license

If you want to use STTextView to develop non open sourced product, and applications, the Commercial license is the appropriate license. With this option, your source code is kept proprietary. Which means, you won't have to change your whole application source code to an open source license. Purchase a STTextView Commercial License

Open source license

If you are creating an open source application under a license compatible with the GNU GPL license v3, you may use STTextView under the terms of the GPLv3.

Description

  • Swift Tools 5.5.0
View More Packages from this Author

Dependencies

  • None
Last updated: Tue Oct 04 2022 02:53:02 GMT-0500 (GMT-05:00)