candidhealth 0.39.11 → 0.40.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (37) hide show
  1. checksums.yaml +4 -4
  2. data/lib/candidhealth/charge_capture/v_1/client.rb +4 -0
  3. data/lib/candidhealth/charge_capture/v_1/types/charge_capture_data.rb +16 -2
  4. data/lib/candidhealth/encounters/v_4/client.rb +35 -8
  5. data/lib/candidhealth/encounters/v_4/types/claim_supplemental_information.rb +86 -0
  6. data/lib/candidhealth/encounters/v_4/types/encounter.rb +15 -1
  7. data/lib/candidhealth/encounters/v_4/types/encounter_optional.rb +16 -2
  8. data/lib/candidhealth/encounters/v_4/types/report_transmission_code.rb +14 -0
  9. data/lib/candidhealth/encounters/v_4/types/report_type_code.rb +73 -0
  10. data/lib/candidhealth/non_insurance_payers/v_1/client.rb +4 -2
  11. data/lib/candidhealth/non_insurance_payers/v_1/types/create_non_insurance_payer_request.rb +15 -2
  12. data/lib/candidhealth/pre_encounter/appointments/v_1/client.rb +8 -4
  13. data/lib/candidhealth/pre_encounter/common/types/human_name.rb +15 -2
  14. data/lib/candidhealth/pre_encounter/coverages/v_1/client.rb +8 -4
  15. data/lib/candidhealth/pre_encounter/images/client.rb +32 -0
  16. data/lib/candidhealth/pre_encounter/images/v_1/client.rb +359 -0
  17. data/lib/candidhealth/pre_encounter/images/v_1/types/coverage_association.rb +74 -0
  18. data/lib/candidhealth/pre_encounter/images/v_1/types/coverage_image_side.rb +16 -0
  19. data/lib/candidhealth/pre_encounter/images/v_1/types/image.rb +188 -0
  20. data/lib/candidhealth/pre_encounter/images/v_1/types/image_status.rb +17 -0
  21. data/lib/candidhealth/pre_encounter/images/v_1/types/mutable_image.rb +125 -0
  22. data/lib/candidhealth/pre_encounter/images/v_1/types/patient_association.rb +75 -0
  23. data/lib/candidhealth/pre_encounter/patients/v_1/client.rb +89 -6
  24. data/lib/candidhealth/pre_encounter/patients/v_1/types/authorization.rb +11 -1
  25. data/lib/candidhealth/service_lines/v_2/types/service_line.rb +6 -4
  26. data/lib/candidhealth/service_lines/v_2/types/service_line_create.rb +6 -4
  27. data/lib/candidhealth/service_lines/v_2/types/service_line_create_standalone.rb +6 -4
  28. data/lib/candidhealth/service_lines/v_2/types/service_line_update.rb +10 -8
  29. data/lib/candidhealth/service_lines/v_2/types/test_result_type.rb +1 -0
  30. data/lib/candidhealth/write_offs/v_1/types/non_insurance_payer_write_off.rb +143 -0
  31. data/lib/candidhealth/write_offs/v_1/types/non_insurance_payer_write_off_create.rb +113 -0
  32. data/lib/candidhealth/write_offs/v_1/types/write_off.rb +13 -0
  33. data/lib/candidhealth/write_offs/v_1/types/write_off_create.rb +13 -0
  34. data/lib/candidhealth/x_12/v_1/types/rarc.rb +114 -0
  35. data/lib/requests.rb +2 -2
  36. data/lib/types_export.rb +11 -0
  37. metadata +15 -2
@@ -62,8 +62,9 @@ module CandidApiClient
62
62
  # than the rendering provider for this service line.
63
63
  # If not required by this implementation guide, do not send.
64
64
  attr_reader :ordering_provider
65
- # @return [Array<CandidApiClient::ServiceLines::V2::Types::TestResult>] Maps to MEA-02 on the 837-P. No more than 5 test results may be submitted per
66
- # service line.
65
+ # @return [Array<CandidApiClient::ServiceLines::V2::Types::TestResult>] Contains a list of test results. Test result types may map to MEA-02 on the
66
+ # 837-P (ex: Hemoglobin, Hematocrit).
67
+ # No more than 5 MEA-02 test results may be submitted per service line.
67
68
  attr_reader :test_results
68
69
  # @return [Boolean] Maps to SV1-11 on the 837-P and Box 24H on the CMS-1500.
69
70
  # If the value is true, the box will be populated with "Y". Otherwise, the box
