Improve image description user experience (#10036)
* Add image descriptions to searchable post content. * Allow multi-line image descriptions. * Request image descriptions in the same query as posts when creating the search index. (see https://github.com/tootsuite/mastodon/pull/10036#discussion_r256551624)
This commit is contained in:
		
							parent
							
								
									80161f4351
								
							
						
					
					
						commit
						309043b158
					
				@ -31,7 +31,7 @@ class StatusesIndex < Chewy::Index
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  define_type ::Status.unscoped.without_reblogs do
 | 
					  define_type ::Status.unscoped.without_reblogs.includes(:media_attachments) do
 | 
				
			||||||
    crutch :mentions do |collection|
 | 
					    crutch :mentions do |collection|
 | 
				
			||||||
      data = ::Mention.where(status_id: collection.map(&:id)).pluck(:status_id, :account_id)
 | 
					      data = ::Mention.where(status_id: collection.map(&:id)).pluck(:status_id, :account_id)
 | 
				
			||||||
      data.each.with_object({}) { |(id, name), result| (result[id] ||= []).push(name) }
 | 
					      data.each.with_object({}) { |(id, name), result| (result[id] ||= []).push(name) }
 | 
				
			||||||
@ -50,7 +50,7 @@ class StatusesIndex < Chewy::Index
 | 
				
			|||||||
    root date_detection: false do
 | 
					    root date_detection: false do
 | 
				
			||||||
      field :account_id, type: 'long'
 | 
					      field :account_id, type: 'long'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      field :text, type: 'text', value: ->(status) { [status.spoiler_text, Formatter.instance.plaintext(status)].join("\n\n") } do
 | 
					      field :text, type: 'text', value: ->(status) { [status.spoiler_text, Formatter.instance.plaintext(status)].concat(status.media_attachments.map(&:description)).join("\n\n") } do
 | 
				
			||||||
        field :stemmed, type: 'text', analyzer: 'content'
 | 
					        field :stemmed, type: 'text', analyzer: 'content'
 | 
				
			||||||
      end
 | 
					      end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -108,9 +108,8 @@ class Upload extends ImmutablePureComponent {
 | 
				
			|||||||
                <label>
 | 
					                <label>
 | 
				
			||||||
                  <span style={{ display: 'none' }}>{intl.formatMessage(messages.description)}</span>
 | 
					                  <span style={{ display: 'none' }}>{intl.formatMessage(messages.description)}</span>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                  <input
 | 
					                  <textarea
 | 
				
			||||||
                    placeholder={intl.formatMessage(messages.description)}
 | 
					                    placeholder={intl.formatMessage(messages.description)}
 | 
				
			||||||
                    type='text'
 | 
					 | 
				
			||||||
                    value={description}
 | 
					                    value={description}
 | 
				
			||||||
                    maxLength={420}
 | 
					                    maxLength={420}
 | 
				
			||||||
                    onFocus={this.handleInputFocus}
 | 
					                    onFocus={this.handleInputFocus}
 | 
				
			||||||
 | 
				
			|||||||
@ -476,7 +476,7 @@
 | 
				
			|||||||
        opacity: 0;
 | 
					        opacity: 0;
 | 
				
			||||||
        transition: opacity .1s ease;
 | 
					        transition: opacity .1s ease;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        input {
 | 
					        textarea {
 | 
				
			||||||
          background: transparent;
 | 
					          background: transparent;
 | 
				
			||||||
          color: $secondary-text-color;
 | 
					          color: $secondary-text-color;
 | 
				
			||||||
          border: 0;
 | 
					          border: 0;
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user