mirror of
				https://github.com/scinote-eln/scinote-web.git
				synced 2025-11-01 00:56:05 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			78 lines
		
	
	
	
		
			3.1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
	
		
			3.1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| class RepositoryDateValue < RepositoryDateTimeValueBase
 | |
|   include RepositoryValueWithReminders
 | |
| 
 | |
|   self.skip_time_zone_conversion_for_attributes = [:data]
 | |
| 
 | |
|   before_save -> { self.data = data.to_date }, if: :data_changed?
 | |
| 
 | |
|   def data_different?(new_data)
 | |
|     Date.parse(new_data).to_date != data.to_date
 | |
|   end
 | |
| 
 | |
|   def formatted
 | |
|     super(:full_date)
 | |
|   end
 | |
| 
 | |
|   def self.add_filter_condition(repository_rows, join_alias, filter_element)
 | |
|     parameters = filter_element.parameters
 | |
|     case filter_element.operator
 | |
|     when 'today'
 | |
|       repository_rows.where("#{join_alias}.data::date = ?", Time.zone.now.to_date)
 | |
|     when 'yesterday'
 | |
|       repository_rows.where("#{join_alias}.data::date = ?", Time.zone.now.to_date - 1.day)
 | |
|     when 'last_week'
 | |
|       repository_rows.where("#{join_alias}.data::date >= ? AND #{join_alias}.data::date < ?",
 | |
|                             Time.zone.now.beginning_of_week.to_date - 1.week, Time.zone.now.beginning_of_week.to_date)
 | |
|     when 'this_month'
 | |
|       repository_rows.where("#{join_alias}.data::date >= ? AND #{join_alias}.data::date <= ?",
 | |
|                             Time.zone.now.beginning_of_month.to_date, Time.zone.now.end_of_month.to_date)
 | |
|     when 'last_year'
 | |
|       repository_rows.where("#{join_alias}.data::date >= ? AND #{join_alias}.data::date < ?",
 | |
|                             Time.zone.now.beginning_of_year.to_date - 1.year, Time.zone.now.beginning_of_year.to_date)
 | |
|     when 'this_year'
 | |
|       repository_rows.where("#{join_alias}.data::date >= ? AND #{join_alias}.data::date <= ?",
 | |
|                             Time.zone.now.beginning_of_year.to_date, Time.zone.now.end_of_year.to_date)
 | |
|     when 'equal_to'
 | |
|       repository_rows.where("#{join_alias}.data::date = ?", Date.parse(parameters['date']))
 | |
|     when 'unequal_to'
 | |
|       repository_rows.where.not("#{join_alias}.data::date = ?", Date.parse(parameters['date']))
 | |
|     when 'greater_than_or_equal_to'
 | |
|       repository_rows.where("#{join_alias}.data::date >= ?", Date.parse(parameters['date']))
 | |
|     when 'less_than'
 | |
|       repository_rows.where("#{join_alias}.data::date < ?", Date.parse(parameters['date']))
 | |
|     when 'between'
 | |
|       repository_rows.where("#{join_alias}.data::date > ? AND #{join_alias}.data::date < ?",
 | |
|                             Date.parse(parameters['start_date']), Date.parse(parameters['end_date']))
 | |
|     else
 | |
|       raise ArgumentError, 'Wrong operator for RepositoryDateValue!'
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   def self.new_with_payload(payload, attributes)
 | |
|     value = new(attributes)
 | |
|     value.data = Date.parse(payload)
 | |
|     value
 | |
|   end
 | |
| 
 | |
|   def update_data!(new_data, user, preview: false)
 | |
|     self.data = if new_data.is_a?(String)
 | |
|                   Date.parse(new_data)
 | |
|                 else
 | |
|                   new_data.to_time.utc
 | |
|                 end
 | |
| 
 | |
|     self.last_modified_by = user
 | |
|     preview ? validate : save!
 | |
|   end
 | |
| 
 | |
|   def self.import_from_text(text, attributes, options = {})
 | |
|     date_format = (options.dig(:user, :settings, :date_format) || Constants::DEFAULT_DATE_FORMAT).gsub(/%-/, '%')
 | |
|     new(attributes.merge(data: DateTime.strptime(text, date_format)))
 | |
|   rescue ArgumentError
 | |
|     nil
 | |
|   end
 | |
| 
 | |
|   alias export_formatted formatted
 | |
| end
 |