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 'beforeload' : true, // fired after page ready, before module building.
34 'load' : true, // fired after module building
35 'authrefreshed' : true // fire on auth updated?? - should be on Login?!?!?
38 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();
85 if (showNewPass.length) {
86 Pman.PasswordChange.show( { passwordReset : showNewPass },
88 // fail and success we do a load...
100 if (Roo.get('loading-logo-tile')) {
101 Roo.get('loading-logo-tile').remove();
103 if (Roo.get('loading-logo-tile-top')) {
104 Roo.get('loading-logo-tile-top').remove();
106 if (Roo.get('loading-logo-bottom')) {
107 Roo.get('loading-logo-bottom').remove();
109 if (Roo.get('loading-logo-center')) {
110 Roo.get('loading-logo-center').remove();
115 loadUserInterface : function()
117 if (this.buildCompleted) { // it get's called from auth checking.. no need to build again..
120 // triggers after authentication verified...
122 if(typeof(uiConfig.fullstory) != 'undefined'){
126 if (Roo.get('loading')) {
127 Roo.get('loading').remove();
129 if (Roo.get('loading-mask')) {
130 Roo.get('loading-mask').show();
132 var au = Pman.Login.authUser;
133 document.title = appName + ' v' + AppVersion + ' - ' + au.company_id_name;
141 Pman.building = true;
143 Roo.XComponent.hideProgress = true;
144 Roo.XComponent.on('beforebuild', this.onBeforeBuild, this);
146 Roo.XComponent.on('buildcomplete', this.onBuildComplete, this);
147 Roo.XComponent.build();
152 finalize : function() {
156 window.onbeforeunload = function(e) {
157 e = e || window.event;
158 var r = "Closing this window will loose changes, are you sure you want to do that?";
160 // For IE and Firefox
170 Roo.bootstrap.MessageBox.hide();
172 if (Roo.get('loading-mask')) {
173 Roo.get('loading-mask').remove();
177 this.buildCompleted = true; // now we can force refreshes on everything..
180 // does the URL indicate we want to see a system..
188 genericDelete : function(tab,tbl) {
193 var s = tab.grid.selModel.getSelections();
195 Roo.bootstrap.MessageBox.alert("Error", "Select at least one Row to delete" );
198 //var reader = tab.grid.reader || tab.grid.ds.reader;
199 for(var i = 0; i < s.length; i++) {
200 r.push(s[i].json.id);
203 Roo.bootstrap.MessageBox.confirm("Confirm", "Are you sure you want to delete that?",
208 //tab.grid.mask("Deleting");
210 url: baseURL + '/Roo/'+tbl+'.php',
214 _delete : r.join(',')
216 success: function(response) {
219 tab.paging.onClick('refresh');
220 } else if (tab.grid.footer && tab.grid.footer.onClick) {
221 // new xtype built grids
222 tab.grid.footer.onClick('refresh');
223 } else if (tab.refresh) {
224 tab.refresh(); // this might cause problems as panels have a refresh method?
226 tab.grid.store.load();
232 failure: function(act) {
238 msg = "Error deleting";
241 Roo.bootstrap.MessageBox.alert("Error", msg);
250 /* fired before building - check permissions on a component.. */
251 onBeforeBuild : function(obj)
253 if (typeof(obj.part) == 'undefined') {
257 if (!obj.part[1].length) {
258 obj.part[1] = obj.part[0];
260 var permname = obj.part.join('.');
262 Roo.log("CHECKING: "+ permname);
264 // we now have permission...
265 // obj.moduleOwner '.' lname
267 if (Pman.Login.hasPermExists(permname) && !Pman.Login.hasPerm(permname,'S')) {
268 // it's a turned off permission...
269 Roo.log(permname + " is Disabled for this user");
274 if (obj.permname && obj.permname.length &&
275 Pman.Login.hasPermExists(obj.permname) && !Pman.Login.hasPerm(obj.permname,'S')) {
276 // it's a turned off permission...
277 Roo.log(obj.permname + " is Disabled for this user");
285 fullstory : function()
287 if(uiConfig.fullstory.domains.indexOf(location.host) < 0){
291 window['_fs_debug'] = false;
292 window['_fs_host'] = 'fullstory.com';
293 window['_fs_org'] = uiConfig.fullstory.account;
294 window['_fs_namespace'] = 'FS';
295 (function(m,n,e,t,l,o,g,y){
296 if (e in m) {if(m.console && m.console.log) { m.console.log('FullStory namespace conflict. Please set window["_fs_namespace"].');} return;}
297 g=m[e]=function(a,b){g.q?g.q.push([a,b]):g._api(a,b);};g.q=[];
298 o=n.createElement(t);o.async=1;o.src='https://'+_fs_host+'/s/fs.js';
299 y=n.getElementsByTagName(t)[0];y.parentNode.insertBefore(o,y);
300 g.identify=function(i,v){g(l,{uid:i});if(v){g(l,v)}};g.setUserVars=function(v){g(l,v)};
301 g.identifyAccount=function(i,v){o='account';v=v||{};v.acctId=i;g(o,v)};
302 g.clearUserCookie=function(c,d,i){if(!c || document.cookie.match('fs_uid=[`;`]*`[`;`]*`[`;`]*`')){
303 d=n.domain;while(1){n.cookie='fs_uid=;domain='+d+
304 ';path=/;expires='+new Date(0).toUTCString();i=d.indexOf('.');if(i<0){break;}d=d.slice(i+1)}}};
305 })(window,document,window['_fs_namespace'],'script','user');