[英]How can I create an Active Admin table in a custom page and insert JSON data?
我正在嘗試在Active Admin的自定義頁面中構建JSON數據表。 JSON響應嵌套得很深,因此我使用了很多循環。 就我所能獲得的/一些我嘗試過的東西:
panel "Boxes" do
boxes.each do |box| #isolate each hash item in the array
# table_for box.values do
box.each do |key, value|
if value.is_a?(Hash) #if value of a hash is a hash
columns do
value.each do |k, v| #iterate through the hash
text_node "#{k}: #{v}"
end
end
elsif value.is_a?(Array) #there's only one value that's an array & the key is "Products"
columns do
value.each do |products_array|
columns do
products_array.each do |k, v|
if v.is_a?(Hash)
v.each do |kk, vv|
if vv.is_a?(Hash)
vv.each do |kkk, vvv|
text_node "#{kkk}: #{vvv}, "
end
else
text_node "#{kk}: #{vv}, "
end
end
else
text_node "#{k}: #{v}, "
end
end
end
end
end
else
# key.each do
# column key
# end
end
end
# end
end
我正在尋找有關如何在自定義Active Admin頁面中創建表以及如何訪問/顯示深度嵌套的數組/哈希屬性的一般指導。 謝謝!
嘗試使用遞歸幫助器將JSON轉換為所需的字符串:
def nested_hash_to_s(h)
h.map { |k, v| v.is_a?(Hash) nested_hash_to_s(v) : "#{k}: #{v}" }.join(", ")
end
那么您的專欄可以簡化為:
columns do
text_node nested_hash_to_s(products_array)
end
可能還有其他問題,但這只是一個開始。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.