mirror of
https://github.com/aasm/aasm
synced 2023-03-27 23:22:41 -04:00
no need for ReadState anymore
This commit is contained in:
parent
3a331e89ca
commit
044e84b181
6 changed files with 38 additions and 50 deletions
|
@ -18,7 +18,7 @@ module AASM
|
|||
private
|
||||
|
||||
def require_files_for(persistence)
|
||||
['base', 'read_state', "#{persistence}_persistence"].each do |file_name|
|
||||
['base', "#{persistence}_persistence"].each do |file_name|
|
||||
require File.join(File.dirname(__FILE__), 'persistence', file_name)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -7,7 +7,6 @@ module AASM
|
|||
# * includes InstanceMethods
|
||||
#
|
||||
# Unless the corresponding methods are already defined, it includes
|
||||
# * ReadState
|
||||
# * WriteState
|
||||
# * WriteStateWithoutPersistence
|
||||
#
|
||||
|
@ -32,10 +31,10 @@ module AASM
|
|||
# end
|
||||
#
|
||||
def self.included(base)
|
||||
base.send(:include, AASM::Persistence::Base)
|
||||
base.extend AASM::Persistence::Base::ClassMethods
|
||||
base.extend AASM::Persistence::ActiveRecordPersistence::ClassMethods
|
||||
base.send(:include, AASM::Persistence::ActiveRecordPersistence::InstanceMethods)
|
||||
base.send(:include, AASM::Persistence::ReadState)
|
||||
base.send(:include, AASM::Persistence::ActiveRecordPersistence::WriteState) unless base.method_defined?(:aasm_write_state)
|
||||
base.send(:include, AASM::Persistence::ActiveRecordPersistence::WriteStateWithoutPersistence) unless base.method_defined?(:aasm_write_state_without_persistence)
|
||||
|
||||
|
|
|
@ -2,6 +2,40 @@ module AASM
|
|||
module Persistence
|
||||
module Base
|
||||
|
||||
# Returns the value of the aasm_column - called from <tt>aasm.current_state</tt>
|
||||
#
|
||||
# If it's a new record, and the aasm state column is blank it returns the initial state
|
||||
# (example provided here for ActiveRecord, but it's true for Mongoid as well):
|
||||
#
|
||||
# class Foo < ActiveRecord::Base
|
||||
# include AASM
|
||||
# aasm :column => :status do
|
||||
# state :opened
|
||||
# state :closed
|
||||
# end
|
||||
# end
|
||||
#
|
||||
# foo = Foo.new
|
||||
# foo.current_state # => :opened
|
||||
# foo.close
|
||||
# foo.current_state # => :closed
|
||||
#
|
||||
# foo = Foo.find(1)
|
||||
# foo.current_state # => :opened
|
||||
# foo.aasm_state = nil
|
||||
# foo.current_state # => nil
|
||||
#
|
||||
# NOTE: intended to be called from an event
|
||||
#
|
||||
# This allows for nil aasm states - be sure to add validation to your model
|
||||
def aasm_read_state
|
||||
if new_record?
|
||||
send(self.class.aasm_column).blank? ? aasm.determine_state_name(self.class.aasm_initial_state) : send(self.class.aasm_column).to_sym
|
||||
else
|
||||
send(self.class.aasm_column).nil? ? nil : send(self.class.aasm_column).to_sym
|
||||
end
|
||||
end
|
||||
|
||||
module ClassMethods
|
||||
# Maps to the aasm_column in the database. Defaults to "aasm_state". You can write
|
||||
# (example provided here for ActiveRecord, but it's true for Mongoid as well):
|
||||
|
@ -39,7 +73,7 @@ module AASM
|
|||
# @aasm_column
|
||||
AASM::StateMachine[self].config.column
|
||||
end
|
||||
end
|
||||
end # ClassMethods
|
||||
|
||||
end # Base
|
||||
end # Persistence
|
||||
|
|
|
@ -7,7 +7,6 @@ module AASM
|
|||
# * includes InstanceMethods
|
||||
#
|
||||
# Unless the corresponding methods are already defined, it includes
|
||||
# * ReadState
|
||||
# * WriteState
|
||||
# * WriteStateWithoutPersistence
|
||||
#
|
||||
|
@ -34,10 +33,10 @@ module AASM
|
|||
# end
|
||||
#
|
||||
def self.included(base)
|
||||
base.send(:include, AASM::Persistence::Base)
|
||||
base.extend AASM::Persistence::Base::ClassMethods
|
||||
base.extend AASM::Persistence::MongoidPersistence::ClassMethods
|
||||
base.send(:include, AASM::Persistence::MongoidPersistence::InstanceMethods)
|
||||
base.send(:include, AASM::Persistence::ReadState)
|
||||
base.send(:include, AASM::Persistence::MongoidPersistence::WriteState) unless base.method_defined?(:aasm_write_state)
|
||||
base.send(:include, AASM::Persistence::MongoidPersistence::WriteStateWithoutPersistence) unless base.method_defined?(:aasm_write_state_without_persistence)
|
||||
|
||||
|
|
|
@ -1,41 +0,0 @@
|
|||
module AASM
|
||||
module Persistence
|
||||
module ReadState
|
||||
|
||||
# Returns the value of the aasm_column - called from <tt>aasm.current_state</tt>
|
||||
#
|
||||
# If it's a new record, and the aasm state column is blank it returns the initial state
|
||||
# (example provided here for ActiveRecord, but it's true for Mongoid as well):
|
||||
#
|
||||
# class Foo < ActiveRecord::Base
|
||||
# include AASM
|
||||
# aasm :column => :status do
|
||||
# state :opened
|
||||
# state :closed
|
||||
# end
|
||||
# end
|
||||
#
|
||||
# foo = Foo.new
|
||||
# foo.current_state # => :opened
|
||||
# foo.close
|
||||
# foo.current_state # => :closed
|
||||
#
|
||||
# foo = Foo.find(1)
|
||||
# foo.current_state # => :opened
|
||||
# foo.aasm_state = nil
|
||||
# foo.current_state # => nil
|
||||
#
|
||||
# NOTE: intended to be called from an event
|
||||
#
|
||||
# This allows for nil aasm states - be sure to add validation to your model
|
||||
def aasm_read_state
|
||||
if new_record?
|
||||
send(self.class.aasm_column).blank? ? aasm.determine_state_name(self.class.aasm_initial_state) : send(self.class.aasm_column).to_sym
|
||||
else
|
||||
send(self.class.aasm_column).nil? ? nil : send(self.class.aasm_column).to_sym
|
||||
end
|
||||
end
|
||||
|
||||
end # ReadState
|
||||
end # Persistence
|
||||
end # AASM
|
|
@ -18,7 +18,6 @@ describe "class methods for classes without own read or write state" do
|
|||
let(:klass) {Gate}
|
||||
it_should_behave_like "aasm model"
|
||||
it "should include all persistence mixins" do
|
||||
klass.included_modules.should be_include(AASM::Persistence::ReadState)
|
||||
klass.included_modules.should be_include(AASM::Persistence::ActiveRecordPersistence::WriteState)
|
||||
klass.included_modules.should be_include(AASM::Persistence::ActiveRecordPersistence::WriteStateWithoutPersistence)
|
||||
end
|
||||
|
@ -28,7 +27,6 @@ describe "class methods for classes with own write state" do
|
|||
let(:klass) {Writer}
|
||||
it_should_behave_like "aasm model"
|
||||
it "should include include all persistence mixins but write state" do
|
||||
klass.included_modules.should be_include(AASM::Persistence::ReadState)
|
||||
klass.included_modules.should_not be_include(AASM::Persistence::ActiveRecordPersistence::WriteState)
|
||||
klass.included_modules.should be_include(AASM::Persistence::ActiveRecordPersistence::WriteStateWithoutPersistence)
|
||||
end
|
||||
|
@ -38,7 +36,6 @@ describe "class methods for classes without persistence" do
|
|||
let(:klass) {Transient}
|
||||
it_should_behave_like "aasm model"
|
||||
it "should include all mixins but persistence" do
|
||||
klass.included_modules.should be_include(AASM::Persistence::ReadState)
|
||||
klass.included_modules.should be_include(AASM::Persistence::ActiveRecordPersistence::WriteState)
|
||||
klass.included_modules.should_not be_include(AASM::Persistence::ActiveRecordPersistence::WriteStateWithoutPersistence)
|
||||
end
|
||||
|
|
Loading…
Add table
Reference in a new issue