From f2a380f7f38c06f418b347e7f59a0b68084be8f3 Mon Sep 17 00:00:00 2001 From: bohung Date: Tue, 23 Mar 2021 16:33:56 +0800 Subject: [PATCH] Add file link to index page. Upload template. --- app/controllers/faqs_controller.rb | 11 ++++++++-- faq.gemspec | 13 +++++++++++- modules/faq/_faq_widget1.html.erb | 15 ++++++++++++++ modules/faq/faq_index1.html.erb | 16 +++++++++++++++ modules/faq/faq_index2.html.erb | 31 +++++++++++++++++++++++++++++ modules/faq/info.json | 30 ++++++++++++++++++++++++++++ modules/faq/show.html.erb | 20 +++++++++++++++++++ modules/faq/thumbs/thumb.png | Bin 0 -> 4075 bytes 8 files changed, 133 insertions(+), 3 deletions(-) create mode 100644 modules/faq/_faq_widget1.html.erb create mode 100644 modules/faq/faq_index1.html.erb create mode 100644 modules/faq/faq_index2.html.erb create mode 100644 modules/faq/info.json create mode 100644 modules/faq/show.html.erb create mode 100644 modules/faq/thumbs/thumb.png diff --git a/app/controllers/faqs_controller.rb b/app/controllers/faqs_controller.rb index 895e39d..2b48ae2 100644 --- a/app/controllers/faqs_controller.rb +++ b/app/controllers/faqs_controller.rb @@ -1,18 +1,25 @@ class FaqsController < ApplicationController def index faqs = Qa.can_display.order_by(:order_position => "asc").filter_by_categories - f = faqs.collect do |qa| + f = faqs.collect do |qa| statuses = qa.statuses_with_classname.collect do |status| { "status" => status["name"], "status-class" => "status-#{status['classname']}" } end + qa_files = qa.qa_files.map do |qa_file| + { + "file_url" => qa_file.file.url, + "file_title" => qa_file.title.blank? ? File.basename(qa_file["file"]) + } + end { "link_to_show" => OrbitHelper.url_to_show(qa.to_param), "question" => qa.title, "answer" => qa.answer, - "statuses" => statuses + "statuses" => statuses, + "qa_files" => qa_files } end { diff --git a/faq.gemspec b/faq.gemspec index 4162312..795c845 100644 --- a/faq.gemspec +++ b/faq.gemspec @@ -2,7 +2,18 @@ $:.push File.expand_path("../lib", __FILE__) # Maintain your gem's version: require "faq/version" - +app_path = File.expand_path(__dir__) +all_template = Dir.glob(template_path+'/*/') +all_template.each do |folder| + if !folder.include?('mobile') + begin + puts "updating faq index page" + Bundler.with_clean_env{%x[cp -f #{app_path}/modules/faq/faq_index2.html.erb #{folder}modules/faq/faq_index2.html.erb]} + rescue + puts "There has some error when updating faq index page." + end + end +end # Describe your gem and declare its dependencies: Gem::Specification.new do |s| s.name = "faq" diff --git a/modules/faq/_faq_widget1.html.erb b/modules/faq/_faq_widget1.html.erb new file mode 100644 index 0000000..357ac03 --- /dev/null +++ b/modules/faq/_faq_widget1.html.erb @@ -0,0 +1,15 @@ +
+

+ {{widget-title}} +

+ +

+ <%= (I18n.locale.to_s =="zh_tw") ? "更多資訊" : "More" %>

+
\ No newline at end of file diff --git a/modules/faq/faq_index1.html.erb b/modules/faq/faq_index1.html.erb new file mode 100644 index 0000000..63b7fad --- /dev/null +++ b/modules/faq/faq_index1.html.erb @@ -0,0 +1,16 @@ +
+

+ {{page-title}} +

+ +
+{{pagination_goes_here}} \ No newline at end of file diff --git a/modules/faq/faq_index2.html.erb b/modules/faq/faq_index2.html.erb new file mode 100644 index 0000000..8db071d --- /dev/null +++ b/modules/faq/faq_index2.html.erb @@ -0,0 +1,31 @@ +
+

+ {{page-title}} +

+ +
+{{pagination_goes_here}} + + \ No newline at end of file diff --git a/modules/faq/info.json b/modules/faq/info.json new file mode 100644 index 0000000..5cefb92 --- /dev/null +++ b/modules/faq/info.json @@ -0,0 +1,30 @@ +{ + "frontend": [ + { + "filename" : "faq_index1", + "name" : { + "zh_tw" : "1. 列表 ( 模組標題, 問題 )", + "en" : "1. Thumbnail ( widget-title, question )" + }, + "thumbnail" : "thumb.png" + }, + { + "filename" : "faq_index2", + "name" : { + "zh_tw" : "2. 手風琴列表 ( 模組標題, 問題 )", + "en" : "2. Accordion list ( widget-title, question )" + }, + "thumbnail" : "thumb.png" + } + ], + "widgets" : [ + { + "filename" : "faq_widget1", + "name" : { + "zh_tw" : "1. 列表 ( 模組標題, 問題 )", + "en" : "1. List (widget-title, question)" + }, + "thumbnail" : "thumb.png" + } + ] +} \ No newline at end of file diff --git a/modules/faq/show.html.erb b/modules/faq/show.html.erb new file mode 100644 index 0000000..e003463 --- /dev/null +++ b/modules/faq/show.html.erb @@ -0,0 +1,20 @@ +
+
+

{{question}}

+
+ + + {{tag}} + +
+

{{answer}}

+
+
+ {{file_title}}
+
+
+ {{link_title}}
+
+
+ +{{link_to_edit}} \ No newline at end of file diff --git a/modules/faq/thumbs/thumb.png b/modules/faq/thumbs/thumb.png new file mode 100644 index 0000000000000000000000000000000000000000..266af5606742714c262a949cd58aedc2b84b1959 GIT binary patch literal 4075 zcmcgvYdBPE`=8Q@or=MZk}-~jIXD}qFebzhVvsZ#jA2HMW=0OFFbKQkR5@2;7{)1- z&=wM+oMYofvU8{uIS&7&UHkuj*w_2v{qU~qTI;!=weH`2-_Lz|o)v3@JtZh0Apin_ z1kKIRw!l~h+!g!w0MC|jUMDb!Q%!MHJBk;Th7Tlwj65ms1cm?>ZoCb zunI6C_z=xP0tt2@SbL8Ul825b)X)H;M@Iny{0US%gzoQ04nooOq2J}A0DAj1918i) zLM7=#|1t_^Wdkvx1QH+`FocQ+LK6wmREHte5jyHR$`Dlq5&=i5!Vy|3NCZkl3xz;J zeq2yMTcD>G$`+0Jp$nMlLw%^!02CZfqtReAH5et(8;;b`(SajW;i{@C0EbEtgG|NK zRmedyKP8|EK^}p`04k9}hHOj3yHkRx`cS~qzn0)1U}g2UU~4vB3<+^0l07N3pzZMdwOTYGka&sUi3z0mL%#bLMf?Z- z>ZS-JMhk;Ms+p<-HXx1FOpGw9+S;btnx?86+SLrFqmAt8Lvxw>O#9Ok(U(6adi=}!UB|h@GFIv~ z3by;zyIaw_j2w*cMtljDe@vCYYBBN{3B_}Vjo?=y5{HRi5Qzi{pS+umos~BYBNJa& zkB#!~P<#uqTbUmXSksK04_O}zQA=O@9o_oaC^d(oz7rtA`(Fz|ZJl&3e@9oBUHof} zii!$-7EjmN-Q6)UF+u6`U4kzeZoO$!*c@J5RNonGEUj;m*6pneu6?<%aM4#VPAhUf8>TQU zggnVU*>r`u;}8-A-Gko$zozhV-1BvXNA*K07ecJnTNzBq!E9)tfjr4yJM48svB1DR(~qCqDFK6W{c3 zH6;U@u$qM5KnN;IP3F7D9z3f3I$hbkK$rIMoRCAwHLHipoCjs(ktYRPYby(rqTtfW z7fFr>j_DmvnAA>kT~$YLGg+S9*wr7Xw)3Wu%pe!sRi1%Rt_BUV0-C(c?B3zSEr zhH7b)e3<)El-#ka)_#IVH0^z&`U1{dmX%seHb(vOMs!!~hq<>EFU{{XL5-qiu9m3X zFi*!wq?oQAXfH&aIseu9xKWe7vpau}vc;d8={1&3PO#V}#$-#v`?2zx+$FnvMUGs| zhQY zv|2uUKg)>djjunlqw$VPb5YP@ElI^eek&T)dwhI1&|~8+I@^icFhGv8YH{sS`ceUPyi9m3ekAZ*W@Ati|`yP&xel^fU=*AW>a4 zZd+$%EfR$e`To`2gg9oV&u7IB z#kt*zr*$^sOlv~URCa1ng@WEaP4^*orb@Z^)1CXE(e8Gsbz+utIg27K!o$f7J@3wY zv7@|OQj)MC7FL>e`PN|K+=^ZIcmS!ofLH8wBz(!GNSAiWMlF@>x3BuHDEoOS8&z6< zpPc=oigpP$V+ES6>G{z?!vor#COgNcSD`y-ofGsk~b~sChbDiXtak z(l;uY@`kK%IhUv~48$w>qUehm1rA^4`F_RsUs-8Yp&tj!JWP)&B_~~D){0ovg8BV@ z7M9oRPUqk&q@dpz$#hv&FcYhKM542fki29$&)6rmJ0~Cz?l)Q2cB>GaGDZt=+bis? zXqNo~cTbhFQzAAtbD3}Ng3pPDmj+L>BpqG_hS|y_=(8HvpJnz&E=LZt`J`AK&|?`r zox)c%&@*rB8F{&HH~K$^)NzW|gdTzo`(~a^TxZ<6o4=77#<$TLhr7L+<6&`wk)Svp zD}vr1rqJ~~ue|>JvtoHRlP(&Y@75|OAl21J3K`wo5IEHq_tN$4Dxr6GKR3CF*BIZH z`ut1YTvC9_eWpp|>Ym~BPC)9;e2iU$tybvJ<->-vV?vcch8R{jw$sK{7C5ty zf`oNblLmwJ>JQxZqE|Gr#EY&C5~uB*i`%3gY8Ck3y>}_P`#I73Lhw$I5Ff-Hgx=3Q z3{dYn3;&2)UHv-U*2A(^k}?eU+o-!VKh*XzS>ZBvxxd&YWxItZ9@V*8erUm>vXwW{ z98VbYAF57n z524D!g-bbHbpCSq#jQ;qX47-ZZs1M9zsB&QOx(`Vy34f5icu@Y@{(_1x@Pt~k$_si zvHH3%z#i06u(POF0od>&Oj;?UPl<83yztEpM$dH0(r7isjR5Qn?aDb>va)`P)d%p3 z`ax%V%{^B|J2l%YXZe)wH6%{Ar@^bFau(K?KaD9R9n*JCJviki+4;?AwxZ2rwe+d@ zcyQxdsXEV0 z+UkxzW!Q8li3R$euYdX9dw%Fdp*GY zog?xFXZ#%Ww<{`H5~T&!%?l3tnu{@+T64SD>Qmv2=*NqL{156qSS@P5RC;%1JxuaT zsPZ4KYB>a;##o$Eil@f?iR-EDs4LZ1oKm~uUrm?=@D4|HbUQnFtoA?hXlJ}PP?QWR zTeQ`azZ6#abhJC2>l0qYbMtmOvwCaPvE$39-rp`wN=HxBhpv`O?}1||BTG*852Fdi zf=bq!Y)hxw^KZ}{@?OYaIJ4|?Z86-WfT&Z+h7^$wIQ)6H8xhTE`Qp%t27{yI5x&}n zjGJe_fr|$Pt|~uDnhZ1N{|vMz!Q7S573!lkX`w*`M_tsqp5B&;jQ4iu-%6ZvY&d?S z(Yb!KKCBjcBfE4hloZ^UW{2r=yHy0PzyN)UnCjQ^&}bh?xwb$$BT+V%+b{b zq?WOa<=b6)e-`d$?21O2jFEohz$tKYMmUzXr zv!G#9d=mkj!$T|>;o(^`Q6(9fne#dcS*H7Knqnn^b1|?Q$