diff --git a/smart_service/apis/publish_api.py b/smart_service/apis/publish_api.py index 86b78a9..836a3d8 100644 --- a/smart_service/apis/publish_api.py +++ b/smart_service/apis/publish_api.py @@ -126,7 +126,8 @@ def json_grouping(args, language): subsystem_out = [] for j in subsystem[d][i]: - subsys = frappe.db.sql('''select `tabSystem Mapping_Sub System`.idx as subSystemdisplayorder, systems,sub_systems, symptom, component, estimated_time, rts, mat, cover_image, `tabSub Systems`.myid, + subsys = frappe.db.sql('''select `tabSystem Mapping_Sub System`.idx as subSystemdisplayorder, systems,sub_systems, symptom, component, + estimate_time as estimated_time, rts, mat, cover_image, `tabSub Systems`.myid, `tabSystem Mapping_Sub System`.active_status,`tabSystem Mapping_Sub System`.cover_image from {4}.`tabSystem Mapping_Sub System` inner join {4}.`tabSub Systems` on `tabSystem Mapping_Sub System`.sub_systems = `tabSub Systems`.name where `tabSystem Mapping_Sub System`.parent like '{0}-{3}%' and systems='{1}' and sub_systems='{2}';'''.format( diff --git a/smart_service/apis/update_validation.py b/smart_service/apis/update_validation.py index 5e3b0a9..fddf895 100644 --- a/smart_service/apis/update_validation.py +++ b/smart_service/apis/update_validation.py @@ -202,7 +202,7 @@ def check_vehicle_update(vehicle_list): subsystem_out = [] for j in appendDict[d][i]: subsys = frappe.db.sql('''select `tabSystem Mapping_Sub System`.idx as subSystemdisplayorder, systems,sub_systems, symptom, - component, estimated_time, rts, mat, cover_image, `tabSub Systems`.myid,`tabSystem Mapping_Sub System`.active_status, + component, estimate_time as estimated_time, rts, mat, cover_image, `tabSub Systems`.myid,`tabSystem Mapping_Sub System`.active_status, `tabSystem Mapping_Sub System`.cover_image from {4}.`tabSystem Mapping_Sub System` inner join {4}.`tabSub Systems` on `tabSystem Mapping_Sub System`.sub_systems = `tabSub Systems`.name where `tabSystem Mapping_Sub System`.parent like '{0}-{3}%' and systems='{1}' and sub_systems='{2}' and `tabSystem Mapping_Sub System`.active_status = 'Active';'''.format(d, i, j, l_id, current_db_name), as_dict=True) diff --git a/smart_service/fixtures/client_script.json b/smart_service/fixtures/client_script.json index c793399..5a79399 100644 --- a/smart_service/fixtures/client_script.json +++ b/smart_service/fixtures/client_script.json @@ -173,12 +173,12 @@ "doctype": "Client Script", "dt": "Publish", "enabled": 1, - "modified": "2022-04-08 22:16:57.218000", + "modified": "2022-04-09 15:46:18.201387", "name": "Publish-Form", "parent": null, "parentfield": null, "parenttype": null, - "script": "cur_frm.fields_dict['variant_mapping'].get_query = function(doc, cdt, cdn) {\n return {query:\"smart_service.transactions.doctype.procedure.procedure.variant\",};\n};\n\ncur_frm.fields_dict['vehicle'].get_query = function(doc, cdt, cdn) {\n return {query:\"smart_service.masters.doctype.vehicle.vehicle.vehicle_filter\",};\n};\n\nvar lang_set_first_time = true;\n\nfrappe.ui.form.on('Publish', {\n onload: function(frm) {\n lang_set_first_time = true;\n frm.get_field('publish_documents').grid.cannot_add_rows = true;\n },\n planned_publish_date: function(frm){\n var date = (frappe.datetime.nowdate())\n if (frm.doc.planned_publish_date < date){\n frm.doc.planned_publish_date = '';\n cur_frm.refresh_fields();\n frappe.msgprint(\"Planned Publish Date: You can not select past date\");\n frappe.validated = false;\n }\n\n },\n refresh: function(frm) {\n if (frm.doc.docstatus === 1 && frm.doc.publish_type == \"Internal\" && frm.doc.publish_status == 'Published' && !frm.doc.global_publish) {\n frm.add_custom_button(__('Global Publish'), function() {\n frappe.call({\n method: \"smart_service.transactions.doctype.publish.publish.global_publish\",\n args: {\n \"doc\": frm.doc.name,\n },\n callback: function(r) {\n cur_frm.reload_doc();\n }\n });\n }).addClass(\"btn-warning\").css({ 'background-color': '#f5b0cd', 'color': 'black' });\n }\n\n\n if(frm.doc.docstatus === 1 && frm.doc.publish_status == 'To Publish'){\n frm.add_custom_button(__('Publish'), function(){\n // frm.trigger(\"auto_version_update\");\n frappe.confirm('Are you sure you want to Internal Publish?',\n () => {\n // action to perform if Yes is selected\n if(frm.doc.vehicle && frm.doc.language && frm.doc.publish_type){\n \t\t frappe.call({\n method: 'smart_service.transactions.doctype.publish.publish.cal_ver',\n args: {\n vehicle: frm.doc.vehicle,\n lang:frm.doc.language,\n publish_type:frm.doc.publish_type,\n doc:frm.doc.name\n },\n callback: (r) => {\n frm.set_value('version',r.message);\n cur_frm.refresh_field('version')\n // },\n \n // });\n //\t}\n if(frm.doc.docstatus === 1 && frm.doc.publish_status == 'To Publish'){\n frappe.call({\n method: \"smart_service.apis.publish_api.api_procedure\",\n // async:false,\n args: {\n \"args\":frm.doc.name,\n \"vehicle\": frm.doc.vehicle,\n \"language\":frm.doc.language,\n \"version\":frm.doc.version\n },\n callback: function(r) {\n frm.set_value('publish_status','Published');\n frm.set_value('actual_published_date',frappe.datetime.nowdate());\n // frm.set_value('published_link',r.message)\n frappe.msgprint(__());\n frappe.msgprint({\n title: __('Notification'),\n message: __('Successfully Published' + r.message),\n primary_action:{\n action(values) {\n frm.save('Update');\n }\n }\n });\n \n }\n \n });\n }\n \n },\n })\n }\n \n }, () => {\n // action to perform if No is selected\n }); \n }).addClass(\"btn-warning\").css({'background-color':'#f5b0cd', 'color':'black'});\n } else if(frm.doc.publish_status == 'Published'){\n frm.set_read_only();\n frm.set_df_property('add_variant_mapping_to_publish', 'hidden', 1);\n }\n \n if(frm.doc.docstatus === 0 && frm.doc.publish_status == 'To Publish'){\n frm.get_field('system_mapping').grid.add_custom_button(__('Add to Publish'), function() {\n\t var added = 0;\n\t var topublish = [];\n if (frm.doc.publish_type =='Global'){topublish = ['Publish Ready'];}else{topublish = ['Review Pending','Publish Ready','Approval Pending'];}\n frm.doc.system_mapping.forEach(row => {\n if (topublish.indexOf(row.procedure_status) > -1){\n var dulicate = false;\n if (frm.doc.publish_documents){\n frm.doc.publish_documents.forEach(publishrow => {\n if (frm.doc.variant_mapping == publishrow.variant_mapping && \n row.systems == publishrow.system && \n row.sub_systems == publishrow.sub_system && row.procedure == publishrow.procedure_link){\n dulicate = true;\n }\n });\n }\n if (dulicate === false){\n var child = cur_frm.add_child(\"publish_documents\");\n child.variant_mapping = frm.doc.variant_mapping;\n child.system = row.systems;\n child.sub_system = row.sub_systems;\n child.procedure_link = row.procedure;\n child.procedure_status = row.procedure_status;\n child.item_category = \"System Mapping\";\n child.variant = frm.doc.variant;\n refresh_field(\"publish_documents\");\n added += 1;\n }\n }\n });\n if (added){frappe.msgprint(__(added + \" Doc(s) Added\"));}\n else{frappe.msgprint(__(\"No Doc Added\"));}\n });\n }\n frm.fields_dict.system_mapping.grid.grid_buttons.find('.btn-custom').removeClass('btn-default').addClass('btn-primary');\n\n\t frm.get_field('variant_mapping_assets').grid.add_custom_button(__('Add to Publish'), function() {\n\t var added = 0;\n\t var topublish = [];\n frm.doc.variant_mapping_assets.forEach(row => {\n if (row.active_status == \"Active\" || row.active_status == \"Inactive\"){\n var dulicate = false;\n if (frm.doc.publish_documents){\n frm.doc.publish_documents.forEach(publishrow => {\n if (frm.doc.variant_mapping == publishrow.variant_mapping && \n row.category == publishrow.asset_category){\n dulicate = true;\n }\n });\n }\n if (dulicate === false){\n var child = cur_frm.add_child(\"publish_documents\");\n child.variant_mapping = frm.doc.variant_mapping;\n child.asset_category = row.category;\n child.item_category = \"Variant Mapping Assets\";\n child.variant = frm.doc.variant;\n refresh_field(\"publish_documents\");\n added += 1;\n }\n }\n });\n if (added){frappe.msgprint(__(added + \" Doc(s) Added\"));}\n else{frappe.msgprint(__(\"No Doc Added\"));}\n });\n \n frm.fields_dict.variant_mapping_assets.grid.grid_buttons.find('.btn-custom').removeClass('btn-default').addClass('btn-primary');\n\t},\n\tvalidate: function(frm) {\n\t \n\t if (frm.fields_dict.publish_documents.grid.grid_rows.length === 0){\n\t frappe.msgprint(__(\"No item selected to Publish\"));\n\t frappe.validated = false;\n\t }\n if (frm.doc.planned_publish_date < frappe.datetime.get_today()) {\n frappe.msgprint(__(\"Planned Publish Date: You can not select past date\"));\n frappe.validated = false;\n }\n },\n before_save: function(frm) {\n //frm.set_value('variant_mapping',null);\n // frm.set_value('system_mapping', null);\n // frm.set_value('variant_mapping_assets', null);\n },\n before_cancel: function(frm) {\n if (frm.doc.publish_status == 'Published'){\n //frappe.throw(__('You can not cancel a Published Document!'));\n //frappe.validated = false;\n }\n },\n\tvariant_mapping:function(frm){\n\t frappe.db.get_value('Variant Mapping', { name: frm.doc.variant_mapping }, ['fuel', 'transmission', 'drive'], (r) => {\n frm.doc.variant = r.fuel + ',' + r.transmission + ',' + r.drive;\n cur_frm.refresh_field('variant');\n })\n\n\t var km_name = frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-KM\";\n\t frappe.db.get_value('Kilometer Mapping', {name: km_name}, 'workflow_state' , (r) =>{\n\t if(r.workflow_state == \"Draft\"){\n\t frm.doc.kilometer_mapping = '';\n\t frm.refresh_field('kilometer_mapping')\n\t frappe.msgprint(\"Kilometer Mapping Draft record not loaded\")\n\t }\n\t \n\t else{\n if (frm.doc.variant_mapping === undefined) {return;}\n frm.set_value('system_mapping', null);\n frm.set_value('variant_mapping_assets', null);\n frappe.db.exists('Kilometer Mapping', frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-KM\")\n .then(exists => {\n if (exists){\n frm.set_value(\"kilometer_mapping\",frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-KM\");\n frm.refresh_field('kilometer_mapping')\n } else {\n // frm.set_value(\"kilometer_mapping\",null);\n frm.set_value(\"km_active_status\",\"Not Configured!\");\n }\n });\n\t }\n\t })\n\t},\n\tkm_active_status:function(frm){\n \tif(frm.doc.km_active_status === \"\" || frm.doc.km_active_status === null) {return;}\n var filter = frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-SM\";\n if (frm.doc.variant_mapping_status == \"Active\" && frm.doc.km_active_status == \"Active\") {\n frappe.call({\n \"method\": \"smart_service.transactions.doctype.publish.publish.get_system\",\n \"args\": {\n \"doc\": frm.doc.variant_mapping,\n },\n callback: function(r) {\n $.each(r.message, function(index, row) {\n var child;\n child = cur_frm.add_child(\"system_mapping\");\n child.systems = row.systems;\n child.sub_systems = row.sub_systems;\n child.active_status = row.active_status;\n child.symptom = row.symptom;\n child.component = row.component;\n child.estimated_time = row.estimated_time;\n child.rts = row.rts;\n child.mat = row.mat;\n //child.cover_image = row.cover_image;\n child.procedure = row.procedure;\n child.procedure_status = row.procedure_status;\n cur_frm.refresh_field('variant_mapping_assets');\n cur_frm.refresh_fields();\n })\n }\n\n })\n \n frappe.call({\n \"method\": \"smart_service.transactions.doctype.publish.publish.get_vm_asset\",\n \"args\": {\n \"doc\": frm.doc.variant_mapping,\n },\n callback: function(r) {\n $.each(r.message, function(index, row) {\n var child;\n child = cur_frm.add_child(\"variant_mapping_assets\");\n child.category = row.category;\n child.language = row.language;\n child.attach_file = row.attach_file;\n child.active_status = row.active_status;\n cur_frm.refresh_field('variant_mapping_assets');\n cur_frm.refresh_fields();\n })\n }\n\n })\n \n frappe.call({\n \"method\": \"smart_service.transactions.doctype.publish.publish.get_sm_asset\",\n \"args\": {\n \"doc\": frm.doc.variant_mapping,\n },\n callback: function(r) {\n $.each(r.message, function(index, row) {\n var child_row;\n child_row = cur_frm.add_child(\"variant_mapping_assets\");\n child_row.category = row.systems;\n child_row.language = row.language;\n child_row.attach_file = row.system_asset;\n child_row.active_status = row.active_status;\n cur_frm.refresh_field('variant_mapping_assets');\n cur_frm.refresh_fields();\n })\n }\n\n })\n /* frappe.db.get_list('System Mapping_Sub System', {\n fields: ['systems', 'sub_systems','active_status','symptom','component','estimated_time','rts','mat','procedure','procedure_status'],\n filters: { parent: filter,\n procedure_is_published: [\"=\",'0'], }\n }).then(records => {\n //frm.set_value('system_mapping', null);\n var child;\n $.each(records, function(index, row){\n child = cur_frm.add_child(\"system_mapping\");\n child.systems = row.systems;\n child.sub_systems = row.sub_systems;\n child.active_status = row.active_status;\n child.symptom = row.symptom;\n child.component = row.component;\n child.estimated_time = row.estimated_time;\n child.rts = row.rts;\n child.mat = row.mat;\n //child.cover_image = row.cover_image;\n child.procedure = row.procedure;\n child.procedure_status = row.procedure_status;\n if (row.procedure) {\n frappe.call({\n \"method\": \"smart_service.transactions.doctype.procedure.procedure.get_doc_status\",\n \"args\": {\n \"docname\": row.procedure,\n \t},\n \tasync:false,\n \tcallback:function(r){\n child.procedure_status = r.message; //doc.workflow_state;\n if (r.message == 'Review Pending'){$(\"div[data-fieldname=system_mapping]\").find('div.grid-row[data-idx=\"'+ child.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffa243'});}\n else if (r.message == 'Publish Ready'){$(\"div[data-fieldname=system_mapping]\").find('div.grid-row[data-idx=\"'+ child.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#cfffcf'});}\n //refresh_field(\"system_mapping\");\n \t}\n });\n //frappe.db.get_doc('Procedure', row.procedure)\n // .then(doc => {\n \n // child.procedure_status = doc.workflow_state;\n // if (doc.workflow_state == 'Review Pending'){$(\"div[data-fieldname=system_mapping]\").find('div.grid-row[data-idx=\"'+ child.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffa243'});}\n // else if (doc.workflow_state == 'Publish Ready'){$(\"div[data-fieldname=system_mapping]\").find('div.grid-row[data-idx=\"'+ child.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#cfffcf'});}\n // frm.refresh_field(\"system_mapping\");\n // });\n }\n });\n frm.refresh_field('system_mapping');\n });\n \n frappe.db.get_list('Variant Mapping_Assets', {\n fields: ['category', 'language','active_status','attach_file'],\n filters: {\n parent: frm.doc.variant_mapping, \n language: frm.doc.language,\n published: [\"=\",'0'],\n \n }\n }).then(assets => {\n var child;\n $.each(assets, function(index, row){\n //child = cur_frm.add_child(\"variant_mapping_assets\");\n // console.log(row.category)\n // child.category = row.category;\n // child.language = row.language;\n //child.attach_file = row.attach_file;\n // child.active_status = row.active_status;\n });\n \n frappe.db.get_list('System Mapping_System Assets', {\n fields: ['systems', 'language','active_status','system_asset'],\n filters: {\n parent: filter,\n published: [\"=\",'0'],\n \n }\n }).then(asset => {\n var child_row;\n $.each(asset, function(index, row){\n child_row = cur_frm.add_child(\"variant_mapping_assets\");\n child_row.category = row.systems;\n child_row.language = row.language;\n child_row.attach_file = row.system_asset;\n child_row.active_status = row.active_status;\n });\n cur_frm.refresh_field('variant_mapping_assets');\n })\n \n });*/\n \n } else {\n if (frm.doc.variant_mapping_status != null){\n frappe.msgprint({\n title: __('Notification'),\n indicator: 'red',\n message: __('System Mapping & Assets not loaded as the selected Variant/Kilometer Mapping is Inactive or not configured')\n });\n }\n }\t\n\t},\n\tadd_variant_mapping_to_publish:function(frm){\n var dulicate = false;\n if (frm.doc.publish_documents){\n frm.doc.publish_documents.forEach(publishrow => {\n if (frm.doc.variant_mapping == publishrow.variant_mapping && publishrow.systems === undefined && publishrow.sub_systems === undefined && publishrow.procedure === undefined){\n dulicate = true;\n }\n });\n }\n if (dulicate === false){\n var child = cur_frm.add_child(\"publish_documents\");\n child.variant_mapping = frm.doc.variant_mapping;\n child.item_category = \"Variant Mapping\";\n refresh_field(\"publish_documents\");\n frappe.msgprint(__(frm.doc.variant_mapping + \" Added\"));\n }\n\t},\n\tkm_report: function(frm, cdt, cdn) {\n frappe.set_route(\"query-report\", 'Kilometer Mapping', { 'kilometer_mapping': frm.doc.kilometer_mapping });\n },\n\n\tvehicle:function(frm){\n\t frappe.call({\n method: \"smart_service.transactions.doctype.publish.publish.old_publish\",\n async:false,\n args: {\n \"vehicle\": frm.doc.vehicle,\n \"language\": frm.doc.language\n },\n callback: function(r) {\n if (r.message) {\n var vehicle = frm.doc.vehicle;\n cur_frm.doc.vehicle = '';\n cur_frm.doc.vehicle_status = '';\n cur_frm.refresh_field('vehicle');\n cur_frm.refresh_field('vehicle_status');\n frappe.throw(\"Already publish record \" + r.message + \" created for \" + vehicle + \" vehicle. Please edit already available internal publish!\")\n }\n }\n });\n\n\n\t \n\t if (frm.doc.vehicle === undefined || frm.doc.vehicle === null) {return;}\n\t //frm.trigger(\"auto_version_update\");\n var filter = frm.doc.vehicle;\n filter = \"%\"+filter+\"%\";\n frm.set_query(\"variant_mapping\", function() {\n return {\n \"filters\": {\n // \"name\": [\"like\",filter]\n \"vehicle\":frm.doc.vehicle\n }\n };\n });\n $(\"[data-fieldname=variant_mapping]\").focus();\n if(frm.doc.vehicle){\n frm.set_df_property('vehicle', 'read_only', 1);\n }\n\t},\n\tlanguage:function(frm){\n if (!lang_set_first_time){\n frappe.confirm('This will clear all the data, are you sure you want to proceed?',\n () => {\n // action to perform if Yes is selected\n frm.set_value('variant_mapping',null);\n frm.set_value('variant_mapping_status',null);\n frm.set_df_property('add_variant_mapping_to_publish', 'hidden', 1);\n frm.set_value('system_mapping', null);\n frm.set_value('variant_mapping_assets', null);\n frm.set_value('publish_documents', null);\n lang_set_first_time = false;\n }, () => {\n // action to perform if No is selected\n });\n } else {lang_set_first_time = false;}\n\t},\n\tauto_version_update:function(frm){\n \tif(frm.doc.vehicle && frm.doc.language && frm.doc.publish_type){\n \t console.log(\"called ver\")\n \t\tfrappe.call({\n method: 'smart_service.transactions.doctype.publish.publish.cal_ver',\n args: {\n vehicle: frm.doc.vehicle,\n lang:frm.doc.language,\n publish_type:frm.doc.publish_type,\n doc:frm.doc.name\n },\n callback: (r) => {\n //frm.set_value('version',r.message);\n cur_frm.refresh_field('version')\n console.log(frm.doc.version);\n },\n error: (r) => {\n // on error\n }\n });\n \t}\n\t},\n});", + "script": "cur_frm.fields_dict['variant_mapping'].get_query = function(doc, cdt, cdn) {\n return {query:\"smart_service.transactions.doctype.procedure.procedure.variant\",};\n};\n\ncur_frm.fields_dict['vehicle'].get_query = function(doc, cdt, cdn) {\n return {query:\"smart_service.masters.doctype.vehicle.vehicle.vehicle_filter\",};\n};\n\nvar lang_set_first_time = true;\n\nfrappe.ui.form.on('Publish', {\n onload: function(frm) {\n lang_set_first_time = true;\n frm.get_field('publish_documents').grid.cannot_add_rows = true;\n },\n planned_publish_date: function(frm){\n var date = (frappe.datetime.nowdate())\n if (frm.doc.planned_publish_date < date){\n frm.doc.planned_publish_date = '';\n cur_frm.refresh_fields();\n frappe.msgprint(\"Planned Publish Date: You can not select past date\");\n frappe.validated = false;\n }\n\n },\n refresh: function(frm) {\n if (frm.doc.docstatus === 1 && frm.doc.publish_type == \"Internal\" && frm.doc.publish_status == 'Published' && !frm.doc.global_publish) {\n frm.add_custom_button(__('Global Publish'), function() {\n frappe.call({\n method: \"smart_service.transactions.doctype.publish.publish.global_publish\",\n args: {\n \"doc\": frm.doc.name,\n },\n callback: function(r) {\n cur_frm.reload_doc();\n }\n });\n }).addClass(\"btn-warning\").css({ 'background-color': '#f5b0cd', 'color': 'black' });\n }\n\n\n if(frm.doc.docstatus === 1 && frm.doc.publish_status == 'To Publish'){\n frm.add_custom_button(__('Publish'), function(){\n // frm.trigger(\"auto_version_update\");\n frappe.confirm('Are you sure you want to Internal Publish?',\n () => {\n // action to perform if Yes is selected\n if(frm.doc.vehicle && frm.doc.language && frm.doc.publish_type){\n \t\t frappe.call({\n method: 'smart_service.transactions.doctype.publish.publish.cal_ver',\n args: {\n vehicle: frm.doc.vehicle,\n lang:frm.doc.language,\n publish_type:frm.doc.publish_type,\n doc:frm.doc.name\n },\n callback: (r) => {\n frm.set_value('version',r.message);\n cur_frm.refresh_field('version')\n // },\n \n // });\n //\t}\n if(frm.doc.docstatus === 1 && frm.doc.publish_status == 'To Publish'){\n frappe.call({\n method: \"smart_service.apis.publish_api.api_procedure\",\n // async:false,\n args: {\n \"args\":frm.doc.name,\n \"vehicle\": frm.doc.vehicle,\n \"language\":frm.doc.language,\n \"version\":frm.doc.version\n },\n callback: function(r) {\n frm.set_value('publish_status','Published');\n frm.set_value('actual_published_date',frappe.datetime.nowdate());\n // frm.set_value('published_link',r.message)\n frappe.msgprint(__());\n frappe.msgprint({\n title: __('Notification'),\n message: __('Successfully Published' + r.message),\n primary_action:{\n action(values) {\n frm.save('Update');\n }\n }\n });\n \n }\n \n });\n }\n \n },\n })\n }\n \n }, () => {\n // action to perform if No is selected\n }); \n }).addClass(\"btn-warning\").css({'background-color':'#f5b0cd', 'color':'black'});\n } else if(frm.doc.publish_status == 'Published'){\n frm.set_read_only();\n frm.set_df_property('add_variant_mapping_to_publish', 'hidden', 1);\n }\n \n if(frm.doc.docstatus === 0 && frm.doc.publish_status == 'To Publish'){\n frm.get_field('system_mapping').grid.add_custom_button(__('Add to Publish'), function() {\n\t var added = 0;\n\t var topublish = [];\n if (frm.doc.publish_type =='Global'){topublish = ['Publish Ready'];}else{topublish = ['Review Pending','Publish Ready','Approval Pending'];}\n frm.doc.system_mapping.forEach(row => {\n if (topublish.indexOf(row.procedure_status) > -1){\n var dulicate = false;\n if (frm.doc.publish_documents){\n frm.doc.publish_documents.forEach(publishrow => {\n if (frm.doc.variant_mapping == publishrow.variant_mapping && \n row.systems == publishrow.system && \n row.sub_systems == publishrow.sub_system && row.procedure == publishrow.procedure_link){\n dulicate = true;\n }\n });\n }\n if (dulicate === false){\n var child = cur_frm.add_child(\"publish_documents\");\n child.variant_mapping = frm.doc.variant_mapping;\n child.system = row.systems;\n child.sub_system = row.sub_systems;\n child.procedure_link = row.procedure;\n child.procedure_status = row.procedure_status;\n child.item_category = \"System Mapping\";\n child.variant = frm.doc.variant;\n refresh_field(\"publish_documents\");\n added += 1;\n }\n }\n });\n if (added){frappe.msgprint(__(added + \" Doc(s) Added\"));}\n else{frappe.msgprint(__(\"No Doc Added\"));}\n });\n }\n frm.fields_dict.system_mapping.grid.grid_buttons.find('.btn-custom').removeClass('btn-default').addClass('btn-primary');\n\n\t frm.get_field('variant_mapping_assets').grid.add_custom_button(__('Add to Publish'), function() {\n\t var added = 0;\n\t var topublish = [];\n frm.doc.variant_mapping_assets.forEach(row => {\n if (row.active_status == \"Active\" || row.active_status == \"Inactive\"){\n var dulicate = false;\n if (frm.doc.publish_documents){\n frm.doc.publish_documents.forEach(publishrow => {\n if (frm.doc.variant_mapping == publishrow.variant_mapping && \n row.category == publishrow.asset_category){\n dulicate = true;\n }\n });\n }\n if (dulicate === false){\n var child = cur_frm.add_child(\"publish_documents\");\n child.variant_mapping = frm.doc.variant_mapping;\n child.asset_category = row.category;\n child.item_category = \"Variant Mapping Assets\";\n child.variant = frm.doc.variant;\n refresh_field(\"publish_documents\");\n added += 1;\n }\n }\n });\n if (added){frappe.msgprint(__(added + \" Doc(s) Added\"));}\n else{frappe.msgprint(__(\"No Doc Added\"));}\n });\n \n frm.fields_dict.variant_mapping_assets.grid.grid_buttons.find('.btn-custom').removeClass('btn-default').addClass('btn-primary');\n\t},\n\tvalidate: function(frm) {\n\t \n\t if (frm.fields_dict.publish_documents.grid.grid_rows.length === 0){\n\t frappe.msgprint(__(\"No item selected to Publish\"));\n\t frappe.validated = false;\n\t }\n if (frm.doc.planned_publish_date < frappe.datetime.get_today()) {\n frappe.msgprint(__(\"Planned Publish Date: You can not select past date\"));\n frappe.validated = false;\n }\n },\n before_save: function(frm) {\n //frm.set_value('variant_mapping',null);\n // frm.set_value('system_mapping', null);\n // frm.set_value('variant_mapping_assets', null);\n },\n before_cancel: function(frm) {\n if (frm.doc.publish_status == 'Published'){\n //frappe.throw(__('You can not cancel a Published Document!'));\n //frappe.validated = false;\n }\n },\n\tvariant_mapping:function(frm){\n\t frappe.db.get_value('Variant Mapping', { name: frm.doc.variant_mapping }, ['fuel', 'transmission', 'drive'], (r) => {\n frm.doc.variant = r.fuel + ',' + r.transmission + ',' + r.drive;\n cur_frm.refresh_field('variant');\n })\n\n\t var km_name = frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-KM\";\n\t frappe.db.get_value('Kilometer Mapping', {name: km_name}, 'workflow_state' , (r) =>{\n\t if(r.workflow_state == \"Draft\"){\n\t frm.doc.kilometer_mapping = '';\n\t frm.refresh_field('kilometer_mapping')\n\t frappe.msgprint(\"Kilometer Mapping Draft record not loaded\")\n\t }\n\t \n\t else{\n if (frm.doc.variant_mapping === undefined) {return;}\n frm.set_value('system_mapping', null);\n frm.set_value('variant_mapping_assets', null);\n frappe.db.exists('Kilometer Mapping', frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-KM\")\n .then(exists => {\n if (exists){\n frm.set_value(\"kilometer_mapping\",frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-KM\");\n frm.refresh_field('kilometer_mapping')\n } else {\n // frm.set_value(\"kilometer_mapping\",null);\n frm.set_value(\"km_active_status\",\"Not Configured!\");\n }\n });\n\t }\n\t })\n\t},\n\tkm_active_status:function(frm){\n \tif(frm.doc.km_active_status === \"\" || frm.doc.km_active_status === null) {return;}\n var filter = frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-SM\";\n if (frm.doc.variant_mapping_status == \"Active\" && frm.doc.km_active_status == \"Active\") {\n frappe.call({\n \"method\": \"smart_service.transactions.doctype.publish.publish.get_system\",\n \"args\": {\n \"doc\": frm.doc.variant_mapping,\n },\n callback: function(r) {\n $.each(r.message, function(index, row) {\n var child;\n child = cur_frm.add_child(\"system_mapping\");\n child.systems = row.systems;\n child.sub_systems = row.sub_systems;\n child.active_status = row.active_status;\n child.symptom = row.symptom;\n child.component = row.component;\n child.estimate_time = row.estimate_time;\n child.rts = row.rts;\n child.mat = row.mat;\n //child.cover_image = row.cover_image;\n child.procedure = row.procedure;\n child.procedure_status = row.procedure_status;\n cur_frm.refresh_field('variant_mapping_assets');\n cur_frm.refresh_fields();\n })\n }\n\n })\n \n frappe.call({\n \"method\": \"smart_service.transactions.doctype.publish.publish.get_vm_asset\",\n \"args\": {\n \"doc\": frm.doc.variant_mapping,\n },\n callback: function(r) {\n $.each(r.message, function(index, row) {\n var child;\n child = cur_frm.add_child(\"variant_mapping_assets\");\n child.category = row.category;\n child.language = row.language;\n child.attach_file = row.attach_file;\n child.active_status = row.active_status;\n cur_frm.refresh_field('variant_mapping_assets');\n cur_frm.refresh_fields();\n })\n }\n\n })\n \n frappe.call({\n \"method\": \"smart_service.transactions.doctype.publish.publish.get_sm_asset\",\n \"args\": {\n \"doc\": frm.doc.variant_mapping,\n },\n callback: function(r) {\n $.each(r.message, function(index, row) {\n var child_row;\n child_row = cur_frm.add_child(\"variant_mapping_assets\");\n child_row.category = row.systems;\n child_row.language = row.language;\n child_row.attach_file = row.system_asset;\n child_row.active_status = row.active_status;\n cur_frm.refresh_field('variant_mapping_assets');\n cur_frm.refresh_fields();\n })\n }\n\n })\n /* frappe.db.get_list('System Mapping_Sub System', {\n fields: ['systems', 'sub_systems','active_status','symptom','component','estimated_time','rts','mat','procedure','procedure_status'],\n filters: { parent: filter,\n procedure_is_published: [\"=\",'0'], }\n }).then(records => {\n //frm.set_value('system_mapping', null);\n var child;\n $.each(records, function(index, row){\n child = cur_frm.add_child(\"system_mapping\");\n child.systems = row.systems;\n child.sub_systems = row.sub_systems;\n child.active_status = row.active_status;\n child.symptom = row.symptom;\n child.component = row.component;\n child.estimated_time = row.estimated_time;\n child.rts = row.rts;\n child.mat = row.mat;\n //child.cover_image = row.cover_image;\n child.procedure = row.procedure;\n child.procedure_status = row.procedure_status;\n if (row.procedure) {\n frappe.call({\n \"method\": \"smart_service.transactions.doctype.procedure.procedure.get_doc_status\",\n \"args\": {\n \"docname\": row.procedure,\n \t},\n \tasync:false,\n \tcallback:function(r){\n child.procedure_status = r.message; //doc.workflow_state;\n if (r.message == 'Review Pending'){$(\"div[data-fieldname=system_mapping]\").find('div.grid-row[data-idx=\"'+ child.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffa243'});}\n else if (r.message == 'Publish Ready'){$(\"div[data-fieldname=system_mapping]\").find('div.grid-row[data-idx=\"'+ child.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#cfffcf'});}\n //refresh_field(\"system_mapping\");\n \t}\n });\n //frappe.db.get_doc('Procedure', row.procedure)\n // .then(doc => {\n \n // child.procedure_status = doc.workflow_state;\n // if (doc.workflow_state == 'Review Pending'){$(\"div[data-fieldname=system_mapping]\").find('div.grid-row[data-idx=\"'+ child.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffa243'});}\n // else if (doc.workflow_state == 'Publish Ready'){$(\"div[data-fieldname=system_mapping]\").find('div.grid-row[data-idx=\"'+ child.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#cfffcf'});}\n // frm.refresh_field(\"system_mapping\");\n // });\n }\n });\n frm.refresh_field('system_mapping');\n });\n \n frappe.db.get_list('Variant Mapping_Assets', {\n fields: ['category', 'language','active_status','attach_file'],\n filters: {\n parent: frm.doc.variant_mapping, \n language: frm.doc.language,\n published: [\"=\",'0'],\n \n }\n }).then(assets => {\n var child;\n $.each(assets, function(index, row){\n //child = cur_frm.add_child(\"variant_mapping_assets\");\n // console.log(row.category)\n // child.category = row.category;\n // child.language = row.language;\n //child.attach_file = row.attach_file;\n // child.active_status = row.active_status;\n });\n \n frappe.db.get_list('System Mapping_System Assets', {\n fields: ['systems', 'language','active_status','system_asset'],\n filters: {\n parent: filter,\n published: [\"=\",'0'],\n \n }\n }).then(asset => {\n var child_row;\n $.each(asset, function(index, row){\n child_row = cur_frm.add_child(\"variant_mapping_assets\");\n child_row.category = row.systems;\n child_row.language = row.language;\n child_row.attach_file = row.system_asset;\n child_row.active_status = row.active_status;\n });\n cur_frm.refresh_field('variant_mapping_assets');\n })\n \n });*/\n \n } else {\n if (frm.doc.variant_mapping_status != null){\n frappe.msgprint({\n title: __('Notification'),\n indicator: 'red',\n message: __('System Mapping & Assets not loaded as the selected Variant/Kilometer Mapping is Inactive or not configured')\n });\n }\n }\t\n\t},\n\tadd_variant_mapping_to_publish:function(frm){\n var dulicate = false;\n if (frm.doc.publish_documents){\n frm.doc.publish_documents.forEach(publishrow => {\n if (frm.doc.variant_mapping == publishrow.variant_mapping && publishrow.systems === undefined && publishrow.sub_systems === undefined && publishrow.procedure === undefined){\n dulicate = true;\n }\n });\n }\n if (dulicate === false){\n var child = cur_frm.add_child(\"publish_documents\");\n child.variant_mapping = frm.doc.variant_mapping;\n child.item_category = \"Variant Mapping\";\n refresh_field(\"publish_documents\");\n frappe.msgprint(__(frm.doc.variant_mapping + \" Added\"));\n }\n\t},\n\tkm_report: function(frm, cdt, cdn) {\n frappe.set_route(\"query-report\", 'Kilometer Mapping', { 'kilometer_mapping': frm.doc.kilometer_mapping });\n },\n\n\tvehicle:function(frm){\n\t frappe.call({\n method: \"smart_service.transactions.doctype.publish.publish.old_publish\",\n async:false,\n args: {\n \"vehicle\": frm.doc.vehicle,\n \"language\": frm.doc.language\n },\n callback: function(r) {\n if (r.message) {\n var vehicle = frm.doc.vehicle;\n cur_frm.doc.vehicle = '';\n cur_frm.doc.vehicle_status = '';\n cur_frm.refresh_field('vehicle');\n cur_frm.refresh_field('vehicle_status');\n frappe.throw(\"Already publish record \" + r.message + \" created for \" + vehicle + \" vehicle. Please edit already available internal publish!\")\n }\n }\n });\n\n\n\t \n\t if (frm.doc.vehicle === undefined || frm.doc.vehicle === null) {return;}\n\t //frm.trigger(\"auto_version_update\");\n var filter = frm.doc.vehicle;\n filter = \"%\"+filter+\"%\";\n frm.set_query(\"variant_mapping\", function() {\n return {\n \"filters\": {\n // \"name\": [\"like\",filter]\n \"vehicle\":frm.doc.vehicle\n }\n };\n });\n $(\"[data-fieldname=variant_mapping]\").focus();\n if(frm.doc.vehicle){\n frm.set_df_property('vehicle', 'read_only', 1);\n }\n\t},\n\tlanguage:function(frm){\n if (!lang_set_first_time){\n frappe.confirm('This will clear all the data, are you sure you want to proceed?',\n () => {\n // action to perform if Yes is selected\n frm.set_value('variant_mapping',null);\n frm.set_value('variant_mapping_status',null);\n frm.set_df_property('add_variant_mapping_to_publish', 'hidden', 1);\n frm.set_value('system_mapping', null);\n frm.set_value('variant_mapping_assets', null);\n frm.set_value('publish_documents', null);\n lang_set_first_time = false;\n }, () => {\n // action to perform if No is selected\n });\n } else {lang_set_first_time = false;}\n\t},\n\tauto_version_update:function(frm){\n \tif(frm.doc.vehicle && frm.doc.language && frm.doc.publish_type){\n \t console.log(\"called ver\")\n \t\tfrappe.call({\n method: 'smart_service.transactions.doctype.publish.publish.cal_ver',\n args: {\n vehicle: frm.doc.vehicle,\n lang:frm.doc.language,\n publish_type:frm.doc.publish_type,\n doc:frm.doc.name\n },\n callback: (r) => {\n //frm.set_value('version',r.message);\n cur_frm.refresh_field('version')\n console.log(frm.doc.version);\n },\n error: (r) => {\n // on error\n }\n });\n \t}\n\t},\n});", "view": "Form" }, { @@ -199,12 +199,12 @@ "doctype": "Client Script", "dt": "System Mapping", "enabled": 1, - "modified": "2022-04-04 13:30:14.041056", + "modified": "2022-04-09 15:51:14.888143", "name": "System Mapping-Form", "parent": null, "parentfield": null, "parenttype": null, - "script": "var dusted = false;\n\nvar sub_system_idx = [];\nvar mat_array = [];\n\ncur_frm.fields_dict['variant_mapping'].get_query = function(doc, cdt, cdn) {\n return {query:\"smart_service.transactions.doctype.procedure.procedure.variant\",};\n};\n\ncur_frm.fields_dict['system_sub_systems'].grid.get_field('systems').get_query = function(doc, cdt, cdn){ \n return {query:\"smart_service.transactions.doctype.system_mapping.system_mapping.systems\",};\n};\n\ncur_frm.fields_dict['system_sub_systems'].grid.get_field('procedure').get_query = function(doc, cdt, cdn){ \n return {query:\"smart_service.transactions.doctype.system_mapping.system_mapping.procedure\",};\n};\n\nfrappe.ui.form.on('System Mapping', {\n onload: function(frm) {\n frm.set_query(\"systems\", \"system_sub_systems\", function(doc , cdt, cdn) {\n return {\n \"query\": \"smart_service.transactions.doctype.system_mapping.system_mapping.system_filter\",\n filters:{\n \"system_filter\": frm.doc.system_filter\n }\n };\n });\n frm.set_query(\"systems\", \"systems_assets\", function(doc , cdt, cdn) {\n var system = [];\n frm.fields_dict.system_sub_systems.grid.grid_rows.forEach((row) => {\n let value = row.doc.systems;\n system.push(value);\n });\n return {\n filters: {'system_name': ['in',system],\n }\n };\n });\n \n frm.trigger('fnLoadmat_initial_values');\n if (frm.doc.kilometer_mapping !== undefined){\n frappe.db.get_doc('Kilometer Mapping', frm.doc.kilometer_mapping)\n .then(doc => {\n frm.set_value(\"km_active_status\",doc.active_status);\n refresh_field(\"km_active_status\");\n });\n \n }\n },\n refresh: function(frm) {\n cur_frm.doc.system_filter = \"All\";\n if(frm.doc.system_filter == \"All\"){\n frm.get_field('system_sub_systems').grid.static_rows = false;\n frm.fields_dict.system_sub_systems.grid.grid_rows.forEach((row) => {\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').show();\n });\n }\n\n frm.disable_save(); //*** Check Refresh for Save Function\n\n frm.add_custom_button(__('Save'), function(){\n frm.trigger('fnSave');\n }).addClass(\"btn-warning\").css({'background-color':'#e31a37', 'color':'white'});\n\n frm.fields_dict.system_sub_systems.grid.get_field('procedure').get_query = function(doc, cdt, cdn) {\n \treturn {\n \t\tfilters:[\n \t\t\t['language', '=', frm.doc.language]\n \t\t]\n \t};\n };\n frm.trigger('fnsetsystemsfilter');\n // Make a Copy of Rows Data for Move Function\n sub_system_idx.length = 0;\n frm.fields_dict.system_sub_systems.grid.data.forEach((row) => {\n sub_system_idx.push(row);\n });\n },\n onload_post_render: function(frm) {\n frm.fields_dict.system_sub_systems.grid.grid_rows.forEach((row) => {\n if (row.doc.procedure_is_published == 1){\n // row.doc.procedure_status = \"Published\";\n }\n if (row.doc.procedure_status == \"Publish Ready\"){\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffc3c3'});\n }else if (row.doc.procedure_status == \"Published\"){\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#93f163'});\n } else {\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffffff'});\n }\n });\n refresh_field(\"system_sub_systems\");\n },\n variant_mapping: function(frm) {\n frm.trigger('fnSet_SM_KM_4_VM');\n },\n language: function(frm) {\n frm.trigger('fnSet_SM_KM_4_VM');\n },\n system_filter: function(frm) {\n if (frm.doc.system_filter == \"All\"){\n frm.get_field('system_sub_systems').grid.static_rows = false;\n frm.fields_dict.system_sub_systems.grid.grid_rows.forEach((row) => {\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').show();\n });\n \n frm.get_field('systems_assets').grid.static_rows = false;\n frm.fields_dict.systems_assets.grid.grid_rows.forEach((row) => {\n $(\"div[data-fieldname=systems_assets]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').show();\n });\n \n } else {\n frm.get_field('system_sub_systems').grid.static_rows = false;\n frm.fields_dict.system_sub_systems.grid.grid_rows.forEach((row) => {\n if (row.doc.systems != frm.doc.system_filter){\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').hide();\n } else {\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').show();\n }\n });\n \n frm.get_field('systems_assets').grid.static_rows = false;\n frm.fields_dict.systems_assets.grid.grid_rows.forEach((row) => {\n if (row.doc.systems != frm.doc.system_filter){\n $(\"div[data-fieldname=systems_assets]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').hide();\n } else {\n $(\"div[data-fieldname=systems_assets]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').show();\n }\n });\n }\n },\n fnsetsystemsfilter: function(frm){\n var filtered_systems = frm.doc.system_filter;\n $(\"select[data-fieldname='system_filter']\").empty();\n $(\"select[data-fieldname='system_filter']\").append(new Option(\"All\", \"All\"));\n frm.fields_dict.system_sub_systems.grid.grid_rows.forEach((row) => {\n let value = row.doc.systems;\n if (value)\n if ($(\"select[data-fieldname='system_filter'] option[value='\" + value + \"']\").length === 0){\n $(\"select[data-fieldname='system_filter']\").append(new Option(value, value));\n }\n \n });\n frm.doc.system_filter = filtered_systems;\n //refresh_field(\"system_sub_systems\");\n },\n fnLoadmat_initial_values: function(frm){\n if (frm.doc.system_sub_systems !== undefined){\n mat_array.length = 0;\n frm.doc.system_sub_systems.forEach(row => {\n // ***Update the Current Procedure Status\n if (row.procedure){\n frappe.db.get_doc('Procedure', row.procedure)\n .then(doc => {\n row.procedure_status = doc.workflow_state;\n refresh_field(\"system_sub_systems\");\n });\n }\n // ***Store the Initial MAT values\n var valueToPush = {};\n valueToPush.name = row.name;\n valueToPush.type = (frm.is_new() ? \"New\":\"Initial\");\n valueToPush.mat_initial = (row.mat === undefined ? null:row.mat);\n valueToPush.mat_update = (frm.is_new() ? row.mat:null);\n valueToPush.sub_systems = row.sub_systems;\n valueToPush.procedure_status = row.procedure_status;\n valueToPush.procedure_is_published = row.procedure_is_published;\n mat_array.push(valueToPush);\n });\n }\n },\n fnSave: function(frm){\n //*** Check the respective Kilometer Mapping Document exisits\n if (frm.is_new()) {\n if(frm.doc.variant_mapping)\n var km_doc_name = frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-KM\";\n frappe.db.exists('System Mapping', frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-SM\")\n .then(smexists => {\n if (smexists){\n frappe.throw(__('System Mapping already Exists!!!'));\n } else {\n frappe.db.exists('Kilometer Mapping', km_doc_name)\n .then(exists => {\n if (exists) {\n frm.trigger('fnSave_caller');\n } else {\n frappe.db.insert({\n doctype: 'Kilometer Mapping',\n variant_mapping: frm.doc.variant_mapping,\n language:frm.doc.language\n }).then(doc => {\n frm.set_value(\"kilometer_mapping\",doc.name);\n refresh_field(\"kilometer_mapping\");\n frm.trigger('fnSave_caller');\n });\n //frappe.throw(__('Corresponding Kilometer Mapping is Created! Please contact Admin.'));\n }\n });\n }\n });\n } else {\n frm.trigger('fnSave_caller');\n }\n },\n fnSave_caller: function(frm){\n //*** Construct the change point as HTML\n \n var html = \"\";\n $.each(mat_array, function(index, row){\n if (row.type !== \"Initial\"){\n html = html + \"\" ;\n dusted = true;\n }\n });\n html = html + \"
\" + row.sub_systems + \" MAT \" + row.type + \": \" + row.mat_update + \"
\";\n\n if (dusted){\n \n frappe.confirm('Changes will impact KM Mapping - '+ frm.doc.kilometer_mapping + '
This Document status will be set to: Draft

Following are the changes updated:
' + html,\n () => {\n //*** Change the State to Draft for KM\n //console.log(\"Dusted:\" + dusted);\n //console.log(\"Is Dirty:\" + frm.is_dirty());\n frappe.db.set_value('Kilometer Mapping', frm.doc.kilometer_mapping, 'workflow_state', 'Draft')\n .then(r => {\n dusted = false;frm.save();\n // MOVE THIS CODE TO PY FILE ********* START\n console.log(\"Step 4: Array Looing Starts\");\n mat_array.forEach((array_row) => {\n \n //*** Add Edit Delete the respective Kiolmeter with Updated/Deleted MAT\n\n if (array_row.type !== \"Initial\"){\n frappe.call({\n \"method\": \"smart_service.transactions.doctype.system_mapping.system_mapping.update_mat\",\n \"args\": {\n \"doc\": cur_frm.doc.name,\n \"km\": frm.doc.kilometer_mapping,\n \"vehicle\": frm.doc.vehicle,\n \"type\": array_row.type,\n \"sub_systems\": array_row.sub_systems,\n \"mat_initial\": array_row.mat_initial, //*** for Deleted\n \"mat_update\": array_row.mat_update, //*** for New, Added & Edited\n \"km_applicable\": 0\n \t},\n \t//freeze: true,\n \tasync:false,\n \tcallback:function(r){}\n });\n }\n });\n // MOVE THIS CODE TO PY FILE ********* END\n frappe.show_alert({\n message:__('Inserted Rows in KM Doc: ' + frm.doc.kilometer_mapping),\n indicator:'green'\n }, 5);\n frm.trigger('fnLoadmat_initial_values');\n });\n }, () => {\n // action to perform if No is selected\n });\n } else if(frm.is_dirty()){\n dusted = false;frm.save();\n frm.trigger('fnLoadmat_initial_values');\n } else {\n frappe.show_alert({\n message:__('No updates for Kilometer Mapping... '),\n indicator:'green'\n }, 5);\n }\n },\n fnSet_SM_KM_4_VM: function (frm) {\n if (frm.doc.variant_mapping === undefined) return;\n frappe.db.exists('System Mapping', frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-SM\")\n .then(smexists => {\n if (smexists){\n frappe.throw(__('System Mapping already Exists!!!'));\n //frm.set_value(\"variant_mapping\",null);\n //refresh_field(\"variant_mapping\");\n } else {\n frappe.db.exists('Kilometer Mapping', frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-KM\")\n .then(exists => {\n if (exists){\n frm.set_value(\"kilometer_mapping\",frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-KM\");\n } else {\n frm.set_value(\"kilometer_mapping\",null);\n frm.set_value(\"km_active_status\",\"Not Configured!\");\n }\n });\n }\n });\n }\n});\n\nfrappe.ui.form.on('System Mapping_Sub System', {\n before_system_sub_systems_remove: function(frm,cdt,cdn) {\n \tvar d = locals[cdt][cdn];\n\n \tvar id = d.idx;\n id = id-1;\n var row = frm.fields_dict.system_sub_systems.grid.grid_rows[id];\n let index = mat_array.findIndex(o => o.name === row.doc.name);\n if (index >= 0){\n \n if (row.doc.mat !== \"\"){\n mat_array[index].type = \"Deleted\";\n mat_array[index].mat_update = row.doc.mat === '' ? null : row.doc.mat;\n }\n }\n },\n system_sub_systems_move: function(frm,cdt,cdn) {\n \tvar d = locals[cdt][cdn];\n\n \tvar id = d.idx;\n \tvar from = id;\n id = id-1;\n var row = frm.fields_dict.system_sub_systems.grid.grid_rows[id];\n\n let index = sub_system_idx.findIndex(o => o.name === d.name);\n var to = index + 1;\n\n if(from > to) {to = [from, from = to][0];}\n\n frm.fields_dict.system_sub_systems.grid.grid_rows.forEach((row) => {\n if (row.doc.procedure_status == \"Publish Ready\"){\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffc3c3'});\n }else if (row.doc.procedure_status == \"Published\"){\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#93f163'});\n } else {\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffffff'});\n }\n if (row.doc.idx >= from && row.doc.idx <= to) {\n if (row.doc.procedure_is_published == 1){\n // row.doc.procedure_status = \"Publish Ready\";\n row.doc.procedure_is_published = 0;\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffc3c3'});\n }\n }\n });\n refresh_field(\"system_sub_systems\");\n },\n system_sub_systems_add: function(frm,cdt,cdn) {\n \tvar d = locals[cdt][cdn];\n \tvar id = d.idx;\n id = id-1;\n var row = frm.fields_dict.system_sub_systems.grid.grid_rows[id];\n var prevrow = frm.fields_dict.system_sub_systems.grid.grid_rows[id-1];\n if (frm.doc.system_filter == \"All\"){\n if (prevrow !== undefined) row.doc.systems = prevrow.doc.systems;\n }else{\n row.doc.systems = frm.doc.system_filter;\n }\n \n },\n systems: function (frm,cdt,cdn) {\n frm.trigger('fnsetsystemsfilter');\n },\n system_sub_systems_remove: function(frm,cdt,cdn) {\n let index = sub_system_idx.findIndex(o => o.name === cdn);\n frm.fields_dict.system_sub_systems.grid.grid_rows.forEach((row) => {\n if (row.doc.procedure_status == \"Publish Ready\"){\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffc3c3'});\n }else if (row.doc.procedure_status == \"Published\"){\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#93f163'});\n } else {\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffffff'});\n }\n if (row.doc.idx >= index) {\n if (row.doc.procedure_is_published == 1){\n // row.doc.procedure_status = \"Publish Ready\";\n row.doc.procedure_is_published = 0;\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffc3c3'});\n }\n }\n });\n frm.refresh();\n frm.doc.system_filter = \"All\";\n },\n systems: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n sub_systems: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n procedure: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n active_status: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n symptom: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n component: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n estimated_time: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n rts: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n cover_image: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n mat: function(frm,cdt,cdn) {\n var res_mat = [];\n var child = locals[cdt,cdn];\n for (var i = 0; i < cur_frm.doc.system_sub_systems.length; i++) {\n for (var j = 0; j < res_mat.length; j++) {\n if (res_mat[j] == cur_frm.doc.system_sub_systems[i].mat) {\n cur_frm.doc.system_sub_systems[i].mat = '';\n cur_frm.refresh_field('mat')\n cur_frm.refresh_fields();\n frappe.throw('You Cannot Select Same MAT ' + cur_frm.doc.system_sub_systems[i].mat + ' Multiple Times');\n }\n }\n if (cur_frm.doc.system_sub_systems[i].mat) {\n res_mat.push(frm.doc.system_sub_systems[i].mat)\n }\n }\n cur_frm.refresh_fields();\n frm.refresh_field(\"system_sub_systems\")\n fn_mat_updated(frm,cdt,cdn)\n },\n sub_systems: function(frm,cdt,cdn) {\n \tvar d = locals[cdt][cdn];\n \tvar id = d.idx;\n \tid = id-1;\n var row = frm.fields_dict.system_sub_systems.grid.grid_rows[id];\n var procedurename = frm.doc.variant_mapping+\"-\"+d.sub_systems+\"-\"+frm.doc.language;\n frappe.db.exists('Procedure', procedurename)\n .then(exists => {\n if (exists){\n frappe.db.get_doc('Procedure', procedurename)\n .then(doc => {\n row.doc.procedure = doc.name;\n row.doc.procedure_status = doc.workflow_state;\n if (row.doc.estimated_time === undefined) row.doc.estimated_time = doc.estimated_time;\n if (row.doc.rts === undefined) row.doc.rts = doc.rts;\n if (row.doc.mat === undefined) {row.doc.mat = doc.mat; fn_mat_updated(frm,cdt,cdn)}\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure\"]').css({'background-color': '#ffc3c3'});\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffc3c3'});\n row.toggle_editable_row(false);\n refresh_field(\"system_sub_systems\");\n });\n }else{\n row.doc.procedure = \"\";\n row.doc.procedure_status = \"\";\n row.toggle_editable_row(false);\n refresh_field(\"system_sub_systems\");\n frappe.throw(__('Procedure to be created or sub-system renamed'));\n }\n });\n },\n procedure: function(frm,cdt,cdn) {\n \tvar d = locals[cdt][cdn];\n \tvar id = d.idx;\n \tid = id-1;\n var row = frm.fields_dict.system_sub_systems.grid.grid_rows[id];\n var procedurename = frm.doc.variant_mapping+\"-\"+d.sub_systems+\"-\"+frm.doc.language;\n if (d.procedure){\n frappe.db.exists('Procedure', d.procedure)\n .then(exists => {\n if (exists){\n frappe.db.get_doc('Procedure', d.procedure)\n .then(doc => {\n row.doc.procedure = doc.name;\n row.doc.procedure_status = doc.workflow_state;\n row.doc.procedure_is_published = 0;\n //if (row.doc.estimated_time === undefined) row.doc.estimated_time = doc.estimated_time;\n //if (row.doc.rts === undefined) row.doc.rts = doc.rts;\n //if (row.doc.mat === undefined) row.doc.mat = doc.mat;\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure\"]').css({'background-color': '#ffc3c3'});\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffc3c3'});\n row.toggle_editable_row(false);\n refresh_field(\"system_sub_systems\");\n });\n }else{\n row.doc.procedure = \"\";\n row.doc.procedure_status = \"\";\n row.toggle_editable_row(false);\n refresh_field(\"system_sub_systems\");\n frappe.throw(__('Procedure to be created or sub-system renamed'));\n }\n });\n } else {\n row.doc.procedure_status = \"\";\n row.toggle_editable_row(false);\n refresh_field(\"system_sub_systems\");\n }\n },\n});\n\nfunction fn_updateProceduteStatus(frm,cdt,cdn){\n var d = locals[cdt][cdn];\n\tvar id = d.idx;\n\tid = id-1;\n var row = frm.fields_dict.system_sub_systems.grid.grid_rows[id];\n if (row.doc.procedure_is_published == 1){\n // row.doc.procedure_status = \"Publish Ready\";\n row.doc.procedure_is_published = 0;\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffc3c3'});\n row.toggle_editable_row(false);\n }\n refresh_field(\"system_sub_systems\"); \n\n}\nfunction fn_mat_updated(frm,cdt,cdn){\n fn_updateProceduteStatus(frm,cdt,cdn);\n var d = locals[cdt][cdn];\n\tvar id = d.idx;\n id = id-1;\n var row = frm.fields_dict.system_sub_systems.grid.grid_rows[id];\n let index = mat_array.findIndex(o => o.name === row.doc.name);\n if (index >= 0){\n mat_array[index].mat_update = row.doc.mat === '' ? null : row.doc.mat;\n if (row.doc.mat === \"\"){\n if (mat_array[index].mat_initial === null){\n mat_array[index].type = \"Initial\";\n if (mat_array[index].procedure_is_published){\n row.doc.procedure_status = \"Published\";\n row.doc.procedure_is_published = 1;\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#93f163'});\n row.toggle_editable_row(false);\n }\n } else {mat_array[index].type = \"Deleted\";}\n } else {\n if (mat_array[index].mat_initial === null){\n mat_array[index].type = \"Added\";\n } else {\n if (mat_array[index].mat_initial == row.doc.mat){\n mat_array[index].type = \"Initial\";\n if (mat_array[index].procedure_is_published){\n row.doc.procedure_status = \"Published\";\n row.doc.procedure_is_published = 1;\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#93f163'});\n row.toggle_editable_row(false);\n }\n } else {mat_array[index].type = \"Edited\";}\n }\n }\n } else {\n var valueToPush = {};\n valueToPush.name = row.doc.name;\n valueToPush.type = \"New\";\n valueToPush.mat_initial = null;\n valueToPush.mat_update = row.doc.mat;\n valueToPush.sub_systems = row.doc.sub_systems;\n valueToPush.procedure_status = row.doc.procedure_status;\n valueToPush.procedure_is_published = row.doc.procedure_is_published;\n mat_array.push(valueToPush);\n }\n\n}\n\nfrappe.ui.form.on('System Mapping_System Assets', {\n remarks: function(frm,cdt,cdn){\n\t\tvar child = locals[cdt][cdn];\n\t\tif(child.active_status == \"Active\"){\n\t\tchild.remarks = '';\n\t\tcur_frm.refresh_fields();\n\t\tfrappe.throw(\"Remarks should not allow for Active status\")\n\t\t}\n\t},\n\tactive_status: function(frm,cdt,cdn){\n\t\tvar child = locals[cdt][cdn];\n\t\tchild.remarks = '';\n\t\tcur_frm.refresh_fields();\n\n\t},\n systems_assets_add: function(frm,cdt,cdn){\n \tvar d = locals[cdt][cdn];\n \tvar id = d.idx;\n id = id-1;\n var row = frm.fields_dict.systems_assets.grid.grid_rows[id];\n var prevrow = frm.fields_dict.systems_assets.grid.grid_rows[id-1];\n if (frm.doc.system_filter == \"All\"){\n if (prevrow !== undefined) row.doc.systems = prevrow.doc.systems;\n }else{\n row.doc.systems = frm.doc.system_filter;\n }\n row.doc.language = frm.doc.language;\n cur_frm.refresh_fields();\n }\n});", + "script": "var dusted = false;\n\nvar sub_system_idx = [];\nvar mat_array = [];\n\ncur_frm.fields_dict['variant_mapping'].get_query = function(doc, cdt, cdn) {\n return {query:\"smart_service.transactions.doctype.procedure.procedure.variant\",};\n};\n\ncur_frm.fields_dict['system_sub_systems'].grid.get_field('systems').get_query = function(doc, cdt, cdn){ \n return {query:\"smart_service.transactions.doctype.system_mapping.system_mapping.systems\",};\n};\n\ncur_frm.fields_dict['system_sub_systems'].grid.get_field('procedure').get_query = function(doc, cdt, cdn){ \n return {query:\"smart_service.transactions.doctype.system_mapping.system_mapping.procedure\",};\n};\n\nfrappe.ui.form.on('System Mapping', {\n onload: function(frm) {\n frm.set_query(\"systems\", \"system_sub_systems\", function(doc , cdt, cdn) {\n return {\n \"query\": \"smart_service.transactions.doctype.system_mapping.system_mapping.system_filter\",\n filters:{\n \"system_filter\": frm.doc.system_filter\n }\n };\n });\n frm.set_query(\"systems\", \"systems_assets\", function(doc , cdt, cdn) {\n var system = [];\n frm.fields_dict.system_sub_systems.grid.grid_rows.forEach((row) => {\n let value = row.doc.systems;\n system.push(value);\n });\n return {\n filters: {'system_name': ['in',system],\n }\n };\n });\n \n frm.trigger('fnLoadmat_initial_values');\n if (frm.doc.kilometer_mapping !== undefined){\n frappe.db.get_doc('Kilometer Mapping', frm.doc.kilometer_mapping)\n .then(doc => {\n frm.set_value(\"km_active_status\",doc.active_status);\n refresh_field(\"km_active_status\");\n });\n \n }\n },\n refresh: function(frm) {\n cur_frm.doc.system_filter = \"All\";\n if(frm.doc.system_filter == \"All\"){\n frm.get_field('system_sub_systems').grid.static_rows = false;\n frm.fields_dict.system_sub_systems.grid.grid_rows.forEach((row) => {\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').show();\n });\n }\n\n frm.disable_save(); //*** Check Refresh for Save Function\n\n frm.add_custom_button(__('Save'), function(){\n frm.trigger('fnSave');\n }).addClass(\"btn-warning\").css({'background-color':'#e31a37', 'color':'white'});\n\n frm.fields_dict.system_sub_systems.grid.get_field('procedure').get_query = function(doc, cdt, cdn) {\n \treturn {\n \t\tfilters:[\n \t\t\t['language', '=', frm.doc.language]\n \t\t]\n \t};\n };\n frm.trigger('fnsetsystemsfilter');\n // Make a Copy of Rows Data for Move Function\n sub_system_idx.length = 0;\n frm.fields_dict.system_sub_systems.grid.data.forEach((row) => {\n sub_system_idx.push(row);\n });\n },\n onload_post_render: function(frm) {\n frm.fields_dict.system_sub_systems.grid.grid_rows.forEach((row) => {\n if (row.doc.procedure_is_published == 1){\n // row.doc.procedure_status = \"Published\";\n }\n if (row.doc.procedure_status == \"Publish Ready\"){\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffc3c3'});\n }else if (row.doc.procedure_status == \"Published\"){\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#93f163'});\n } else {\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffffff'});\n }\n });\n refresh_field(\"system_sub_systems\");\n },\n variant_mapping: function(frm) {\n frm.trigger('fnSet_SM_KM_4_VM');\n },\n language: function(frm) {\n frm.trigger('fnSet_SM_KM_4_VM');\n },\n system_filter: function(frm) {\n if (frm.doc.system_filter == \"All\"){\n frm.get_field('system_sub_systems').grid.static_rows = false;\n frm.fields_dict.system_sub_systems.grid.grid_rows.forEach((row) => {\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').show();\n });\n \n frm.get_field('systems_assets').grid.static_rows = false;\n frm.fields_dict.systems_assets.grid.grid_rows.forEach((row) => {\n $(\"div[data-fieldname=systems_assets]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').show();\n });\n \n } else {\n frm.get_field('system_sub_systems').grid.static_rows = false;\n frm.fields_dict.system_sub_systems.grid.grid_rows.forEach((row) => {\n if (row.doc.systems != frm.doc.system_filter){\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').hide();\n } else {\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').show();\n }\n });\n \n frm.get_field('systems_assets').grid.static_rows = false;\n frm.fields_dict.systems_assets.grid.grid_rows.forEach((row) => {\n if (row.doc.systems != frm.doc.system_filter){\n $(\"div[data-fieldname=systems_assets]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').hide();\n } else {\n $(\"div[data-fieldname=systems_assets]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').show();\n }\n });\n }\n },\n fnsetsystemsfilter: function(frm){\n var filtered_systems = frm.doc.system_filter;\n $(\"select[data-fieldname='system_filter']\").empty();\n $(\"select[data-fieldname='system_filter']\").append(new Option(\"All\", \"All\"));\n frm.fields_dict.system_sub_systems.grid.grid_rows.forEach((row) => {\n let value = row.doc.systems;\n if (value)\n if ($(\"select[data-fieldname='system_filter'] option[value='\" + value + \"']\").length === 0){\n $(\"select[data-fieldname='system_filter']\").append(new Option(value, value));\n }\n \n });\n frm.doc.system_filter = filtered_systems;\n //refresh_field(\"system_sub_systems\");\n },\n fnLoadmat_initial_values: function(frm){\n if (frm.doc.system_sub_systems !== undefined){\n mat_array.length = 0;\n frm.doc.system_sub_systems.forEach(row => {\n // ***Update the Current Procedure Status\n if (row.procedure){\n frappe.db.get_doc('Procedure', row.procedure)\n .then(doc => {\n row.procedure_status = doc.workflow_state;\n refresh_field(\"system_sub_systems\");\n });\n }\n // ***Store the Initial MAT values\n var valueToPush = {};\n valueToPush.name = row.name;\n valueToPush.type = (frm.is_new() ? \"New\":\"Initial\");\n valueToPush.mat_initial = (row.mat === undefined ? null:row.mat);\n valueToPush.mat_update = (frm.is_new() ? row.mat:null);\n valueToPush.sub_systems = row.sub_systems;\n valueToPush.procedure_status = row.procedure_status;\n valueToPush.procedure_is_published = row.procedure_is_published;\n mat_array.push(valueToPush);\n });\n }\n },\n fnSave: function(frm){\n //*** Check the respective Kilometer Mapping Document exisits\n if (frm.is_new()) {\n if(frm.doc.variant_mapping)\n var km_doc_name = frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-KM\";\n frappe.db.exists('System Mapping', frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-SM\")\n .then(smexists => {\n if (smexists){\n frappe.throw(__('System Mapping already Exists!!!'));\n } else {\n frappe.db.exists('Kilometer Mapping', km_doc_name)\n .then(exists => {\n if (exists) {\n frm.trigger('fnSave_caller');\n } else {\n frappe.db.insert({\n doctype: 'Kilometer Mapping',\n variant_mapping: frm.doc.variant_mapping,\n language:frm.doc.language\n }).then(doc => {\n frm.set_value(\"kilometer_mapping\",doc.name);\n refresh_field(\"kilometer_mapping\");\n frm.trigger('fnSave_caller');\n });\n //frappe.throw(__('Corresponding Kilometer Mapping is Created! Please contact Admin.'));\n }\n });\n }\n });\n } else {\n frm.trigger('fnSave_caller');\n }\n },\n fnSave_caller: function(frm){\n //*** Construct the change point as HTML\n \n var html = \"\";\n $.each(mat_array, function(index, row){\n if (row.type !== \"Initial\"){\n html = html + \"\" ;\n dusted = true;\n }\n });\n html = html + \"
\" + row.sub_systems + \" MAT \" + row.type + \": \" + row.mat_update + \"
\";\n\n if (dusted){\n \n frappe.confirm('Changes will impact KM Mapping - '+ frm.doc.kilometer_mapping + '
This Document status will be set to: Draft

Following are the changes updated:
' + html,\n () => {\n //*** Change the State to Draft for KM\n //console.log(\"Dusted:\" + dusted);\n //console.log(\"Is Dirty:\" + frm.is_dirty());\n frappe.db.set_value('Kilometer Mapping', frm.doc.kilometer_mapping, 'workflow_state', 'Draft')\n .then(r => {\n dusted = false;frm.save();\n // MOVE THIS CODE TO PY FILE ********* START\n console.log(\"Step 4: Array Looing Starts\");\n mat_array.forEach((array_row) => {\n \n //*** Add Edit Delete the respective Kiolmeter with Updated/Deleted MAT\n\n if (array_row.type !== \"Initial\"){\n frappe.call({\n \"method\": \"smart_service.transactions.doctype.system_mapping.system_mapping.update_mat\",\n \"args\": {\n \"doc\": cur_frm.doc.name,\n \"km\": frm.doc.kilometer_mapping,\n \"vehicle\": frm.doc.vehicle,\n \"type\": array_row.type,\n \"sub_systems\": array_row.sub_systems,\n \"mat_initial\": array_row.mat_initial, //*** for Deleted\n \"mat_update\": array_row.mat_update, //*** for New, Added & Edited\n \"km_applicable\": 0\n \t},\n \t//freeze: true,\n \tasync:false,\n \tcallback:function(r){}\n });\n }\n });\n // MOVE THIS CODE TO PY FILE ********* END\n frappe.show_alert({\n message:__('Inserted Rows in KM Doc: ' + frm.doc.kilometer_mapping),\n indicator:'green'\n }, 5);\n frm.trigger('fnLoadmat_initial_values');\n });\n }, () => {\n // action to perform if No is selected\n });\n } else if(frm.is_dirty()){\n dusted = false;frm.save();\n frm.trigger('fnLoadmat_initial_values');\n } else {\n frappe.show_alert({\n message:__('No updates for Kilometer Mapping... '),\n indicator:'green'\n }, 5);\n }\n },\n fnSet_SM_KM_4_VM: function (frm) {\n if (frm.doc.variant_mapping === undefined) return;\n frappe.db.exists('System Mapping', frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-SM\")\n .then(smexists => {\n if (smexists){\n frappe.throw(__('System Mapping already Exists!!!'));\n //frm.set_value(\"variant_mapping\",null);\n //refresh_field(\"variant_mapping\");\n } else {\n frappe.db.exists('Kilometer Mapping', frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-KM\")\n .then(exists => {\n if (exists){\n frm.set_value(\"kilometer_mapping\",frm.doc.variant_mapping + \"-\" + frm.doc.language + \"-KM\");\n } else {\n frm.set_value(\"kilometer_mapping\",null);\n frm.set_value(\"km_active_status\",\"Not Configured!\");\n }\n });\n }\n });\n }\n});\n\nfrappe.ui.form.on('System Mapping_Sub System', {\n before_system_sub_systems_remove: function(frm,cdt,cdn) {\n \tvar d = locals[cdt][cdn];\n\n \tvar id = d.idx;\n id = id-1;\n var row = frm.fields_dict.system_sub_systems.grid.grid_rows[id];\n let index = mat_array.findIndex(o => o.name === row.doc.name);\n if (index >= 0){\n \n if (row.doc.mat !== \"\"){\n mat_array[index].type = \"Deleted\";\n mat_array[index].mat_update = row.doc.mat === '' ? null : row.doc.mat;\n }\n }\n },\n system_sub_systems_move: function(frm,cdt,cdn) {\n \tvar d = locals[cdt][cdn];\n\n \tvar id = d.idx;\n \tvar from = id;\n id = id-1;\n var row = frm.fields_dict.system_sub_systems.grid.grid_rows[id];\n\n let index = sub_system_idx.findIndex(o => o.name === d.name);\n var to = index + 1;\n\n if(from > to) {to = [from, from = to][0];}\n\n frm.fields_dict.system_sub_systems.grid.grid_rows.forEach((row) => {\n if (row.doc.procedure_status == \"Publish Ready\"){\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffc3c3'});\n }else if (row.doc.procedure_status == \"Published\"){\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#93f163'});\n } else {\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffffff'});\n }\n if (row.doc.idx >= from && row.doc.idx <= to) {\n if (row.doc.procedure_is_published == 1){\n // row.doc.procedure_status = \"Publish Ready\";\n row.doc.procedure_is_published = 0;\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffc3c3'});\n }\n }\n });\n refresh_field(\"system_sub_systems\");\n },\n system_sub_systems_add: function(frm,cdt,cdn) {\n \tvar d = locals[cdt][cdn];\n \tvar id = d.idx;\n id = id-1;\n var row = frm.fields_dict.system_sub_systems.grid.grid_rows[id];\n var prevrow = frm.fields_dict.system_sub_systems.grid.grid_rows[id-1];\n if (frm.doc.system_filter == \"All\"){\n if (prevrow !== undefined) row.doc.systems = prevrow.doc.systems;\n }else{\n row.doc.systems = frm.doc.system_filter;\n }\n \n },\n systems: function (frm,cdt,cdn) {\n frm.trigger('fnsetsystemsfilter');\n },\n system_sub_systems_remove: function(frm,cdt,cdn) {\n let index = sub_system_idx.findIndex(o => o.name === cdn);\n frm.fields_dict.system_sub_systems.grid.grid_rows.forEach((row) => {\n if (row.doc.procedure_status == \"Publish Ready\"){\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffc3c3'});\n }else if (row.doc.procedure_status == \"Published\"){\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#93f163'});\n } else {\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffffff'});\n }\n if (row.doc.idx >= index) {\n if (row.doc.procedure_is_published == 1){\n // row.doc.procedure_status = \"Publish Ready\";\n row.doc.procedure_is_published = 0;\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffc3c3'});\n }\n }\n });\n frm.refresh();\n frm.doc.system_filter = \"All\";\n },\n systems: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n sub_systems: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n procedure: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n active_status: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n symptom: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n component: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n estimate_time: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n rts: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n cover_image: function(frm,cdt,cdn) {fn_updateProceduteStatus(frm,cdt,cdn)},\n mat: function(frm,cdt,cdn) {\n var res_mat = [];\n var child = locals[cdt,cdn];\n for (var i = 0; i < cur_frm.doc.system_sub_systems.length; i++) {\n for (var j = 0; j < res_mat.length; j++) {\n if (res_mat[j] == cur_frm.doc.system_sub_systems[i].mat) {\n cur_frm.doc.system_sub_systems[i].mat = '';\n cur_frm.refresh_field('mat')\n cur_frm.refresh_fields();\n frappe.throw('You Cannot Select Same MAT ' + cur_frm.doc.system_sub_systems[i].mat + ' Multiple Times');\n }\n }\n if (cur_frm.doc.system_sub_systems[i].mat) {\n res_mat.push(frm.doc.system_sub_systems[i].mat)\n }\n }\n cur_frm.refresh_fields();\n frm.refresh_field(\"system_sub_systems\")\n fn_mat_updated(frm,cdt,cdn)\n },\n sub_systems: function(frm,cdt,cdn) {\n \tvar d = locals[cdt][cdn];\n \tvar id = d.idx;\n \tid = id-1;\n var row = frm.fields_dict.system_sub_systems.grid.grid_rows[id];\n var procedurename = frm.doc.variant_mapping+\"-\"+d.sub_systems+\"-\"+frm.doc.language;\n frappe.db.exists('Procedure', procedurename)\n .then(exists => {\n if (exists){\n frappe.db.get_doc('Procedure', procedurename)\n .then(doc => {\n row.doc.procedure = doc.name;\n row.doc.procedure_status = doc.workflow_state;\n if (row.doc.estimate_time === undefined) row.doc.estimate_time = doc.estimate_time;\n if (row.doc.rts === undefined) row.doc.rts = doc.rts;\n if (row.doc.mat === undefined) {row.doc.mat = doc.mat; fn_mat_updated(frm,cdt,cdn)}\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure\"]').css({'background-color': '#ffc3c3'});\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffc3c3'});\n row.toggle_editable_row(false);\n refresh_field(\"system_sub_systems\");\n });\n }else{\n row.doc.procedure = \"\";\n row.doc.procedure_status = \"\";\n row.toggle_editable_row(false);\n refresh_field(\"system_sub_systems\");\n frappe.throw(__('Procedure to be created or sub-system renamed'));\n }\n });\n },\n procedure: function(frm,cdt,cdn) {\n \tvar d = locals[cdt][cdn];\n \tvar id = d.idx;\n \tid = id-1;\n var row = frm.fields_dict.system_sub_systems.grid.grid_rows[id];\n var procedurename = frm.doc.variant_mapping+\"-\"+d.sub_systems+\"-\"+frm.doc.language;\n if (d.procedure){\n frappe.db.exists('Procedure', d.procedure)\n .then(exists => {\n if (exists){\n frappe.db.get_doc('Procedure', d.procedure)\n .then(doc => {\n row.doc.procedure = doc.name;\n row.doc.procedure_status = doc.workflow_state;\n row.doc.procedure_is_published = 0;\n //if (row.doc.estimated_time === undefined) row.doc.estimated_time = doc.estimated_time;\n //if (row.doc.rts === undefined) row.doc.rts = doc.rts;\n //if (row.doc.mat === undefined) row.doc.mat = doc.mat;\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure\"]').css({'background-color': '#ffc3c3'});\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffc3c3'});\n row.toggle_editable_row(false);\n refresh_field(\"system_sub_systems\");\n });\n }else{\n row.doc.procedure = \"\";\n row.doc.procedure_status = \"\";\n row.toggle_editable_row(false);\n refresh_field(\"system_sub_systems\");\n frappe.throw(__('Procedure to be created or sub-system renamed'));\n }\n });\n } else {\n row.doc.procedure_status = \"\";\n row.toggle_editable_row(false);\n refresh_field(\"system_sub_systems\");\n }\n },\n});\n\nfunction fn_updateProceduteStatus(frm,cdt,cdn){\n var d = locals[cdt][cdn];\n\tvar id = d.idx;\n\tid = id-1;\n var row = frm.fields_dict.system_sub_systems.grid.grid_rows[id];\n if (row.doc.procedure_is_published == 1){\n // row.doc.procedure_status = \"Publish Ready\";\n row.doc.procedure_is_published = 0;\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#ffc3c3'});\n row.toggle_editable_row(false);\n }\n refresh_field(\"system_sub_systems\"); \n\n}\nfunction fn_mat_updated(frm,cdt,cdn){\n fn_updateProceduteStatus(frm,cdt,cdn);\n var d = locals[cdt][cdn];\n\tvar id = d.idx;\n id = id-1;\n var row = frm.fields_dict.system_sub_systems.grid.grid_rows[id];\n let index = mat_array.findIndex(o => o.name === row.doc.name);\n if (index >= 0){\n mat_array[index].mat_update = row.doc.mat === '' ? null : row.doc.mat;\n if (row.doc.mat === \"\"){\n if (mat_array[index].mat_initial === null){\n mat_array[index].type = \"Initial\";\n if (mat_array[index].procedure_is_published){\n row.doc.procedure_status = \"Published\";\n row.doc.procedure_is_published = 1;\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#93f163'});\n row.toggle_editable_row(false);\n }\n } else {mat_array[index].type = \"Deleted\";}\n } else {\n if (mat_array[index].mat_initial === null){\n mat_array[index].type = \"Added\";\n } else {\n if (mat_array[index].mat_initial == row.doc.mat){\n mat_array[index].type = \"Initial\";\n if (mat_array[index].procedure_is_published){\n row.doc.procedure_status = \"Published\";\n row.doc.procedure_is_published = 1;\n $(\"div[data-fieldname=system_sub_systems]\").find('div.grid-row[data-idx=\"'+ row.doc.idx + '\"]').find('div.col[data-fieldname=\"procedure_status\"]').css({'background-color': '#93f163'});\n row.toggle_editable_row(false);\n }\n } else {mat_array[index].type = \"Edited\";}\n }\n }\n } else {\n var valueToPush = {};\n valueToPush.name = row.doc.name;\n valueToPush.type = \"New\";\n valueToPush.mat_initial = null;\n valueToPush.mat_update = row.doc.mat;\n valueToPush.sub_systems = row.doc.sub_systems;\n valueToPush.procedure_status = row.doc.procedure_status;\n valueToPush.procedure_is_published = row.doc.procedure_is_published;\n mat_array.push(valueToPush);\n }\n\n}\n\nfrappe.ui.form.on('System Mapping_System Assets', {\n remarks: function(frm,cdt,cdn){\n\t\tvar child = locals[cdt][cdn];\n\t\tif(child.active_status == \"Active\"){\n\t\tchild.remarks = '';\n\t\tcur_frm.refresh_fields();\n\t\tfrappe.throw(\"Remarks should not allow for Active status\")\n\t\t}\n\t},\n\tactive_status: function(frm,cdt,cdn){\n\t\tvar child = locals[cdt][cdn];\n\t\tchild.remarks = '';\n\t\tcur_frm.refresh_fields();\n\n\t},\n systems_assets_add: function(frm,cdt,cdn){\n \tvar d = locals[cdt][cdn];\n \tvar id = d.idx;\n id = id-1;\n var row = frm.fields_dict.systems_assets.grid.grid_rows[id];\n var prevrow = frm.fields_dict.systems_assets.grid.grid_rows[id-1];\n if (frm.doc.system_filter == \"All\"){\n if (prevrow !== undefined) row.doc.systems = prevrow.doc.systems;\n }else{\n row.doc.systems = frm.doc.system_filter;\n }\n row.doc.language = frm.doc.language;\n cur_frm.refresh_fields();\n }\n});", "view": "Form" }, { diff --git a/smart_service/transactions/doctype/publish/publish.py b/smart_service/transactions/doctype/publish/publish.py index f24ed71..ee25b6d 100644 --- a/smart_service/transactions/doctype/publish/publish.py +++ b/smart_service/transactions/doctype/publish/publish.py @@ -189,5 +189,5 @@ def get_system(doc): if system_map: for s in system_map: doc = frappe.get_doc("System Mapping",s.name) - system = frappe.db.sql("""select systems,sub_systems,active_status,symptom,component,estimated_time,rts,component,mat,procedure_status,`procedure` from {0}.`tabSystem Mapping_Sub System` where parent = '{1}' and procedure_is_published = '0'""".format(current_db_name,s.name),as_dict=True) + system = frappe.db.sql("""select systems,sub_systems,active_status,symptom,component,estimate_time,rts,component,mat,procedure_status,`procedure` from {0}.`tabSystem Mapping_Sub System` where parent = '{1}' and procedure_is_published = '0'""".format(current_db_name,s.name),as_dict=True) return system diff --git a/smart_service/transactions/doctype/publish_temp_doc/publish_temp_doc.json b/smart_service/transactions/doctype/publish_temp_doc/publish_temp_doc.json index ae70746..e17737e 100644 --- a/smart_service/transactions/doctype/publish_temp_doc/publish_temp_doc.json +++ b/smart_service/transactions/doctype/publish_temp_doc/publish_temp_doc.json @@ -11,7 +11,7 @@ "column_break_4", "symptom", "component", - "estimated_time", + "estimate_time", "rts", "mat", "cover_image", @@ -60,11 +60,6 @@ "fieldtype": "Check", "label": "Component" }, - { - "fieldname": "estimated_time", - "fieldtype": "Duration", - "label": "Estimated Time" - }, { "fieldname": "rts", "fieldtype": "Data", @@ -98,12 +93,18 @@ "in_list_view": 1, "label": "Procedure Status", "read_only": 1 + }, + { + "fieldname": "estimate_time", + "fieldtype": "Float", + "label": "Estimated Time", + "read_only": 1 } ], "index_web_pages_for_search": 1, "istable": 1, "links": [], - "modified": "2021-11-25 17:15:47.559805", + "modified": "2022-04-09 15:44:31.084747", "modified_by": "Administrator", "module": "Transactions", "name": "Publish_Temp Doc", diff --git a/smart_service/transactions/doctype/system_mapping/system_mapping.py b/smart_service/transactions/doctype/system_mapping/system_mapping.py index 9a34d50..5ee35bb 100644 --- a/smart_service/transactions/doctype/system_mapping/system_mapping.py +++ b/smart_service/transactions/doctype/system_mapping/system_mapping.py @@ -8,7 +8,7 @@ class SystemMapping(Document): def validate(self): ###If anything change to be set Published flag as 0 current_db_name = frappe.conf.get("db_name") - systems = frappe.db.sql("""select systems,sub_systems,active_status,estimated_time,idx,rts,mat,cover_image,`procedure` + systems = frappe.db.sql("""select systems,sub_systems,active_status,estimate_time,idx,rts,mat,cover_image,`procedure` from {0}.`tabSystem Mapping_Sub System` where parent = '{1}'""".format(current_db_name,self.name),as_dict=True) if systems: for prev_system in systems: @@ -26,7 +26,7 @@ class SystemMapping(Document): if prev_system.procedure != cur_system.procedure: cur_system.procedure_is_published = "0" update_procedure(current_db_name,self.name,str(cur_system.idx)) - if prev_system.estimated_time != cur_system.estimated_time: + if prev_system.estimate_time != cur_system.estimate_time: cur_system.procedure_is_published = "0" update_procedure(current_db_name,self.name,str(cur_system.idx)) if prev_system.rts != cur_system.rts: diff --git a/smart_service/transactions/doctype/system_mapping_sub_system/system_mapping_sub_system.json b/smart_service/transactions/doctype/system_mapping_sub_system/system_mapping_sub_system.json index 8467cc9..692b918 100644 --- a/smart_service/transactions/doctype/system_mapping_sub_system/system_mapping_sub_system.json +++ b/smart_service/transactions/doctype/system_mapping_sub_system/system_mapping_sub_system.json @@ -13,7 +13,7 @@ "column_break_4", "symptom", "component", - "estimated_time", + "estimate_time", "rts", "mat", "cover_image", @@ -63,11 +63,6 @@ "fieldtype": "Check", "label": "Component" }, - { - "fieldname": "estimated_time", - "fieldtype": "Data", - "label": "Estimated Time" - }, { "fieldname": "rts", "fieldtype": "Data", @@ -123,12 +118,17 @@ "fieldname": "cover_image", "fieldtype": "Attach Image", "label": "Cover Image" + }, + { + "fieldname": "estimate_time", + "fieldtype": "Float", + "label": "Estimated Time" } ], "index_web_pages_for_search": 1, "istable": 1, "links": [], - "modified": "2022-03-15 13:21:41.072236", + "modified": "2022-04-09 15:24:09.686783", "modified_by": "Administrator", "module": "Transactions", "name": "System Mapping_Sub System",