@@ -110,8 +111,9 @@ module CandidApiClient
110
111
  # @param ordering_provider [CandidApiClient::EncounterProviders::V2::Types::OrderingProvider] Required when the service or supply was ordered by a provider who is different
111
112
  # than the rendering provider for this service line.
112
113
  # If not required by this implementation guide, do not send.
113
- # @param test_results [Array<CandidApiClient::ServiceLines::V2::Types::TestResult>] Maps to MEA-02 on the 837-P. No more than 5 test results may be submitted per
114
- # service line.
114
+ # @param test_results [Array<CandidApiClient::ServiceLines::V2::Types::TestResult>] Contains a list of test results. Test result types may map to MEA-02 on the
115
+ # 837-P (ex: Hemoglobin, Hematocrit).
116
+ # No more than 5 MEA-02 test results may be submitted per service line.
115
117
  # @param has_epsdt_indicator [Boolean] Maps to SV1-11 on the 837-P and Box 24H on the CMS-1500.
116
118
  # If the value is true, the box will be populated with "Y". Otherwise, the box
117
119
  # will not be populated.
@@ -60,10 +60,11 @@ module CandidApiClient
60
60
  attr_reader :date_of_service
61
61
  # @return [Date]
62
62
  attr_reader :end_date_of_service
63
- # @return [Array<CandidApiClient::ServiceLines::V2::Types::TestResult>] Maps to MEA-02 on the 837-P. Updating test results utilizes PUT semantics,
64
- # so the test results on the service line will be set to whatever inputs are
65
- # provided. No more than 5 test
66
- # results may be submitted per service line.
63
+ # @return [Array<CandidApiClient::ServiceLines::V2::Types::TestResult>] Contains a list of test results. Test result types may map to MEA-02 on the
64
+ # 837-P (ex: Hemoglobin, Hematocrit).
65
+ # No more than 5 MEA-02 test results may be submitted per service line.
66
+ # Updating test results utilizes PUT semantics, so the test results on the service
67
+ # line will be set to whatever inputs are provided.
67
68
  attr_reader :test_results
68
69
  # @return [Boolean] Maps to SV1-11 on the 837-P and Box 24H on the CMS-1500.
69
70
  # If the value is true, the box will be populated with "Y". Otherwise, the box
@@ -110,10 +111,11 @@ module CandidApiClient
110
111
  # @param date_of_service [Date] date_of_service must be defined on either the encounter or the service lines but
111
112
  # not both.
112
113
  # @param end_date_of_service [Date]
113
- # @param test_results [Array<CandidApiClient::ServiceLines::V2::Types::TestResult>] Maps to MEA-02 on the 837-P. Updating test results utilizes PUT semantics,
114
- # so the test results on the service line will be set to whatever inputs are
115
- # provided. No more than 5 test
116
- # results may be submitted per service line.
114
+ # @param test_results [Array<CandidApiClient::ServiceLines::V2::Types::TestResult>] Contains a list of test results. Test result types may map to MEA-02 on the
115
+ # 837-P (ex: Hemoglobin, Hematocrit).
116
+ # No more than 5 MEA-02 test results may be submitted per service line.
117
+ # Updating test results utilizes PUT semantics, so the test results on the service
118
+ # line will be set to whatever inputs are provided.
117
119
  # @param has_epsdt_indicator [Boolean] Maps to SV1-11 on the 837-P and Box 24H on the CMS-1500.
118
120
  # If the value is true, the box will be populated with "Y". Otherwise, the box
119
121
  # will not be populated.
@@ -7,6 +7,7 @@ module CandidApiClient
7
7
  class TestResultType
8
8
  HEMATOCRIT = "HEMATOCRIT"
9
9
  HEMOGLOBIN = "HEMOGLOBIN"
10
+ LDL = "LDL"
10
11
  end
11
12
  end
12
13
  end
