marty 0.5.15 → 0.5.16
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +27 -0
- data/.rspec +3 -0
- data/.travis.yml +23 -0
- data/Gemfile +23 -0
- data/INDEPENDENCE_ISSUES.md +23 -0
- data/app/assets/images/marty/.gitkeep +0 -0
- data/app/components/marty/report_form.rb +9 -4
- data/gemini_deprecations.md +6 -0
- data/lib/marty/data_change.rb +99 -0
- data/lib/marty/data_conversion.rb +11 -3
- data/lib/marty/data_exporter.rb +9 -0
- data/lib/marty/version.rb +1 -1
- data/marty.gemspec +35 -0
- data/script/rails +8 -0
- data/spec/controllers/application_controller_spec.rb +52 -0
- data/spec/controllers/job_controller_spec.rb +226 -0
- data/spec/controllers/rpc_controller_spec.rb +379 -0
- data/spec/controllers/rpc_import_spec.rb +45 -0
- data/spec/dummy/README.rdoc +261 -0
- data/spec/dummy/Rakefile +7 -0
- data/spec/dummy/app/assets/javascripts/application.js +15 -0
- data/spec/dummy/app/assets/stylesheets/application.css +13 -0
- data/spec/dummy/app/controllers/application_controller.rb +3 -0
- data/spec/dummy/app/controllers/components_controller.rb +7 -0
- data/spec/dummy/app/helpers/application_helper.rb +2 -0
- data/spec/dummy/app/mailers/.gitkeep +0 -0
- data/spec/dummy/app/models/.gitkeep +0 -0
- data/spec/dummy/app/models/gemini/amortization_type.rb +5 -0
- data/spec/dummy/app/models/gemini/bud_category.rb +7 -0
- data/spec/dummy/app/models/gemini/entity.rb +2 -0
- data/spec/dummy/app/models/gemini/extras/data_import.rb +5 -0
- data/spec/dummy/app/models/gemini/extras/settlement_import.rb +28 -0
- data/spec/dummy/app/models/gemini/fannie_bup.rb +29 -0
- data/spec/dummy/app/models/gemini/grouping.rb +8 -0
- data/spec/dummy/app/models/gemini/grouping_head_version.rb +14 -0
- data/spec/dummy/app/models/gemini/head.rb +7 -0
- data/spec/dummy/app/models/gemini/head_version.rb +14 -0
- data/spec/dummy/app/models/gemini/helper.rb +44 -0
- data/spec/dummy/app/models/gemini/loan_program.rb +11 -0
- data/spec/dummy/app/models/gemini/mortgage_type.rb +5 -0
- data/spec/dummy/app/models/gemini/simple.rb +6 -0
- data/spec/dummy/app/models/gemini/streamline_type.rb +16 -0
- data/spec/dummy/app/views/layouts/application.html.erb +14 -0
- data/spec/dummy/config.ru +4 -0
- data/spec/dummy/config/application.rb +82 -0
- data/spec/dummy/config/boot.rb +10 -0
- data/spec/dummy/config/database.yml.example +10 -0
- data/spec/dummy/config/environment.rb +5 -0
- data/spec/dummy/config/environments/development.rb +35 -0
- data/spec/dummy/config/environments/production.rb +69 -0
- data/spec/dummy/config/environments/test.rb +39 -0
- data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/spec/dummy/config/initializers/delayed_job.rb +5 -0
- data/spec/dummy/config/initializers/inflections.rb +15 -0
- data/spec/dummy/config/initializers/mime_types.rb +5 -0
- data/spec/dummy/config/initializers/secret_token.rb +7 -0
- data/spec/dummy/config/initializers/session_store.rb +8 -0
- data/spec/dummy/config/initializers/wrap_parameters.rb +14 -0
- data/spec/dummy/config/locales/en.yml +5 -0
- data/spec/dummy/config/routes.rb +12 -0
- data/spec/dummy/db/migrate/20140801000000_create_groupings.rb +11 -0
- data/spec/dummy/db/migrate/20150406171536_create_categories.rb +27 -0
- data/spec/dummy/db/migrate/20150408200916_create_loan_programs.rb +26 -0
- data/spec/dummy/db/migrate/20150408201429_create_types.rb +21 -0
- data/spec/dummy/db/migrate/20150420000001_create_heads.rb +14 -0
- data/spec/dummy/db/migrate/20150420000002_create_head_versions.rb +15 -0
- data/spec/dummy/db/migrate/20150420000003_create_grouping_head_versions.rb +12 -0
- data/spec/dummy/db/migrate/20151023000001_create_simple.rb +12 -0
- data/spec/dummy/db/seeds.rb +8 -0
- data/spec/dummy/delorean/blame_report.dl +171 -0
- data/spec/dummy/delorean/data_report.dl +105 -0
- data/spec/dummy/delorean/fields.dl +52 -0
- data/spec/dummy/delorean/styles.dl +134 -0
- data/spec/dummy/lib/assets/.gitkeep +0 -0
- data/spec/dummy/lib/class_list.rb +3 -0
- data/spec/dummy/log/.gitkeep +0 -0
- data/spec/dummy/public/404.html +26 -0
- data/spec/dummy/public/422.html +26 -0
- data/spec/dummy/public/500.html +25 -0
- data/spec/dummy/public/favicon.ico +0 -0
- data/spec/dummy/public/icons/READ.txt +3 -0
- data/spec/dummy/public/icons/application_cascade.png +0 -0
- data/spec/dummy/public/icons/application_delete.png +0 -0
- data/spec/dummy/public/icons/application_put.png +0 -0
- data/spec/dummy/public/icons/application_view_detail.png +0 -0
- data/spec/dummy/public/icons/arrow_in.png +0 -0
- data/spec/dummy/public/icons/arrow_refresh.png +0 -0
- data/spec/dummy/public/icons/database_save.png +0 -0
- data/spec/dummy/public/icons/door_in.png +0 -0
- data/spec/dummy/public/icons/door_out.png +0 -0
- data/spec/dummy/public/icons/group.png +0 -0
- data/spec/dummy/public/icons/page_lightning.png +0 -0
- data/spec/dummy/public/icons/printer.png +0 -0
- data/spec/dummy/public/icons/report_disk.png +0 -0
- data/spec/dummy/public/icons/report_go.png +0 -0
- data/spec/dummy/public/icons/report_magnify.png +0 -0
- data/spec/dummy/public/icons/script.png +0 -0
- data/spec/dummy/public/icons/script_add.png +0 -0
- data/spec/dummy/public/icons/script_go.png +0 -0
- data/spec/dummy/public/icons/script_key.png +0 -0
- data/spec/dummy/public/icons/table_go.png +0 -0
- data/spec/dummy/public/icons/time.png +0 -0
- data/spec/dummy/public/icons/time_add.png +0 -0
- data/spec/dummy/public/icons/time_go.png +0 -0
- data/spec/dummy/public/icons/timeline_marker.png +0 -0
- data/spec/dummy/public/icons/user_add.png +0 -0
- data/spec/dummy/public/icons/user_delete.png +0 -0
- data/spec/dummy/public/icons/user_edit.png +0 -0
- data/spec/dummy/public/icons/wrench.png +0 -0
- data/spec/dummy/script/delayed_job +6 -0
- data/spec/dummy/script/rails +6 -0
- data/spec/features/javascripts/job_dashboard_live_search.js.coffee +8 -0
- data/spec/features/javascripts/login.js.coffee +8 -0
- data/spec/features/jobs_dashboard_netzke_spec.rb +24 -0
- data/spec/features/jobs_dashboard_spec.rb +49 -0
- data/spec/fixtures/scripts/load_tests/script1.dl +2 -0
- data/spec/fixtures/scripts/load_tests/script2.dl +2 -0
- data/spec/job_helper.rb +102 -0
- data/spec/lib/data_exporter_spec.rb +71 -0
- data/spec/lib/data_importer_spec.rb +461 -0
- data/spec/lib/xl_spec.rb +198 -0
- data/spec/lib/xl_styles_spec.rb +115 -0
- data/spec/models/api_auth_spec.rb +187 -0
- data/spec/models/posting_spec.rb +107 -0
- data/spec/models/promise_spec.rb +65 -0
- data/spec/models/script_spec.rb +187 -0
- data/spec/models/user_spec.rb +68 -0
- data/spec/requests/routes_spec.rb +12 -0
- data/spec/spec_helper.rb +61 -0
- data/spec/support/clean_db_helpers.rb +18 -0
- data/spec/support/delayed_job_helpers.rb +12 -0
- data/spec/support/user_helpers.rb +12 -0
- metadata +139 -89
- data/app/components/marty/auth_app.rb~ +0 -51
- data/app/components/marty/auth_app/javascripts/auth_app.js~ +0 -91
- data/app/components/marty/cm_form_panel.rb~ +0 -5
- data/app/components/marty/cm_grid_panel.rb~ +0 -35
- data/app/components/marty/data_import_view.rb~ +0 -142
- data/app/components/marty/extras/layout.rb~ +0 -46
- data/app/components/marty/live_search_grid_panel.rb~ +0 -49
- data/app/components/marty/main_auth_app.rb~ +0 -238
- data/app/components/marty/mcfly_grid_panel.rb~ +0 -80
- data/app/components/marty/new_posting_form.rb~ +0 -46
- data/app/components/marty/new_posting_window.rb~ +0 -21
- data/app/components/marty/pivot_grid.rb +0 -52
- data/app/components/marty/pivot_grid/endpoints.rb +0 -45
- data/app/components/marty/pivot_grid/javascripts/extensions.js +0 -150
- data/app/components/marty/pivot_grid/javascripts/pivot_grid.js +0 -86
- data/app/components/marty/pivot_grid/services.rb +0 -44
- data/app/components/marty/posting_grid.rb~ +0 -140
- data/app/components/marty/promise_view.rb~ +0 -157
- data/app/components/marty/promise_view/stylesheets/promise_view.css~ +0 -15
- data/app/components/marty/report_form.rb~ +0 -217
- data/app/components/marty/report_select.rb~ +0 -133
- data/app/components/marty/reporting.rb~ +0 -39
- data/app/components/marty/script_detail.rb~ +0 -430
- data/app/components/marty/script_form.rb~ +0 -233
- data/app/components/marty/script_form/javascripts/Ext.ux.form.field.CodeMirror.js~ +0 -909
- data/app/components/marty/script_grid.rb~ +0 -99
- data/app/components/marty/script_tester.rb~ +0 -213
- data/app/components/marty/scripting.rb~ +0 -124
- data/app/components/marty/select_report.rb~ +0 -143
- data/app/components/marty/simple_app.rb~ +0 -101
- data/app/components/marty/tag_grid.rb~ +0 -89
- data/app/components/marty/tree_panel.rb~ +0 -256
- data/app/components/marty/tree_panel/javascripts/tree_panel.js~ +0 -317
- data/app/components/marty/user_pivot.rb +0 -128
- data/app/components/marty/user_view.rb~ +0 -188
- data/app/controllers/marty/application_controller.rb~ +0 -133
- data/app/controllers/marty/components_controller.rb~ +0 -37
- data/app/controllers/marty/job_controller.rb~ +0 -28
- data/app/controllers/marty/rpc_controller.rb~ +0 -61
- data/app/helpers/marty/script_set.rb~ +0 -59
- data/app/models/marty/api_auth.rb~ +0 -48
- data/app/models/marty/data_change.rb~ +0 -141
- data/app/models/marty/enum.rb~ +0 -16
- data/app/models/marty/import_type.rb~ +0 -48
- data/app/models/marty/poop.rb~ +0 -169
- data/app/models/marty/posting.rb~ +0 -86
- data/app/models/marty/posting_type.rb~ +0 -21
- data/app/models/marty/promise.rb~ +0 -196
- data/app/models/marty/role.rb~ +0 -10
- data/app/models/marty/script.rb~ +0 -62
- data/app/models/marty/tag.rb~ +0 -91
- data/app/models/marty/user.rb~ +0 -148
- data/app/models/marty/user_role.rb~ +0 -13
- data/app/views/layouts/marty/application.html.erb~ +0 -11
- data/config/routes.rb~ +0 -10
- data/db/migrate/019_create_marty_postings.rb~ +0 -19
- data/db/migrate/095_create_marty_tags.rb~ +0 -19
- data/lib/marty.rb~ +0 -13
- data/lib/marty/content_handler.rb~ +0 -93
- data/lib/marty/data_exporter.rb~ +0 -137
- data/lib/marty/data_importer.rb~ +0 -114
- data/lib/marty/data_row_processor.rb~ +0 -206
- data/lib/marty/drop_folder_hook.rb~ +0 -17
- data/lib/marty/folder_hook.rb~ +0 -9
- data/lib/marty/lazy_column_loader.rb~ +0 -47
- data/lib/marty/mcfly_query.rb~ +0 -188
- data/lib/marty/migrations.rb~ +0 -65
- data/lib/marty/monkey.rb~ +0 -160
- data/lib/marty/permissions.rb~ +0 -69
- data/lib/marty/promise.rb~ +0 -41
- data/lib/marty/promise_job.rb~ +0 -121
- data/lib/marty/promise_proxy.rb~ +0 -69
- data/lib/marty/util.rb~ +0 -80
- data/lib/marty/version.rb~ +0 -3
- data/lib/marty/xl.rb~ +0 -526
- data/lib/pyxll/README.txt~ +0 -16
- data/lib/pyxll/gemini.py~ +0 -110
- data/lib/pyxll/pyxll.cfg~ +0 -12
@@ -1,80 +0,0 @@
|
|
1
|
-
class Marty::McflyGridPanel < Marty::CmGridPanel
|
2
|
-
def configure(c)
|
3
|
-
super
|
4
|
-
|
5
|
-
warped = Marty::Util.warped?
|
6
|
-
|
7
|
-
c.enable_extended_search = false
|
8
|
-
c.enable_edit_in_form &&= !warped
|
9
|
-
c.prohibit_update ||= warped
|
10
|
-
c.prohibit_delete ||= warped
|
11
|
-
c.prohibit_create ||= warped
|
12
|
-
#c.prohibit_read ||= !self.class.has_any_perm?
|
13
|
-
|
14
|
-
# default sort all Mcfly grids with id
|
15
|
-
c.data_store.sorters ||= {property: :id, direction: 'ASC'}
|
16
|
-
|
17
|
-
# Set Mcfly scoping
|
18
|
-
c.scope = lambda { |r|
|
19
|
-
ts = Mcfly.normalize_infinity(Marty::Util.get_posting_time)
|
20
|
-
tb = data_class.table_name
|
21
|
-
r.where("#{tb}.obsoleted_dt >= ? AND #{tb}.created_dt < ?", ts, ts)
|
22
|
-
}
|
23
|
-
end
|
24
|
-
|
25
|
-
######################################################################
|
26
|
-
|
27
|
-
def augment_column_config(c)
|
28
|
-
super
|
29
|
-
|
30
|
-
name = c[:name]
|
31
|
-
|
32
|
-
# Set mcfly_scope if the attribute is a mcfly association
|
33
|
-
if !c[:scope] && data_adapter.association_attr?(name)
|
34
|
-
assoc_name, assoc_method = name.split('__')
|
35
|
-
begin
|
36
|
-
aklass = data_class.reflect_on_association(assoc_name.to_sym).klass
|
37
|
-
rescue
|
38
|
-
raise "trouble finding #{assoc_name} assoc class on #{data_class}"
|
39
|
-
end
|
40
|
-
|
41
|
-
# FIXME: MCFLY_UNIQUENESS is the easiest way I can think of
|
42
|
-
# figuring out if a class is Mcfly.
|
43
|
-
if (aklass.const_get(:MCFLY_UNIQUENESS) rescue nil)
|
44
|
-
c[:scope] = self.class.mcfly_scope(assoc_method || 'id')
|
45
|
-
else
|
46
|
-
c[:scope] = self.class.sorted_scope(assoc_method || 'id')
|
47
|
-
end
|
48
|
-
end
|
49
|
-
end
|
50
|
-
|
51
|
-
# HACKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKK
|
52
|
-
# # The basepack grid doesn't catch general exceptions. We can get
|
53
|
-
# # this if there's some sort of failure with saving to the DB.
|
54
|
-
# # e.g. range violation.
|
55
|
-
# def process_data_with_error_handling(data, operation)
|
56
|
-
# begin
|
57
|
-
# process_data_without_error_handling(data, operation)
|
58
|
-
# rescue => exc
|
59
|
-
# success = false
|
60
|
-
# flash :error => "Error: #{exc}"
|
61
|
-
# end
|
62
|
-
# end
|
63
|
-
|
64
|
-
# alias_method_chain :process_data, :error_handling
|
65
|
-
|
66
|
-
private
|
67
|
-
def self.mcfly_scope(sort_column)
|
68
|
-
lambda { |r|
|
69
|
-
ts = Mcfly.normalize_infinity(Marty::Util.get_posting_time)
|
70
|
-
r.where("obsoleted_dt >= ? AND created_dt < ?", ts, ts).
|
71
|
-
order(sort_column.to_sym)
|
72
|
-
}
|
73
|
-
end
|
74
|
-
|
75
|
-
def self.sorted_scope(sort_column)
|
76
|
-
lambda { |r|
|
77
|
-
r.order(sort_column.to_sym)
|
78
|
-
}
|
79
|
-
end
|
80
|
-
end
|
@@ -1,46 +0,0 @@
|
|
1
|
-
class Marty::NewPostingForm < Marty::CmFormPanel
|
2
|
-
extend Marty::Permissions
|
3
|
-
|
4
|
-
# override this to set permissions for posting types
|
5
|
-
has_marty_permissions read: :any
|
6
|
-
|
7
|
-
js_configure do |c|
|
8
|
-
c.close_me = <<-JS
|
9
|
-
function() {
|
10
|
-
// assume we're embedded in a window
|
11
|
-
this.netzkeGetParentComponent().close();
|
12
|
-
}
|
13
|
-
JS
|
14
|
-
end
|
15
|
-
|
16
|
-
action :apply do |a|
|
17
|
-
a.text = I18n.t("create_posting")
|
18
|
-
a.tooltip = I18n.t("create_posting")
|
19
|
-
a.icon = :time_add
|
20
|
-
end
|
21
|
-
|
22
|
-
######################################################################
|
23
|
-
|
24
|
-
endpoint :netzke_submit do |params, this|
|
25
|
-
res = super(params, this)
|
26
|
-
this.close_me
|
27
|
-
res
|
28
|
-
end
|
29
|
-
|
30
|
-
def configure(c)
|
31
|
-
super
|
32
|
-
|
33
|
-
c.model = "Marty::Posting"
|
34
|
-
c.items = [
|
35
|
-
{
|
36
|
-
name: :posting_type__name,
|
37
|
-
scope: lambda { |r|
|
38
|
-
r.where(name: Marty::NewPostingForm.can_perform_actions)
|
39
|
-
},
|
40
|
-
},
|
41
|
-
:comment,
|
42
|
-
]
|
43
|
-
end
|
44
|
-
end
|
45
|
-
|
46
|
-
NewPostingForm = Marty::NewPostingForm
|
@@ -1,21 +0,0 @@
|
|
1
|
-
require 'marty/new_posting_form'
|
2
|
-
|
3
|
-
class Marty::NewPostingWindow < Netzke::Basepack::Window
|
4
|
-
def configure(c)
|
5
|
-
super
|
6
|
-
|
7
|
-
c.title = I18n.t('new_posting')
|
8
|
-
c.modal = true
|
9
|
-
c.items = [:new_posting_form]
|
10
|
-
c.lazy_loading = true
|
11
|
-
c.width = 350
|
12
|
-
c.height = 150
|
13
|
-
end
|
14
|
-
|
15
|
-
component :new_posting_form do |c|
|
16
|
-
c.header = false
|
17
|
-
end
|
18
|
-
|
19
|
-
end
|
20
|
-
|
21
|
-
NewPostingWindow = Marty::NewPostingWindow
|
@@ -1,52 +0,0 @@
|
|
1
|
-
class Marty::PivotGrid < Netzke::Base
|
2
|
-
include self::Endpoints
|
3
|
-
include self::Services
|
4
|
-
include Netzke::Basepack::Columns
|
5
|
-
include Netzke::Basepack::DataAccessor
|
6
|
-
include Netzke::Core::ConfigToDslDelegator
|
7
|
-
|
8
|
-
js_configure do |c|
|
9
|
-
c.require "/home2/abostani/pivot-grid/mzPivotGrid-all.js"
|
10
|
-
|
11
|
-
c.extend = 'Mz.pivot.Grid'
|
12
|
-
c.mixin :pivot_grid
|
13
|
-
|
14
|
-
c.mixins << "Netzke.mixins.Basepack.Columns"
|
15
|
-
c.mixins << "Netzke.mixins.Basepack.GridEventHandlers"
|
16
|
-
|
17
|
-
c.require :extensions
|
18
|
-
end
|
19
|
-
|
20
|
-
css_configure do |c|
|
21
|
-
c.require "/home2/abostani/pivot-grid/mzPivotGrid.css"
|
22
|
-
end
|
23
|
-
|
24
|
-
delegates_to_dsl :model
|
25
|
-
|
26
|
-
def js_configure(c)
|
27
|
-
super
|
28
|
-
|
29
|
-
c.title = c.title || self.class.js_config.properties[:title] || data_class.name.pluralize
|
30
|
-
c.context_menu = context_menu
|
31
|
-
c.columns = {items: js_columns}
|
32
|
-
c.columns_order = columns_order
|
33
|
-
c.inline_data = read if c.load_inline_data
|
34
|
-
c.pri = data_adapter.primary_key
|
35
|
-
end
|
36
|
-
|
37
|
-
def config
|
38
|
-
@config ||= ActiveSupport::OrderedOptions.new.tap do |c|
|
39
|
-
# extend with data_store convenient config object
|
40
|
-
c.data_store = ActiveSupport::OrderedOptions.new
|
41
|
-
end
|
42
|
-
end
|
43
|
-
|
44
|
-
def context_menu
|
45
|
-
config.has_key?(:context_menu) ? config[:context_menu] : default_context_menu
|
46
|
-
end
|
47
|
-
|
48
|
-
# Override to change the default context menu
|
49
|
-
def default_context_menu
|
50
|
-
[]
|
51
|
-
end
|
52
|
-
end
|
@@ -1,45 +0,0 @@
|
|
1
|
-
class Marty::PivotGrid < Netzke::Base
|
2
|
-
module Endpoints
|
3
|
-
extend ActiveSupport::Concern
|
4
|
-
|
5
|
-
included do
|
6
|
-
endpoint :server_read do |data, this|
|
7
|
-
attempt_operation(:read, data, this)
|
8
|
-
end
|
9
|
-
|
10
|
-
# Returns options for a combobox
|
11
|
-
# params receive:
|
12
|
-
# +attr+ - column's name
|
13
|
-
# +query+ - what's typed-in in the combobox
|
14
|
-
# +id+ - selected record id
|
15
|
-
endpoint :get_combobox_options do |params, this|
|
16
|
-
column = final_columns.detect{ |c| c[:name] == params[:attr] }
|
17
|
-
this.data = data_adapter.combo_data(column, params[:query])
|
18
|
-
end
|
19
|
-
|
20
|
-
# Operations:
|
21
|
-
# create, read, update, delete
|
22
|
-
def attempt_operation(op, data, this)
|
23
|
-
# if data is ActionController::Parameters and a scope is in the component config
|
24
|
-
# then ran this in an ActiveModel::ForbiddenAttributesError (rails 4 strong parameters)
|
25
|
-
# solution: in this case convert ActionController::Parameters to a Hash
|
26
|
-
if data.is_a?ActionController::Parameters
|
27
|
-
dataHash = {}
|
28
|
-
data.each do |k,v|
|
29
|
-
#preserve keys as symbol
|
30
|
-
dataHash[k.to_sym] = v
|
31
|
-
end
|
32
|
-
data = dataHash
|
33
|
-
end
|
34
|
-
if !config["prohibit_#{op}"]
|
35
|
-
res = send(op, data)
|
36
|
-
this.netzke_set_result res
|
37
|
-
res
|
38
|
-
else
|
39
|
-
this.netzke_feedback I18n.t("netzke.basepack.grid.cannot_#{op}")
|
40
|
-
this.netzke_set_result(data: [], total: 0)
|
41
|
-
end
|
42
|
-
end
|
43
|
-
end
|
44
|
-
end
|
45
|
-
end
|
@@ -1,150 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* Extended Ext.data.reader.Array, which can handle commands from the endpoint, and fires the 'endpointcommands' event
|
3
|
-
* when commands are present in the endpoint response
|
4
|
-
*/
|
5
|
-
Ext.define('Netzke.classes.Basepack.Grid.ArrayReader', {
|
6
|
-
extend: 'Ext.data.reader.Array',
|
7
|
-
config: {
|
8
|
-
rootProperty: 'data',
|
9
|
-
successProperty: 'success',
|
10
|
-
totalProperty: 'total',
|
11
|
-
},
|
12
|
-
read: function(response) {
|
13
|
-
var data = {data: response.data, total: response.total, success: response.success};
|
14
|
-
delete(response.data);
|
15
|
-
delete(response.total);
|
16
|
-
delete(response.success);
|
17
|
-
this.fireEvent('endpointcommands', response);
|
18
|
-
return this.callParent([data]);
|
19
|
-
}
|
20
|
-
});
|
21
|
-
|
22
|
-
Ext.define('Netzke.classes.Basepack.Grid.Proxy', {
|
23
|
-
extend: 'Ext.data.proxy.Server',
|
24
|
-
|
25
|
-
batch: function(options) {
|
26
|
-
if (!options) return;
|
27
|
-
for (operation in options.operations) {
|
28
|
-
var op = new Ext.data.Operation({action: operation, records: options.operations[operation]});
|
29
|
-
this[op.action](op, Ext.emptyFn, this);
|
30
|
-
}
|
31
|
-
},
|
32
|
-
|
33
|
-
destroy: function(op, callback, scope) {
|
34
|
-
var data = Ext.Array.map(op.getRecords(), function(r) { return r.getData().id; });
|
35
|
-
var store = this.grid.getStore();
|
36
|
-
this.grid.serverDelete(data, function(res){
|
37
|
-
var errors = [];
|
38
|
-
for (id in res) {
|
39
|
-
var error;
|
40
|
-
if (error = res[id].error) {
|
41
|
-
errors.push(error);
|
42
|
-
store.getRemovedRecords().forEach(function(record, i){
|
43
|
-
if (record.getId() == id) {
|
44
|
-
store.insert(record.index, record);
|
45
|
-
}
|
46
|
-
});
|
47
|
-
}
|
48
|
-
}
|
49
|
-
|
50
|
-
// clear store state
|
51
|
-
store.commitChanges();
|
52
|
-
|
53
|
-
if (errors.length > 0) {
|
54
|
-
this.grid.netzkeFeedback([errors]);
|
55
|
-
}
|
56
|
-
|
57
|
-
this.grid.getStore().load();
|
58
|
-
|
59
|
-
}, this);
|
60
|
-
},
|
61
|
-
|
62
|
-
create: function(op, callback, scope) {
|
63
|
-
var records = op.getRecords(),
|
64
|
-
data = Ext.Array.map(records, function(r) { return Ext.apply(r.getData(), {internal_id: r.internalId}); });
|
65
|
-
|
66
|
-
this.grid.serverCreate(data, function(res) {
|
67
|
-
var errors = [];
|
68
|
-
Ext.each(records, function(r) {
|
69
|
-
var rid = r.internalId,
|
70
|
-
recordData = res[rid].record,
|
71
|
-
error = res[rid].error;
|
72
|
-
if (recordData) {
|
73
|
-
serverRecord = this.getReader().read({data: [res[rid].record]}).records[0];
|
74
|
-
r.copyFrom(serverRecord);
|
75
|
-
r.commit();
|
76
|
-
}
|
77
|
-
if (error) { errors.push(error); }
|
78
|
-
}, this);
|
79
|
-
|
80
|
-
if (errors.length == 0) {
|
81
|
-
this.grid.getStore().load();
|
82
|
-
} else {
|
83
|
-
this.grid.netzkeFeedback(errors);
|
84
|
-
}
|
85
|
-
|
86
|
-
}, this);
|
87
|
-
},
|
88
|
-
|
89
|
-
update: function(op, callback, scope) {
|
90
|
-
var data = Ext.Array.map(op.getRecords(), function(r) { return r.getData(); });
|
91
|
-
|
92
|
-
this.grid.serverUpdate(data, function(res) {
|
93
|
-
var errors = [];
|
94
|
-
Ext.each(op.records, function(r) {
|
95
|
-
var rid = r.getId(),
|
96
|
-
recordData = res[rid].record,
|
97
|
-
error = res[rid].error;
|
98
|
-
if (recordData) {
|
99
|
-
serverRecord = this.getReader().read({data: [res[rid].record]}).records[0];
|
100
|
-
r.copyFrom(serverRecord);
|
101
|
-
r.commit();
|
102
|
-
}
|
103
|
-
if (error) { errors.push(error); }
|
104
|
-
}, this);
|
105
|
-
|
106
|
-
if (errors.length == 0) {
|
107
|
-
this.grid.getStore().load();
|
108
|
-
} else {
|
109
|
-
this.grid.netzkeFeedback(errors);
|
110
|
-
}
|
111
|
-
}, this);
|
112
|
-
},
|
113
|
-
|
114
|
-
read: function(operation, callback, scope) {
|
115
|
-
this.grid.serverRead(this.paramsFromOperation(operation), function(res) {
|
116
|
-
this.processResponse(true, operation, {}, res, callback, scope);
|
117
|
-
}, this);
|
118
|
-
return {};
|
119
|
-
},
|
120
|
-
|
121
|
-
// Build consistent request params
|
122
|
-
paramsFromOperation: function(operation) {
|
123
|
-
var params = Ext.apply({}, this.getParams(operation));
|
124
|
-
|
125
|
-
if (params.filter) {
|
126
|
-
params.filters = Ext.decode(params.filter);
|
127
|
-
delete params.filter;
|
128
|
-
}
|
129
|
-
|
130
|
-
if (params.sort) {
|
131
|
-
params.sorters = Ext.decode(params.sort);
|
132
|
-
delete params.sort;
|
133
|
-
}
|
134
|
-
|
135
|
-
Ext.apply(params, this.extraParams);
|
136
|
-
|
137
|
-
return params;
|
138
|
-
}
|
139
|
-
});
|
140
|
-
|
141
|
-
/**
|
142
|
-
* A fix for CheckColumn
|
143
|
-
*/
|
144
|
-
Ext.override(Ext.ux.CheckColumn, {
|
145
|
-
processEvent: function(type) {
|
146
|
-
// by returning true, we'll allow event propagation, so it reacts similarly to other columns
|
147
|
-
if (this.readOnly && type == 'mousedown') return true;
|
148
|
-
else return this.callOverridden(arguments);
|
149
|
-
}
|
150
|
-
});
|
@@ -1,86 +0,0 @@
|
|
1
|
-
{
|
2
|
-
initComponent: function(){
|
3
|
-
// if we are being created by the locking feature - everything is configured already, nothing to do
|
4
|
-
if (this.isLocked) return this.callParent();
|
5
|
-
|
6
|
-
this.plugins = this.plugins || [];
|
7
|
-
this.features = this.features || [];
|
8
|
-
|
9
|
-
// Normalize columns. Extract data fields and meta column.
|
10
|
-
this.netzkeProcessColumns();
|
11
|
-
|
12
|
-
this.netzkeBuildModel('Ext.data.Model');
|
13
|
-
|
14
|
-
delete this.fields;
|
15
|
-
|
16
|
-
// Prepare column model config with columns in the correct order; columns out of order go to the end.
|
17
|
-
var colModelConfig = [];
|
18
|
-
var columns = this.columns;
|
19
|
-
|
20
|
-
Ext.each(this.columnsOrder, function(c) {
|
21
|
-
var mainColConfig;
|
22
|
-
Ext.each(this.columns.items, function(oc) {
|
23
|
-
if (c.name === oc.name) {
|
24
|
-
mainColConfig = Ext.apply({}, oc);
|
25
|
-
return false;
|
26
|
-
}
|
27
|
-
});
|
28
|
-
|
29
|
-
colModelConfig.push(Ext.apply(mainColConfig, c));
|
30
|
-
}, this);
|
31
|
-
|
32
|
-
this.columns.items = colModelConfig;
|
33
|
-
|
34
|
-
// data store
|
35
|
-
this.store = this.netzkeBuildStore();
|
36
|
-
|
37
|
-
// load inline data if available
|
38
|
-
if (this.inlineData) this.store.loadRawData(this.inlineData);
|
39
|
-
|
40
|
-
this.callParent();
|
41
|
-
|
42
|
-
// Context menu
|
43
|
-
if (this.contextMenu) {
|
44
|
-
this.on('itemcontextmenu', this.onItemContextMenu, this);
|
45
|
-
}
|
46
|
-
|
47
|
-
if(this.getStore().autoSync){
|
48
|
-
// if autoSync is enabled, cancel event and call onApply() instead
|
49
|
-
this.getStore().on('beforesync', function(){
|
50
|
-
this.onApply();
|
51
|
-
return false;
|
52
|
-
}, this);
|
53
|
-
}
|
54
|
-
},
|
55
|
-
|
56
|
-
netzkeBuildStore: function() {
|
57
|
-
var store = Ext.create('Ext.data.Store', Ext.apply({
|
58
|
-
model: Netzke.modelName(this.id),
|
59
|
-
proxy: this.netzkeBuildProxy(),
|
60
|
-
pruneModifiedRecords: true,
|
61
|
-
remoteSort: true,
|
62
|
-
remoteFilter: true,
|
63
|
-
pageSize: this.rowsPerPage,
|
64
|
-
autoLoad: !this.loadInlineData
|
65
|
-
}, this.dataStore));
|
66
|
-
|
67
|
-
delete this.dataStore;
|
68
|
-
|
69
|
-
store.getProxy().getReader().on('endpointcommands', function(commands) {
|
70
|
-
this.netzkeBulkExecute(commands);
|
71
|
-
}, this);
|
72
|
-
|
73
|
-
return store;
|
74
|
-
},
|
75
|
-
|
76
|
-
netzkeBuildProxy: function() {
|
77
|
-
return Ext.create('Netzke.classes.Basepack.Grid.Proxy', {
|
78
|
-
reader: this.netzkeBuildReader(),
|
79
|
-
grid: this
|
80
|
-
});
|
81
|
-
},
|
82
|
-
|
83
|
-
netzkeBuildReader: function() {
|
84
|
-
return Ext.create('Netzke.classes.Basepack.Grid.ArrayReader');
|
85
|
-
}
|
86
|
-
}
|