All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jbpm.designer.public.js.Plugins.dictionary.js Maven / Gradle / Ivy

if (!ORYX.Plugins) 
    ORYX.Plugins = {};

if (!ORYX.Config)
	ORYX.Config = {};

ORYX.Config.Dictionary = {};

if(!ORYX.Dictionary) ORYX.Dictionary = {};

ORYX.Dictionary.DictionaryDef = Ext.data.Record.create([{
    name: 'name'
}, {
    name: 'aliases'
}, {
	name: 'description'
}
]);

ORYX.Dictionary.DictionaryProxy = new Ext.data.MemoryProxy({
    root: []
});

ORYX.Dictionary.Dictionaryitems = new Ext.data.Store({
	autoDestroy: true,
    reader: new Ext.data.JsonReader({
        root: "root"
    }, ORYX.Dictionary.DictionaryDef),
    proxy: ORYX.Dictionary.DictionaryProxy, 
    sorters: [{
        property: 'name',
        direction:'ASC'
    }]
});
ORYX.Dictionary.Dictionaryitems.load();

ORYX.Plugins.Dictionary = Clazz.extend({
	construct: function(facade){
		this.facade = facade;
		
		this.facade.registerOnEvent(ORYX.CONFIG.EVENT_DICTIONARY_ADD, this.initAndShowDictionary.bind(this));
		
		this.initDictionary();
		
		/* Register dictionary to model */
        if(!(ORYX.READONLY == true || ORYX.VIEWLOCKED == true)) {
            this.facade.offer({
                'name': ORYX.I18N.Dictionary.dictionary,
                'functionality': this.initAndShowDictionary.bind(this),
                'group': ORYX.I18N.View.jbpmgroup,
                'icon': ORYX.BASE_FILE_PATH + "images/dictionary.png",
                'description': ORYX.I18N.Dictionary.processDictionary,
                'index': 8,
                'minShape': 0,
                'maxShape': 0,
                'isEnabled': function(){
                    return !(ORYX.READONLY == true || ORYX.VIEWLOCKED == true);
    //				profileParamName = "profile";
    //				profileParamName = profileParamName.replace(/[\[]/,"\\\[").replace(/[\]]/,"\\\]");
    //				regexSa = "[\\?&]"+profileParamName+"=([^&#]*)";
    //		        regexa = new RegExp( regexSa );
    //		        profileParams = regexa.exec( window.location.href );
    //		        profileParamValue = profileParams[1];
    //				return profileParamValue == "jbpm";
                }.bind(this)
            });
        }
	},
	initAndShowDictionary : function(options) {
		this.initDictionary(this.showDictionary, options);
	},
	initDictionary: function(callback,options) {
		Ext.Ajax.request({
            url: ORYX.PATH + 'dictionary',
            method: 'POST',
            success: function(response) {
    	   		try {
            		ORYX.Dictionary.Dictionaryitems.removeAll();
    	   			var responseJson = Ext.decode(response.responseText);
    	   			if(responseJson.length > 0 && responseJson != "false") {
    		        	for(var i=0;i 0) {
	    	   				ORYX.Dictionary.Dictionaryitems.add(new ORYX.Dictionary.DictionaryDef({
	                            name: options.entry,
	                            aliases: '',
	                            description: ''
	                        }));
    	   				}
    	   			}
    	   			ORYX.Dictionary.Dictionaryitems.commitChanges();
    	   			if(callback) {
    	   				callback();
    	   			}
    	   		} catch(e) {
                       ORYX.EDITOR._pluginFacade.raiseEvent({
                           type 		: ORYX.CONFIG.EVENT_NOTIFICATION_SHOW,
                           ntype		: 'error',
                           msg         : ORYX.I18N.Dictionary.errorLoadingProcDic+ ': ' + e,
                           title       : ''

                       });
    	   		}
            }.bind(this),
            failure: function(){
                ORYX.EDITOR._pluginFacade.raiseEvent({
                    type 		: ORYX.CONFIG.EVENT_NOTIFICATION_SHOW,
                    ntype		: 'error',
                    msg         : ORYX.I18N.Dictionary.errorLoadingProcDic + '.',
                    title       : ''

                });
            },
            params: {
            	action: 'load',
            	profile: ORYX.PROFILE,
            	uuid :  window.btoa(encodeURI(ORYX.UUID))
            }
        });
	},
	showDictionary : function() {
		var dialogSize = ORYX.Utils.getDialogSize(400, 700);
		var gridProportion = 0.5;
		var extractionPanelProportion = 0.5;
		var gridWidth = dialogSize.width * gridProportion;
		var itemDeleterWidth = 70;
		var gridColWidth = (gridWidth - itemDeleterWidth) / 3;

		var itemDeleter = new Extensive.grid.ItemDeleter();
    	var gridId = Ext.id();
//    	var dictionaryPaging = new Ext.PagingToolbar({
//    	    pageSize: 10,
//    	    store: Dictionaryitems,
//    	    displayInfo: true,
//    	    displayMsg: 'Entry {0} - {1} of {2}',
//    	    emptyMsg: 'No entries to display'
//    	});
    	
    	var grid = new Ext.grid.EditorGridPanel({
            store: ORYX.Dictionary.Dictionaryitems,
            id: gridId,
            stripeRows: true,
            //bbar: dictionaryPaging,
            cm: new Ext.grid.ColumnModel([new Ext.grid.RowNumberer(), {
            	id: 'name',
                header: ORYX.I18N.Dictionary.header_name,
                width: gridColWidth,
                dataIndex: 'name',
                editor: new Ext.form.TextField({ allowBlank: false })
            }, {
            	id: 'aliases',
                header: ORYX.I18N.Dictionary.headerAliases,
                width: gridColWidth,
                dataIndex: 'aliases',
                editor: new Ext.form.TextField({ allowBlank: true })
            }, {
            	id: 'description',
                header: ORYX.I18N.Dictionary.headerDesc,
                width: gridColWidth,
                dataIndex: 'description',
                editor: new Ext.form.TextField({ allowBlank: true })
            }, 
            itemDeleter]),
    		selModel: itemDeleter,
            autoHeight: true,
            tbar: [{
                text: ORYX.I18N.Dictionary.addNewEntry,
                handler : function(){
                	ORYX.Dictionary.Dictionaryitems.add(new ORYX.Dictionary.DictionaryDef({
                        name: '',
                        aliases: '',
                        description: ''
                    }));
                    grid.fireEvent('cellclick', grid, ORYX.Dictionary.Dictionaryitems.getCount()-1, 1, null);
                }
            }],
            clicksToEdit: 1
        });

    	var processJSON = ORYX.EDITOR.getSerializedJSON();
    	var processDocumentation = jsonPath(processJSON.evalJSON(), "$.properties.documentation");
    	var docText = "";
    	if(processDocumentation && processDocumentation[0].length > 0) {
    		docText = processDocumentation[0];
    	} else {
    		docText = ORYX.I18N.Dictionary.noProcDoc;
    	}

    	var extractFromDocsButton = new Ext.Button({
    		text: ORYX.I18N.Dictionary.procDoc,
    	    handler: function(){ 
    	    	Ext.getCmp('processdocs').setValue(docText);
    	    }
    	});
    	var extractImportFormFromDocs = new Ext.Panel({
    			title: ORYX.I18N.Dictionary.fromDoc,
    			bodyStyle:'padding:5px',
    			autoScroll: false,
    			height: 60,
    	        items: [extractFromDocsButton],
    	        layoutConfig: {
                    padding:'5',
                    align:'middle'
                }
    	});
    	var extractImportFormFromFile = new Ext.Panel({
    		baseCls: 'x-plain',
    		labelWidth: 50,
    		defaultType: 'textfield',
			autoScroll: false,
	        items: [
	        {
	            fieldLabel: ORYX.I18N.Dictionary.select,
	            name: 		'subject',
				inputType : 'file',
				style : 	'margin-bottom:10px;display:block;width:150px',
				itemCls :	'ext_specific_window_overflow'
	        }
	        ]
    	});

    	var extractImportFormFromDocsWrapper = new Ext.Panel({
			title: ORYX.I18N.Dictionary.fromFile,
			bodyStyle:'padding:5px',
			autoScroll: false,
			height: 60,
	        items: [extractImportFormFromFile],
	        layoutConfig: {
                padding:'5',
                align:'middle'
            }
	});


    	var dictionaryInnerPanel = new Ext.Panel({
    		header: false,
    		width: '100%',
    	    layout:'column',
    	    border : false,
    	    layoutConfig: {
    			columns: 2,
    			pack:'center',
    		    align:'middle'
    		},
    	    items: [
    	            {
    	              columnWidth: .5,
    	              items: extractImportFormFromDocs
    	            },{
    	              columnWidth: .5,
    	              items: extractImportFormFromDocsWrapper
    	            }
    	          ]
    	});

    	var textPannel = new Ext.Panel({
    		title: ORYX.I18N.Dictionary.highlightText,
    		width: '100%',
    		height: 350,
    	    layout:'column',
    	    autoScroll:false,
    	    bodyStyle:'padding:5px',
    	    items:[
    		       {
    		    	    id: 'processdocs',
    		            xtype: 'textarea',
    		            hideLabel: true,
    		            name: 'processtextbox',
    			        grow: false,
    	                width: '100%',
    	                height: 280,
    	                preventScrollbars: false,
    	                style:{overflow:'auto'}
    		        }
                  ],
            tbar: [{
            	text: ORYX.I18N.Dictionary.add,
                handler : function(){
                	var e = document.getElementById('processdocs'); 
                    var selected = e.value.substring(e.selectionStart, e.selectionEnd);
                	if(selected && selected.length > 0) {
                		ORYX.Dictionary.Dictionaryitems.add(new ORYX.Dictionary.DictionaryDef({
                            name: selected,
                            aliases: '',
                            description: ''
                        }));
                	}
                  }
                  }]
    	});

    	var extractionPanel = new Ext.Panel({
    		id: 'processdocspanel',
    		title: ORYX.I18N.Dictionary.extractDicEntries,
    		layout:'column',
    		items:[
    		       dictionaryInnerPanel,textPannel
                  ],
    		layoutConfig: {
    			columns: 1
    		},
    		defaults: {
    	        columnWidth: 1.0
    	    }
    	});

    	var dictionaryOutterPanel = new Ext.Panel({
    		header: false,
    	    layout:'column',
			items: [
    	            {
    	              columnWidth: gridProportion,
    	              items: grid
    	            },{
    	              columnWidth: extractionPanelProportion,
    	              items: extractionPanel
    	            }
    	          ]
    	});

        var dialog = new Ext.Window({
			layout		: 'anchor',
			autoCreate	: true, 
			title		: ORYX.I18N.Dictionary.procDicEditor,
			height		: dialogSize.height,
			width		: dialogSize.width,
			modal		: true,
			collapsible	: false,
			fixedcenter	: true, 
			shadow		: true, 
			resizable   : true,
			proxyDrag	: true,
			autoScroll  : true,
			keys:[{
				fn	: function(){
						dialog.hide();
				}.bind(this)
			}],
			items		:[dictionaryOutterPanel],
			listeners	:{
				hide: function(){
					dialog.destroy();
				}.bind(this)				
			},
			buttons		: [{
                text: ORYX.I18N.Dictionary.Save,
                handler: function(){
                	// commit locally
                	ORYX.Dictionary.Dictionaryitems.commitChanges();
                	// store server-side
                	var datar = new Array();
                    var jsonDataEncode = "";
                    var records = ORYX.Dictionary.Dictionaryitems.getRange();
                    for (var i = 0; i < records.length; i++) {
                        datar.push(records[i].data);
                    }
                    jsonDataEncode = Ext.util.JSON.encode(datar);

                    ORYX.EDITOR._pluginFacade.raiseEvent({
                        type 		: ORYX.CONFIG.EVENT_NOTIFICATION_SHOW,
                        ntype		: 'info',
                        msg         : ORYX.I18N.Dictionary.storingDic,
                        title       : ''

                    });
                    Ext.Ajax.request({
        	            url: ORYX.PATH + 'dictionary',
        	            method: 'POST',
        	            success: function(request) {
        	    	   		try {
        	    	   			dialog.hide();
        	    	   		} catch(e) {
                                   ORYX.EDITOR._pluginFacade.raiseEvent({
                                       type 		: ORYX.CONFIG.EVENT_NOTIFICATION_SHOW,
                                       ntype		: 'error',
                                       msg         : ORYX.I18N.Dictionary.errorSavingDic+' :\n' + e,
                                       title       : ''

                                   });
        	    	   		}
        	            }.createDelegate(this),
        	            failure: function(){
                            ORYX.EDITOR._pluginFacade.raiseEvent({
                                type 		: ORYX.CONFIG.EVENT_NOTIFICATION_SHOW,
                                ntype		: 'error',
                                msg         : ORYX.I18N.Dictionary.errorSavingDic+'.',
                                title       : ''

                            });
        	            },
        	            params: {
        	            	action: 'save',
        	            	profile: ORYX.PROFILE,
        	            	uuid :  window.btoa(encodeURI(ORYX.UUID)),
        	            	dvalue : jsonDataEncode
        	            }
        	        });
                }.bind(this)
            }, {
                text: ORYX.I18N.Dictionary.cancel,
                handler: function(){
                	dialog.hide()
                }.bind(this)
            }]
		});

		dialog.show();
		//grid.render();
		//grid.focus( false, 100 );
		extractImportFormFromFile.items.items[0].getEl().dom.addEventListener('change',function(evt){
			var reader = new FileReader();
			reader.onload = function(e) { 
				Ext.getCmp('processdocs').setValue( e.target.result );
			} 
			reader.readAsText(evt.target.files[0], 'UTF-8');
		}, true);
	},
	_tobr: function(str) {
        return str.replace(/(\r\n|[\r\n])/g, "
"); } });




© 2015 - 2025 Weber Informatics LLC | Privacy Policy