@@ -0,0 +1,143 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "../../../non_insurance_payers/v_1/types/non_insurance_payer"
4
+ require "date"
5
+ require_relative "insurance_write_off_reason"
6
+ require "ostruct"
7
+ require "json"
8
+
9
+ module CandidApiClient
10
+ module WriteOffs
11
+ module V1
12
+ module Types
13
+ class NonInsurancePayerWriteOff
14
+ # @return [String]
15
+ attr_reader :write_off_id
16
+ # @return [CandidApiClient::NonInsurancePayers::V1::Types::NonInsurancePayer]
17
+ attr_reader :non_insurance_payer
18
+ # @return [String]
19
+ attr_reader :service_line_id
20
+ # @return [DateTime]
21
+ attr_reader :write_off_timestamp
22
+ # @return [String]
23
+ attr_reader :write_off_note
24
+ # @return [CandidApiClient::WriteOffs::V1::Types::InsuranceWriteOffReason]
25
+ attr_reader :write_off_reason
26
+ # @return [String]
27
+ attr_reader :reverts_write_off_id
28
+ # @return [String]
29
+ attr_reader :reverted_by_write_off_id
30
+ # @return [Integer]
31
+ attr_reader :amount_cents
32
+ # @return [OpenStruct] Additional properties unmapped to the current class definition
33
+ attr_reader :additional_properties
34
+ # @return [Object]
35
+ attr_reader :_field_set
36
+ protected :_field_set
37
+
38
+ OMIT = Object.new
39
+
40
+ # @param write_off_id [String]
41
+ # @param non_insurance_payer [CandidApiClient::NonInsurancePayers::V1::Types::NonInsurancePayer]
42
+ # @param service_line_id [String]
43
+ # @param write_off_timestamp [DateTime]
44
+ # @param write_off_note [String]
45
+ # @param write_off_reason [CandidApiClient::WriteOffs::V1::Types::InsuranceWriteOffReason]
46
+ # @param reverts_write_off_id [String]
47
+ # @param reverted_by_write_off_id [String]
48
+ # @param amount_cents [Integer]
49
+ # @param additional_properties [OpenStruct] Additional properties unmapped to the current class definition
50
+ # @return [CandidApiClient::WriteOffs::V1::Types::NonInsurancePayerWriteOff]
51
+ def initialize(write_off_id:, non_insurance_payer:, service_line_id:, write_off_timestamp:, write_off_reason:, amount_cents:,
52
+ write_off_note: OMIT, reverts_write_off_id: OMIT, reverted_by_write_off_id: OMIT, additional_properties: nil)
53
+ @write_off_id = write_off_id
54
+ @non_insurance_payer = non_insurance_payer
55
+ @service_line_id = service_line_id
56
+ @write_off_timestamp = write_off_timestamp
57
+ @write_off_note = write_off_note if write_off_note != OMIT
58
+ @write_off_reason = write_off_reason
59
+ @reverts_write_off_id = reverts_write_off_id if reverts_write_off_id != OMIT
60
+ @reverted_by_write_off_id = reverted_by_write_off_id if reverted_by_write_off_id != OMIT
61
+ @amount_cents = amount_cents
62
+ @additional_properties = additional_properties
63
+ @_field_set = {
64
+ "write_off_id": write_off_id,
65
+ "non_insurance_payer": non_insurance_payer,
66
+ "service_line_id": service_line_id,
67
+ "write_off_timestamp": write_off_timestamp,
68
+ "write_off_note": write_off_note,
69
+ "write_off_reason": write_off_reason,
70
+ "reverts_write_off_id": reverts_write_off_id,
71
+ "reverted_by_write_off_id": reverted_by_write_off_id,
72
+ "amount_cents": amount_cents
73
+ }.reject do |_k, v|
74
+ v == OMIT
75
+ end
76
+ end
77
+
78
+ # Deserialize a JSON object to an instance of NonInsurancePayerWriteOff
79
+ #
80
+ # @param json_object [String]
81
+ # @return [CandidApiClient::WriteOffs::V1::Types::NonInsurancePayerWriteOff]
82
+ def self.from_json(json_object:)
83
+ struct = JSON.parse(json_object, object_class: OpenStruct)
84
+ parsed_json = JSON.parse(json_object)
85
+ write_off_id = struct["write_off_id"]
86
+ if parsed_json["non_insurance_payer"].nil?
87
+ non_insurance_payer = nil
88
+ else
89
+ non_insurance_payer = parsed_json["non_insurance_payer"].to_json
90
+ non_insurance_payer = CandidApiClient::NonInsurancePayers::V1::Types::NonInsurancePayer.from_json(json_object: non_insurance_payer)
91
+ end
92
+ service_line_id = struct["service_line_id"]
93
+ write_off_timestamp = unless parsed_json["write_off_timestamp"].nil?
94
+ DateTime.parse(parsed_json["write_off_timestamp"])
95
+ end
96
+ write_off_note = struct["write_off_note"]
97
+ write_off_reason = struct["write_off_reason"]
98
+ reverts_write_off_id = struct["reverts_write_off_id"]
99
+ reverted_by_write_off_id = struct["reverted_by_write_off_id"]
100
+ amount_cents = struct["amount_cents"]
101
+ new(
102
+ write_off_id: write_off_id,
103
+ non_insurance_payer: non_insurance_payer,
104
+ service_line_id: service_line_id,
105
+ write_off_timestamp: write_off_timestamp,
106
+ write_off_note: write_off_note,
107
+ write_off_reason: write_off_reason,
108
+ reverts_write_off_id: reverts_write_off_id,
109
+ reverted_by_write_off_id: reverted_by_write_off_id,
110
+ amount_cents: amount_cents,
111
+ additional_properties: struct
112
+ )
113
+ end
114
+
115
+ # Serialize an instance of NonInsurancePayerWriteOff to a JSON object
116
+ #
117
+ # @return [String]
118
+ def to_json(*_args)
119
+ @_field_set&.to_json
120
+ end
121
+
122
+ # Leveraged for Union-type generation, validate_raw attempts to parse the given
123
+ # hash and check each fields type against the current object's property
124
+ # definitions.
125
+ #
126
+ # @param obj [Object]
127
+ # @return [Void]
128
+ def self.validate_raw(obj:)
129
+ obj.write_off_id.is_a?(String) != false || raise("Passed value for field obj.write_off_id is not the expected type, validation failed.")
130
+ CandidApiClient::NonInsurancePayers::V1::Types::NonInsurancePayer.validate_raw(obj: obj.non_insurance_payer)
131
+ obj.service_line_id.is_a?(String) != false || raise("Passed value for field obj.service_line_id is not the expected type, validation failed.")
132
+ obj.write_off_timestamp.is_a?(DateTime) != false || raise("Passed value for field obj.write_off_timestamp is not the expected type, validation failed.")
133
+ obj.write_off_note&.is_a?(String) != false || raise("Passed value for field obj.write_off_note is not the expected type, validation failed.")
134
+ obj.write_off_reason.is_a?(CandidApiClient::WriteOffs::V1::Types::InsuranceWriteOffReason) != false || raise("Passed value for field obj.write_off_reason is not the expected type, validation failed.")
135
+ obj.reverts_write_off_id&.is_a?(String) != false || raise("Passed value for field obj.reverts_write_off_id is not the expected type, validation failed.")
136
+ obj.reverted_by_write_off_id&.is_a?(String) != false || raise("Passed value for field obj.reverted_by_write_off_id is not the expected type, validation failed.")
137
+ obj.amount_cents.is_a?(Integer) != false || raise("Passed value for field obj.amount_cents is not the expected type, validation failed.")
138
+ end
139
+ end
140
+ end
141
+ end
142
+ end
143
+ end
@@ -0,0 +1,113 @@
1
+ # frozen_string_literal: true
2
+
3
+ require "date"
4
+ require_relative "insurance_write_off_reason"
5
+ require "ostruct"
6
+ require "json"
7
+
8
+ module CandidApiClient
9
+ module WriteOffs
10
+ module V1
11
+ module Types
12
+ class NonInsurancePayerWriteOffCreate
13
+ # @return [String]
14
+ attr_reader :non_insurance_payer_id
15
+ # @return [String]
16
+ attr_reader :service_line_id
17
+ # @return [DateTime]
18
+ attr_reader :write_off_timestamp
19
+ # @return [String]
20
+ attr_reader :write_off_note
21
+ # @return [CandidApiClient::WriteOffs::V1::Types::InsuranceWriteOffReason]
22
+ attr_reader :write_off_reason
23
+ # @return [Integer]
24
+ attr_reader :amount_cents
25
+ # @return [OpenStruct] Additional properties unmapped to the current class definition
26
+ attr_reader :additional_properties
27
+ # @return [Object]
28
+ attr_reader :_field_set
29
+ protected :_field_set
30
+
31
+ OMIT = Object.new
32
+
33
+ # @param non_insurance_payer_id [String]
34
+ # @param service_line_id [String]
35
+ # @param write_off_timestamp [DateTime]
36
+ # @param write_off_note [String]
37
+ # @param write_off_reason [CandidApiClient::WriteOffs::V1::Types::InsuranceWriteOffReason]
38
+ # @param amount_cents [Integer]
39
+ # @param additional_properties [OpenStruct] Additional properties unmapped to the current class definition
40
+ # @return [CandidApiClient::WriteOffs::V1::Types::NonInsurancePayerWriteOffCreate]
41
+ def initialize(non_insurance_payer_id:, service_line_id:, write_off_timestamp:, write_off_reason:,
42
+ amount_cents:, write_off_note: OMIT, additional_properties: nil)
43
+ @non_insurance_payer_id = non_insurance_payer_id
44
+ @service_line_id = service_line_id
45
+ @write_off_timestamp = write_off_timestamp
46
+ @write_off_note = write_off_note if write_off_note != OMIT
47
+ @write_off_reason = write_off_reason
48
+ @amount_cents = amount_cents
49
+ @additional_properties = additional_properties
50
+ @_field_set = {
51
+ "non_insurance_payer_id": non_insurance_payer_id,
52
+ "service_line_id": service_line_id,
53
+ "write_off_timestamp": write_off_timestamp,
54
+ "write_off_note": write_off_note,
55
+ "write_off_reason": write_off_reason,
56
+ "amount_cents": amount_cents
57
+ }.reject do |_k, v|
58
+ v == OMIT
59
+ end
60
+ end
61
+
62
+ # Deserialize a JSON object to an instance of NonInsurancePayerWriteOffCreate
63
+ #
64
+ # @param json_object [String]
65
+ # @return [CandidApiClient::WriteOffs::V1::Types::NonInsurancePayerWriteOffCreate]
66
+ def self.from_json(json_object:)
67
+ struct = JSON.parse(json_object, object_class: OpenStruct)
68
+ parsed_json = JSON.parse(json_object)
69
+ non_insurance_payer_id = struct["non_insurance_payer_id"]
70
+ service_line_id = struct["service_line_id"]
71
+ write_off_timestamp = unless parsed_json["write_off_timestamp"].nil?
72
+ DateTime.parse(parsed_json["write_off_timestamp"])
73
+ end
74
+ write_off_note = struct["write_off_note"]
75
+ write_off_reason = struct["write_off_reason"]
76
+ amount_cents = struct["amount_cents"]
77
+ new(
78
+ non_insurance_payer_id: non_insurance_payer_id,
79
+ service_line_id: service_line_id,
80
+ write_off_timestamp: write_off_timestamp,
81
+ write_off_note: write_off_note,
82
+ write_off_reason: write_off_reason,
83
+ amount_cents: amount_cents,
84
+ additional_properties: struct
85
+ )
86
+ end
87
+
88
+ # Serialize an instance of NonInsurancePayerWriteOffCreate to a JSON object
89
+ #
90
+ # @return [String]
91
+ def to_json(*_args)
92
+ @_field_set&.to_json
93
+ end
94
+
95
+ # Leveraged for Union-type generation, validate_raw attempts to parse the given
96
+ # hash and check each fields type against the current object's property
97
+ # definitions.
98
+ #
99
+ # @param obj [Object]
100
+ # @return [Void]
101
+ def self.validate_raw(obj:)
102
+ obj.non_insurance_payer_id.is_a?(String) != false || raise("Passed value for field obj.non_insurance_payer_id is not the expected type, validation failed.")
103
+ obj.service_line_id.is_a?(String) != false || raise("Passed value for field obj.service_line_id is not the expected type, validation failed.")
104
+ obj.write_off_timestamp.is_a?(DateTime) != false || raise("Passed value for field obj.write_off_timestamp is not the expected type, validation failed.")
105
+ obj.write_off_note&.is_a?(String) != false || raise("Passed value for field obj.write_off_note is not the expected type, validation failed.")
106
+ obj.write_off_reason.is_a?(CandidApiClient::WriteOffs::V1::Types::InsuranceWriteOffReason) != false || raise("Passed value for field obj.write_off_reason is not the expected type, validation failed.")
107
+ obj.amount_cents.is_a?(Integer) != false || raise("Passed value for field obj.amount_cents is not the expected type, validation failed.")
108
+ end
109
+ end
110
+ end
111
+ end
112
+ end
113
+ end
@@ -3,6 +3,7 @@
3
3
  require "json"
