Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add TextOverflow "ellipsisStart" , "ellipsisMiddle" and "ellipsisEnd" #45336

Open
oodavid opened this issue Nov 21, 2019 · 39 comments
Open

Add TextOverflow "ellipsisStart" , "ellipsisMiddle" and "ellipsisEnd" #45336

oodavid opened this issue Nov 21, 2019 · 39 comments
Assignees
Labels
a: typography Text rendering, possibly libtxt c: new feature Nothing broken; request for a new capability c: proposal A detailed proposal for a change to Flutter customer: crowd Affects or could affect many people, though not necessarily a specific customer. customer: google Various Google teams framework flutter/packages/flutter repository. See also f: labels. Bot is counting down the days until it unassigns the issue P1 High-priority issues at the top of the work list team-framework Owned by Framework team triaged-framework Triaged by Framework team

Comments

@oodavid
Copy link

oodavid commented Nov 21, 2019

Use case

When displaying file-paths, I'd prefer to show the file-name and clip the file-path.

In this example, it's not possible to see the filenames:

Text(
  '/root/sdcard/storage/camera/2019-11-20 12:12:11 a-file-with-a-long-path.png',
  overflow: TextOverflow.ellipsis,
)

Screenshot 2019-11-21 at 10 47 04

Proposal

Allow TextOverflow to clip text on the leading edge rather than the trailing edge.

Internal bug - b/180975303

@iapicca iapicca added a: typography Text rendering, possibly libtxt c: proposal A detailed proposal for a change to Flutter c: new feature Nothing broken; request for a new capability labels Nov 21, 2019
@HansMuller HansMuller added the framework flutter/packages/flutter repository. See also f: labels. label Nov 21, 2019
@iapicca iapicca added the customer: crowd Affects or could affect many people, though not necessarily a specific customer. label Dec 22, 2019
@feinstein
Copy link
Contributor

As I said in #47543 I suggest TextOverflow.ellipsisStart, TextOverflow.ellipsisMiddleand TextOverflow.ellipsisEnd.

@iapicca iapicca changed the title TextOverflow on leading edge Add TextOverflow "ellipsisStart" , "ellipsisMiddle" and "ellipsisEnd" Dec 30, 2019
@trqalothman

This comment was marked as off-topic.

@feinstein

This comment was marked as off-topic.

@trqalothman

This comment was marked as off-topic.

@feinstein
Copy link
Contributor

Give it a 👍🏻 (as they prioritize based on thumbs up count) and hope someone will get to fix it.

@trqalothman

This comment was marked as off-topic.

@ajain-bst

This comment was marked as off-topic.

@trqalothman

This comment was marked as off-topic.

@trqalothman
Copy link

Here is the link for the Truncation property of Label, it is called line break and you can set it as "Truncate Head", "Truncate Middle", and "Truncate Tail". In flutter it only implements "Truncate Tail" and not the others.

https://developer.apple.com/documentation/swiftui/text/truncationmode/middle

@jxzy999

This comment was marked as duplicate.

@sm2017

This comment was marked as off-topic.

@iapicca

This comment was marked as off-topic.

@zmtzawqlp
Copy link
Contributor

zmtzawqlp commented Apr 25, 2021

https://pub.dev/packages/extended_text support this feature now. you can define it as following:

enum TextOverflowPosition {
  start,
  middle,
  end,
}
  ExtendedText(
   overflowWidget: TextOverflowWidget(
     position: TextOverflowPosition.end,
     align: TextOverflowAlign.center,
     // just for debug
     debugOverflowRectColor: Colors.red.withOpacity(0.1),
     child: Container(
       child: Row(
         mainAxisSize: MainAxisSize.min,
         children: <Widget>[
           const Text('\u2026 '),
           InkWell(
             child: const Text(
               'more',
             ),
             onTap: () {
               launch(
                   'https://github.com/fluttercandies/extended_text');
             },
           )
         ],
       ),
     ),
   ),
  )

image

@iapicca
Copy link
Contributor

iapicca commented Apr 25, 2021

https://pub.dev/packages/extended_text support this function now. you can define it as following:

@zmtzawqlp
nice to have a 3rd party package!
but I feel that this feature should be first party with "first party grade" testing and such

@JordanRoberts1
Copy link

https://pub.dev/packages/extended_text support this feature now. you can define it as following:

Extended Text doesn't support Flutter Master Channel so this isn't a successful work around for everyone:
fluttercandies/extended_text_field#80 (comment)

Would be nice if TextOverflow had "ellipsisStart", "ellipsisMiddle", and "ellipsisEnd" and would just be passed to Text.overflow

Text(
  'Hello World'
  overflow: TextOverflow.ellipsisStart
)

@jowenn
Copy link

jowenn commented May 21, 2021

I think this should be a standard feature, not needing 3rdparty packages.

@xster xster added the customer: google Various Google teams label Sep 28, 2021
@Ltei

This comment was marked as duplicate.

@loic-hamdi

This comment was marked as duplicate.

@kaustav07

This comment was marked as duplicate.

@booooohdan

This comment was marked as duplicate.

@Vrajs16
Copy link

Vrajs16 commented Mar 21, 2022

@AlexV525 AlexV525 added the P2 Important issues not at the top of the work list label Jul 26, 2022
@Max-Job

This comment was marked as duplicate.

@hrxiang

This comment was marked as duplicate.

@z-chu

This comment was marked as duplicate.

@felixriehm

This comment was marked as duplicate.

@flutter-triage-bot flutter-triage-bot bot added team-framework Owned by Framework team triaged-framework Triaged by Framework team labels Jul 8, 2023
@FrankyLee-dev

