| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403 |
- Ext.QuickTips.init();
- Ext.define('erp.controller.hr.emplmana.Archive', {
- extend: 'Ext.app.Controller',
- FormUtil: Ext.create('erp.util.FormUtil'),
- BaseUtil: Ext.create('erp.util.BaseUtil'),
- GridUtil: Ext.create('erp.util.GridUtil'),
- views:[
- 'hr.emplmana.Archive','core.form.Panel','core.grid.Panel2','core.toolbar.Toolbar','hr.emplmana.RelationGrid',
- 'hr.emplmana.EducationGrid','hr.emplmana.PositionGrid','hr.emplmana.WorkGrid',
- 'core.button.Add','core.button.Save','core.button.Close','hr.emplmana.ReandpunishGrid',
- 'core.button.Update','core.button.Delete','core.form.YnField','core.button.DeleteDetail',
- 'core.trigger.DbfindTrigger','core.grid.YnColumn','core.form.YnField','core.button.ResAudit',
- 'core.button.Audit','core.button.Submit','core.button.ResSubmit','core.form.FileField','hr.emplmana.ContractGrid'
- ],
- init:function(){
- var me = this;
- this.control({
- 'erpGridPanel2': {
- itemclick: function(selModel, record){
- this.GridUtil.onGridItemClick(selModel, record);
- }
- },
- 'reandpunishgrid':{
- itemclick: function(selModel, record){
- this.GridUtil.onGridItemClick(selModel, record, 'reandpunishgrid');
- }
- },
- 'positiongrid':{
- itemclick: function(selModel, record){
- this.GridUtil.onGridItemClick(selModel, record, 'positiongrid');
- }
- },
- 'workgrid':{
- itemclick: function(selModel, record){
- this.GridUtil.onGridItemClick(selModel, record, 'workgrid');
- }
- },
- 'educationgrid':{
- itemclick: function(selModel, record){
- this.GridUtil.onGridItemClick(selModel, record, 'educationgrid');
- }
- },
- 'relationgrid':{
- itemclick: function(selModel, record){
- this.GridUtil.onGridItemClick(selModel, record, 'relationgrid');
- }
- },
- 'erpSaveButton': {
- click: function(btn){
- this.beforeSave();
- }
- },
- 'erpSubmitButton': {
- afterrender: function(btn){
- var status = Ext.getCmp('em_statuscode');
- if(status && status.value != 'ENTERING'){
- btn.hide();
- }
- },
- click: function(btn){
- me.FormUtil.onSubmit(Ext.getCmp('em_id').value);
- }
- },
- 'erpResSubmitButton': {
- afterrender: function(btn){
- var status = Ext.getCmp('em_statuscode');
- if(status && status.value != 'COMMITED'){
- btn.hide();
- }
- },
- click: function(btn){
- me.FormUtil.onResSubmit(Ext.getCmp('em_id').value);
- }
- },
- 'erpAuditButton': {
- afterrender: function(btn){
- var status = Ext.getCmp('em_statuscode');
- if(status && status.value != 'COMMITED'){
- btn.hide();
- }
- },
- click: function(btn){
- me.FormUtil.onAudit(Ext.getCmp('em_id').value);
- }
- },
- 'erpResAuditButton': {
- afterrender: function(btn){
- var status = Ext.getCmp('em_statuscode');
- if(status && status.value != 'AUDITED'){
- btn.hide();
- }
- },
- click: function(btn){
- me.FormUtil.onResAudit(Ext.getCmp('em_id').value);
- }
- },
- 'field[name=em_id]': {
- afterrender: function(f){
- if(f.value != null && f.value != ''){
- var emid = Ext.getCmp('em_id').value;
- var positiongrid = Ext.getCmp('positiongrid');
- positiongrid.getMyData(emid);
- var workgrid = Ext.getCmp('workgrid');
- workgrid.getMyData(emid);
- var reandpunishgrid = Ext.getCmp('reandpunishgrid');
- reandpunishgrid.getMyData(emid);
- var educationgrid = Ext.getCmp('educationgrid');
- educationgrid.getMyData(emid);
- var relationgrid = Ext.getCmp('relationgrid');
- relationgrid.getMyData(emid);
- var contractgrid = Ext.getCmp('contractgrid');
- contractgrid.getMyData(emid);
- }
- },
- change: function(f){
- if(f.value != null && f.value != ''){
- var emid = Ext.getCmp('em_id').value;
- Ext.getCmp('positiongrid').getMyData(emid);
- Ext.getCmp('workgrid').getMyData(emid);
- Ext.getCmp('reandpunishgrid').getMyData(emid);
- Ext.getCmp('educationgrid').getMyData(emid);
- Ext.getCmp('contractgrid').getMyData(emid);
- //Ext.getCmp('relationgrid').getMyData(emid);
- }
- }
- },
- 'field[name=em_iccode]':{
- blur:function(f){
- if(f.value != null && f.value != ''){
- if(f.value.length!=18){
- showError('身份证填写不正确!');
- return;
- }
- var year=f.value.slice(6,10);
- var month=f.value.slice(10,12);
- var day=f.value.slice(12,14);
- var year_int=year-0;
- var month_int=month-0;
- var day_int=day-0;
- if(isNaN(year_int)||isNaN(month_int)||isNaN(day_int)){
- showError('身份证填写不正确!');
- return;
- }
- if(month_int>12||day_int>31){
- showError('身份证填写不正确!');
- return;
- }
- Ext.getCmp('em_birthday').setValue(year+'-'+month+'-'+day);
- }
- }
- },
- 'erpCloseButton': {
- click: function(btn){
- this.FormUtil.beforeClose(this);
- }
- },
- 'erpUpdateButton': {
- click: function(btn){
- this.beforeUpdate();
- }
- },
- 'erpDeleteButton': {
- click: function(btn){
- me.FormUtil.onDelete(Ext.getCmp('em_id').value);
- }
- },
- 'erpAddButton': {
- click: function(){
- me.FormUtil.onAdd('addArchive', '新增人员档案', 'jsps/hr/emplmana/archive.jsp');
- }
- }
- });
- },
- getForm: function(btn){
- return btn.ownerCt.ownerCt;
- },
- beforeSave: function(){
- var me = this;
- var form = Ext.getCmp('form');
- if(! me.FormUtil.checkForm()){
- return;
- }
- if(Ext.getCmp(form.keyField).value == null || Ext.getCmp(form.keyField).value == ''){
- me.FormUtil.getSeqId(form);
- }
- var detail = Ext.getCmp('grid');
- var education = Ext.getCmp('educationgrid');
- var position = Ext.getCmp('positiongrid');
- var work = Ext.getCmp('workgrid');
- var reandpunish = Ext.getCmp('reandpunishgrid');
- var relation = Ext.getCmp('relationgrid');
- var param1 = me.GridUtil.getGridStore(detail);
- var param2 = me.GridUtil.getGridStore(education);
- var param3 = me.GridUtil.getGridStore(position);
- var param4 = me.GridUtil.getGridStore(work);
- var param5 = me.GridUtil.getGridStore(reandpunish);
- var param6 = me.GridUtil.getGridStore(relation);
- if(param6.length==0&&Ext.getCmp('em_havefriend').value=='有'){
- showError('请填写亲友信息!');
- return;
- }
- if(detail.necessaryField.length > 0 && (param1.length == 0)){//
- showError($I18N.common.grid.emptyDetail);
- return;
- } else {
- param1 = param1 == null ? [] : "[" + param1.toString().replace(/\\/g,"%") + "]";
- param2 = param2 == null ? [] : "[" + param2.toString().replace(/\\/g,"%") + "]";
- param3 = param3 == null ? [] : "[" + param3.toString().replace(/\\/g,"%") + "]";
- param4 = param4 == null ? [] : "[" + param4.toString().replace(/\\/g,"%") + "]";
- param5 = param5 == null ? [] : "[" + param5.toString().replace(/\\/g,"%") + "]";
- param6 = param6 == null ? [] : "[" + param6.toString().replace(/\\/g,"%") + "]";
- if(form.getForm().isValid()){
- Ext.each(form.items.items, function(item){
- if(item.xtype == 'numberfield'){
- if(item.value == null || item.value == ''){
- item.setValue(0);
- }
- }
- });
- var r = form.getValues();
- me.FormUtil.save(r, param1, param2, param3,param4,param5,param6);
- }else{
- me.FormUtil.checkForm();
- }
- }
- },
- beforeUpdate: function(){
- var me = this;
- var form = Ext.getCmp('form');
- if(! me.FormUtil.checkForm()){
- return;
- }
- if(Ext.getCmp(form.keyField).value == null || Ext.getCmp(form.keyField).value == ''){
- me.FormUtil.getSeqId(form);
- }
- var detail = Ext.getCmp('grid');
- var education = Ext.getCmp('educationgrid');
- var position = Ext.getCmp('positiongrid');
- var work = Ext.getCmp('workgrid');
- var reandpunish = Ext.getCmp('reandpunishgrid');
- var relation = Ext.getCmp('relationgrid');
- var param1 = me.GridUtil.getGridStore(detail);
- var param2 = me.GridUtil.getGridStore(education);
- var param3 = me.GridUtil.getGridStore(position);
- var param4 = me.GridUtil.getGridStore(work);
- var param5 = me.GridUtil.getGridStore(reandpunish);
- var param6 = me.GridUtil.getGridStore(relation);
- if(detail.necessaryField.length > 0 && (param1.length == 0)){
- showError($I18N.common.grid.emptyDetail);
- return;
- } else {
- param1 = param1 == null ? [] : "[" + param1.toString().replace(/\\/g,"%") + "]";
- param2 = param2 == null ? [] : "[" + param2.toString().replace(/\\/g,"%") + "]";
- param3 = param3 == null ? [] : "[" + param3.toString().replace(/\\/g,"%") + "]";
- param4 = param4 == null ? [] : "[" + param4.toString().replace(/\\/g,"%") + "]";
- param5 = param5 == null ? [] : "[" + param5.toString().replace(/\\/g,"%") + "]";
- param6 = param6 == null ? [] : "[" + param6.toString().replace(/\\/g,"%") + "]";
- if(form.getForm().isValid()){
- Ext.each(form.items.items, function(item){
- if(item.xtype == 'numberfield'){
- if(item.value == null || item.value == ''){
- item.setValue(0);
- }
- }
- });
- var r = form.getValues();
- me.FormUtil.update(r, param1, param2, param3,param4,param5,param6);
- }else{
- me.FormUtil.checkForm();
- }
- }
- },
- add10EmptyItems: function(grid){
- var items = grid.store.data.items;
- var detno = grid.detno;
- if(detno){
- var index = items.length == 0 ? 0 : Number(items[items.length-1].data[detno]);
- for(var i=0;i<10;i++){
- var o = new Object();
- o[detno] = index + i + 1;
- grid.store.insert(items.length, o);
- items[items.length-1]['index'] = items.length-1;
- }
- } else {
- for(var i=0;i<10;i++){
- var o = new Object();
- grid.store.insert(items.length, o);
- items[items.length-1]['index'] = items.length-1;
- }
- }
- },
- onGridItemClick2: function(selModel, record){
- var grid = Ext.getCmp('positiongrid');
- var index = null;
- if(grid.detno){
- index = record.data[grid.detno];
- index = index == null ? (record.index + 1) : index;
- if(index.toString() == 'NaN'){
- index = '';
- }
- if(index == grid.store.data.items[grid.store.data.items.length-1].data[grid.detno]){//如果选择了最后一行
- this.add10EmptyItems(grid);//就再加10行
- }
- } else {
- index = record.index + 1;
- if(index.toString() == 'NaN'){
- index = '';
- }
- if(index == grid.store.data.items[grid.store.data.items.length-1].index + 1){//如果选择了最后一行
- this.add10EmptyItems(grid);//就再加10行
- }
- }
- var btn = Ext.ComponentQuery.query('erpDeleteDetailButton')[0];
- btn.setDisabled(false);
- btn.setText(btn.text.split(':')[0] + ":" + index);
- btn = Ext.ComponentQuery.query('copydetail')[0];
- btn.setDisabled(false);
- btn.setText(btn.text.split(':')[0] + ":" + index);
- btn = Ext.ComponentQuery.query('pastedetail')[0];
- btn.setDisabled(false);
- btn.setText(btn.text.split(':')[0] + ":" + index);
- btn = Ext.ComponentQuery.query('updetail')[0];
- btn.setDisabled(false);
- btn.setText(btn.text.split(':')[0] + ":" + index);
- btn = Ext.ComponentQuery.query('downdetail')[0];
- btn.setDisabled(false);
- btn.setText(btn.text.split(':')[0] + ":" + index);
- },
- onGridItemClick3: function(selModel, record){
- var grid = Ext.getCmp('workgrid');
- var index = null;
- if(grid.detno){
- index = record.data[grid.detno];
- index = index == null ? (record.index + 1) : index;
- if(index.toString() == 'NaN'){
- index = '';
- }
- if(index == grid.store.data.items[grid.store.data.items.length-1].data[grid.detno]){//如果选择了最后一行
- this.add10EmptyItems(grid);//就再加10行
- }
- } else {
- index = record.index + 1;
- if(index.toString() == 'NaN'){
- index = '';
- }
- if(index == grid.store.data.items[grid.store.data.items.length-1].index + 1){//如果选择了最后一行
- this.add10EmptyItems(grid);//就再加10行
- }
- }
- var btn = Ext.ComponentQuery.query('erpDeleteDetailButton')[0];
- btn.setDisabled(false);
- btn.setText(btn.text.split(':')[0] + ":" + index);
- btn = Ext.ComponentQuery.query('copydetail')[0];
- btn.setDisabled(false);
- btn.setText(btn.text.split(':')[0] + ":" + index);
- btn = Ext.ComponentQuery.query('pastedetail')[0];
- btn.setDisabled(false);
- btn.setText(btn.text.split(':')[0] + ":" + index);
- btn = Ext.ComponentQuery.query('updetail')[0];
- btn.setDisabled(false);
- btn.setText(btn.text.split(':')[0] + ":" + index);
- btn = Ext.ComponentQuery.query('downdetail')[0];
- btn.setDisabled(false);
- btn.setText(btn.text.split(':')[0] + ":" + index);
- },
- onGridItemClick4: function(selModel, record){
- var grid = Ext.getCmp('educationgrid');
- var index = null;
- if(grid.detno){
- index = record.data[grid.detno];
- index = index == null ? (record.index + 1) : index;
- if(index.toString() == 'NaN'){
- index = '';
- }
- if(index == grid.store.data.items[grid.store.data.items.length-1].data[grid.detno]){//如果选择了最后一行
- this.add10EmptyItems(grid);//就再加10行
- }
- } else {
- index = record.index + 1;
- if(index.toString() == 'NaN'){
- index = '';
- }
- if(index == grid.store.data.items[grid.store.data.items.length-1].index + 1){//如果选择了最后一行
- this.add10EmptyItems(grid);//就再加10行
- }
- }
- var btn = Ext.ComponentQuery.query('erpDeleteDetailButton')[0];
- btn.setDisabled(false);
- btn.setText(btn.text.split(':')[0] + ":" + index);
- btn = Ext.ComponentQuery.query('copydetail')[0];
- btn.setDisabled(false);
- btn.setText(btn.text.split(':')[0] + ":" + index);
- btn = Ext.ComponentQuery.query('pastedetail')[0];
- btn.setDisabled(false);
- btn.setText(btn.text.split(':')[0] + ":" + index);
- btn = Ext.ComponentQuery.query('updetail')[0];
- btn.setDisabled(false);
- btn.setText(btn.text.split(':')[0] + ":" + index);
- btn = Ext.ComponentQuery.query('downdetail')[0];
- btn.setDisabled(false);
- btn.setText(btn.text.split(':')[0] + ":" + index);
- }
- });
|