4
4
  require_relative "patient_write_off"
5
5
  require_relative "insurance_write_off"
6
+ require_relative "non_insurance_payer_write_off"
6
7
 
7
8
  module CandidApiClient
8
9
  module WriteOffs
@@ -36,6 +37,8 @@ module CandidApiClient
36
37
  CandidApiClient::WriteOffs::V1::Types::PatientWriteOff.from_json(json_object: json_object)
37
38
  when "insurance"
38
39
  CandidApiClient::WriteOffs::V1::Types::InsuranceWriteOff.from_json(json_object: json_object)
40
+ when "non_insurance_payer"
41
+ CandidApiClient::WriteOffs::V1::Types::NonInsurancePayerWriteOff.from_json(json_object: json_object)
39
42
  else
40
43
  CandidApiClient::WriteOffs::V1::Types::PatientWriteOff.from_json(json_object: json_object)
41
44
  end
@@ -51,6 +54,8 @@ module CandidApiClient
51
54
  { **@member.to_json, type: @discriminant }.to_json
52
55
  when "insurance"
53
56
  { **@member.to_json, type: @discriminant }.to_json
57
+ when "non_insurance_payer"
58
+ { **@member.to_json, type: @discriminant }.to_json
54
59
  else
55
60
  { "type": @discriminant, value: @member }.to_json
