ticket_overviews_controller.rb 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455
  1. class TicketOverviewsController < ApplicationController
  2. before_filter :authentication_check
  3. # GET /tickets
  4. def show
  5. #sleep 2
  6. # get navbar overview data
  7. if !params[:view]
  8. result = Ticket.overview(
  9. :current_user_id => current_user.id,
  10. )
  11. render :json => result
  12. return
  13. end
  14. # get real overview data
  15. if params[:array]
  16. overview = Ticket.overview(
  17. :view => params[:view],
  18. :current_user_id => current_user.id,
  19. :array => true,
  20. )
  21. tickets = []
  22. overview[:tickets].each {|ticket|
  23. data = { :id => ticket.id }
  24. tickets.push data
  25. }
  26. # return result
  27. render :json => {
  28. :overview => overview[:overview],
  29. :tickets => tickets,
  30. :tickets_count => overview[:tickets_count],
  31. }
  32. return
  33. end
  34. overview = Ticket.overview(
  35. :view => params[:view],
  36. :view_mode => params[:view_mode],
  37. :current_user_id => current_user.id,
  38. :start_page => params[:start_page],
  39. :array => true,
  40. )
  41. # get related users
  42. users = {}
  43. tickets = []
  44. overview[:tickets].each {|ticket|
  45. data = Ticket.full_data(ticket.id)
  46. tickets.push data
  47. if !users[ data['owner_id'] ]
  48. users[ data['owner_id'] ] = User.user_data_full( data['owner_id'] )
  49. end
  50. if !users[ data['customer_id'] ]
  51. users[ data['customer_id'] ] = User.user_data_full( data['customer_id'] )
  52. end
  53. if !users[ data['created_by_id'] ]
  54. users[ data['created_by_id'] ] = User.user_data_full( data['created_by_id'] )
  55. end
  56. }
  57. # get data for bulk action
  58. bulk_owners = Role.where( :name => ['Agent'] ).first.users.select(:id).where( :active => true ).uniq()
  59. bulk_owner_ids = []
  60. bulk_owners.each { |user|
  61. bulk_owner_ids.push user.id
  62. if !users[ user.id ]
  63. users[ user.id ] = User.user_data_full( user.id )
  64. end
  65. }
  66. # return result
  67. render :json => {
  68. :overview => overview[:overview],
  69. :tickets => tickets,
  70. :tickets_count => overview[:tickets_count],
  71. :users => users,
  72. :bulk => {
  73. :owner_id => {
  74. :id => bulk_owner_ids,
  75. },
  76. },
  77. }
  78. end
  79. # GET /ticket_create/1
  80. def ticket_create
  81. # get attributes
  82. (users, ticket_owner_ids, ticket_group_ids, ticket_state_ids, ticket_priority_ids) = Ticket.create_attributes(
  83. :current_user_id => current_user.id,
  84. )
  85. # split data
  86. ticket = nil
  87. articles = nil
  88. if params[:ticket_id] && params[:article_id]
  89. ticket = Ticket.find( params[:ticket_id] )
  90. # get related users
  91. users = {}
  92. if !users[ticket.owner_id]
  93. users[ticket.owner_id] = User.user_data_full(ticket.owner_id)
  94. end
  95. if !users[ticket.customer_id]
  96. users[ticket.customer_id] = User.user_data_full(ticket.customer_id)
  97. end
  98. if !users[ticket.created_by_id]
  99. users[ticket.created_by_id] = User.user_data_full(ticket.created_by_id)
  100. end
  101. owner_ids = []
  102. ticket.agent_of_group.each { |user|
  103. owner_ids.push user.id
  104. if !users[user.id]
  105. users[user.id] = User.user_data_full(user.id)
  106. end
  107. }
  108. # get related articles
  109. ticket[:article_ids] = [ params[:article_id] ]
  110. article = Ticket::Article.find( params[:article_id] )
  111. # add attachment list to article
  112. article['attachments'] = Store.list( :object => 'Ticket::Article', :o_id => article.id )
  113. # load users
  114. if !users[article.created_by_id]
  115. users[article.created_by_id] = User.user_data_full(article.created_by_id)
  116. end
  117. end
  118. # return result
  119. render :json => {
  120. :ticket => ticket,
  121. :articles => [ article ],
  122. :users => users,
  123. :edit_form => {
  124. :owner_id => {
  125. :id => ticket_owner_ids
  126. },
  127. :group_id => {
  128. :id => ticket_group_ids
  129. },
  130. :ticket_state_id => {
  131. :id => ticket_state_ids
  132. },
  133. :ticket_priority_id => {
  134. :id => ticket_priority_ids
  135. }
  136. }
  137. }
  138. end
  139. # GET /ticket_full/1
  140. def ticket_full
  141. ticket = Ticket.find(params[:id])
  142. # get related users
  143. users = {}
  144. if !users[ticket.owner_id]
  145. users[ticket.owner_id] = User.user_data_full(ticket.owner_id)
  146. end
  147. if !users[ticket.customer_id]
  148. users[ticket.customer_id] = User.user_data_full(ticket.customer_id)
  149. end
  150. if !users[ticket.created_by_id]
  151. users[ticket.created_by_id] = User.user_data_full(ticket.created_by_id)
  152. end
  153. owner_ids = []
  154. ticket.agent_of_group.each { |user|
  155. owner_ids.push user.id
  156. if !users[user.id]
  157. users[user.id] = User.user_data_full(user.id)
  158. end
  159. }
  160. # get related articles
  161. ticket[:article_ids] = []
  162. articles = ticket.articles || []
  163. # get related users
  164. articles.each {|article|
  165. # load article ids
  166. ticket[:article_ids].push article.id
  167. # add attachment list to article
  168. article['attachments'] = Store.list( :object => 'Ticket::Article', :o_id => article.id )
  169. # load users
  170. if !users[article.created_by_id]
  171. users[article.created_by_id] = User.user_data_full(article.created_by_id)
  172. end
  173. }
  174. # log object as viewed
  175. log_view(ticket)
  176. # return result
  177. render :json => {
  178. :ticket => ticket,
  179. :articles => articles,
  180. :users => users,
  181. :edit_form => {
  182. :owner_id => {
  183. :id => owner_ids
  184. }
  185. }
  186. }
  187. end
  188. # POST /ticket_attachment/new
  189. def ticket_attachment_new
  190. # puts '-------'
  191. # puts params.inspect
  192. # store file
  193. # content_type = request.content_type
  194. content_type = request[:content_type]
  195. puts 'content_type: ' + content_type.inspect
  196. if !content_type || content_type == 'application/octet-stream'
  197. if MIME::Types.type_for(params[:qqfile]).first
  198. content_type = MIME::Types.type_for(params[:qqfile]).first.content_type
  199. else
  200. content_type = 'application/octet-stream'
  201. end
  202. end
  203. headers_store = {
  204. 'Content-Type' => content_type
  205. }
  206. Store.add(
  207. :object => 'UploadCache::' + params[:form] + '::' + current_user.id.to_s,
  208. :o_id => params[:form_id],
  209. :data => request.body.read,
  210. :filename => params[:qqfile],
  211. :preferences => headers_store
  212. )
  213. # return result
  214. render :json => {
  215. :success => true,
  216. }
  217. end
  218. # GET /ticket_attachment/1
  219. def ticket_attachment
  220. # permissin check
  221. # find file
  222. file = Store.find(params[:id])
  223. send_data(
  224. file.store_file.data,
  225. :filename => file.filename,
  226. :type => file.preferences['Content-Type'] || file.preferences['Mime-Type'],
  227. :disposition => 'inline'
  228. )
  229. end
  230. # GET /ticket_article_plain/1
  231. def ticket_article_plain
  232. # permissin check
  233. list = Store.list(
  234. :object => 'Ticket::Article::Mail',
  235. :o_id => params[:id],
  236. )
  237. # find file
  238. if list
  239. file = Store.find(list.first)
  240. send_data(
  241. file.store_file.data,
  242. :filename => file.filename,
  243. :type => 'message/rfc822',
  244. :disposition => 'inline'
  245. )
  246. end
  247. end
  248. # GET /ticket_customer
  249. # GET /tickets_customer
  250. def ticket_customer
  251. # get closed/open states
  252. ticket_state_list_open = Ticket::State.where(
  253. :ticket_state_type_id => Ticket::StateType.where(:name => ['new','open', 'pending remidner', 'pending action'])
  254. )
  255. ticket_state_list_closed = Ticket::State.where(
  256. :ticket_state_type_id => Ticket::StateType.where(:name => ['closed'] )
  257. )
  258. # get tickets
  259. tickets_open = Ticket.where(
  260. :customer_id => params[:customer_id],
  261. :ticket_state_id => ticket_state_list_open
  262. ).limit(15).order('created_at DESC')
  263. tickets_closed = Ticket.where(
  264. :customer_id => params[:customer_id],
  265. :ticket_state_id => ticket_state_list_closed
  266. ).limit(15).order('created_at DESC')
  267. # tickets = Ticket.where(:customer_id => user_id).limit(15).order('created_at DESC')
  268. # ticket_items = []
  269. # tickets.each do |ticket|
  270. # style = ''
  271. # ticket_state_type = ticket.ticket_state.ticket_state_type.name
  272. # if ticket_state_type == 'closed' || ticket_state_type == 'merged'
  273. # style = 'text-decoration: line-through'
  274. # end
  275. # item = {
  276. # :url => '#ticket/zoom/' + ticket.id.to_s,
  277. # :name => 'T:' + ticket.number.to_s,
  278. # :title => ticket.title,
  279. # :style => style
  280. # }
  281. # ticket_items.push item
  282. # end
  283. # if ticket_items[0]
  284. # topic = {
  285. # :title => 'Tickets',
  286. # :items => ticket_items
  287. # }
  288. # user['links'].push topic
  289. # end
  290. # return result
  291. render :json => {
  292. :tickets => {
  293. :open => tickets_open,
  294. :closed => tickets_closed
  295. }
  296. # :users => users,
  297. }
  298. end
  299. # GET /ticket_history/1
  300. def ticket_history
  301. # get ticket data
  302. ticket = Ticket.find(params[:id])
  303. # get history of ticket
  304. history = History.history_list( 'Ticket', params[:id], 'Ticket::Article' )
  305. # get related users
  306. users = {}
  307. history.each do |item|
  308. users[ item['created_by_id'] ] = User.user_data_full( item['created_by_id'] )
  309. if item['history_object'] == 'Ticket::Article'
  310. item['type'] = 'Article ' + item['type'].to_s
  311. else
  312. item['type'] = 'Ticket ' + item['type'].to_s
  313. end
  314. end
  315. # fetch meta relations
  316. history_objects = History::Object.all()
  317. history_types = History::Type.all()
  318. history_attributes = History::Attribute.all()
  319. # return result
  320. render :json => {
  321. :ticket => ticket,
  322. :users => users,
  323. :history => history,
  324. :history_objects => history_objects,
  325. :history_types => history_types,
  326. :history_attributes => history_attributes
  327. }
  328. end
  329. # GET /ticket_merge/1/1
  330. def ticket_merge
  331. # check master ticket
  332. ticket_master = Ticket.where( :number => params[:master_ticket_number] ).first
  333. if !ticket_master
  334. render :json => {
  335. :result => 'faild',
  336. :message => 'No such master ticket number!',
  337. }
  338. return
  339. end
  340. # check slave ticket
  341. ticket_slave = Ticket.where( :id => params[:slave_ticket_id] ).first
  342. if !ticket_slave
  343. render :json => {
  344. :result => 'faild',
  345. :message => 'No such slave ticket!',
  346. }
  347. return
  348. end
  349. # check diffetent ticket ids
  350. if ticket_slave.id == ticket_master.id
  351. render :json => {
  352. :result => 'faild',
  353. :message => 'Can\'t merge ticket with it self!',
  354. }
  355. return
  356. end
  357. # merge ticket
  358. success = ticket_slave.merge_to(
  359. {
  360. :ticket_id => ticket_master.id,
  361. :created_by_id => current_user.id,
  362. }
  363. )
  364. # return result
  365. render :json => {
  366. :result => 'success',
  367. :master_ticket => ticket_master.attributes,
  368. :slave_ticket => ticket_slave.attributes,
  369. }
  370. end
  371. # GET /user_search
  372. def user_search
  373. # get params
  374. query = params[:term]
  375. limit = params[:limit] || 18
  376. # do query
  377. user_all = User.find(
  378. :all,
  379. :limit => limit,
  380. :conditions => ['firstname LIKE ? or lastname LIKE ? or email LIKE ?', "%#{query}%", "%#{query}%", "%#{query}%"],
  381. :order => 'firstname'
  382. )
  383. # build result list
  384. users = []
  385. user_all.each do |user|
  386. realname = user.firstname.to_s + ' ' + user.lastname.to_s
  387. if user.email && user.email.to_s != ''
  388. realname = realname + ' <' + user.email.to_s + '>'
  389. end
  390. a = { :id => user.id, :label => realname, :value => realname }
  391. users.push a
  392. end
  393. # return result
  394. render :json => users
  395. end
  396. end