This comment was marked as duplicate.

@maximkuznetsovwork
Copy link

maximkuznetsovwork commented Jan 30, 2024

Hello guys! You can use Text.rich and WidgetSpan with Text inside it. Then wrap Text.rich and Text both with Transform.flip with flipX: true. It works and you don't need 3rd party libraries

image image image

@ana-pat

This comment was marked as duplicate.

@vuleanh

This comment was marked as duplicate.

@anadreau

This comment was marked as spam.

@LongCatIsLooong LongCatIsLooong self-assigned this May 22, 2024
@LongCatIsLooong
Copy link
Contributor

LongCatIsLooong commented May 22, 2024

The HTML renderer for the web platform is unlikely to be able to support this feature (there does not seem to be a CSS equivalent).

@LongCatIsLooong LongCatIsLooong added P1 High-priority issues at the top of the work list and removed P2 Important issues not at the top of the work list labels Jun 11, 2024
@LongCatIsLooong
Copy link
Contributor

LongCatIsLooong commented Jul 9, 2024

Determining the ellipsis style

SkParagraph currently does iterative shaping to determine the style of the text style of the ellipsis.

Interestingly it seems UIKit, even with the .byTruncatingMiddle option, has a similar behavior:

UIKit code demonstrating that the first ellipsized (logical?) character determines the style
    let colors : [UIColor] = [.red, .green, .blue, .yellow, .orange]
    let bgColors : [UIColor] = [.white, .lightGray]
    for i in 0 ..< growingText.length {
      let font = UIFont.systemFont(
        ofSize: 20.0 + CGFloat(i),
        weight: .regular,
        width: i % 2 == 0 ? .compressed : .expanded)
      growingText.addAttribute(.font, value: font, range: NSRange(location: i, length: 1))
      growingText.addAttribute(.foregroundColor, value: colors[i % colors.count], range: NSRange(location: i, length: 1))
      growingText.addAttribute(.backgroundColor, value: bgColors[i % bgColors.count], range: NSRange(location: i, length: 1))
    }

Ellipsized text with byTruncatingHead, byTruncatingMiddle and byTruncatingTail:

image

On the other hand Pango and Android do not do that.

This would mean that the UILabel ellipsis may need to be shaped iteratively. Since UIKit doesn't seem to support custom ellipsis strings (but coretext does), I guess shaping a standalone character is usually much less expensive (or they could just ask the font engine for the x advance of U+2026, since the fonts need to be resolved even for elided characters).

Upon further inspection, TextKit2 (which uses a private coretext function `CTLineCreateTruncatedLineWithTokenHandler`) seems to make some strange ellipsizing choices in some test cases.
Full Text max width = 220 max width = 200
image image image
Each block is a character. large block font size = 100, small block font size = 20. Total width = 300 From top to bottom: .byTruncatingHead,.byTruncatingMiddle,.byTruncatingTail:
The 3rd line could have included 2 more characters?
The 3rd line could have included 3 more characters?
max width = 180 max width = 160 max width = 140
image image image
max width = 120 max width = 100 max width = 80
image image image

Ellipsizing Across Bidi Boundaries

image

    let A = "A"
    let alef = "ا"
    let bidiText = ""
      + String(repeating: A, count: 1)
      + String(repeating: alef, count: 5)
      + String(repeating: A, count: 6)
    let colors : [UIColor] = [.red, .green, .blue, .yellow, .orange]
    for i in 0 ..< bidiText.length {
      bidiText.addAttribute(.foregroundColor, value: colors[i % colors.count], range: NSRange(location: i, length: 1))
    }

This is the render results of the string show above, in a special font where "A" looks like ▶ (for LTR) and "ا" looks like ◀ (for RTL).
Each glyph is 20 px wide, and each character (in logical order) is assigned a color.

Here's the result if the max width is set to 200 and lineBreakMode set to .byTruncatingMiddle

image

So

  • the 5, 6, 7th (start index = 1, in logical order) characters are elided (the 5th, 6th are RTL and the 7th is LTR),
  • the ellipsis seems to be considered RTL. This is surprising, U+2026 is a neutral character and the paragraph level should be LTR.

@flutter-triage-bot flutter-triage-bot bot added the Bot is counting down the days until it unassigns the issue label Nov 12, 2024
@flutter-triage-bot
Copy link

This issue is assigned to @LongCatIsLooong but has had no recent status updates. Please consider unassigning this issue if it is not going to be addressed in the near future. This allows people to have a clearer picture of what work is actually planned. Thanks!

@haykgalstyan
Copy link

I'm shocked this is not supported already and not being addressed.

@flutter-triage-bot flutter-triage-bot bot added Bot is counting down the days until it unassigns the issue and removed Bot is counting down the days until it unassigns the issue labels Jan 14, 2025
@flutter-triage-bot
Copy link

This issue is assigned to @LongCatIsLooong but has had no recent status updates. Please consider unassigning this issue if it is not going to be addressed in the near future. This allows people to have a clearer picture of what work is actually planned. Thanks!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
a: typography Text rendering, possibly libtxt c: new feature Nothing broken; request for a new capability c: proposal A detailed proposal for a change to Flutter customer: crowd Affects or could affect many people, though not necessarily a specific customer. customer: google Various Google teams framework flutter/packages/flutter repository. See also f: labels. Bot is counting down the days until it unassigns the issue P1 High-priority issues at the top of the work list team-framework Owned by Framework team triaged-framework Triaged by Framework team
Projects
None yet
Development

No branches or pull requests