Class: Stupidedi::Versions::FunctionalGroups::TwoThousandOne::ElementTypes::IdentifierVal::NonEmpty

Inherits:
Stupidedi::Versions::FunctionalGroups::TwoThousandOne::ElementTypes::IdentifierVal show all
Extended by:
Forwardable, Operators::Relational, Operators::Unary, Operators::Wrappers
Includes:
Comparable
Defined in:
lib/stupidedi/versions/functional_groups/002001/element_types/identifier_val.rb

Overview

Non-empty identifier value. Shouldn’t be directly instantiated – instead, use the value constructor

Instance Attribute Summary collapse

Attributes inherited from Stupidedi::Values::SimpleElementVal

#position, #usage

Instance Method Summary collapse

Methods included from Operators::Wrappers

wrappers

Methods included from Operators::Unary

unary_operators

Methods included from Operators::Relational

relational_operators

Methods inherited from Stupidedi::Versions::FunctionalGroups::TwoThousandOne::ElementTypes::IdentifierVal

empty, #id?, #map, value

Methods inherited from Stupidedi::Values::SimpleElementVal

#allowed?, #component?, #date?, #id?, #leaf?, #numeric?, #simple?, #string?, #time?

Methods inherited from Stupidedi::Values::AbstractElementVal

#element?, #size

Methods inherited from Stupidedi::Values::AbstractVal

#blank?, #characters, #component?, #composite?, #definition, #element?, #empty?, #functional_group?, #interchange?, #invalid?, #loop?, #present?, #repeated?, #segment?, #separator?, #simple?, #size, #table?, #transaction_set?, #transmission?

Methods included from Color

ansi, #ansi

Constructor Details

#initialize(value, usage, position) ⇒ NonEmpty

Returns a new instance of NonEmpty.



263
264
265
266
# File 'lib/stupidedi/versions/functional_groups/002001/element_types/identifier_val.rb', line 263

def initialize(value, usage, position)
  @value = value
  super(usage, position)
end

Instance Attribute Details

#valueString (readonly)

Returns:



235
236
237
# File 'lib/stupidedi/versions/functional_groups/002001/element_types/identifier_val.rb', line 235

def value
  @value
end

Instance Method Details

#coerce(other) ⇒ Object



276
277
278
279
280
281
282
283
284
285
# File 'lib/stupidedi/versions/functional_groups/002001/element_types/identifier_val.rb', line 276

def coerce(other)
  # me, he = other.coerce(self)
  # me <OP> he
  if other.respond_to?(:to_str)
    return copy(:value => other.to_str), self
  else
    raise TypeError,
      "cannot coerce IdentifierVal to #{other.class}"
  end
end

#copy(changes = {}) ⇒ IdentifierVal

Returns:



269
270
271
272
273
274
# File 'lib/stupidedi/versions/functional_groups/002001/element_types/identifier_val.rb', line 269

def copy(changes = {})
  IdentifierVal.value \
    changes.fetch(:value, @value),
    changes.fetch(:usage, usage),
    changes.fetch(:position, position)
end

#inspectString

Returns:



306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
# File 'lib/stupidedi/versions/functional_groups/002001/element_types/identifier_val.rb', line 306

def inspect
  id = definition.bind do |d|
    "[#{'% 5s' % d.id}: #{d.name}]".bind do |s|
      if usage.forbidden?
        ansi.forbidden(s)
      elsif usage.required?
        ansi.required(s)
      else
        ansi.optional(s)
      end
    end
  end

  codes = definition.code_list

  if codes.try(&:internal?)
    if codes.defined_at?(@value)
      value = "#{@value}: " << ansi.dark(codes.at(@value))
    else
      value = ansi.red(@value)
    end
  else
    value = @value
  end

  ansi.element("ID.value#{id}") << "(#{value})"
end

#to_x12(truncate = true) ⇒ String

Returns:



300
301
302
303
# File 'lib/stupidedi/versions/functional_groups/002001/element_types/identifier_val.rb', line 300

def to_x12(truncate = true)
  x12 = @value.ljust(definition.min_length, " ")
  truncate ? x12.take(definition.max_length) : x12
end

#too_long?Boolean

Returns:

  • (Boolean)


291
292
293
# File 'lib/stupidedi/versions/functional_groups/002001/element_types/identifier_val.rb', line 291

def too_long?
  @value.length > definition.max_length
end

#too_short?Boolean

Returns:

  • (Boolean)


295
296
297
# File 'lib/stupidedi/versions/functional_groups/002001/element_types/identifier_val.rb', line 295

def too_short?
  @value.length < definition.min_length
end

#valid?Boolean

Returns:

  • (Boolean)


287
288
289
# File 'lib/stupidedi/versions/functional_groups/002001/element_types/identifier_val.rb', line 287

def valid?
  true
end