4 * This is the main Pman class [for bootstrap]
6 * In theory it's lighter than the original, as no BC concerns..
16 Pman = new Roo.Document(
19 // Tab not needed, as that's now our top level UI element..
23 rightNames: { }, /// register right names here - so they can be translated and rendered.
25 * @property {Roo.menu.Menu} pulldownMenu - the 'add menu pulldown, you can use it to add items..
31 buildCompleted : false, // flag to say if we are building interface..
33 'beforeauth' : true, // fired after page ready, before authentication check
34 'beforeload' : true, // fired after page ready, before module building.
35 'load' : true, // fired after module building
36 'authrefreshed' : true // fire on auth updated?? - should be on Login?!?!?
39 onBuildComplete : function ()
41 this.building = false;
42 //this.layout.getRegion('center').showPanel(0);
43 //this.layout.endUpdate();
44 //this.addTopToolbar();
46 this.fireEvent('load',this);
48 if (Pman.Login.authUser) {
50 if (typeof(FS) == 'undefined') {
51 Roo.log("failed to initialize FS");
55 FS.identify(Pman.Login.authUser.id, {
56 displayName: Pman.Login.authUser.firstname + ' ' + Pman.Login.authUser.lastname,
57 email: Pman.Login.authUser.email
69 // kludge to fix firebug debugger
70 if (typeof(console) == 'undefined') {
71 console = { log : function() { } };
75 if (Roo.get('loading')) {
76 Roo.get('loading').remove();
79 Roo.state.Manager.setProvider(new Roo.state.CookieProvider());
80 Roo.bootstrap.Tooltip.init();
88 if (Roo.get('loading-logo-tile')) {
89 Roo.get('loading-logo-tile').remove();
91 if (Roo.get('loading-logo-tile-top')) {
92 Roo.get('loading-logo-tile-top').remove();
94 if (Roo.get('loading-logo-bottom')) {
95 Roo.get('loading-logo-bottom').remove();
97 if (Roo.get('loading-logo-center')) {
98 Roo.get('loading-logo-center').remove();
103 loadUserInterface : function()
105 if (this.buildCompleted) { // it get's called from auth checking.. no need to build again..
108 // triggers after authentication verified...
110 if(typeof(uiConfig.fullstory) != 'undefined'){
114 if (Roo.get('loading')) {
115 Roo.get('loading').remove();
117 if (Roo.get('loading-mask')) {
118 Roo.get('loading-mask').show();
120 var au = Pman.Login.authUser;
121 document.title = appName + ' v' + AppVersion + ' - ' + au.company_id_name;
129 Pman.building = true;
131 Roo.XComponent.hideProgress = true;
132 Roo.XComponent.on('beforebuild', this.onBeforeBuild, this);
134 Roo.XComponent.on('buildcomplete', this.onBuildComplete, this);
135 Roo.XComponent.build();
140 finalize : function() {
144 window.onbeforeunload = function(e) {
145 e = e || window.event;
146 var r = "Closing this window will loose changes, are you sure you want to do that?";
148 // For IE and Firefox
158 Roo.bootstrap.MessageBox.hide();
160 if (Roo.get('loading-mask')) {
161 Roo.get('loading-mask').remove();
165 this.buildCompleted = true; // now we can force refreshes on everything..
168 // does the URL indicate we want to see a system..
176 genericDelete : function(tab,tbl) {
181 var s = tab.grid.selModel.getSelections();
183 Roo.bootstrap.MessageBox.alert("Error", "Select at least one Row to delete" );
186 //var reader = tab.grid.reader || tab.grid.ds.reader;
187 for(var i = 0; i < s.length; i++) {
188 r.push(s[i].json.id);
191 Roo.bootstrap.MessageBox.confirm("Confirm", "Are you sure you want to delete that?",
197 //tab.grid.mask("Deleting");
199 url: baseURL + '/Roo/'+tbl+'.php',
203 _delete : r.join(',')
205 success: function(response) {
208 tab.paging.onClick('refresh');
209 } else if (tab.grid.footer && tab.grid.footer.onClick) {
210 // new xtype built grids
211 tab.grid.footer.onClick('refresh');
212 } else if (tab.refresh) {
213 tab.refresh(); // this might cause problems as panels have a refresh method?
215 tab.grid.store.load();
221 failure: function(act) {
222 Roo.bootstrap.MessageBox.hide();
229 msg = "Error deleting";
232 Roo.bootstrap.MessageBox.alert("Error", msg);
242 /* fired before building - check permissions on a component.. */
243 onBeforeBuild : function(obj)
245 if (typeof(obj.part) == 'undefined') {
249 if (!obj.part[1].length) {
250 obj.part[1] = obj.part[0];
252 var permname = obj.part.join('.');
254 Roo.log("CHECKING: "+ permname);
256 if (typeof(appDisabled) != 'undefined' && appDisabled.indexOf(permname)> -1) {
259 // we now have permission...
260 // obj.moduleOwner '.' lname
262 if (Pman.Login.hasPermExists(permname) && !Pman.Login.hasPerm(permname,'S')) {
263 // it's a turned off permission...
264 Roo.log(permname + " is Disabled for this user");
269 if (obj.permname && obj.permname.length &&
270 Pman.Login.hasPermExists(obj.permname) && !Pman.Login.hasPerm(obj.permname,'S')) {
271 // it's a turned off permission...
272 Roo.log(obj.permname + " is Disabled for this user");
280 fullstory : function()
282 if(uiConfig.fullstory.domains.indexOf(location.host) < 0){
286 window['_fs_debug'] = false;
287 window['_fs_host'] = 'fullstory.com';
288 window['_fs_org'] = uiConfig.fullstory.account;
289 window['_fs_namespace'] = 'FS';
290 (function(m,n,e,t,l,o,g,y){
291 if (e in m) {if(m.console && m.console.log) { m.console.log('FullStory namespace conflict. Please set window["_fs_namespace"].');} return;}
292 g=m[e]=function(a,b){g.q?g.q.push([a,b]):g._api(a,b);};g.q=[];
293 o=n.createElement(t);o.async=1;o.src='https://'+_fs_host+'/s/fs.js';
294 y=n.getElementsByTagName(t)[0];y.parentNode.insertBefore(o,y);
295 g.identify=function(i,v){g(l,{uid:i});if(v){g(l,v)}};g.setUserVars=function(v){g(l,v)};
296 g.identifyAccount=function(i,v){o='account';v=v||{};v.acctId=i;g(o,v)};
297 g.clearUserCookie=function(c,d,i){if(!c || document.cookie.match('fs_uid=[`;`]*`[`;`]*`[`;`]*`')){
298 d=n.domain;while(1){n.cookie='fs_uid=;domain='+d+
299 ';path=/;expires='+new Date(0).toUTCString();i=d.indexOf('.');if(i<0){break;}d=d.slice(i+1)}}};
300 })(window,document,window['_fs_namespace'],'script','user');