jinda 0.7.7.2 → 0.7.7.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +12 -1
- data/app/config/routes.rb +44 -0
- data/lib/generators/jinda/templates/README.md +3 -1
- data/lib/generators/jinda/templates/app/assets/stylesheets/application.css.scss +2 -2
- data/lib/generators/jinda/templates/app/assets/stylesheets/jinda_jqm.css.scss +32 -0
- data/lib/generators/jinda/templates/app/mailers/{application_mailer.rb → application_mailer.rb-org} +0 -0
- data/lib/generators/jinda/templates/config/mongoid.yml +3 -3
- data/lib/jinda/version.rb +1 -1
- data/test/Gemfile +2 -0
- data/test/dummy/Dockerfile +26 -0
- data/test/dummy/Gemfile +99 -0
- data/test/dummy/Gemfile.lock +515 -0
- data/test/dummy/{db/development.sqlite3 → README.md} +0 -0
- data/test/dummy/README.md.bak +24 -0
- data/test/dummy/Rakefile +1 -1
- data/test/dummy/app/assets/config/manifest.js +2 -1
- data/test/dummy/app/assets/config/manifest.js-rails +2 -0
- data/test/dummy/app/assets/javascripts/application.js +15 -0
- data/test/dummy/app/assets/stylesheets/{application.css → application.css.bak} +3 -3
- data/test/dummy/app/assets/stylesheets/application.css.scss +15 -0
- data/test/dummy/app/assets/stylesheets/jinda_jqm.css.scss +32 -0
- data/test/dummy/app/controllers/admins_controller.rb +6 -0
- data/test/dummy/app/controllers/api/v1/notes_controller.rb +81 -0
- data/test/dummy/app/controllers/application_controller.rb +39 -0
- data/test/dummy/app/controllers/application_controller.rb.bak +2 -0
- data/test/dummy/app/controllers/articles_controller.rb +110 -0
- data/test/dummy/app/controllers/comments_controller.rb +31 -0
- data/test/dummy/app/controllers/docs_controller.rb +56 -0
- data/test/dummy/app/controllers/identities_controller.rb +5 -0
- data/test/dummy/app/controllers/notes_controller.rb +84 -0
- data/test/dummy/app/controllers/password_resets.rb +28 -0
- data/test/dummy/app/controllers/password_resets_controller.rb +34 -0
- data/test/dummy/app/controllers/sessions_controller.rb +44 -0
- data/test/dummy/app/controllers/sitemap_controller.rb +12 -0
- data/test/dummy/app/controllers/users_controller.rb +35 -0
- data/test/dummy/app/helpers/admins_helper.rb +2 -0
- data/test/dummy/app/helpers/application_helper.rb +31 -0
- data/test/dummy/app/helpers/application_helper.rb.bak +2 -0
- data/test/dummy/app/helpers/articles_helper.rb +2 -0
- data/test/dummy/app/helpers/basic_helper.rb +2 -0
- data/test/dummy/app/helpers/comments_helper.rb +2 -0
- data/test/dummy/app/helpers/ctrs_helper.rb +2 -0
- data/test/dummy/app/helpers/devs_helper.rb +2 -0
- data/test/dummy/app/helpers/pictures_helper.rb +2 -0
- data/test/dummy/app/helpers/sitemap_helper.rb +2 -0
- data/test/dummy/app/helpers/users_helper.rb +2 -0
- data/test/dummy/app/jinda/index.mm +486 -0
- data/test/dummy/app/jinda/template/index.mm +366 -0
- data/test/dummy/app/jinda/template/linkview.haml +21 -0
- data/test/dummy/app/jinda/template/view.html.erb +34 -0
- data/test/dummy/app/mailers/application_mailer.rb +2 -2
- data/test/dummy/app/mailers/application_mailer.rb-org +4 -0
- data/test/dummy/app/mailers/jinda_mailer.rb +7 -0
- data/test/dummy/app/mailers/note_mailer.rb +10 -0
- data/test/dummy/app/mailers/user_mailer.rb +15 -0
- data/test/dummy/app/models/address.rb +14 -0
- data/test/dummy/app/models/article.rb +14 -0
- data/test/dummy/app/models/comment.rb +14 -0
- data/test/dummy/app/models/identity.rb +18 -0
- data/test/dummy/app/models/jinda/doc.rb +36 -0
- data/test/dummy/app/models/jinda/module.rb +11 -0
- data/test/dummy/app/models/jinda/notice.rb +14 -0
- data/test/dummy/app/models/jinda/role.rb +8 -0
- data/test/dummy/app/models/jinda/runseq.rb +24 -0
- data/test/dummy/app/models/jinda/service.rb +17 -0
- data/test/dummy/app/models/jinda/xmain.rb +38 -0
- data/test/dummy/app/models/note.rb +22 -0
- data/test/dummy/app/models/param.rb +41 -0
- data/test/dummy/app/models/person.rb +14 -0
- data/test/dummy/app/models/user.rb +66 -0
- data/test/dummy/app/views/adminbsbs/content.haml +241 -0
- data/test/dummy/app/views/admins/edit_role/edit_role.html.erb +7 -0
- data/test/dummy/app/views/admins/edit_role/select_user.html.erb +4 -0
- data/test/dummy/app/views/api/v1/note.haml +0 -0
- data/test/dummy/app/views/articles/_report.haml +35 -0
- data/test/dummy/app/views/articles/edit.haml +23 -0
- data/test/dummy/app/views/articles/edit_article/edit_article.html.erb +15 -0
- data/test/dummy/app/views/articles/edit_article/select_article.html.erb +12 -0
- data/test/dummy/app/views/articles/index.haml +5 -0
- data/test/dummy/app/views/articles/my.haml +5 -0
- data/test/dummy/app/views/articles/new_article/form_article.html.erb +16 -0
- data/test/dummy/app/views/articles/show.html.haml +58 -0
- data/test/dummy/app/views/articles/xedit_article/edit_article.html.erb +13 -0
- data/test/dummy/app/views/ctrs/vfolder1/viewfile1.html.erb +23 -0
- data/test/dummy/app/views/ctrs/vfolder1/viewfile2.html.erb +23 -0
- data/test/dummy/app/views/ctrs/vfolder2/viewfile2.html.erb +23 -0
- data/test/dummy/app/views/custom/_adsense.haml +6 -0
- data/test/dummy/app/views/docs/doc_edit/doc_edit.html.erb +21 -0
- data/test/dummy/app/views/docs/doc_edit/doc_select.html.erb +14 -0
- data/test/dummy/app/views/docs/doc_new/doc_form.html.erb +32 -0
- data/test/dummy/app/views/docs/doc_new/doc_form.md +36 -0
- data/test/dummy/app/views/docs/doc_xedit/doc_edit.html.erb +21 -0
- data/test/dummy/app/views/docs/edit/select_note.html.erb +14 -0
- data/test/dummy/app/views/docs/index.haml +21 -0
- data/test/dummy/app/views/docs/my.haml +27 -0
- data/test/dummy/app/views/identities/new.html.haml +32 -0
- data/test/dummy/app/views/jinda/_activity.md +10 -0
- data/test/dummy/app/views/jinda/_menu.haml +27 -0
- data/test/dummy/app/views/jinda/_menu_mm.haml +44 -0
- data/test/dummy/app/views/jinda/_model.md +5 -0
- data/test/dummy/app/views/jinda/_modul.md +9 -0
- data/test/dummy/app/views/jinda/_pending_home.haml +5 -0
- data/test/dummy/app/views/jinda/_pending_page.haml +24 -0
- data/test/dummy/app/views/jinda/_service.md +24 -0
- data/test/dummy/app/views/jinda/_static.haml +13 -0
- data/test/dummy/app/views/jinda/doc-thai.md +37 -0
- data/test/dummy/app/views/jinda/doc.md +36 -0
- data/test/dummy/app/views/jinda/error_logs.haml +22 -0
- data/test/dummy/app/views/jinda/feed.rss.builder +27 -0
- data/test/dummy/app/views/jinda/help.haml +20 -0
- data/test/dummy/app/views/jinda/index.html.haml +53 -0
- data/test/dummy/app/views/jinda/logs.haml +22 -0
- data/test/dummy/app/views/jinda/notice_logs.haml +18 -0
- data/test/dummy/app/views/jinda/pending.haml +1 -0
- data/test/dummy/app/views/jinda/run_form.haml +42 -0
- data/test/dummy/app/views/jinda/run_output.haml +38 -0
- data/test/dummy/app/views/jinda/search.haml +20 -0
- data/test/dummy/app/views/jinda/status.haml +61 -0
- data/test/dummy/app/views/jinda_mailer/gmail.html.erb +9 -0
- data/test/dummy/app/views/layouts/_head.html.erb +10 -0
- data/test/dummy/app/views/layouts/_meta_tag.html.erb +19 -0
- data/test/dummy/app/views/layouts/application.haml +4 -0
- data/test/dummy/app/views/layouts/{application.html.erb → application.html.erb.bak} +2 -1
- data/test/dummy/app/views/layouts/bsb/_footer.haml +7 -0
- data/test/dummy/app/views/layouts/bsb/_header.haml +147 -0
- data/test/dummy/app/views/layouts/bsb/_menu.haml +47 -0
- data/test/dummy/app/views/layouts/bsb/_menu_mm.haml +34 -0
- data/test/dummy/app/views/layouts/bsb/_rightbar.haml +123 -0
- data/test/dummy/app/views/layouts/bsb/_sidebar.haml +155 -0
- data/test/dummy/app/views/layouts/bsb/application.haml-bsb +47 -0
- data/test/dummy/app/views/layouts/gmail.html.erb +9 -0
- data/test/dummy/app/views/layouts/jqm/_full.haml +33 -0
- data/test/dummy/app/views/layouts/jqm/_page.haml +16 -0
- data/test/dummy/app/views/layouts/jqm/application.haml-jqm +4 -0
- data/test/dummy/app/views/layouts/mailer.html.haml +3 -0
- data/test/dummy/app/views/layouts/mailer.text.haml +1 -0
- data/test/dummy/app/views/layouts/mobile.html.erb +13 -0
- data/test/dummy/app/views/layouts/mobilejq.html.erb +31 -0
- data/test/dummy/app/views/layouts/print.html.erb +22 -0
- data/test/dummy/app/views/layouts/utf8.html.erb +22 -0
- data/test/dummy/app/views/note_mailer/gmail.html.haml +7 -0
- data/test/dummy/app/views/note_mailer/gmail.text.haml +8 -0
- data/test/dummy/app/views/notes/delete/select_note.html.erb +14 -0
- data/test/dummy/app/views/notes/edit/edit_note.html.erb +10 -0
- data/test/dummy/app/views/notes/edit/select_note.html.erb +14 -0
- data/test/dummy/app/views/notes/index.haml +71 -0
- data/test/dummy/app/views/notes/mail/display_mail.html.erb +20 -0
- data/test/dummy/app/views/notes/mail/select_note.html.erb +19 -0
- data/test/dummy/app/views/notes/mail/show.html.haml +13 -0
- data/test/dummy/app/views/notes/my.haml +21 -0
- data/test/dummy/app/views/notes/new/new_note.html.erb +13 -0
- data/test/dummy/app/views/notes/show.haml +10 -0
- data/test/dummy/app/views/notes/xedit/edit_note.html.erb +10 -0
- data/test/dummy/app/views/password_resets/edit.html.erb +21 -0
- data/test/dummy/app/views/password_resets/new.html.haml +11 -0
- data/test/dummy/app/views/sessions/new.html.haml +22 -0
- data/test/dummy/app/views/sitemap/index.xml.haml +10 -0
- data/test/dummy/app/views/user_mailer/password_reset.html.haml +3 -0
- data/test/dummy/app/views/user_mailer/password_reset.text.erb +3 -0
- data/test/dummy/app/views/user_mailer/password_reset.text.haml +3 -0
- data/test/dummy/app/views/users/index.haml +13 -0
- data/test/dummy/app/views/users/pwd/enter.html.erb +6 -0
- data/test/dummy/app/views/users/user/enter_user.html.erb +10 -0
- data/test/dummy/bin/rails +3 -3
- data/test/dummy/bin/rake +2 -2
- data/test/dummy/bin/setup +9 -17
- data/test/dummy/config/application.rb +51 -9
- data/test/dummy/config/boot.rb +3 -4
- data/test/dummy/config/cloudinary.yml +9 -0
- data/test/dummy/config/credentials.yml.enc +1 -0
- data/test/dummy/config/environment.rb +7 -1
- data/test/dummy/config/environments/development.rb +20 -20
- data/test/dummy/config/environments/production.rb +16 -40
- data/test/dummy/config/environments/test.rb +19 -11
- data/test/dummy/config/initializers/assets.rb +1 -1
- data/test/dummy/config/initializers/content_security_policy.rb +21 -24
- data/test/dummy/config/initializers/filter_parameter_logging.rb +6 -2
- data/test/dummy/config/initializers/fix_mongoid_generator.rb-org +14 -0
- data/test/dummy/config/initializers/inflections.rb +4 -4
- data/test/dummy/config/initializers/jinda.rb +14 -0
- data/test/dummy/config/initializers/mongoid.rb +10 -0
- data/test/dummy/config/initializers/omniauth.rb +17 -0
- data/test/dummy/config/initializers/permissions_policy.rb +11 -0
- data/test/dummy/config/locales/en.yml +3 -3
- data/test/dummy/config/mongoid.yml +196 -0
- data/test/dummy/config/mongoid.yml-docker +182 -0
- data/test/dummy/config/mongoid.yml-localhost +182 -0
- data/test/dummy/config/puma.rb +7 -2
- data/test/dummy/config/routes.rb +5 -1
- data/test/dummy/config.ru +2 -1
- data/test/dummy/db/seeds.rb +6 -0
- data/test/dummy/docker-compose.yml +19 -0
- data/test/dummy/dot/dot.env +2 -0
- data/test/dummy/entrypoint.sh +13 -0
- data/test/dummy/log/development.log +697 -6
- data/test/dummy/public/robots.txt +1 -0
- data/test/dummy/spec/controllers/api/v1_get_index_spec.rb +23 -0
- data/test/dummy/spec/controllers/api/v1_get_my_spec.rb +14 -0
- data/test/dummy/spec/controllers/api/v1_post_spec.rb +19 -0
- data/test/dummy/spec/controllers/sessions_controller_spec.rb +98 -0
- data/test/dummy/spec/features/userlogins_spec.rb +23 -0
- data/test/dummy/spec/mailers/note_spec.rb +24 -0
- data/test/dummy/spec/mailers/previews/note_preview.rb +9 -0
- data/test/dummy/spec/models/note_spec.rb +41 -0
- data/test/dummy/spec/models/user_spec.rb +12 -0
- data/test/dummy/spec/rails_helper.rb +42 -0
- data/test/dummy/spec/spec_helper.rb +80 -0
- data/test/dummy/spec/support/authentication_helper.rb +20 -0
- data/test/dummy/spec/support/databasecleaner.rb +13 -0
- data/test/dummy/spec/support/factory_bot.rb +12 -0
- data/test/dummy/spec/support/omniauth_macros.rb +38 -0
- data/test/dummy/spec/support/request_spec_helper.rb +8 -0
- data/test/dummy/spec/views/articles/_article.html.erb_spec.rbx +14 -0
- data/test/dummy/tmp/development_secret.txt +1 -1
- metadata +188 -17
- data/test/dummy/app/javascript/packs/application.js +0 -15
- data/test/dummy/app/models/application_record.rb +0 -3
- data/test/dummy/config/database.yml +0 -25
- data/test/dummy/config/initializers/application_controller_renderer.rb +0 -8
- data/test/dummy/config/initializers/backtrace_silencers.rb +0 -7
- data/test/dummy/config/initializers/cookies_serializer.rb +0 -5
- data/test/dummy/config/initializers/mime_types.rb +0 -4
- data/test/dummy/config/initializers/wrap_parameters.rb +0 -14
- data/test/dummy/config/spring.rb +0 -6
- data/test/dummy/config/storage.yml +0 -34
@@ -0,0 +1,53 @@
|
|
1
|
+
.content-header
|
2
|
+
%div(style="text-align:center")
|
3
|
+
= image_tag "logo_jinda.png"
|
4
|
+
%ol.breadcrumb
|
5
|
+
%li.fa.fa-dashboard
|
6
|
+
Dashboard
|
7
|
+
.content
|
8
|
+
%div.row::before
|
9
|
+
%div.col-lg-4.col-md-4.col-xs-12
|
10
|
+
%div.small-box.bg-aqua
|
11
|
+
%div.inner
|
12
|
+
%b Current gems version found:
|
13
|
+
%ul
|
14
|
+
%li Ruby Version #{RUBY_VERSION }
|
15
|
+
%li Rails Version #{Rails.version }
|
16
|
+
%li gem jinda #{Gem.loaded_specs['jinda'].version}
|
17
|
+
%div.col-lg-4.col-md-4.col-xs-12
|
18
|
+
%div.small-box.bg-green
|
19
|
+
%div.inner
|
20
|
+
%b Recently tested with:
|
21
|
+
%ul
|
22
|
+
%li Rubygems 2.7.1
|
23
|
+
%li Rails 6.1.0
|
24
|
+
%div.col-lg-4.col-md-4.col-xs-12
|
25
|
+
%div.small-box.bg-yellow
|
26
|
+
%div.inner
|
27
|
+
%b Create New Rails:
|
28
|
+
%ul
|
29
|
+
%li rails new YOURAPP --skip-test-unit --skip-bundle --skip-active-record --skip-javascript --skip-turbolinks
|
30
|
+
%li (rails new YOURAPP -BOTJ)
|
31
|
+
%div.col-lg-6.col-md-12.col-xs-12
|
32
|
+
%div.small-box.bg-red
|
33
|
+
%div.inner
|
34
|
+
%b Installation
|
35
|
+
%ul
|
36
|
+
%li add gem 'jinda' # to Gemfile then $ bundle
|
37
|
+
%li rails generate jinda:install, then bundle
|
38
|
+
%li rails generate jinda:config
|
39
|
+
%li rails jinda:seed, will create initial user:password admin:secret
|
40
|
+
%li when update app/jinda/index.mm, run rake jinda:update
|
41
|
+
%div.col-lg-6.col-md-12.col-xs-12
|
42
|
+
%div.small-box.bg-blue
|
43
|
+
%div.inner
|
44
|
+
%b Option: Themes available: Jinda_adminbsb, Jinda_adminlte
|
45
|
+
%ul
|
46
|
+
%li To install gem 'jinda_adminlte'
|
47
|
+
%li Install
|
48
|
+
%li gem 'jinda_adminlte'
|
49
|
+
%li Then
|
50
|
+
%li $ bundle
|
51
|
+
%li $ rails generate jinda_adminlte:install
|
52
|
+
|
53
|
+
|
@@ -0,0 +1,22 @@
|
|
1
|
+
- @title= "Jinda Logs"
|
2
|
+
= paginate @xmains
|
3
|
+
%table{:id=>"pending-table", :width=>"100%"}
|
4
|
+
%tr{:style=>"color:white; background-color:#97BF60;"}
|
5
|
+
%th id
|
6
|
+
%th task
|
7
|
+
%th step
|
8
|
+
%th starter
|
9
|
+
%th begin
|
10
|
+
%th status
|
11
|
+
- @xmains.each do |xmain|
|
12
|
+
- @xmain= xmain
|
13
|
+
- next unless xmain.current_runseq
|
14
|
+
- @runseq= Jinda::Runseq.find(xmain.current_runseq)
|
15
|
+
- next unless @runseq
|
16
|
+
%tr
|
17
|
+
%td= link_to xmain.xid, "/jinda/status?xid=#{xmain.xid}"
|
18
|
+
%td= xmain.name
|
19
|
+
%td= @runseq.name
|
20
|
+
%td(align="center")= xmain.user.try :code
|
21
|
+
%td= xmain.start.strftime("%c")
|
22
|
+
%td(align="center")= status_icon(xmain.status)
|
@@ -0,0 +1,18 @@
|
|
1
|
+
- @title= "Notice Error Logs"
|
2
|
+
= paginate @notices
|
3
|
+
%table{:id=>"pending-table", :width=>"100%"}
|
4
|
+
%tr{:style=>"color:white; background-color:#97BF60;"}
|
5
|
+
%th created
|
6
|
+
%th user
|
7
|
+
%th message
|
8
|
+
- @notices.each do |notice|
|
9
|
+
- @notice= notice
|
10
|
+
- current_notice = @notice.id
|
11
|
+
- #current_notice_user = @notice.user
|
12
|
+
- notice_user = (User.find @notice.user ? notice.user : 0)
|
13
|
+
- (notice_user_name = notice_user.code) if notice_user
|
14
|
+
|
15
|
+
%tr
|
16
|
+
%td(style='vertical-align:top;')= notice.created_at
|
17
|
+
%td(style='vertical-align:top;')= notice_user_name
|
18
|
+
%td(style='vertical-align:top;')= notice.message
|
@@ -0,0 +1 @@
|
|
1
|
+
= render :partial=>"pending_page", :locals=>{:xmains=>@xmains}
|
@@ -0,0 +1,42 @@
|
|
1
|
+
.container
|
2
|
+
.head
|
3
|
+
= step(@runseq.form_step, @xvars['total_form_steps'])
|
4
|
+
%p
|
5
|
+
- user = current_ma_user || User.new
|
6
|
+
- form_class = 'formtastic'
|
7
|
+
- next_step = 'end_form'
|
8
|
+
- if @help
|
9
|
+
%div(data-role="collapsible" data-theme="e" data-content-theme="c" data-mini="true")
|
10
|
+
%h3 Help
|
11
|
+
%p= markdown(@help)
|
12
|
+
= form_tag({ :action => next_step } , {:multipart => true, :onSubmit=>'return validate()', :class=>form_class, "data-ajax"=>"#{ajax?(@ui)}"}) do
|
13
|
+
= hidden_field_tag 'xmain_id', @xmain.id
|
14
|
+
= hidden_field_tag 'ajax', ajax?(@ui)
|
15
|
+
= hidden_field_tag 'runseq_id', @runseq.id
|
16
|
+
= hidden_field_tag 'step', @xvars[:current_step]
|
17
|
+
%div(data-role="fieldcontain")
|
18
|
+
= render :inline=> @ui
|
19
|
+
%p
|
20
|
+
= submit_tag NEXT
|
21
|
+
%p
|
22
|
+
:javascript
|
23
|
+
$(function() {
|
24
|
+
$('.required').append('<span style="color:red"> *</span>');
|
25
|
+
$('.refresh').append(" <img src='/images/refresh.png'/>");
|
26
|
+
$("input").keypress(function (evt) {
|
27
|
+
//Deterime where our character code is coming from within the event
|
28
|
+
var charCode = evt.charCode || evt.keyCode;
|
29
|
+
if (charCode == 13) { //Enter key's keycode
|
30
|
+
alert("Please click the button");
|
31
|
+
return false;
|
32
|
+
}
|
33
|
+
});
|
34
|
+
});
|
35
|
+
$( document ).one( "pagechange", function(){
|
36
|
+
$('input[type="file"]').textinput({theme: 'c'});
|
37
|
+
});
|
38
|
+
|
39
|
+
function validate() {
|
40
|
+
// alert("Validate");
|
41
|
+
}
|
42
|
+
|
@@ -0,0 +1,38 @@
|
|
1
|
+
.head
|
2
|
+
- @title= @xmain.name
|
3
|
+
= step(@runseq.form_step, @xvars['total_form_steps'])
|
4
|
+
#title(style='text-align:right;')= "click '#{@runseq.name}' to print"
|
5
|
+
%p
|
6
|
+
=javascript_include_tag "disable_enter_key"
|
7
|
+
= form_tag({ :action => 'end_output' } , {:multipart => true, :onKeyPress=>'return disableEnterKey(event)', :class=>'formtastic'}) do
|
8
|
+
= hidden_field_tag 'xmain_id', @xmain.id
|
9
|
+
= hidden_field_tag 'runseq_id', @runseq.id
|
10
|
+
= hidden_field_tag 'step', @xvars[:current_step]
|
11
|
+
#output_link
|
12
|
+
= link_to @runseq.name, url_for(:controller=>'jinda', :action=>'document', :id=>@doc.id), :target=>'_blank'
|
13
|
+
%p
|
14
|
+
.label
|
15
|
+
= image_tag "cog.png"
|
16
|
+
= t "documents"
|
17
|
+
%table{:width=>"100%"}
|
18
|
+
%tr{:style=>"color:white; background-color:#6A6A6A;"}
|
19
|
+
%th= t "id"
|
20
|
+
%th= t "document"
|
21
|
+
%th= t "file name"
|
22
|
+
%th= t "user"
|
23
|
+
%th= "date"
|
24
|
+
- @xmain.docs.each do |doc|
|
25
|
+
- next unless doc.ma_display
|
26
|
+
%tr
|
27
|
+
%td= doc.id
|
28
|
+
%td
|
29
|
+
- if doc.content_type=='output'
|
30
|
+
= image_tag 'page_output.png'
|
31
|
+
- else
|
32
|
+
= image_tag 'page_attach.png'
|
33
|
+
= link_to_blank align_text(doc.name), :controller=>"jinda", :action=>:document, :id=>doc.id
|
34
|
+
%td= doc.filename
|
35
|
+
%td= doc.user.code
|
36
|
+
%td= doc.updated_at
|
37
|
+
= submit_tag @message
|
38
|
+
%p
|
@@ -0,0 +1,20 @@
|
|
1
|
+
/%h3= "Search #{@q}"
|
2
|
+
= will_paginate @docs, :class=>'flickr_pagination', :params=>{:q=>@q}
|
3
|
+
/= will_paginate @xmains, :class=>'flickr_pagination', :params=>{:q=>@q}
|
4
|
+
|
5
|
+
%table{:width=>"100%"}
|
6
|
+
%tr{:style=>"color:white; background-color:#6A6A6A; text-shadow:none;"}
|
7
|
+
%th id
|
8
|
+
%th task
|
9
|
+
%th starter
|
10
|
+
%th begin
|
11
|
+
%th end
|
12
|
+
%th status
|
13
|
+
- @xmains.each do |xmain|
|
14
|
+
%tr
|
15
|
+
%td= link_to xmain.id, :action=>"status", :id=>xmain.id
|
16
|
+
%td= link_to xmain.name, :action=>"status", :id=>xmain.id
|
17
|
+
%td{:align=>'center'}= xmain.ma_user.full_name
|
18
|
+
%td= date_thai xmain.start, :date_only=>true
|
19
|
+
%td= xmain.stop ? date_thai(xmain.stop, :date_only=>true) : ' '
|
20
|
+
%td(align='center')= status_icon xmain
|
@@ -0,0 +1,61 @@
|
|
1
|
+
%table{:width=>"100%"}
|
2
|
+
%tr{:style=>"color:white; background-color:#6A6A6A;"}
|
3
|
+
%th Status
|
4
|
+
%th Step
|
5
|
+
%th Starter
|
6
|
+
%th Begin
|
7
|
+
%th End
|
8
|
+
- @xmain.runseqs.form_action.each do |r|
|
9
|
+
%tr
|
10
|
+
- if @xmain.status=='X'
|
11
|
+
%td{:align=>'center'}= image_tag 'cancel.png'
|
12
|
+
- else
|
13
|
+
%td{:align=>'center'}= status_icon(r.status)
|
14
|
+
%td= r.name
|
15
|
+
%td{:align=>'center'}
|
16
|
+
- if r.role.blank? && @xvars[:action]
|
17
|
+
- u = @xvars[:action][:assign].blank? ? ' ' : User.find(@xvars[:action][:assign]).full_name
|
18
|
+
= u
|
19
|
+
- if @xvars[:action][:final]=='n'
|
20
|
+
%td{:align=>'center'} -
|
21
|
+
%td{:align=>'center'} -
|
22
|
+
- else
|
23
|
+
- if r.start
|
24
|
+
%td= r.start.strftime('%c')
|
25
|
+
- else
|
26
|
+
%td{:align=>'center'} -
|
27
|
+
- if r.stop
|
28
|
+
%td= r.stop.strftime('%c')
|
29
|
+
- else
|
30
|
+
%td{:align=>'center'} -
|
31
|
+
- else
|
32
|
+
= role_name r.role
|
33
|
+
- if r.start
|
34
|
+
%td= r.start.strftime('%c')
|
35
|
+
- else
|
36
|
+
%td{:align=>'center'} -
|
37
|
+
- if r.stop
|
38
|
+
%td= r.stop.strftime('%c')
|
39
|
+
- else
|
40
|
+
%td{:align=>'center'} -
|
41
|
+
.label
|
42
|
+
= image_tag "cog.png"
|
43
|
+
Document
|
44
|
+
%table{:width=>"100%"}
|
45
|
+
%tr{:style=>"color:white; background-color:#6A6A6A;"}
|
46
|
+
%th Document
|
47
|
+
%th Name
|
48
|
+
%th User
|
49
|
+
%th Date
|
50
|
+
- @xmain.docs.each do |doc|
|
51
|
+
- next unless doc.display
|
52
|
+
%tr
|
53
|
+
%td
|
54
|
+
- if doc.content_type=='output'
|
55
|
+
= image_tag 'page_output.png'
|
56
|
+
- else
|
57
|
+
= image_tag 'page_attach.png'
|
58
|
+
= link_to align_text(doc.name), "/engine/document/#{doc.id}", :target=>'_blank'
|
59
|
+
%td= doc.filename
|
60
|
+
%td= doc.user.try(:full_name)
|
61
|
+
%td= doc.created_at.strftime('%c')
|
@@ -0,0 +1,10 @@
|
|
1
|
+
<head>
|
2
|
+
<%= favicon_link_tag %>
|
3
|
+
<meta name="description" content="Jinda" />
|
4
|
+
<%= stylesheet_link_tag "application", media: "all", "data-turbolinks-track":"reload" %>
|
5
|
+
<%= javascript_include_tag "application", "data-turbolinks-track": "reload" %>
|
6
|
+
<%= stylesheet_link_tag "jinda", "sarabun" %>
|
7
|
+
<script src = "https://ajax.aspnetcdn.com/ajax/jquery.validate/1.12.0/jquery.validate.js" ></script>
|
8
|
+
<%= csrf_meta_tags %>
|
9
|
+
<%= display_meta_tags %>
|
10
|
+
</head>
|
@@ -0,0 +1,19 @@
|
|
1
|
+
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
|
2
|
+
<meta name="robots" content="follow, all" />
|
3
|
+
<meta name="language" content="en, th" />
|
4
|
+
<meta name="viewport" content="width=device-width, minimum-scale=1, maximum-scale=1, initial-scale=1">
|
5
|
+
<title>
|
6
|
+
<% if content_for?(:title) %>
|
7
|
+
<%= content_for(:title) %>
|
8
|
+
<% else %>
|
9
|
+
Jinda | Tools for | Ruby on Rails
|
10
|
+
<% end %>
|
11
|
+
</title>
|
12
|
+
|
13
|
+
<% if content_for :meta_description %>
|
14
|
+
<meta name="description" content="<%= content_for :meta_description %>" />
|
15
|
+
<% else %>
|
16
|
+
<meta name="description" content="Jinda Tools to create visual programming using mindmap" />
|
17
|
+
<% end %>
|
18
|
+
|
19
|
+
<meta name="keywords" content="Jinda, Rails, ruby" />
|
@@ -2,10 +2,11 @@
|
|
2
2
|
<html>
|
3
3
|
<head>
|
4
4
|
<title>Dummy</title>
|
5
|
+
<meta name="viewport" content="width=device-width,initial-scale=1">
|
5
6
|
<%= csrf_meta_tags %>
|
6
7
|
<%= csp_meta_tag %>
|
7
8
|
|
8
|
-
<%= stylesheet_link_tag
|
9
|
+
<%= stylesheet_link_tag "application" %>
|
9
10
|
</head>
|
10
11
|
|
11
12
|
<body>
|
@@ -0,0 +1,147 @@
|
|
1
|
+
%nav.navbar
|
2
|
+
.container-fluid
|
3
|
+
.navbar-header
|
4
|
+
%a.navbar-toggle.collapsed{"aria-expanded" => "false", "data-target" => "#navbar-collapse", "data-toggle" => "collapse", :href => "javascript:void(0);"}
|
5
|
+
%a.bars{:href => "javascript:void(0);"}
|
6
|
+
%a.navbar-brand{:href => "index.html"} ADMINBSB - MATERIAL DESIGN
|
7
|
+
#navbar-collapse.collapse.navbar-collapse
|
8
|
+
%ul.nav.navbar-nav.navbar-right
|
9
|
+
/ Call Search
|
10
|
+
%li
|
11
|
+
%a.js-search{"data-close" => "true", :href => "javascript:void(0);"}
|
12
|
+
%i.material-icons search
|
13
|
+
/ #END# Call Search
|
14
|
+
/ Notifications
|
15
|
+
%li.dropdown
|
16
|
+
%a.dropdown-toggle{"data-toggle" => "dropdown", :href => "javascript:void(0);", :role => "button"}
|
17
|
+
%i.material-icons notifications
|
18
|
+
%span.label-count 7
|
19
|
+
%ul.dropdown-menu
|
20
|
+
%li.header NOTIFICATIONS
|
21
|
+
%li.body
|
22
|
+
%ul.menu
|
23
|
+
%li
|
24
|
+
%a{:href => "javascript:void(0);"}
|
25
|
+
.icon-circle.bg-light-green
|
26
|
+
%i.material-icons person_add
|
27
|
+
.menu-info
|
28
|
+
%h4 12 new members joined
|
29
|
+
%p
|
30
|
+
%i.material-icons access_time
|
31
|
+
14 mins ago
|
32
|
+
%li
|
33
|
+
%a{:href => "javascript:void(0);"}
|
34
|
+
.icon-circle.bg-cyan
|
35
|
+
%i.material-icons add_shopping_cart
|
36
|
+
.menu-info
|
37
|
+
%h4 4 sales made
|
38
|
+
%p
|
39
|
+
%i.material-icons access_time
|
40
|
+
22 mins ago
|
41
|
+
%li
|
42
|
+
%a{:href => "javascript:void(0);"}
|
43
|
+
.icon-circle.bg-red
|
44
|
+
%i.material-icons delete_forever
|
45
|
+
.menu-info
|
46
|
+
%h4
|
47
|
+
%b Nancy Doe
|
48
|
+
deleted account
|
49
|
+
%p
|
50
|
+
%i.material-icons access_time
|
51
|
+
3 hours ago
|
52
|
+
%li
|
53
|
+
%a{:href => "javascript:void(0);"}
|
54
|
+
.icon-circle.bg-orange
|
55
|
+
%i.material-icons mode_edit
|
56
|
+
.menu-info
|
57
|
+
%h4
|
58
|
+
%b Nancy
|
59
|
+
changed name
|
60
|
+
%p
|
61
|
+
%i.material-icons access_time
|
62
|
+
2 hours ago
|
63
|
+
%li
|
64
|
+
%a{:href => "javascript:void(0);"}
|
65
|
+
.icon-circle.bg-blue-grey
|
66
|
+
%i.material-icons comment
|
67
|
+
.menu-info
|
68
|
+
%h4
|
69
|
+
%b John
|
70
|
+
commented your post
|
71
|
+
%p
|
72
|
+
%i.material-icons access_time
|
73
|
+
4 hours ago
|
74
|
+
%li
|
75
|
+
%a{:href => "javascript:void(0);"}
|
76
|
+
.icon-circle.bg-light-green
|
77
|
+
%i.material-icons cached
|
78
|
+
.menu-info
|
79
|
+
%h4
|
80
|
+
%b John
|
81
|
+
updated status
|
82
|
+
%p
|
83
|
+
%i.material-icons access_time
|
84
|
+
3 hours ago
|
85
|
+
%li
|
86
|
+
%a{:href => "javascript:void(0);"}
|
87
|
+
.icon-circle.bg-purple
|
88
|
+
%i.material-icons settings
|
89
|
+
.menu-info
|
90
|
+
%h4 Settings updated
|
91
|
+
%p
|
92
|
+
%i.material-icons access_time
|
93
|
+
Yesterday
|
94
|
+
%li.footer
|
95
|
+
%a{:href => "javascript:void(0);"} View All Notifications
|
96
|
+
/ #END# Notifications
|
97
|
+
/ Tasks
|
98
|
+
%li.dropdown
|
99
|
+
%a.dropdown-toggle{"data-toggle" => "dropdown", :href => "javascript:void(0);", :role => "button"}
|
100
|
+
%i.material-icons flag
|
101
|
+
%span.label-count 9
|
102
|
+
%ul.dropdown-menu
|
103
|
+
%li.header TASKS
|
104
|
+
%li.body
|
105
|
+
%ul.menu.tasks
|
106
|
+
%li
|
107
|
+
%a{:href => "javascript:void(0);"}
|
108
|
+
%h4
|
109
|
+
Footer display issue
|
110
|
+
%small 32%
|
111
|
+
.progress
|
112
|
+
.progress-bar.bg-pink{"aria-valuemax" => "100", "aria-valuemin" => "0", "aria-valuenow" => "85", :role => "progressbar", :style => "width: 32%"}
|
113
|
+
%li
|
114
|
+
%a{:href => "javascript:void(0);"}
|
115
|
+
%h4
|
116
|
+
Make new buttons
|
117
|
+
%small 45%
|
118
|
+
.progress
|
119
|
+
.progress-bar.bg-cyan{"aria-valuemax" => "100", "aria-valuemin" => "0", "aria-valuenow" => "85", :role => "progressbar", :style => "width: 45%"}
|
120
|
+
%li
|
121
|
+
%a{:href => "javascript:void(0);"}
|
122
|
+
%h4
|
123
|
+
Create new dashboard
|
124
|
+
%small 54%
|
125
|
+
.progress
|
126
|
+
.progress-bar.bg-teal{"aria-valuemax" => "100", "aria-valuemin" => "0", "aria-valuenow" => "85", :role => "progressbar", :style => "width: 54%"}
|
127
|
+
%li
|
128
|
+
%a{:href => "javascript:void(0);"}
|
129
|
+
%h4
|
130
|
+
Solve transition issue
|
131
|
+
%small 65%
|
132
|
+
.progress
|
133
|
+
.progress-bar.bg-orange{"aria-valuemax" => "100", "aria-valuemin" => "0", "aria-valuenow" => "85", :role => "progressbar", :style => "width: 65%"}
|
134
|
+
%li
|
135
|
+
%a{:href => "javascript:void(0);"}
|
136
|
+
%h4
|
137
|
+
Answer GitHub questions
|
138
|
+
%small 92%
|
139
|
+
.progress
|
140
|
+
.progress-bar.bg-purple{"aria-valuemax" => "100", "aria-valuemin" => "0", "aria-valuenow" => "85", :role => "progressbar", :style => "width: 92%"}
|
141
|
+
%li.footer
|
142
|
+
%a{:href => "javascript:void(0);"} View All Tasks
|
143
|
+
/ #END# Tasks
|
144
|
+
%li.pull-right
|
145
|
+
%a.js-right-sidebar{"data-close" => "true", :href => "javascript:void(0);"}
|
146
|
+
%i.material-icons more_vert
|
147
|
+
/ #Top Bar
|
@@ -0,0 +1,47 @@
|
|
1
|
+
- head = login? ? current_ma_user.code : DEFAULT_HEADER
|
2
|
+
|
3
|
+
.menu
|
4
|
+
%ul.list
|
5
|
+
%li.header MAIN NAVIGATION
|
6
|
+
%li.active
|
7
|
+
%a{:href =>"/jinda","data-panel" => "main"}
|
8
|
+
%i.material-icons home
|
9
|
+
%span Home
|
10
|
+
|
11
|
+
= render 'layouts/jqm/menu_mm'
|
12
|
+
|
13
|
+
- if login?
|
14
|
+
%li
|
15
|
+
%a{:href=>"/jinda/pending", "data-panel" => "main"} Pending Tasks
|
16
|
+
%li
|
17
|
+
%a{"data-panel" => "main", :href => logout_path, "data-ajax"=>"false"}
|
18
|
+
%i.material-icons layers
|
19
|
+
%span Sign Out
|
20
|
+
- else
|
21
|
+
%li
|
22
|
+
%a{:href =>new_session_path,"data-panel" => "main"}
|
23
|
+
%i.material-icons layers
|
24
|
+
%span Sign In
|
25
|
+
%li
|
26
|
+
%a{:href =>new_identity_path, "data-panel" => "main"}
|
27
|
+
%i.material-icons layers
|
28
|
+
%span Sign Up
|
29
|
+
%li
|
30
|
+
= link_to "Refresh", "#", :onclick=>"window.location.replace('/')"
|
31
|
+
- if !login?
|
32
|
+
%a.btn.btn-block.btn-social.btn-facebook{:href => "/auth/facebook", rel: "external"}
|
33
|
+
%i.material-icons facebook
|
34
|
+
%span Sign in with Facebook
|
35
|
+
|
36
|
+
.legal
|
37
|
+
.copyright
|
38
|
+
© 2016 - 2017
|
39
|
+
= succeed "." do
|
40
|
+
%a{:href => "javascript:void(0);"} AdminBSB - Material Design
|
41
|
+
.version
|
42
|
+
%b Version:
|
43
|
+
1.0.5
|
44
|
+
|
45
|
+
|
46
|
+
|
47
|
+
|
@@ -0,0 +1,34 @@
|
|
1
|
+
%li.treeview
|
2
|
+
- process_services
|
3
|
+
- Jinda::Module.all.asc(:seq).each do |m|
|
4
|
+
- unless m.role.blank?
|
5
|
+
- next unless login?
|
6
|
+
- next unless current_ma_user.role
|
7
|
+
- next unless current_ma_user.role.upcase.split(',').include?(m.role.upcase)
|
8
|
+
%li
|
9
|
+
%a.menu-toggle{:href => "javascript:void(0);"}
|
10
|
+
%i.material-icons.col-light-blue donut_small
|
11
|
+
%span
|
12
|
+
= m.name
|
13
|
+
%ul.ml-menu
|
14
|
+
%li
|
15
|
+
- m.services.asc(:seq).each do |s|
|
16
|
+
- next unless s.list
|
17
|
+
- xml= REXML::Document.new(s.xml).root
|
18
|
+
- unless s.rule.blank?
|
19
|
+
- next if (!eval(s.rule))
|
20
|
+
- unless s.role.blank?
|
21
|
+
- next unless login?
|
22
|
+
- next unless current_ma_user.role
|
23
|
+
- next unless current_ma_user.role.upcase.split(',').include?(s.role.upcase)
|
24
|
+
- if s.code.downcase=="link"
|
25
|
+
- name, url = s.name.split(":", 2)
|
26
|
+
- url.strip!
|
27
|
+
- else
|
28
|
+
- name= s.name; url= "/jinda/init?s=#{s.module_code}:#{s.code}"
|
29
|
+
- if s.confirm
|
30
|
+
%li
|
31
|
+
%a{"data-panel"=>"main", :onclick=>"if (confirm('Please Confirm')) {location.hash='#{url}'};"}= name
|
32
|
+
- else
|
33
|
+
%li
|
34
|
+
%a{"data-panel"=>"main", :href=> url}= name
|