forked from martin-denizet/redmine_glossary
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathinit.rb
95 lines (86 loc) · 3.08 KB
/
init.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
require 'redmine'
require 'cgi'
require 'glossary_asset_tag_helper_patch'
require 'term_link_helper'
require 'csv'
RG_CSV = CSV
ActionView::Base.class_eval do
include ActionView::Helpers::TermLinkHelper
end
Redmine::Plugin.register :redmine_glossary do
name 'Redmine Glossary Plugin'
author 'M. Yoshida'
description "This is a Redmine plugin to create
a glossary which is is a list of terms in a project"
version '0.9.3'
requires_redmine version_or_higher: '3.0.0'
author_url 'http://yohshiy.blog.fc2.com/'
url 'http://www.r-labs.org/projects/rp-glossary/wiki/GlossaryEn'
settings default: {
hide_item_term_en: false,
hide_item_codename: false,
hide_item_datatype: false,
hide_item_rubi: false,
hide_item_abbr_whole: false
}, partial: 'settings/glossary_settings'
project_module :glossary do
permission(:view_terms, glossary: %i[index index_clear show show_all])
permission(:manage_terms,
{ glossary: %i[new edit destroy preview
import_csv import_csv_exec move_all] },
require: :member)
permission(:manage_term_categories,
{ glossary: %i[add_term_category move_all],
term_categories: %i[index change_order edit destroy] },
require: :member)
end
menu(:project_menu, :glossary,
{ controller: 'glossary', action: 'index' },
caption: :glossary_title, param: :project_id)
end
Redmine::WikiFormatting::Macros.register do
desc 'Glossary term link by ID'
macro :termno do |obj, args|
raise I18n.t(:error_termno_macro_arg) if args.size != 1
tid = args[0].strip
term = Term.find_by_id(tid.to_i)
raise format(I18n.t(:error_term_not_found_id), tid) unless term
term_link(term)
end
end
Redmine::WikiFormatting::Macros.register do
desc 'Glossary term link'
macro :term do |obj, args|
sargs = args.map { |arg| CGI.unescapeHTML(arg.strip) }
term = nil
case sargs.size
when 1
proj = nil
if obj
# In case page has content (like WikiContent, Issue
# In this case we can get project refer obj.project
proj = obj.respond_to?(:project) ? obj.project : nil
# In case pages does not have its own contents
elsif params[:controller] == 'projects' && params[:action] == 'show'
# project overview
proj = Project.find_by_identifier(params[:id])
elsif params.key?(:project_id)
# glossary index or other
proj = Project.find_by_identifier(params[:project_id])
else
# In case cannot specify project (like redmine home, mypage
proj = nil
end
term = Term.find_for_macro(sargs[0], proj, true) if proj
when 2
proj = Project.find_by_identifier(sargs[1])
raise format(I18n.t(:error_project_not_found), sargs[1]) unless proj
term = Term.find_for_macro(sargs[0], proj)
else
raise I18n.t(:error_term_macro_arg)
end
return term unless proj # prevent raising error and render raw text
term ? term_link(term) : term_link_new(sargs[0], proj)
end
end
Redmine::Search.register :terms