dorsale 1.2.6 → 2.0.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/app/assets/javascripts/accounting.js +413 -0
- data/app/assets/javascripts/dorsale/billing_machine/all.coffee +20 -0
- data/app/assets/javascripts/dorsale/billing_machine/invoices.coffee +39 -0
- data/app/assets/javascripts/dorsale/billing_machine/quotations.coffee +38 -0
- data/app/assets/javascripts/dorsale/comments.coffee +4 -0
- data/app/assets/javascripts/dorsale/customer_vault/all.coffee +9 -0
- data/app/assets/javascripts/dorsale/datepicker.coffee +1 -1
- data/app/assets/javascripts/dorsale/flyboy/all.coffee +0 -0
- data/app/assets/javascripts/dorsale/forms.coffee +20 -6
- data/app/assets/stylesheets/dorsale/billing_machine/all.sass +15 -0
- data/app/assets/stylesheets/dorsale/bootstrap_nav_left.sass +34 -0
- data/app/assets/stylesheets/dorsale/comments.sass +25 -3
- data/app/assets/stylesheets/dorsale/customer_vault/all.sass +89 -0
- data/app/assets/stylesheets/dorsale/filters.sass +4 -1
- data/app/assets/stylesheets/dorsale/flyboy/all.sass +52 -0
- data/app/assets/stylesheets/dorsale/forms.sass +19 -0
- data/app/controllers/dorsale/alexandrie/attachments_controller.rb +52 -0
- data/app/controllers/dorsale/billing_machine/application_controller.rb +15 -0
- data/app/controllers/dorsale/billing_machine/invoices_controller.rb +180 -0
- data/app/controllers/dorsale/billing_machine/quotations_controller.rb +151 -0
- data/app/controllers/dorsale/comments_controller.rb +64 -17
- data/app/controllers/dorsale/customer_vault/application_controller.rb +26 -0
- data/app/controllers/dorsale/customer_vault/corporations_controller.rb +100 -0
- data/app/controllers/dorsale/customer_vault/individuals_controller.rb +104 -0
- data/app/controllers/dorsale/customer_vault/links_controller.rb +92 -0
- data/app/controllers/dorsale/customer_vault/people_controller.rb +42 -0
- data/app/controllers/dorsale/flyboy/application_controller.rb +9 -0
- data/app/controllers/dorsale/flyboy/folders_controller.rb +124 -0
- data/app/controllers/dorsale/flyboy/task_comments_controller.rb +29 -0
- data/app/controllers/dorsale/flyboy/tasks_controller.rb +171 -0
- data/app/controllers/dorsale/small_data/filters_controller.rb +7 -0
- data/app/helpers/dorsale/alexandrie/attachments_helper.rb +17 -0
- data/app/helpers/dorsale/all_helpers.rb +12 -9
- data/app/helpers/dorsale/button_helper.rb +23 -3
- data/app/helpers/dorsale/comments_helper.rb +4 -0
- data/app/helpers/dorsale/customer_vault/application_helper.rb +98 -0
- data/app/helpers/dorsale/flyboy/application_helper.rb +44 -0
- data/app/helpers/dorsale/form_helper.rb +7 -0
- data/app/helpers/dorsale/link_helper.rb +3 -2
- data/app/helpers/dorsale/routes_helper.rb +5 -3
- data/app/helpers/dorsale/text_helper.rb +28 -1
- data/app/models/dorsale/ability_helper.rb +7 -0
- data/app/models/dorsale/alexandrie/ability_helper.rb +9 -0
- data/app/models/dorsale/alexandrie/attachment.rb +18 -0
- data/app/models/dorsale/billing_machine/ability_helper.rb +10 -0
- data/app/models/dorsale/billing_machine/id_card.rb +18 -0
- data/app/models/dorsale/billing_machine/invoice.rb +126 -0
- data/app/models/dorsale/billing_machine/invoice_line.rb +27 -0
- data/app/models/dorsale/billing_machine/payment_term.rb +12 -0
- data/app/models/dorsale/billing_machine/quotation.rb +66 -0
- data/app/models/dorsale/billing_machine/quotation_line.rb +25 -0
- data/app/models/dorsale/billing_machine/small_data/filter_for_invoices.rb +21 -0
- data/app/models/dorsale/billing_machine/small_data/filter_for_quotations.rb +20 -0
- data/app/models/dorsale/billing_machine/small_data/filter_strategy_by_customer.rb +12 -0
- data/app/models/dorsale/billing_machine/small_data/filter_strategy_by_payment_status.rb +23 -0
- data/app/models/dorsale/billing_machine/small_data/filter_strategy_by_time_period.rb +27 -0
- data/app/models/dorsale/comment.rb +6 -2
- data/app/models/dorsale/customer_vault/ability_helper.rb +9 -0
- data/app/models/dorsale/customer_vault/corporation.rb +12 -0
- data/app/models/dorsale/customer_vault/individual.rb +17 -0
- data/app/models/dorsale/customer_vault/link.rb +10 -0
- data/app/models/dorsale/customer_vault/person.rb +35 -0
- data/app/models/dorsale/customer_vault/small_data/filter_for_people.rb +19 -0
- data/app/models/dorsale/customer_vault/small_data/filter_strategy_by_tags.rb +18 -0
- data/app/models/dorsale/flyboy/ability_helper.rb +41 -0
- data/app/models/dorsale/flyboy/folder.rb +77 -0
- data/app/models/dorsale/flyboy/small_data/filter_for_folders.rb +19 -0
- data/app/models/dorsale/flyboy/small_data/filter_for_tasks.rb +19 -0
- data/app/models/dorsale/flyboy/small_data/filter_strategy_by_done.rb +12 -0
- data/app/models/dorsale/flyboy/small_data/filter_strategy_by_nothing.rb +11 -0
- data/app/models/dorsale/flyboy/small_data/filter_strategy_by_status.rb +15 -0
- data/app/models/dorsale/flyboy/task.rb +97 -0
- data/app/models/dorsale/flyboy/task_comment.rb +35 -0
- data/app/pdfs/dorsale/billing_machine/invoice_pdf.rb +209 -0
- data/app/pdfs/dorsale/billing_machine/quotation_pdf.rb +53 -0
- data/app/pdfs/dorsale/flyboy/roadmap.rb +51 -0
- data/app/uploaders/dorsale/alexandrie/file_uploader.rb +6 -0
- data/app/uploaders/dorsale/file_uploader.rb +9 -0
- data/app/uploaders/dorsale/image_uploader.rb +7 -0
- data/app/views/dorsale/_contextual.html.slim +3 -0
- data/app/views/dorsale/alexandrie/attachments/_form.html.slim +13 -0
- data/app/views/dorsale/alexandrie/attachments/_form_and_list.html.slim +2 -0
- data/app/views/dorsale/alexandrie/attachments/_list.html.slim +7 -0
- data/app/views/dorsale/billing_machine/invoices/_data_context.html.slim +10 -0
- data/app/views/dorsale/billing_machine/invoices/_filters.html.slim +16 -0
- data/app/views/dorsale/billing_machine/invoices/_form.html.slim +62 -0
- data/app/views/dorsale/billing_machine/invoices/_line_fields.html.slim +23 -0
- data/app/views/dorsale/billing_machine/invoices/_list.html.slim +30 -0
- data/app/views/dorsale/billing_machine/invoices/edit.html.slim +2 -0
- data/app/views/dorsale/billing_machine/invoices/index.html.slim +15 -0
- data/app/views/dorsale/billing_machine/invoices/new.html.slim +2 -0
- data/app/views/dorsale/billing_machine/invoices/show.html.slim +53 -0
- data/app/views/dorsale/billing_machine/quotations/_data_context.html.slim +10 -0
- data/app/views/dorsale/billing_machine/quotations/_filters.html.slim +13 -0
- data/app/views/dorsale/billing_machine/quotations/_form.html.slim +55 -0
- data/app/views/dorsale/billing_machine/quotations/_line_fields.html.slim +23 -0
- data/app/views/dorsale/billing_machine/quotations/_list.html.slim +30 -0
- data/app/views/dorsale/billing_machine/quotations/edit.html.slim +2 -0
- data/app/views/dorsale/billing_machine/quotations/index.html.slim +14 -0
- data/app/views/dorsale/billing_machine/quotations/new.html.slim +2 -0
- data/app/views/dorsale/billing_machine/quotations/show.html.slim +61 -0
- data/app/views/dorsale/comments/_comment.html.slim +23 -9
- data/app/views/dorsale/comments/_comments.html.slim +2 -2
- data/app/views/dorsale/comments/_form.html.slim +1 -1
- data/app/views/dorsale/comments/_list.html.slim +2 -0
- data/app/views/dorsale/comments/edit.html.slim +5 -0
- data/app/views/dorsale/customer_vault/_breadcrumb.html.slim +4 -0
- data/app/views/dorsale/customer_vault/corporations/_context.html.slim +20 -0
- data/app/views/dorsale/customer_vault/corporations/_form.html.slim +21 -0
- data/app/views/dorsale/customer_vault/corporations/_list_details.html.slim +20 -0
- data/app/views/dorsale/customer_vault/corporations/edit.html.slim +14 -0
- data/app/views/dorsale/customer_vault/corporations/new.html.slim +14 -0
- data/app/views/dorsale/customer_vault/corporations/show.html.slim +1 -0
- data/app/views/dorsale/customer_vault/individuals/_context.html.slim +15 -0
- data/app/views/dorsale/customer_vault/individuals/_form.html.slim +22 -0
- data/app/views/dorsale/customer_vault/individuals/_list_details.html.slim +20 -0
- data/app/views/dorsale/customer_vault/individuals/edit.html.slim +14 -0
- data/app/views/dorsale/customer_vault/individuals/new.html.slim +14 -0
- data/app/views/dorsale/customer_vault/individuals/show.html.slim +1 -0
- data/app/views/dorsale/customer_vault/links/_title.html.slim +7 -0
- data/app/views/dorsale/customer_vault/links/edit.html.slim +19 -0
- data/app/views/dorsale/customer_vault/links/new.html.slim +15 -0
- data/app/views/dorsale/customer_vault/people/_activity_tab.html.slim +5 -0
- data/app/views/dorsale/customer_vault/people/_comment.html.slim +1 -0
- data/app/views/dorsale/customer_vault/people/_context.html.slim +4 -0
- data/app/views/dorsale/customer_vault/people/_data_context.html.slim +32 -0
- data/app/views/dorsale/customer_vault/people/_filters.html.slim +15 -0
- data/app/views/dorsale/customer_vault/people/_index_tabs.html.slim +7 -0
- data/app/views/dorsale/customer_vault/people/_links_tab.html.slim +16 -0
- data/app/views/dorsale/customer_vault/people/_new_people_contexts.html.slim +7 -0
- data/app/views/dorsale/customer_vault/people/_show.html.slim +31 -0
- data/app/views/dorsale/customer_vault/people/_tasks_tab.html.slim +1 -0
- data/app/views/dorsale/customer_vault/people/activity.slim +20 -0
- data/app/views/dorsale/customer_vault/people/list.html.slim +27 -0
- data/app/views/dorsale/flyboy/_filters.html.slim +12 -0
- data/app/views/dorsale/flyboy/folders/_actions.html.slim +15 -0
- data/app/views/dorsale/flyboy/folders/_context.html.slim +18 -0
- data/app/views/dorsale/flyboy/folders/_form.html.slim +22 -0
- data/app/views/dorsale/flyboy/folders/_list.html.slim +30 -0
- data/app/views/dorsale/flyboy/folders/edit.html.slim +2 -0
- data/app/views/dorsale/flyboy/folders/index.html.slim +8 -0
- data/app/views/dorsale/flyboy/folders/new.html.slim +2 -0
- data/app/views/dorsale/flyboy/folders/show.html.slim +9 -0
- data/app/views/dorsale/flyboy/task_comments/_list.html.slim +31 -0
- data/app/views/dorsale/flyboy/tasks/_actions.html.slim +9 -0
- data/app/views/dorsale/flyboy/tasks/_context.html.slim +15 -0
- data/app/views/dorsale/flyboy/tasks/_form.html.slim +29 -0
- data/app/views/dorsale/flyboy/tasks/_list.html.slim +43 -0
- data/app/views/dorsale/flyboy/tasks/_tasks_for_taskable.html.slim +6 -0
- data/app/views/dorsale/flyboy/tasks/edit.html.slim +2 -0
- data/app/views/dorsale/flyboy/tasks/index.html.slim +10 -0
- data/app/views/dorsale/flyboy/tasks/index.xls.erb +29 -0
- data/app/views/dorsale/flyboy/tasks/new.html.slim +2 -0
- data/app/views/dorsale/flyboy/tasks/show.html.slim +14 -0
- data/app/views/dorsale/search/_form.html.slim +6 -0
- data/config/locales/alexandrie.fr.yml +8 -0
- data/config/locales/billing_machine.fr.yml +50 -0
- data/config/locales/common.fr.yml +142 -0
- data/config/locales/customer_vault.fr.yml +69 -0
- data/config/locales/flyboy.fr.yml +66 -0
- data/config/locales/fr.yml +8 -87
- data/config/routes.rb +50 -1
- data/db/migrate/20141010140200_create_dorsale_addresses.rb +1 -1
- data/db/migrate/20150312083147_create_dorsale_comments.rb +3 -3
- data/db/migrate/20150616074852_create_dorsale_alexandrie_attachments.rb +9 -0
- data/db/migrate/20150622075000_create_flyboy.rb +50 -0
- data/db/migrate/20150622075038_create_billing_machine.rb +121 -0
- data/db/migrate/20150622105217_create_customer_vault.rb +49 -0
- data/db/migrate/20150623093218_dorsale_v2_changes.rb +68 -0
- data/db/migrate/20150625093326_billing_machine_quotations_add_expires_at.rb +5 -0
- data/db/migrate/20150625131155_billing_machine_add_tracking_ids.rb +6 -0
- data/lib/active_record_comma_type_cast.rb +12 -0
- data/lib/dorsale/alexandrie/prawn.rb +17 -0
- data/lib/dorsale/engine.rb +19 -0
- data/lib/dorsale/file_loader.rb +10 -0
- data/lib/dorsale/model_i18n.rb +21 -0
- data/lib/dorsale/model_to_s.rb +13 -0
- data/lib/dorsale/polymorphic_id.rb +2 -0
- data/lib/dorsale/version.rb +1 -1
- data/spec/controllers/dorsale/alexandrie/attachments_controller_spec.rb +47 -0
- data/spec/controllers/dorsale/comments_controller_spec.rb +45 -0
- data/spec/controllers/dorsale/customer_vault/corporations_controller_spec.rb +132 -0
- data/spec/controllers/dorsale/customer_vault/individuals_controller_spec.rb +130 -0
- data/spec/controllers/dorsale/customer_vault/people_controller_spec.rb +59 -0
- data/spec/controllers/dorsale/flyboy/folders_controller_spec.rb +111 -0
- data/spec/controllers/dorsale/flyboy/task_comments_controller_spec.rb +16 -0
- data/spec/controllers/dorsale/flyboy/tasks_controller_spec.rb +234 -0
- data/spec/dummy/app/assets/javascripts/application.coffee +10 -0
- data/spec/dummy/app/assets/stylesheets/application.sass +9 -0
- data/spec/dummy/app/controllers/application_controller.rb +4 -0
- data/spec/dummy/app/models/ability.rb +16 -0
- data/spec/dummy/app/models/dummy_model.rb +2 -0
- data/spec/dummy/app/views/layouts/application.html.erb +10 -3
- data/spec/dummy/config/application.rb +4 -2
- data/spec/dummy/db/development.sqlite3 +0 -0
- data/spec/dummy/db/migrate/20150616082916_create_dorsale_dummy_models.rb +8 -0
- data/spec/dummy/db/migrate/20150624081204_acts_as_taggable_on_migration.acts_as_taggable_on_engine.rb +31 -0
- data/spec/dummy/db/migrate/20150624081205_add_missing_unique_indices.acts_as_taggable_on_engine.rb +20 -0
- data/spec/dummy/db/migrate/20150624081206_add_taggings_counter_cache_to_tags.acts_as_taggable_on_engine.rb +15 -0
- data/spec/dummy/db/migrate/20150624081207_add_missing_taggable_index.acts_as_taggable_on_engine.rb +10 -0
- data/spec/dummy/db/migrate/20150624081208_change_collation_for_tag_names.acts_as_taggable_on_engine.rb +10 -0
- data/spec/dummy/db/schema.rb +243 -5
- data/spec/dummy/db/seed.rb +1 -0
- data/spec/dummy/db/test.sqlite3 +0 -0
- data/spec/dummy/log/development.log +227 -0
- data/spec/dummy/log/test.log +2740 -25
- data/spec/dummy/{app/assets/stylesheets/application.css → tmp/cache/assets/development/sprockets/13fe41fee1fe35b49d145bcc06610705} +0 -0
- data/spec/dummy/tmp/cache/assets/development/sprockets/2f5173deea6c795b8fdde723bb4b63af +0 -0
- data/spec/dummy/tmp/cache/assets/development/sprockets/357970feca3ac29060c1e3861e2c0953 +0 -0
- data/spec/dummy/tmp/cache/assets/development/sprockets/cffd775d018f68ce5dba1ee0d951a994 +0 -0
- data/spec/dummy/tmp/cache/assets/development/sprockets/d771ace226fc8215a3572e0aa35bb0d6 +0 -0
- data/spec/dummy/tmp/cache/assets/development/sprockets/f7cbd26ba1d28d48de824f0e94586655 +0 -0
- data/spec/factories/alexandrie_attachments.rb +12 -0
- data/spec/factories/billing_machine_id_cards.rb +26 -0
- data/spec/factories/billing_machine_invoice_lines.rb +11 -0
- data/spec/factories/billing_machine_invoices.rb +12 -0
- data/spec/factories/billing_machine_payment_terms.rb +5 -0
- data/spec/factories/billing_machine_quotation_lines.rb +12 -0
- data/spec/factories/billing_machine_quotations.rb +12 -0
- data/spec/factories/customer_vault_corporations.rb +14 -0
- data/spec/factories/customer_vault_individuals.rb +19 -0
- data/spec/factories/customer_vault_links.rb +7 -0
- data/spec/factories/dorsale_addresses.rb +6 -8
- data/spec/factories/dorsale_comments.rb +8 -0
- data/spec/factories/flyboy_folders.rb +7 -0
- data/spec/factories/flyboy_task_comments.rb +8 -0
- data/spec/factories/flyboy_tasks.rb +12 -0
- data/spec/files/pdf.pdf +0 -0
- data/spec/helpers/dorsale/flyboy/application_helper_spec.rb +91 -0
- data/spec/helpers/dorsale/link_helper_spec.rb +1 -0
- data/spec/helpers/dorsale/text_helper_spec.rb +33 -9
- data/spec/models/dorsale/ability_helper_spec.rb +11 -0
- data/spec/models/dorsale/alexandrie/ability_helper_spec.rb +10 -0
- data/spec/models/dorsale/alexandrie/attachment_spec.rb +12 -0
- data/spec/models/dorsale/billing_machine/id_card_spec.rb +12 -0
- data/spec/models/dorsale/billing_machine/invoice_line_spec.rb +50 -0
- data/spec/models/dorsale/billing_machine/invoice_spec.rb +156 -0
- data/spec/models/dorsale/billing_machine/quotation_line_spec.rb +36 -0
- data/spec/models/dorsale/billing_machine/quotation_spec.rb +91 -0
- data/spec/models/dorsale/comment_spec.rb +11 -0
- data/spec/models/dorsale/customer_vault/corporation_spec.rb +17 -0
- data/spec/models/dorsale/customer_vault/individual_spec.rb +17 -0
- data/spec/models/dorsale/customer_vault/link_spec.rb +12 -0
- data/spec/models/dorsale/customer_vault/person_spec.rb +44 -0
- data/spec/models/dorsale/flyboy/ability_spec.rb +148 -0
- data/spec/models/dorsale/flyboy/folder_spec.rb +103 -0
- data/spec/models/dorsale/flyboy/task_comment_spec.rb +52 -0
- data/spec/models/dorsale/flyboy/task_spec.rb +83 -0
- data/spec/pdfs/dorsale/billing_machine/invoice_pdf_spec.rb +252 -0
- data/spec/pdfs/dorsale/billing_machine/quotation_pdf_spec.rb +255 -0
- data/spec/rails_helper.rb +11 -11
- data/spec/routing/dorsale/alexandrie/attachments_routing_spec.rb +19 -0
- data/spec/routing/dorsale/billing_machine/invoices_routing_spec.rb +53 -0
- data/spec/routing/dorsale/billing_machine/quotations_routing_spec.rb +43 -0
- data/spec/routing/dorsale/comments_routing_spec.rb +25 -0
- data/spec/routing/dorsale/customer_vault/corporations_routing_spec.rb +66 -0
- data/spec/routing/dorsale/customer_vault/individual_routing_spec.rb +66 -0
- data/spec/routing/dorsale/customer_vault/people_routing_spec.rb +22 -0
- data/spec/routing/dorsale/flyboy/folders_routing_spec.rb +44 -0
- data/spec/routing/dorsale/flyboy/task_comments_routing_spec.rb +12 -0
- data/spec/routing/dorsale/flyboy/tasks_routing_spec.rb +44 -0
- data/spec/spec_helper.rb +0 -6
- metadata +439 -10
- data/MIT-LICENSE +0 -20
- data/README.rdoc +0 -3
- data/spec/dummy/app/assets/javascripts/application.js +0 -13
@@ -0,0 +1,111 @@
|
|
1
|
+
describe Dorsale::Flyboy::FoldersController, type: :controller do
|
2
|
+
render_views
|
3
|
+
routes { Dorsale::Engine.routes }
|
4
|
+
|
5
|
+
let(:folder){
|
6
|
+
create(:flyboy_folder)
|
7
|
+
}
|
8
|
+
|
9
|
+
describe '#index' do
|
10
|
+
context 'when applying filter' do
|
11
|
+
before(:each) do
|
12
|
+
Dorsale::Flyboy::Folder.destroy_all
|
13
|
+
@folder1 = create(:flyboy_folder, status: "open")
|
14
|
+
@folder2 = create(:flyboy_folder, status: "closed")
|
15
|
+
end
|
16
|
+
|
17
|
+
it 'should display both when not filtered' do
|
18
|
+
get :index
|
19
|
+
expect(assigns(:folders)).to eq [@folder2, @folder1]
|
20
|
+
end
|
21
|
+
|
22
|
+
it 'should filter by status closed' do
|
23
|
+
Dorsale::Flyboy::SmallData::FilterForFolders.new(request.cookies)
|
24
|
+
.store(status: "closed")
|
25
|
+
|
26
|
+
get :index
|
27
|
+
expect(assigns(:folders)).to eq [@folder2]
|
28
|
+
end
|
29
|
+
|
30
|
+
it 'should filter by status open' do
|
31
|
+
Dorsale::Flyboy::SmallData::FilterForFolders.new(request.cookies)
|
32
|
+
.store(status: "open")
|
33
|
+
|
34
|
+
get :index
|
35
|
+
expect(assigns(:folders)).to eq [@folder1]
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
39
|
+
context "when sorting" do
|
40
|
+
before do
|
41
|
+
Dorsale::Flyboy::Folder.destroy_all
|
42
|
+
@folder1 = create(:flyboy_folder, name: "Abc", progress: 100, status: "open")
|
43
|
+
@folder2 = create(:flyboy_folder, name: "dEF", progress: 0, status: "closed")
|
44
|
+
@folder3 = create(:flyboy_folder, name: "xyz", progress: 35, status: "closed")
|
45
|
+
end
|
46
|
+
|
47
|
+
it "sorting by name asc" do
|
48
|
+
get :index, sort: "name"
|
49
|
+
expect(assigns(:folders).to_a).to eq [@folder1, @folder2, @folder3]
|
50
|
+
end
|
51
|
+
|
52
|
+
it "sorting by name desc" do
|
53
|
+
get :index, sort: "-name"
|
54
|
+
expect(assigns(:folders).to_a).to eq [@folder3, @folder2, @folder1]
|
55
|
+
end
|
56
|
+
|
57
|
+
it "sorting by progress asc" do
|
58
|
+
get :index, sort: "progress"
|
59
|
+
expect(assigns(:folders).to_a).to eq [@folder2, @folder3, @folder1]
|
60
|
+
end
|
61
|
+
|
62
|
+
it "sorting by progress desc" do
|
63
|
+
get :index, sort: "-progress"
|
64
|
+
expect(assigns(:folders).to_a).to eq [@folder1, @folder3, @folder2]
|
65
|
+
end
|
66
|
+
|
67
|
+
it "sorting by status asc" do
|
68
|
+
get :index, sort: "status"
|
69
|
+
expect(assigns(:folders).to_a).to eq [@folder2, @folder3, @folder1]
|
70
|
+
end
|
71
|
+
|
72
|
+
it "sorting by status desc" do
|
73
|
+
get :index, sort: "-status"
|
74
|
+
expect(assigns(:folders).to_a).to eq [@folder1, @folder2, @folder3]
|
75
|
+
end
|
76
|
+
end
|
77
|
+
end
|
78
|
+
|
79
|
+
describe "#close" do
|
80
|
+
before(:each) do
|
81
|
+
@folder = create(:flyboy_folder, status: "open")
|
82
|
+
end
|
83
|
+
|
84
|
+
it "should close folder" do
|
85
|
+
patch :close, id: @folder
|
86
|
+
expect(@folder.reload.status).to eq "closed"
|
87
|
+
end
|
88
|
+
|
89
|
+
it "should redirect to folders path" do
|
90
|
+
patch :close, id: @folder
|
91
|
+
expect(response).to redirect_to flyboy_folders_path
|
92
|
+
end
|
93
|
+
end
|
94
|
+
|
95
|
+
describe "#open" do
|
96
|
+
before(:each) do
|
97
|
+
@folder = create(:flyboy_folder, status: "closed")
|
98
|
+
end
|
99
|
+
|
100
|
+
it "should open folder" do
|
101
|
+
patch :open, id: @folder
|
102
|
+
expect(@folder.reload.status).to eq "open"
|
103
|
+
end
|
104
|
+
|
105
|
+
it "should redirect to folder path" do
|
106
|
+
patch :open, id: @folder
|
107
|
+
expect(response).to redirect_to flyboy_folder_path(@folder)
|
108
|
+
end
|
109
|
+
end
|
110
|
+
|
111
|
+
end
|
@@ -0,0 +1,16 @@
|
|
1
|
+
require "spec_helper"
|
2
|
+
|
3
|
+
describe Dorsale::Flyboy::TaskCommentsController, type: :controller do
|
4
|
+
routes { Dorsale::Engine.routes }
|
5
|
+
|
6
|
+
let(:task) { create(:flyboy_task) }
|
7
|
+
let(:task_comment) { create(:flyboy_task_comment, task: task) }
|
8
|
+
|
9
|
+
describe "#create" do
|
10
|
+
it "should create the task_comment" do
|
11
|
+
post :create, task_id: task.id, task_comment: task_comment.attributes
|
12
|
+
expect(assigns(:task_comment).persisted?).to be true
|
13
|
+
end
|
14
|
+
end
|
15
|
+
|
16
|
+
end
|
@@ -0,0 +1,234 @@
|
|
1
|
+
require "spec_helper"
|
2
|
+
|
3
|
+
describe Dorsale::Flyboy::TasksController, type: :controller do
|
4
|
+
routes { Dorsale::Engine.routes }
|
5
|
+
|
6
|
+
let!(:task) {
|
7
|
+
create(:flyboy_task, done: false)
|
8
|
+
}
|
9
|
+
|
10
|
+
let!(:task2) {
|
11
|
+
create(:flyboy_task, taskable: task.taskable, done: true)
|
12
|
+
}
|
13
|
+
|
14
|
+
let(:valid_attributes) {
|
15
|
+
{ name: "New Task" , taskable_id: task.taskable.id, taskable_type: task.taskable.class, reminder: Date.today, term: Date.today}
|
16
|
+
}
|
17
|
+
|
18
|
+
describe "#complete" do
|
19
|
+
before(:each) do
|
20
|
+
request.env["HTTP_REFERER"] = "where_i_came_from"
|
21
|
+
end
|
22
|
+
|
23
|
+
it "should mark the task as done" do
|
24
|
+
patch :complete, {id: task.id}
|
25
|
+
expect(task.reload.done).to be true
|
26
|
+
end
|
27
|
+
|
28
|
+
it "should set progress to 100" do
|
29
|
+
patch :complete, {id: task.id}
|
30
|
+
expect(task.reload.progress).to eq(100)
|
31
|
+
end
|
32
|
+
|
33
|
+
it "should add a task_comment" do
|
34
|
+
count = task.comments.count
|
35
|
+
patch :complete, {id: task.id}
|
36
|
+
expect(task.reload.comments.count).to eq(count+1)
|
37
|
+
expect(task.comments.last.progress).to eq(100)
|
38
|
+
end
|
39
|
+
|
40
|
+
it "should redirect to the referer page" do
|
41
|
+
patch :complete, {id: task.id}
|
42
|
+
expect(response).to redirect_to "where_i_came_from"
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
describe "GET index" do
|
47
|
+
it "assigns all tasks as @tasks" do
|
48
|
+
get :index, {}
|
49
|
+
expect(assigns(:tasks).sort).to eq Dorsale::Flyboy::Task.all.sort
|
50
|
+
end
|
51
|
+
|
52
|
+
context "when applying filter" do
|
53
|
+
before do
|
54
|
+
Dorsale::Flyboy::Task.destroy_all
|
55
|
+
@task1 = create(:flyboy_task, done: true)
|
56
|
+
@task2 = create(:flyboy_task, done: false)
|
57
|
+
end
|
58
|
+
|
59
|
+
it 'should display both when not filtered' do
|
60
|
+
get :index
|
61
|
+
expect(assigns(:tasks).to_a.sort).to eq [@task1, @task2].sort
|
62
|
+
end
|
63
|
+
|
64
|
+
it 'should filter by status closed' do
|
65
|
+
Dorsale::Flyboy::SmallData::FilterForTasks.new(request.cookies).store({'status' => "closed"})
|
66
|
+
get :index
|
67
|
+
expect(assigns(:tasks).to_a).to eq [@task1]
|
68
|
+
end
|
69
|
+
|
70
|
+
it 'should filter by status opened' do
|
71
|
+
Dorsale::Flyboy::SmallData::FilterForTasks.new(request.cookies).store({'status' => "opened"})
|
72
|
+
get :index
|
73
|
+
expect(assigns(:tasks).to_a).to eq [@task2]
|
74
|
+
end
|
75
|
+
end
|
76
|
+
|
77
|
+
context "when sorting" do
|
78
|
+
before do
|
79
|
+
Dorsale::Flyboy::Folder.destroy_all
|
80
|
+
Dorsale::Flyboy::Task.destroy_all
|
81
|
+
@folder1 = create(:flyboy_folder, name: "Abc")
|
82
|
+
@folder2 = create(:flyboy_folder, name: "dEF")
|
83
|
+
@folder3 = create(:flyboy_folder, name: "xyz")
|
84
|
+
|
85
|
+
@task1 = create(:flyboy_task, taskable: @folder1, name: "Abc", progress: 100, term: "21/12/2012", reminder: "21/12/2012")
|
86
|
+
@task2 = create(:flyboy_task, taskable: @folder2, name: "dEF", progress: 0, term: "23/12/2012", reminder: "23/12/2012")
|
87
|
+
@task3 = create(:flyboy_task, taskable: @folder3, name: "xyz", progress: 35, term: "22/12/2012", reminder: "22/12/2012")
|
88
|
+
end
|
89
|
+
|
90
|
+
it "sorting by taskable asc" do
|
91
|
+
get :index, sort: "taskable"
|
92
|
+
expect(assigns(:tasks).to_a).to eq [@task1, @task2, @task3]
|
93
|
+
end
|
94
|
+
|
95
|
+
it "sorting by taskable desc" do
|
96
|
+
get :index, sort: "-taskable"
|
97
|
+
expect(assigns(:tasks).to_a).to eq [@task3, @task2, @task1]
|
98
|
+
end
|
99
|
+
|
100
|
+
it "sorting by name asc" do
|
101
|
+
get :index, sort: "name"
|
102
|
+
expect(assigns(:tasks).to_a).to eq [@task1, @task2, @task3]
|
103
|
+
end
|
104
|
+
|
105
|
+
it "sorting by name desc" do
|
106
|
+
get :index, sort: "-name"
|
107
|
+
expect(assigns(:tasks).to_a).to eq [@task3, @task2, @task1]
|
108
|
+
end
|
109
|
+
|
110
|
+
it "sorting by progress asc" do
|
111
|
+
get :index, sort: "progress"
|
112
|
+
expect(assigns(:tasks).to_a).to eq [@task2, @task3, @task1]
|
113
|
+
end
|
114
|
+
|
115
|
+
it "sorting by progress desc" do
|
116
|
+
get :index, sort: "-progress"
|
117
|
+
expect(assigns(:tasks).to_a).to eq [@task1, @task3, @task2]
|
118
|
+
end
|
119
|
+
|
120
|
+
it "sorting by term asc" do
|
121
|
+
get :index, sort: "term"
|
122
|
+
expect(assigns(:tasks).to_a).to eq [@task1, @task3, @task2]
|
123
|
+
end
|
124
|
+
|
125
|
+
it "sorting by term desc" do
|
126
|
+
get :index, sort: "-term"
|
127
|
+
expect(assigns(:tasks).to_a).to eq [@task2, @task3, @task1]
|
128
|
+
end
|
129
|
+
end
|
130
|
+
end
|
131
|
+
|
132
|
+
describe "GET show" do
|
133
|
+
it "assigns the requested task as @task" do
|
134
|
+
get :show, {:id => task.to_param}
|
135
|
+
expect(assigns(:task)).to eq(task)
|
136
|
+
end
|
137
|
+
end
|
138
|
+
|
139
|
+
describe "GET new" do
|
140
|
+
it "assigns a new task as @task" do
|
141
|
+
get :new, {:folder_id => task.taskable.id}
|
142
|
+
expect(assigns(:task)).to be_a_new(Dorsale::Flyboy::Task)
|
143
|
+
end
|
144
|
+
end
|
145
|
+
|
146
|
+
describe "GET edit" do
|
147
|
+
it "assigns the requested task as @task" do
|
148
|
+
get :edit, {:id => task.to_param}
|
149
|
+
expect(assigns(:task)).to eq(task)
|
150
|
+
end
|
151
|
+
end
|
152
|
+
|
153
|
+
describe "POST create" do
|
154
|
+
describe "with valid params" do
|
155
|
+
it "creates a new Task" do
|
156
|
+
expect {
|
157
|
+
post :create, {:task => valid_attributes}
|
158
|
+
}.to change(Dorsale::Flyboy::Task, :count).by(1)
|
159
|
+
end
|
160
|
+
|
161
|
+
it "assigns a newly created task as @task" do
|
162
|
+
post :create, {:task => valid_attributes}
|
163
|
+
expect(assigns(:task)).to be_a(Dorsale::Flyboy::Task)
|
164
|
+
expect(assigns(:task)).to be_persisted
|
165
|
+
end
|
166
|
+
|
167
|
+
it "redirects to the created task" do
|
168
|
+
post :create, {:task => valid_attributes}
|
169
|
+
expect(response).to redirect_to Dorsale::Flyboy::Task.order("id ASC").last
|
170
|
+
end
|
171
|
+
end
|
172
|
+
|
173
|
+
describe "with invalid params" do
|
174
|
+
it "assigns a newly created but unsaved task as @task" do
|
175
|
+
post :create, task: {name: nil, taskable_id: task.taskable.id, taskable_type: task.taskable.class}
|
176
|
+
expect(assigns(:task)).to be_a_new(Dorsale::Flyboy::Task)
|
177
|
+
end
|
178
|
+
end
|
179
|
+
|
180
|
+
end
|
181
|
+
|
182
|
+
describe "PUT update" do
|
183
|
+
describe "with valid params" do
|
184
|
+
it "assigns the requested task as @task" do
|
185
|
+
task = Dorsale::Flyboy::Task.create! valid_attributes
|
186
|
+
patch :update, {:id => task.to_param, :task => valid_attributes}
|
187
|
+
expect(assigns(:task)).to eq(task)
|
188
|
+
end
|
189
|
+
|
190
|
+
it "redirects to the task" do
|
191
|
+
task = Dorsale::Flyboy::Task.create! valid_attributes
|
192
|
+
patch :update, {:id => task.to_param, :task => valid_attributes}
|
193
|
+
expect(response).to redirect_to(task)
|
194
|
+
end
|
195
|
+
end
|
196
|
+
|
197
|
+
describe "with invalid params" do
|
198
|
+
it "assigns the task as @task" do
|
199
|
+
task = Dorsale::Flyboy::Task.create! valid_attributes
|
200
|
+
|
201
|
+
patch :update, {
|
202
|
+
:id => task.to_param,
|
203
|
+
:task => {:name => nil}
|
204
|
+
}
|
205
|
+
|
206
|
+
expect(assigns(:task)).to eq(task)
|
207
|
+
end
|
208
|
+
end
|
209
|
+
end
|
210
|
+
|
211
|
+
describe "DELETE destroy" do
|
212
|
+
it "destroys the requested task" do
|
213
|
+
task = Dorsale::Flyboy::Task.create! valid_attributes
|
214
|
+
expect {
|
215
|
+
delete :destroy, {:id => task.to_param}
|
216
|
+
}.to change(Dorsale::Flyboy::Task, :count).by(-1)
|
217
|
+
end
|
218
|
+
|
219
|
+
it "redirects to the tasks list" do
|
220
|
+
task = Dorsale::Flyboy::Task.create! valid_attributes
|
221
|
+
delete :destroy, {:id => task.to_param}
|
222
|
+
expect(response).to redirect_to(flyboy_tasks_path)
|
223
|
+
end
|
224
|
+
end
|
225
|
+
|
226
|
+
describe "snooze" do
|
227
|
+
it "should redirect to the task list to refresh it" do
|
228
|
+
task = Dorsale::Flyboy::Task.create! valid_attributes
|
229
|
+
patch :snooze, {:id => task.to_param}
|
230
|
+
expect(response).to redirect_to(flyboy_tasks_path)
|
231
|
+
end
|
232
|
+
end
|
233
|
+
|
234
|
+
end
|
@@ -0,0 +1,10 @@
|
|
1
|
+
//= require jquery
|
2
|
+
//= require jquery_ujs
|
3
|
+
//= require turbolinks
|
4
|
+
//= require bootstrap
|
5
|
+
//= require cocoon
|
6
|
+
//= require accounting
|
7
|
+
//= require selectize
|
8
|
+
//= require dorsale/all
|
9
|
+
//= require dorsale/billing_machine/all
|
10
|
+
//= require dorsale/customer_vault/all
|
@@ -0,0 +1,16 @@
|
|
1
|
+
class Ability
|
2
|
+
include CanCan::Ability
|
3
|
+
include ::Dorsale::AbilityHelper
|
4
|
+
include ::Dorsale::Alexandrie::AbilityHelper
|
5
|
+
include ::Dorsale::Flyboy::AbilityHelper
|
6
|
+
include ::Dorsale::BillingMachine::AbilityHelper
|
7
|
+
include ::Dorsale::CustomerVault::AbilityHelper
|
8
|
+
|
9
|
+
def initialize(*)
|
10
|
+
define_alexandrie_abilities
|
11
|
+
define_dorsale_comment_abilities
|
12
|
+
define_dorsale_flyboy_abilities
|
13
|
+
define_dorsale_billing_machine_abilities
|
14
|
+
define_dorsale_customer_vault_abilities
|
15
|
+
end
|
16
|
+
end
|
@@ -1,14 +1,21 @@
|
|
1
1
|
<!DOCTYPE html>
|
2
2
|
<html>
|
3
3
|
<head>
|
4
|
+
<meta content="width=device-width, initial-scale=1" name="viewport">
|
4
5
|
<title>Dummy</title>
|
5
|
-
<%= stylesheet_link_tag
|
6
|
-
<%= javascript_include_tag
|
6
|
+
<%= stylesheet_link_tag 'application', media: 'all', 'data-turbolinks-track' => true %>
|
7
|
+
<%= javascript_include_tag 'application', 'data-turbolinks-track' => true %>
|
7
8
|
<%= csrf_meta_tags %>
|
8
9
|
</head>
|
9
10
|
<body>
|
10
11
|
|
11
|
-
|
12
|
+
<div id="flash" class="container">
|
13
|
+
<%= render "dorsale/flash" %>
|
14
|
+
</div>
|
15
|
+
|
16
|
+
<div class="container">
|
17
|
+
<%= yield %>
|
18
|
+
</div>
|
12
19
|
|
13
20
|
</body>
|
14
21
|
</html>
|
@@ -18,11 +18,13 @@ module Dummy
|
|
18
18
|
|
19
19
|
# Set Time.zone default to the specified zone and make Active Record auto-convert to this zone.
|
20
20
|
# Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC.
|
21
|
-
|
21
|
+
config.time_zone = 'Paris'
|
22
22
|
|
23
23
|
# The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded.
|
24
24
|
# config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s]
|
25
|
-
|
25
|
+
config.i18n.default_locale = :fr
|
26
|
+
|
27
|
+
config.active_record.raise_in_transactional_callbacks = true
|
26
28
|
end
|
27
29
|
end
|
28
30
|
|