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 |