Sha256: 79c38bd482e3e440cca662611c00b2e98c102cd707a3d66cc82c2017335e94b1

Contents?: true

Size: 1.65 KB

Versions: 2

Compression:

Stored size: 1.65 KB

Contents

def delete
  update_attributes :trash => true unless new_card?
end

def delete!
  update_attributes! :trash => true unless new_card?
end


event :pull_from_trash, :before=>:store, :on=>:create do
  if trashed_card = Card.find_by_key_and_trash(key, true)
    # a. (Rails way) tried Card.where(:key=>'wagn_bot').select(:id), but it wouldn't work.  This #select
    #    generally breaks on cards. I think our initialization process screws with something
    # b. (Wagn way) we could get card directly from fetch if we add :include_trashed (eg).
    #    likely low ROI, but would be nice to have interface to retrieve cards from trash...
    self.id = trashed_card.id
    @from_trash = true
    @new_record = false
  end
  self.trash = false
  true
end

event :validate_delete, :before=>:approve, :on=>:delete do
  if !codename.blank?
    errors.add :delete, "#{name} is is a system card. (#{codename})"
  end

  undeletable_all_rules_tags = %w{ default style layout create read update delete }
  if junction? and l=left and l.codename == 'all' and undeletable_all_rules_tags.member? right.codename
    errors.add :delete, "#{name} is an indestructible rule"
  end

  if account && Card::Act.find_by_actor_id( self.id )
    errors.add :delete, "Edits have been made with #{name}'s user account.\nDeleting this card would mess up our history."
  end
end

event :validate_delete_children, :after=>:approve, :on=>:delete do
  children.each do |child|
    child.supercard = self
    subcards[child.name]=child
    child.trash = true
    unless child.valid?
      child.errors.each do |field, message|
        errors.add field, "can't delete #{child.name}: #{message}"
      end
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
card-1.16.6 mod/01_core/set/all/trash.rb
card-1.16.5 mod/01_core/set/all/trash.rb