tallty_import_export 1.0.13 → 1.0.18

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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 44d0cfc1f2d9fda3dae9e82861cdb8e4cad7f7535deedc488b49e487a926b67b
4
- data.tar.gz: 31514974c3010af2809271f3f0aca99cb5e53e4bd1f00d116601ed9c70cd5711
3
+ metadata.gz: 56c0a62d935867d8420680ac232d8c156c8c653b805534ede5880bc615514706
4
+ data.tar.gz: 4efe0c40688bed288036ae32f51fe6ac7d3e28a9faddb7aa0dc05f8f901cc0c0
5
5
  SHA512:
6
- metadata.gz: 0633e13811f7c3e119f8e68e4e0defc0e77e407fc5a4049b97bc17558a4b27713d892ddb117c2105dce96cc5d21f1bf92840d6ee1191a0469385888346ae0143
7
- data.tar.gz: f34f948a034d20a48d7c921ef3da36809fefc5fda0b6fab0b7997619f0cb0a2eadb597f776a13b1c50cdc28a00768b8da057fdf9f8003d7dc98269d9595a4245
6
+ metadata.gz: b4f9e59896340ed7d75128c165d40ca8ddc4d0d584953d3953433f90bfbfe3d8cfe355cd7b4ee3182c19217a238f98c8d10b2100483b949ebc5aad1a73d31868
7
+ data.tar.gz: 0f36b4f04a2bc8759b4e835cd4dcd0e051933735322a0fefb18b5a06f438a0954d269fb9c7d3e30f436b603e94c54cfedb26e4dfcf1039d92c734874c2da838e
@@ -38,14 +38,15 @@ module TalltyImportExport
38
38
  workbook = pack.workbook
39
39
 
40
40
  if @group_by.present?
41
- @header = nil # 因为group_by的,基本上都是export_header动态变化的,因此去掉选择
42
41
  if records.is_a?(Array)
43
42
  records.group_by { |record| record.send(@group_by)}.each do |key, group_records|
43
+ next unless key.present?
44
44
  @group_key = key
45
45
  export_workbook workbook, group_records
46
46
  end
47
47
  else
48
48
  records.group(@group_by).count.keys.each do |key|
49
+ next unless key.present?
49
50
  @group_key = key
50
51
  export_workbook workbook, records.ransack("#{@group_where}" => key).result
51
52
  end
@@ -15,6 +15,7 @@ module TalltyImportExport
15
15
  # convert: 导入时候,把excel的内容转换成导入时候代码逻辑需要的内容
16
16
  # primary_key: 是否是主键
17
17
  # json: model_payload,代表存储在某一个列中
18
+ # finder: 执行代码,可以查找到相关的对象
18
19
 
19
20
  # xlsx_file 为 file path or file object or TalltyImportExport::Excel.new
20
21
  def import_xlsx xlsx_file, associations, **options
@@ -53,6 +54,7 @@ module TalltyImportExport
53
54
  options = options.with_indifferent_access
54
55
  @headers = options.delete(:headers) || import_headers
55
56
  @primary_keys = options.delete(:primary_keys) || @headers.map { |header| header[:primary_key] ? header[:key].to_sym : nil }.compact
57
+ @params = options
56
58
 
57
59
  @excel_hash = @headers.reduce({}) do |h, header|
58
60
  h[header[:key].to_sym] = header[:name]
@@ -63,6 +65,8 @@ module TalltyImportExport
63
65
  end
64
66
 
65
67
  def process_line_info line_info, associations
68
+ # 去除空行内容
69
+ return unless line_info.values.any?(&:present?)
66
70
  # 转换处理导入的数据格式
67
71
  line_info = convert_data(line_info)
68
72
 
@@ -84,6 +88,11 @@ module TalltyImportExport
84
88
  if header[:json]
85
89
  h[header[:json]] ||= {}
86
90
  h[header[:json]][k] = val
91
+ elsif header[:finder]
92
+ $SAFE = 2
93
+ eval_string = header[:finder] + '(val)'
94
+ eval_val = eval eval_string
95
+ h[k.to_sym] = eval_val
87
96
  else
88
97
  h[k.to_sym] = val
89
98
  end
@@ -1,3 +1,3 @@
1
1
  module TalltyImportExport
2
- VERSION = "1.0.13"
2
+ VERSION = "1.0.18"
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: tallty_import_export
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.0.13
4
+ version: 1.0.18
5
5
  platform: ruby
6
6
  authors:
7
7
  - liyijie
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2021-06-17 00:00:00.000000000 Z
11
+ date: 2021-06-18 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: zip-zip