56
61
  end
@@ -69,6 +74,8 @@ module CandidApiClient
69
74
  CandidApiClient::WriteOffs::V1::Types::PatientWriteOff.validate_raw(obj: obj)
70
75
  when "insurance"
71
76
  CandidApiClient::WriteOffs::V1::Types::InsuranceWriteOff.validate_raw(obj: obj)
77
+ when "non_insurance_payer"
78
+ CandidApiClient::WriteOffs::V1::Types::NonInsurancePayerWriteOff.validate_raw(obj: obj)
72
79
  else
73
80
  raise("Passed value matched no type within the union, validation failed.")
74
81
  end
@@ -93,6 +100,12 @@ module CandidApiClient
93
100
  def self.insurance(member:)
94
101
  new(member: member, discriminant: "insurance")
95
102
  end
103
+
104
+ # @param member [CandidApiClient::WriteOffs::V1::Types::NonInsurancePayerWriteOff]
105
+ # @return [CandidApiClient::WriteOffs::V1::Types::WriteOff]
106
+ def self.non_insurance_payer(member:)
107
+ new(member: member, discriminant: "non_insurance_payer")
108
+ end
96
109
  end
97
110
  end
98
111
  end
@@ -3,6 +3,7 @@
3
3
  require "json"
4
4
  require_relative "patient_write_off_create"
