Sha256: 0bf3289d8a3b68868ece3e40411e68ea34ccaae7d41d0fe3e103eb04d51b03e7
Contents?: true
Size: 1.06 KB
Versions: 2
Compression:
Stored size: 1.06 KB
Contents
module Axlsx # A self serializing collection of ranges that should be protected in # the worksheet class ProtectedRanges < SimpleTypedList attr_reader :worksheet def initialize(worksheet) raise ArgumentError, 'You must provide a worksheet' unless worksheet.is_a?(Worksheet) super ProtectedRange @worksheet = worksheet end # Adds a protected range # @param [Array|String] cells A string range reference or array of cells that will be protected def add_range(cells) sqref = if cells.is_a?(String) cells elsif cells.is_a?(SimpleTypedList) || cells.is_a?(Array) Axlsx::cell_range(cells, false) end self << ProtectedRange.new(:sqref => sqref, :name => "Range#{size}") last end # Serializes the protected ranges # @param [String] str # @return [String] def to_xml_string(str = '') return if empty? str << '<protectedRanges>' each { |range| range.to_xml_string(str) } str << '</protectedRanges>' end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
caxlsx-3.4.1 | lib/axlsx/workbook/worksheet/protected_ranges.rb |
caxlsx-3.4.0 | lib/axlsx/workbook/worksheet/protected_ranges.rb |