class Peta.Item extends Backbone.Model\r
+ \r
+ initialize: (attr = {}, options = {}) ->\r
+ @url = @default_url()\r
+ super(attr, options)\r
+ @expire_time = options.expire_time\r
+ @boosters = {}\r
+ @templates = {}\r
+ \r
@child_models: () ->\r
@my_manifest().child_models()\r
\r
\r
# ClassMethods\r
\r
+ @default_url: () ->\r
+ '/' + @table_name() + '/'\r
+ \r
@my_class: () ->\r
this\r
\r
@parent_model: () ->\r
null\r
\r
+ @has_picture: () ->\r
+ false\r
+ \r
@path_name: (with_engine = false) ->\r
@table_name()\r
\r
- @pickup_item_name: () ->\r
- @item_name()\r
- \r
- @pickup_column_name: () ->\r
- 'id'\r
- \r
@find_boost_name: (column_name) ->\r
@my_peta().find_boost_name column_name\r
\r
if my_settings\r
attr[manifest.settings_column_name] = my_settings.to_json\r
\r
+ @retrieve: (id, context, options = {}) ->\r
+ item = new this({id: id})\r
+ item.retrieve(context, options)\r
+ \r
+ @trace_routes: () ->\r
+ {}\r
+ \r
#InstanceMethods\r
\r
+ default_url: () ->\r
+ r = @my_class().default_url()\r
+ r = r.concat( @id ) if @id\r
+ r\r
+ \r
singular: () ->\r
@my_class().singular()\r
\r
path_name: (with_engine = false) ->\r
@my_class().path_name(with_engine)\r
\r
- pickup_item_name: () ->\r
- @my_class().pickup_item_name()\r
- \r
- pickup_column_name: () ->\r
- @my_class().pickup_column_name()\r
- \r
- pickup_id: () ->\r
- @get(pickup_column_name())\r
- \r
form_template: (with_engine = false) ->\r
@path_name(with_engine) + '/form'\r
\r
else\r
@item_name()\r
\r
+ get_association: (routes, context, options) ->\r
+ routes = [routes] if _.isString(routes)\r
+ route = routes.shift()\r
+ if _.isEmpty(routes)\r
+ # fetching terminate association. callback\r
+ cxt = options.context || context\r
+ @fetch_association(route, cxt, {\r
+ success: (association_item, options) =>\r
+ options.success.call(context, association_item)\r
+ context: context,\r
+ options: options\r
+ })\r
+ else\r
+ # fetching through associations\r
+ @fetch_association(route, this, {\r
+ success: (association_item, options) =>\r
+ association_item.get_association(routes, this, options)\r
+ context: context,\r
+ options: options\r
+ })\r
+ \r
+ fetch_association: (name, context, options) =>\r
+ a = @my_class().my_manifest().associations\r
+ fetch_options = {\r
+ success: (association_item) =>\r
+ options.success.call(context, association_item, options.options)\r
+ }\r
+ if a.belongs_to[name]\r
+ @get_parent(name, context, fetch_options)\r
+ else if a.has_many[name]\r
+ @get_children(name, context, fetch_options)\r
+ else if a.has_one[name]\r
+ @get_child(name, context, fetch_options)\r
+ else\r
+ console.error('association does not exist in model manifest')\r
+ \r
+ get_parent: (belongs_to_name, context, options = null) ->\r
+ m = Manifest.item_name_to_model(belongs_to_name)\r
+ retriever = new Pettanr.Cache.Retriever(m, @get(belongs_to_name + '_id'))\r
+ return retriever if !options\r
+ @listenTo(retriever, 'retrieve', (item) =>\r
+ options.success.call(context, item)\r
+ )\r
+ retriever.retrieve()\r
+ \r
+ get_child: (has_one_name, context, options = null) ->\r
+ list = @has_one(has_one_name)\r
+ list.open(context, {\r
+ success: (items) =>\r
+ callback = options.success\r
+ item = items[0]\r
+ callback.call(context, item)\r
+ })\r
+ \r
+ get_children: (has_many_name, context, options = null) ->\r
+ list = @has_many(has_many_name)\r
+ list.open(context, {\r
+ success: (items) =>\r
+ callback = options.success\r
+ callback.call(context, items)\r
+ })\r
+ \r
+ has_many: (has_many_name) ->\r
+ has_many_manifest = @my_class().my_manifest().associations.has_many[has_many_name]\r
+ action_name = has_many_manifest.list_action_name\r
+ Locmare.ListGroup.list(\r
+ has_many_name, action_name, {id: @get('id')}\r
+ )\r
+ \r
+ has_one: (has_one_name) ->\r
+ has_one_manifest = @my_class().my_manifest().associations.has_one[has_one_name]\r
+ controller_name = has_one_manifest.model().table_name()\r
+ action_name = has_one_manifest.list_action_name\r
+ Locmare.ListGroup.list(\r
+ controller_name, action_name, {id: @get('id')}\r
+ )\r
+ \r
+ trace_to: (trace_name, context, options) ->\r
+ routes = @my_class().trace_routes()[trace_name]\r
+ if !routes\r
+ console.error('no trace route')\r
+ return\r
+ @get_association(routes, this, {\r
+ success: (association) => \r
+ options.success.call(context, association)\r
+ })\r
+ \r
boosts: (level) ->\r
c = @my_class().my_peta().boost\r
_.each c, (boost_manifest, boost_name) =>\r
@boost boost_manifest\r
\r
boost: (boost_manifest) ->\r
- @boosters ||= {}\r
@boosters[boost_manifest.name] = new Locmare.Booster(boost_manifest, this)\r
# fetched item is not cleared . force write booster\r
#@boosters[boost_manifest.name] ||= new Locmare.Booster(boost_manifest, this)\r
\r
- boosters: () ->\r
- @boosters ||= {}\r
- \r
is_extend_column: (column_name) ->\r
@is_extend_column column_name\r
\r
- is_visible: (operators) ->\r
+ is_visible: (operators = Pettanr.cache.operators) ->\r
if Manifest.manifest().magic_numbers['run_mode'] == 0\r
return false if not operators.is_guest()\r
else\r
return false if not operators.is_resource_reader()\r
true\r
\r
+ retriever: () ->\r
+ new Pettanr.Cache.Retriever(@my_class(), @get('id'))\r
+ \r
+ retrieve: (context, options = {}) ->\r
+ retriever = new Pettanr.Cache.Retriever(@my_class(), @get('id'))\r
+ @listenTo(retriever, 'retrieve', (item) =>\r
+ callback = options.success\r
+ callback.call(context, item)\r
+ )\r
+ retriever.retrieve(options.force)\r
+ \r
+ @pick_item_name: () ->\r
+ null\r
+ \r
+ @pick_model: () ->\r
+ Manifest.item_name_to_model(@pick_item_name())\r
+ \r
+ @traceable_item_names: () ->\r
+ []\r
+ \r
+ @is_traceable: (item_name) ->\r
+ _.contains(@traceable_item_names(), item_name)\r
+ \r
+ @is_picker_inspire: (item_name) ->\r
+ item_name == @item_name()\r
+ \r
+ @is_picker_trace: (item_name) ->\r
+ @is_traceable(item_name)\r
+ \r
+ @is_picker_pick: (item_name) ->\r
+ item_name == @pick_item_name()\r
+ \r
+ @pick_type: (item_name) ->\r
+ if @is_picker_inspire(item_name)\r
+ 'inspire'\r
+ else if @is_picker_trace(item_name)\r
+ 'trace'\r
+ else if @is_picker_pick(item_name)\r
+ 'pick'\r
+ else\r
+ 'none'\r
+ \r
+ symbol_option: (context, options) ->\r
+ @trace_to('symbol', this, {\r
+ success: (symbol_item) => \r
+ options.success.call(context, symbol_item.to_symbol())\r
+ })\r
+ \r
+ to_symbol: () ->\r
+ @tmb_opt_img_tag()\r
+ \r
icon_view: (half) ->\r
new Pettanr.Views[@my_class().singular()].Icon({item: this, half: half})\r
\r
+ @index_url: () ->\r
+ Pettanr.url(@table_name(), 'index', {id: null})\r
+ \r
+ index_url: () ->\r
+ @my_class().index_url()\r
+ \r
+ list_url: (action_name = 'index') ->\r
+ Pettanr.url(@table_name(), action_name, {id: @get('id')})\r
+ \r
+ show_url: () ->\r
+ Pettanr.url(@table_name(), 'show', {id: @get('id')})\r
+ \r
+ prof_url: () ->\r
+ Pettanr.url(@table_name(), 'show', {id: @get('id'), format: 'prof'})\r
+ \r
+ new_url: () ->\r
+ Pettanr.url(@table_name(), 'new', {})\r
+ \r
+ create_url: () ->\r
+ Pettanr.url(@table_name(), 'create', {})\r
+ \r
+ edit_url: () ->\r
+ Pettanr.url(@table_name(), 'edit', {id: @get('id')})\r
+ \r
+ update_url: () ->\r
+ Pettanr.url(@table_name(), 'update', {id: @get('id')})\r
+ \r
+ destroy_url: () ->\r
+ Pettanr.url(@table_name(), 'destroy', {id: @get('id')})\r
+ \r
+ hold: () ->\r
+ Pettanr.cache.hold(this)\r
+ \r
+ fix: () ->\r
+ Pettanr.cache.fix(this)\r
+ \r
+ release: () ->\r
+ Pettanr.cache.release(this)\r
+ \r
+ save: (model_attr) ->\r
+ super(model_attr || @attributes, {\r
+ success: (model, response, options) =>\r
+ @trigger('save:success', model, response)\r
+ error: (model, response, options) =>\r
+ @trigger('save:fail', model, response)\r
+ })\r
+ \r
+ destroy: () ->\r
+ super({\r
+ success: (model, response, options) =>\r
+ @trigger('destroy:success', model, response)\r
+ error: (model, response, options) =>\r
+ @trigger('destroy:fail', model, response)\r
+ })\r
+ \r
is_editize: () ->\r
@editor\r
\r
dom_id: () ->\r
(@get('id') || '').toString()\r
\r
+ cache_key: () ->\r
+ @table_name() + '-' + @dom_id()\r
+ \r
dom_pool_type: () ->\r
@new_record ? 'stored' : 'new'\r
\r