You are here: Hello » blog

Anti-Spam Security

I hate spam, as everyone do. Since my website was quite vulnerable by spam bots- I had to implement some kind of security. From now on every unregistered user must enter capcha text, visible right after comment form. I don't mean to raise any difficulties for my visitors, but this type of security is essential.

2014/02/04 20:18 · 0 Comments

Obstacles and traps of JQuery

Celebration of Christmas and New Year have ended. Its time to back to work on projects.
Did some progress on Spot-In's server backend. Begun to update front end. I would like to allow user to delete his own report within few minutes after posting. It's quite ordinal in mobile UI1) that taphold2) event brings additional menu for touched item. I would like to use it to delete record.
Everything looks good till you try. Attached tap and taphold events for items and problems flow out:

  • If you taphold, tap event is executed
  • If you try to scroll down- taphold event is executed. As mentioned is previous problem, taphold is followed with tap.

Well, I could deal with tap and taphold problem if where would be no need to scroll down. This ListViews requirement was my traps. Searched whole web. I've tried various hakish ways of achieving what is needed and each time I've banged head into wall.

Finally, after a week I've found one simple and interesting solution, that really works. Swipe (scroll), taphold work perfectly. Solution is quite simple: taphold threshold and swipe duration threshold must differentiate at least 1ms(millisecond). And these thresholds mus be set before loading JQuery mobile library. Script should look like so:

<script type="text/javascript" charset="utf-8" src="jquery.min.js"></script>
<script type="text/javascript">
    $(document).bind("mobileinit", function () {
        $.event.special.tap.tapholdThreshold = 1000,
        $.event.special.swipe.durationThreshold = 999;
    });
</script>
<script type="text/javascript" charset="utf-8" src="jquery.mobile.min.js"></script>

One problem solved, but one left: how to prevent tap after taphold. I have tried everything what I came up with: various settings, hakish event handling and so on. This bug is registered in official jQuery bug tracked. Resolution- “wont fix” 8-o
And suddenly idea strike my head: unbind tap event on taphold and rebind it later. Little bit lame, but ir works :)

$("#object").on('taphold', function(e){
	$(this).off("click");
	//do whatever is needed
	setTimeout(function(){		//after 3 seconds return click event, as it was removed
		$(this).on("click", function(){
			// TAP event processing
		})
	},3000);
})

Looks like these two snippets let scroll, taphold and tap events to behave friendly without teasing each other :-)
Now I can continue to work on next version of spot-in for android.

P.S. I've found a remote Mac service. But about this later, till I be able to test it.

2014/02/04 20:18 · 0 Comments

iOS development

Apple probably is out of their mind?!

I'm looking for a way to develop iOS apps. My initial research gave me strange stare into monitor, then I found these “apple gems”. I have to pay 99$3) to be able to develop apps (even for myself), and to be able to release my apps- I must own MAC. Appple WTF?!

If I will not find working alternative on windows/linux- I'm not going to burn such a money. And my antipathy for apple is growing stronger and stronger.

2014/02/04 20:18 · 0 Comments

Spot-In project finished

I've just finished my second mobile application, named after Spot-In. Created using Apache Cordova4). It was quite a challenging job: I had to Create:

  • UI5),
  • Database structure,
  • Server side software,
  • Communication protocol
  • Glue everything into one working software package

I've had to deal with some Android 2.1-2.3 gliches like fixed position of footer bar (in this case footer is my menu) not on the bottom of the page if you scroll down the page. Some peoples used iScroll plugin for JQuery, but i've found even better and realy simple work-a-round. Look for this hack in tutorial section. Also it was a good practice of SQL and JQuery.

Spot-In Online version

Lazy Saturday, gloomy sky. Didn't had any urgent job so I've came up with new Spot-in version. This time application released as Web version. It is read-only version with restricted functionality, for those want to use Spot-In on non-supported device (atm6): iOS, Win, etc…) Just make bookmark in prefered web browser and use it until Spot-In will be supported on your device.

Cheers ;-)

2014/02/04 20:18 · 0 Comments

<< Newer entries

1) , 5) user interface
2) click and hold for second
3) 265 Lt
4) aka PhoneGap
6) at the moment
Except where otherwise noted, content on this wiki is licensed under the following license: CC Attribution-Noncommercial-Share Alike 3.0 Unported

Hey.lt - Nemokamas lankytojų skaitliukas XHTML