On Wednesday, April 8, 2015 at 3:20:28 AM UTC-7, sasogeek wrote: > > I was doing it the wrong way i think, but i did a workaround. I used the A > helper to place a button on the page and when it's clicked it replaces > itself with the form at statusform.load with ajax=True, and it works just > fine > > Glad you got it going. Sounds like a step beyond what I've done (just the button so far), but I admit to skimming your original post.
/dps > On Tuesday, 7 April 2015 15:11:58 UTC+1, sasogeek wrote: >> >> default.py >> >> @auth.requires_login() >> def load_home(): >> loader = """$('#right-side').html("<i style='font-size:24px;' >> class='fa fa-spinner fa-spin'></i>")""" >> websocket_send('http://127.0.0.1:8888', loader, 'mykey', 'home%s' % >> auth.user.id) >> remove_class1 = "$('#bk').removeClass('active')" #books >> remove_class2 = "$('#ls').removeClass('active')" #lecture slides >> remove_class3 = "$('#pq').removeClass('active')" #past questions >> remove_class4 = "$('#cs').removeClass('active')" #courses >> remove_class5 = "$('#bl').removeClass('active')" #blogs >> remove_class6 = "$('#nt').removeClass('active')" #notes >> remove_class7 = "$('#fr').removeClass('active')" #friends >> add_class = "$('#hm').addClass('active')" #home >> websocket_send('http://127.0.0.1:8888', remove_class1, 'mykey', >> 'home%s' % auth.user.id) >> websocket_send('http://127.0.0.1:8888', remove_class2, 'mykey', >> 'home%s' % auth.user.id) >> websocket_send('http://127.0.0.1:8888', remove_class3, 'mykey', >> 'home%s' % auth.user.id) >> websocket_send('http://127.0.0.1:8888', remove_class4, 'mykey', >> 'home%s' % auth.user.id) >> websocket_send('http://127.0.0.1:8888', remove_class5, 'mykey', >> 'home%s' % auth.user.id) >> websocket_send('http://127.0.0.1:8888', remove_class6, 'mykey', >> 'home%s' % auth.user.id) >> websocket_send('http://127.0.0.1:8888', remove_class7, 'mykey', >> 'home%s' % auth.user.id) >> websocket_send('http://127.0.0.1:8888', add_class, 'mykey', 'home%s' >> % auth.user.id) >> >> message = """<section class='content'><br/><div class='row'><div >> class='col-md-4'><div class='grid box-profile bg-red'><div >> class='grid-body'><img src='%s' class='img-circle' alt='User >> Profile'><h3>%s</h3><span>Lorem ipsum dolor sit amet consectetur >> adipisicing elit sed do eiusmod</span></div><div class='footer clearfix >> bg-red'><div class='col-xs-4'><div class='grid-body full'><h3><i class='fa >> fa-facebook-square'></i> 823k</h3></div></div><div class='col-xs-4'><div >> class='grid-body full'><h3><i class='fa fa-twitter'></i> >> 402k</h3></div></div><div class='col-xs-4'><div class='grid-body >> full'><h3><i class='fa fa-linkedin-square'></i> >> 97k</h3></div></div></div></div></div> <div class='col-md-8 >> pull-right'><div class='grid'><div class='grid-header'><img >> style='height:30px;' src='%s' class='img-polaroid pull-left' alt='User >> Profile'><span class='grid-title'>Status</span></div><div class='grid-body' >> id='sf'></div></div></div></div></section>""" % (URL('download', >> args=[auth.user.profile_picture]) if auth.user.profile_picture else >> "../static/nb/html/assets/img/logo.png", auth.user.full_name, >> URL('download', args=[auth.user.profile_picture]) if >> auth.user.profile_picture else "../static/nb/html/assets/img/logo.png") >> >> message = message.strip().replace("'", '"') >> message = message.strip().replace("\n", "") >> message = message.strip().replace("\r", "") >> message = message.strip().replace("\t", "") >> message = >> "$('#right-side').html($('%s').fadeIn('slow').slideDown('slow'))" % message >> websocket_send('http://127.0.0.1:8888', message, 'mykey', 'home%s' % >> auth.user.id) >> >> form = LOAD(c='default', f='statusform', ajax=True, content=XML('<i >> style="font-size:24px;" class="fa fa-cog fa-spin"></i>')) >> form = "$('#sf').html($('%s').fadeIn('slow').slideDown('slow'))" % >> form >> websocket_send('http://127.0.0.1:8888', form, 'mykey', 'home%s' % >> auth.user.id) >> >> def statusform(): >> status = crud.create(db.statuses) >> msg = status.element('textarea', _name="status") >> msg['_class'] = "form-control" >> msg['_style'] = "height: 40px; width:45vw; margin-bottom:5px;" >> user_id = status.element('input', _name='user_id') >> user_id['_type'] = 'hidden' >> user_id['_value'] = auth.user.id >> submit = status.element('input', _type="submit") >> submit['_class'] = "btn btn-primary pull-right" >> submit['_value'] = "Post" >> if status.process().accepted: >> userPic=db(db.auth_user.id >> ==request.post_vars.user_id).select().first().profile_picture >> now = prettydate(datetime.datetime.now()) >> message1 = """<div class="col-md-8 pull-right" >> style="width:51.9vw;"><div class="grid"><div class="grid-header"><img >> style="height:30px; width: 30px;" src="%s" class="img-polaroid pull-left" >> alt="User Profile"><span class="grid-title">%s</span><div class="pull-right >> grid-tools"><a data-widget="collapse" >> title="Collapse">%s</a></div></div><div >> class="grid-body">%s</div></div></div>""" % (URL('download', >> args=[userPic]) if userPic else "../static/nb/html/assets/img/logo.png", db( >> db.auth_user.id == >> request.post_vars.user_id).select().first().full_name, now, >> request.post_vars.status) >> >> message1 = message1.strip().replace("\n", "<br/>") >> message1 = message1.strip().replace("\r", "") >> script1 = >> """$('#statuses1').prepend($('%s').fadeIn('slow').slideDown('slow'))""" % >> message1 >> script2 = "$('#statuses1').show('slow')" >> >> message2 = """<div class="col-md-8 pull-right" >> style="width:95vw;"><div class="grid"><div class="grid-header"><img >> style="height:30px; width: 30px;" src="%s" class="img-polaroid pull-left" >> alt="User Profile"><span class="grid-title">%s</span><div class="pull-right >> grid-tools"><a data-widget="collapse" >> title="Collapse">%s</a></div></div><div >> class="grid-body">%s</div></div></div>""" % (URL('download', >> args=[userPic]) if userPic else "../static/nb/html/assets/img/logo.png", db( >> db.auth_user.id == >> request.post_vars.user_id).select().first().full_name, now, >> request.post_vars.status) >> >> message2 = message2.strip().replace("\n", "<br/>") >> message2 = message2.strip().replace("\r", "") >> script3 = >> """$('#statuses2').prepend($('%s').fadeIn('slow').slideDown('slow'))""" % >> message2 >> script4 = "$('#statuses2').show('slow')" >> >> websocket_send('http://127.0.0.1:8888', script1, 'mykey', >> 'mygroup') >> websocket_send('http://127.0.0.1:8888', script2, 'mykey', >> 'mygroup') >> websocket_send('http://127.0.0.1:8888', script3, 'mykey', >> 'mygroup') >> websocket_send('http://127.0.0.1:8888', script4, 'mykey', >> 'mygroup') >> return status >> >> >> >> home.html >> <ul class="sidebar-menu"> >> <li class="active" id="hm" onclick="ajax('load_home', [], 'mmmm');"> >> <a href="#"> >> <i class="fa fa-home"></i><span>Home</span> >> </a> >> </li> >> ... >> </ul> >> >> ... >> <aside class="right-side" id="right-side"> >> </aside> >> >> <script> >> $(document).ready(function(){ >> var data; >> $.web2py.web2py_websocket('ws:// >> 127.0.0.1:8888/realtime/home{{=auth.user.id}} >> <http://127.0.0.1:8888/realtime/home%7B%7B=auth.user.id%7D%7D> >> ',function(e){data=eval('('+e.data+')')}); >> }); >> </script> >> >> >> I'm using ajax to call the function *load_home* and load_home is >> supposed to return a form using LOAD with ajax=True. The normal home >> function in the controller returns form using LOAD with ajax=True and that >> works just fine. But now I'm also using websocket_messaging.py to load >> parts of the page for navigation without whole page reloads, chats, etc. >> I'm trying to use the same mechanism to reload the home page when the >> "Home" link is clicked, so that I have the form working just as though the >> home page was being loaded afresh.... if that makes sense.... >> >> The problem here is that when I use ajax=False in the load_home function >> form = LOAD(c='default', f='statusform', ajax=False, content=XML('<i >> style="font-size:24px;" class="fa fa-cog fa-spin"></i>')) >> >> The form appears just fine (but even that when someone submits the form, >> it doesn't save the details in the db), but when ajax=True >> form = LOAD(c='default', f='statusform', ajax=True, content=XML('<i >> style="font-size:24px;" class="fa fa-cog fa-spin"></i>')) >> >> The cog icon keeps spinning. >> >> How can I accomplish what I'm aiming at... >> >> >> >> -- Resources: - http://web2py.com - http://web2py.com/book (Documentation) - http://github.com/web2py/web2py (Source code) - https://code.google.com/p/web2py/issues/list (Report Issues) --- You received this message because you are subscribed to the Google Groups "web2py-users" group. To unsubscribe from this group and stop receiving emails from it, send an email to web2py+unsubscr...@googlegroups.com. For more options, visit https://groups.google.com/d/optout.