mirror of
				https://github.com/scinote-eln/scinote-web.git
				synced 2025-10-26 22:16:28 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			70 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| class RepositoryTextValue < ApplicationRecord
 | |
|   belongs_to :created_by, foreign_key: :created_by_id,
 | |
|                           class_name: 'User',
 | |
|                           inverse_of: :created_repository_text_values
 | |
|   belongs_to :last_modified_by, foreign_key: :last_modified_by_id,
 | |
|                                 class_name: 'User',
 | |
|                                 inverse_of: :modified_repository_text_values
 | |
|   has_one :repository_cell, as: :value, dependent: :destroy, touch: true
 | |
|   accepts_nested_attributes_for :repository_cell
 | |
| 
 | |
|   before_save -> { self.has_smart_annotation = data.match?(SmartAnnotations::TagToHtml::ALL_REGEX) }, if: -> { data_changed? }
 | |
| 
 | |
|   validates :repository_cell, presence: true
 | |
|   validates :data, presence: true, length: { maximum: Constants::TEXT_MAX_LENGTH }
 | |
| 
 | |
|   SORTABLE_COLUMN_NAME = 'repository_text_values.data'
 | |
| 
 | |
|   def formatted
 | |
|     data
 | |
|   end
 | |
| 
 | |
|   def self.add_filter_condition(repository_rows, join_alias, filter_element)
 | |
|     case filter_element.operator
 | |
|     when 'contains'
 | |
|       repository_rows
 | |
|         .where("#{join_alias}.data ILIKE ?", "%#{sanitize_sql_like(filter_element.parameters['text'])}%")
 | |
|     when 'doesnt_contain'
 | |
|       repository_rows
 | |
|         .where.not("#{join_alias}.data ILIKE ?", "%#{sanitize_sql_like(filter_element.parameters['text'])}%")
 | |
|     else
 | |
|       raise ArgumentError, 'Wrong operator for RepositoryTextValue!'
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   def data_different?(new_data)
 | |
|     new_data != data
 | |
|   end
 | |
| 
 | |
|   def update_data!(new_data, user, preview: false)
 | |
|     self.data = new_data
 | |
|     self.last_modified_by = user
 | |
|     preview ? validate : save!
 | |
|   end
 | |
| 
 | |
|   def snapshot!(cell_snapshot)
 | |
|     value_snapshot = dup
 | |
|     value_snapshot.assign_attributes(
 | |
|       repository_cell: cell_snapshot,
 | |
|       created_at: created_at,
 | |
|       updated_at: updated_at
 | |
|     )
 | |
|     value_snapshot.save!
 | |
|   end
 | |
| 
 | |
|   def self.new_with_payload(payload, attributes)
 | |
|     value = new(attributes)
 | |
|     value.data = payload
 | |
|     value
 | |
|   end
 | |
| 
 | |
|   def self.import_from_text(text, attributes, _options = {})
 | |
|     return nil if text.blank?
 | |
| 
 | |
|     new(attributes.merge(data: text))
 | |
|   end
 | |
| 
 | |
|   alias export_formatted formatted
 | |
| end
 |