5
5
  require_relative "insurance_write_off_create"
6
+ require_relative "non_insurance_payer_write_off_create"
6
7
 
7
8
  module CandidApiClient
8
9
  module WriteOffs
@@ -36,6 +37,8 @@ module CandidApiClient
36
37
  CandidApiClient::WriteOffs::V1::Types::PatientWriteOffCreate.from_json(json_object: json_object)
37
38
  when "insurance"
38
39
  CandidApiClient::WriteOffs::V1::Types::InsuranceWriteOffCreate.from_json(json_object: json_object)
40
+ when "non_insurance_payer"
41
+ CandidApiClient::WriteOffs::V1::Types::NonInsurancePayerWriteOffCreate.from_json(json_object: json_object)
39
42
  else
40
43
  CandidApiClient::WriteOffs::V1::Types::PatientWriteOffCreate.from_json(json_object: json_object)
41
44
  end
@@ -51,6 +54,8 @@ module CandidApiClient
51
54
  { **@member.to_json, type: @discriminant }.to_json
52
55
  when "insurance"
53
56
  { **@member.to_json, type: @discriminant }.to_json
57
+ when "non_insurance_payer"
58
+ { **@member.to_json, type: @discriminant }.to_json
54
59
  else
55
60
  { "type": @discriminant, value: @member }.to_json
56
61
  end
@@ -69,6 +74,8 @@ module CandidApiClient
69
74
  CandidApiClient::WriteOffs::V1::Types::PatientWriteOffCreate.validate_raw(obj: obj)
70
75
  when "insurance"
71
76
  CandidApiClient::WriteOffs::V1::Types::InsuranceWriteOffCreate.validate_raw(obj: obj)
77
+ when "non_insurance_payer"
78
+ CandidApiClient::WriteOffs::V1::Types::NonInsurancePayerWriteOffCreate.validate_raw(obj: obj)
72
79
  else
73
80
  raise("Passed value matched no type within the union, validation failed.")
74
81
  end
@@ -93,6 +100,12 @@ module CandidApiClient
93
100
  def self.insurance(member:)
94
101
  new(member: member, discriminant: "insurance")
95
102
  end
103
+
104
+ # @param member [CandidApiClient::WriteOffs::V1::Types::NonInsurancePayerWriteOffCreate]
105
+ # @return [CandidApiClient::WriteOffs::V1::Types::WriteOffCreate]
106
+ def self.non_insurance_payer(member:)
107
+ new(member: member, discriminant: "non_insurance_payer")
108
+ end
96
109
  end
97
110
  end
98
111
  end