Top 10 simple tools you should know for working with remote team

remote_development_work-123There has been a sharp increase in Remote Development team in different parts of world, who provide product development, support and maintenance services.

Looking into current demand for skilled pool of Dedicated Developers, it is efficient to hire skilled developers and designers who are located at remote locations and use the right tools to chat, video conference, share screen and keep all the tasks in single place to develop your product efficiently and cost-effectively.

Here are the 10 must have tools to set up a virtual office and work with your remote team:

1. Skype:

Skype_logo

 

 

 

Skype is a voice and text based Instant messaging system that works on the VOIP technology. If you have a microphone and speaker, you can make phone free calls from your computer to other people on Skype and make cheaper calls to landlines and cell phones. Other features include instant messaging, file transfer, video conferencing and screen sharing. Skype also has an Internet connection box that lets you convert your regular telephone to use the internet for telephone service.

 

2. Google+ Hangouts:

Google_Hangouts

 

 

 

It is a free video chat service that offers both ‘one-on-one’ and group chats with up to ten people at a time. It focuses more on “face-to-face-to-face” group interaction as opposed to one-on-one video chats, and makes use of sophisticated technology to seamlessly switch the focus to the person currently chatting. It provides a ‘Hangouts on Air’ to broadcast live video conversation which are accessible to anyone with web browser.

3. join.me

join.me_image

 

 

 

 

join.me is a free one click screen sharing and conferencing tool. Just download the app, run and share the URL and you’ve got instant screen sharing along with text chat, voice conferencing as well as mouse sharing (if you allow it). You can also voice chat while watching the demonstration on the shared screen and even share files.

4. Cisco WebEx:

CiscoWebex_image

 

 

 

It is an on demand collaboration, web conferencing, online meeting and video conferencing app.  It is a full-fledged service that offers Screen sharing, audio and video recording, meeting scheduling and future event scheduling tools for both presenters and participants.

5. Orangescrum:

OrangeScrum_new_logo

 

 

 

 

There are numerous project collaboration tools available. However, we used Orangescrum which is developed by our development team. It is a project collaboration tool for project handling and effective communication between the developers and customers. It facilitates file attachments of any size and format; assigning tasks to a group. Set e-mail alerts as well as prioritize and target them to the concerned team members. It has got everything that a project collaboration tool demands.

 

6. Google Docs:

Google_logo

 

 

 

 

Google Docs is a free web based application in which documents and spreadsheets can be created, edited at the real time. Files can be accessed remotely form any PC with an internet connection and a Web browser. Users can import and edit docs and spreadsheets in various fonts, formats, formulas, lists, tables and images. Multiple users can work together in real time from remote locations.

 

7. DropBox:

Dropbox_image

 

 

 

 

 

DropBox is a personal cloud storage service which is used for file sharing and collaboration. It automatically updates the file changes across multiple devices which can be accessed from the DropBox repository. It can also be used with Android, iOS and windows mobile devices. Along with file sharing it also offers file versioning which are saved automatically.

 

8. Google Calendar:

Google_logo

 

 

 

Google Calendar app facilitates users to create private and public calendars. It store the calendars within its own servers hence, can be accessed from anywhere through a Web browser. This is probably the best app for scheduling and managing your events and meetings.

 

9. Sqwiggle:

sqwiggle1

 

 

 

 

Sqwiggle is browser-based group video chat service. They also have a stand-alone client for OS-X. According to TechCrunch- “It’s got the office-like immediacy that Skype lacks, but without the noise of a Google Hangout”

 

10. HipChat:

HipChat

 

 

HipChat is a private chat and instant messaging service that allows users to create and join chat rooms and send one-on-one messages with other users. Other primary features include searchable chat history, sharing images, uploading files and also SMS messaging for one-to-one conversation.

Things you must do after Apps development

mobile_marketing-large

Android and iOS both are the most lucrative mobile app development platform. Although Apple is the dominant player in US, Android has the widest customers around the world. Hence for business requirements, both iOS and Android is the most viable option. With over 850,000 applications in the Google Play and still counting Android has become the most versatile platform for the businesses as well as individuals to release any sort of apps in the market. Whereas App Store accounts for over 40 billion apps purchases and possesses around 775,000 apps ‘and still counting’.

After publishing the application to the App Store and Google Play, it is essential to promote those apps for generating revenue. Developers should popularize their apps over web to attract the attention of customers. Here are few ways to market and promote your applications on application stores.

Simultaneous App marketing and Development

Don’t wait till you finish developing your app; instead start marketing when the development process is ongoing. You could setup a website or a blog about the application you would be releasing in future. You could also promote the concept of your application through blog or social media websites. Developers should also write articles and reviews on topics and products related to the type of application they are willing to develop. This would help to gain visibility on the web as well as making people familiar about the idea of the applications. All the articles and app promotion through social media and blog posting has to be relevant.

Search optimize your Google Play and App Store Page

Every application released on the Google Play and App Store has its own page. Customers and users would come to this page through links in articles, blogs and social media updates. Developers will have just few seconds to persuade their possible customers through their page hence, the contents and information on the page has to be compelling. It would help if the app is named smartly i.e. the name should reflect the purpose of the application. Developers should also take utmost care while designing the app icons. It would be helpful if high resolution screenshots are also included in the Google Play and App Store page.

Involve your Friends, Family any one you can

The first few days of the release of the application to the application stores are the most crucial time which would decide the future of your apps promotion. Most users rely on the ratings given to the application before actually downloading it to their mobile device. Along with the rating, comments and reviews also matters. If the app gets a good number of downloads and has good ratings, there is a chance that it will be placed in the top list of best selling app or staff picks section.  Hence, ask your friends and family to give 5-star ratings to the applications, in fact ask as many people you know to give your application a 5-star rating and write impressive comments and reviews about the applications. Ensure a higher number of downloads by requesting trusted friends to download the app.

Support:

Offer continuous support to the users by addressing their queries and comments. If a user has raised an issue regarding app’s performance or functionality, address them by fixing the issue and then reply their comments by intimating them about the bug fixes. It facilitates developers to build a trust with their customers. Also watch out for negative feedback and bad reviews and remove any prevalent bugs that might be hampering your app’s reputation.

Android Application Development and iPhone application development are considered to be the best mobile app development platform for businesses. Because of its wider reach, it facilitates them to promote and market their application to a wider group of people.

An Introduction Of PHP Frameworks Guides For Developers

A framework is a structure that developers choose to build their application. It determines the structure of the application and facilitates it to connect with many different API’s. A proficient PHP framework enables developers to develop PHP application faster, efficiently and assist in building stable applications thereby reducing the amount of repetitive coding for PHP programmers.

Frameworks provide scaffolding features that facilitates the development team to build faster and cleaner application. They often provide tool sets for both the UI components and the database access.

Note: It is advisable to use the latest stable version of a framework.

Never miss an update from us. Join 10,000+ marketers and leaders.

Here are few aspects of a proficient PHP framework:

MVC Architecture:

  • The framework should make use of Model View Controller (MVC) architecture. Some of the best frameworks also provide libraries, plug-ins, helpers, and extensions to assist developers. It would be smart and efficient to employ a framework that has at least two of these options.

Database Support:

  • It is one of the most crucial aspects of every PHP development framework. You need decide your framework depending on the database you are going to use for your web application.

For Example:  ‘CodeIgniter’ supports MySQL, Oracle, and SQLite, whereas the ‘Kohana’ framework doesn’t.

Community & Documentation:

  • The framework should be supported by a strong community, not just in terms of size but also in terms of activity and usefulness. Even if it’s a small community, you should be able to get ample support from the community.

A PHP framework should also have good documentation. It should be comprehensive and up-to-date.

Below, I have provided a list of some popular and commonly used PHP frameworks.

CakePHP 2.x:

  • CakePHP is a rapid development framework for PHP. It’s a foundational structure for programmers to create web applications. CakePHP has an active developer team and community, bringing great value to the project. It is also the most preferred development framework.

        Source:http://book.cakephp.org/2.0/en/index.html

Symfony 2.x:

  • Speed up the creation and maintenance of your PHP web applications. Replace the repetitive coding tasks by power, control and pleasure.

        Source: http://symfony.com/

CodeIgniter 2.x:

  • CodeIgniter is a powerful PHP framework with a very small footprint, built for PHP coders who need a simple and elegant toolkit to create full-featured web applications.

         Source: http://ellislab.com/codeigniter

Zend Framework 2:

  • It is an open source framework for developing web applications and services using PHP 5.3+. Zend Framework 2 uses 100% object-oriented code and utilizes most of the new features of PHP 5.3, namely namespaces, late static binding, lambda functions and closures.
  • Zend Framework 2 evolved from Zend Framework 1, a successful PHP framework with over 15 million.

        Source: http://framework.zend.com

Yii Framework 1.1.x:

  • Yii comes with rich features: MVC, DAO/ActiveRecord, I18N/L10N, caching, authentication and role-based access control, scaffolding, testing, etc. It will reduce your development time significantly.

        Source: http://www.yiiframework.com

Kohana 3.x:

  • An elegant HMVC (Hierarchical model–view–controller) PHP5 framework that provides a rich set of components for building web applications.

        Source: http://kohanaframework.org/

FuelPHP:

  • It is a simple, flexible, community driven PHP 5.3+ framework, based on the best ideas of other frameworks.

        Source: http://fuelphp.com/

There are a number of PHP development frameworks in the market which enables the development team to do more with the programming language. Development frameworks makes coding for PHP more manageable and programmers can take its advantage by making use of a convenient development framework.

Things You Should Know Before Planning Your Mobile App-Part-I

When you are looking at all the popular apps, you too are tempted to have one of your own; however, it can’t be done overnight. It is because; there are thousands of mobile app programmers and companies who may be thinking of doing the very much similar things. To have a successful mobile app it takes lots of hard work and well defined requirements.  You need to think about the main development aspects before planning to go for your mobile app.

Basic Steps You Need to Know For Developing Mobile App:

From our experiences, here are some guidelines you must go through if you are planning to develop a successful mobile app:

  1. The most crucial step is to come up with an innovative idea. Here, you need to make sure that there is little or no competition for it.
  2. Identify your targeted audience and build your app form their perspective, something that is more likely to be appreciated by these users.
  3.  Judge and determine major pain points and challenges that you expect to face for your application. You should hire a dedicated development team who could understand your specific business requirements and turn your ideas into a working app.
  4. Make sure that your app provides good usability and practical values to the users i.e., they should find your app useful and productive.
  5. Your app should have a solid built with no loose ends. Make sure to run a vigorous crash test and beta test phase before actually publishing it. User experience must be intuitive as well as engaging. If you are willing to implement APIs, ensure that it is robust and doesn’t generate any glitches in the application.
  6. After publishing your app to the application stores, you need to start promoting and market your application. One of the best ways to reach a wider audience is by promoting it over social media. Next, you will have to avail as much positive feedback from users as possible.
  7. You should offer constant support to your customers by addressing their comments, expectations and complaints. Then you should release updates and new features for your app to woo your existing customers as well as attracting the attention of new ones.
  8. Offering basic features for free and then selling premium stuff is a popular way to keep users hooked up and to gain traction. Also make sure that the app is noticed and favored by your customer.

iOS application development and Android app development can be easily executed and managed with the help of expertise mobile app developers. Moreover, it is advisable to outsource mobile application development tasks to development companies. Hiring a professional development company would facilitate you to build flawless and unique mobile apps which would greatly leverage revenue.

How to put custom Gradient backgrounds in IOS App

iOS_screenshot-196x300

Introduction:

It is essential to have a unique design for every iPhone application; in order to deliver the most intriguing and compelling interfaces, customization is necessary in every step. A great place to start is to implement your own background and use a clear table view background. Many iOS apps are now following this. Another way is to add a custom background colour. It is as easy as setting the cells background color property.

I tried both the above methods, and still not satisfied with it. There are numerous applications that have pretty similar interfaces. That’s why I thought about putting a gradient view as the background.

Core Graphics is a great resource that helped me in the right direction. It is supposed to customize the background of a cell, but I used it as a basis for my code to draw a gradient.

Here is an example of GradientView

GradientView.h

[sourcecode]#import <UIKit/UIKit.h>
@interface GradientView : UIView
{
}
@end[/sourcecode]

GradientView.m

[sourcecode]#import "GradientView.h"
#import <QuartzCore/QuartzCore.h>
@implementation GradientView
//
// layerClass
//
// returns a CAGradientLayer class as the default layer class for this view
//
+ (Class)layerClass
{
return [CAGradientLayer class];
}
//
// setupGradientLayer
//
// Construct the gradient for either construction method
//
– (void)setupGradientLayer
{
CAGradientLayer *gradientLayer = (CAGradientLayer *)self.layer;
gradientLayer.colors =
[NSArray arrayWithObjects:
(id)[UIColor colorWithRed:0.85 green:0.85 blue:0.85 alpha:0.8].CGColor,(id)[UIColor colorWithRed:1.0 green:1.0 blue:1.0 alpha:1].CGColor,
(id)[UIColor colorWithRed:1.0 green:1.0 blue:1.0 alpha:1].CGColor,(id)[UIColor colorWithRed:1.0 green:1.0 blue:1.0 alpha:1].CGColor,
nil];
self.backgroundColor = [UIColor clearColor];
}
//
// initWithFrame:
//
// Initialise the view.
//
– (id)initWithFrame:(CGRect)frame
{
self = [super initWithFrame:frame];
if (self)
{
CAGradientLayer *gradientLayer = (CAGradientLayer *)self.layer;
//gradientLayer.cornerRadius = 10;
gradientLayer.colors =
[NSArray arrayWithObjects:
(id)[UIColor colorWithRed:0.255/255.0 green:0.215/255.0 blue:0.0/255.0 alpha:0.5].CGColor,(id)[UIColor colorWithRed:1.0 green:1.0 blue:1.0 alpha:1].CGColor,
(id)[UIColor colorWithRed:1.0 green:1.0 blue:1.0 alpha:1].CGColor,(id)[UIColor colorWithRed:1.0 green:1.0 blue:1.0 alpha:1].CGColor,(id)[UIColor colorWithRed:1.0 green:1.0 blue:1.0 alpha:1].CGColor,
nil];
self.backgroundColor = [UIColor clearColor];
}
return self;
}
@end[/sourcecode]

Then u can use this class object in “cellForRowAtIndex” method of “UITableViewController” class as follows

[sourcecode]- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
static NSString *CellIdentifier = @"Cell";
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
if (cell == nil) {
cell = [[UITableViewCell alloc]
initWithStyle:UITableViewCellStyleDefault         reuseIdentifier:CellIdentifier] ;            cell.accessoryType=UITableViewCellAccessoryDisclosureIndicator;
cell.selectionStyle = UITableViewCellSelectionStyleNone;
cell.backgroundView = [[[GradientView alloc] init] autorelease];
}
// Configure the cell.
cell.textLabel.text = [self.allFolder objectAtIndex:indexPath.row];
cell.textLabel.backgroundColor = [UIColor clearColor];
cell.imageView.image=[UIImage imageNamed:@"folder.png"];
return cell;
}[/sourcecode]

Conclusion:

Many times, we need to make the application stand out from the crowd. While redesigning, we need something that would make our list of contents distinct from all the other table views. Hence, implementing custom background tables in ‘UITableView’ will be a smart way to start.

The Best Practices for Rails App Development

“Rails” is an amazing framework to develop web applications quickly through its inbuilt helper libraries. However, there are certain best practices that you should follow to get your rails app perform better.

Conventional programming methods:

Most developers love to place the logic inside the controller and use the model for the “Active Record” operation only.

This leads to a “Fat controller and skinny model” interface which eventually kills an app’s performance and looses the maintainability of the code. This way, application stops responding when the load is high.

What should be the best practices?

Below, I have mentioned some of the most essential and useful practices that should be followed by every Ruby on Rails developer.

Fat Model, Skinny Controller

Write all the non-response-related logics inside the model with nice and testable methods; and don’t forget to use comments.

You should follow the Ruby on Rails motto i.e. “Fat Model, Skinny Controller”. Because the “skinny” controller offers a nice interface between the view and model.

By moving any logic that isn’t about the response (for example, setting a flash message, or choosing whether to redirect or render a view) to the model instead of the controller, not only you can reuse the codes where

possible but you’ve also made it possible to test your code.

Reusable Scopes

A scope is a set of constraints on database interactions (such as a condition, limit, or offset) that are chainable and reusable.

Let’s see a simple example:

[sourcecode language=”plain”]
def index
@paid_users= User.where(“is_active=? AND is_paid=?”,true, true).order(“name”)
@unpaid_users= User.where(“is_active=? AND is_paid=?”, true, false).order(“name”)
[/sourcecode]

You can change it to this:

[sourcecode language=”plain”]
def index
@paid_users= User.paid.all
@unpaid_users= User.unpaid.all
end[/sourcecode]

Then, you can move the logic to your User model, where it might look like this:

[sourcecode language=”plain”]
scope :paid, lambda { where(“is_active=? AND is_paid=?”,true, true).order(“name”) }
scope :unpaid, lambda { where(“is_active=? AND is_paid=?”,true, false).order(“name”) }
[/sourcecode]

Using the methods User.paid.all and User.unpaid.all, we’ve not only made it simpler to test our code, but also made it possible to reuse that same set of conditions in another location.

You should avoid the use of default_scope because:

  1. You can’t override default scope
  2. default_scope will affect your model initialization

Package Your Code into Gems and Plugins

Writing a particular set code more than once for different applications is exhausting as well as redundant, hence, it is advisable to create a plugin or gem to use it further. It will save your development time and effort.

Manage Your Attribute Access

While creating or updating an object, Rails app usually assigns every attribute without checking the data. Validation only prevents the bad data but doesn’t exactly prevent it from overwriting an attribute that we don’t want to change.

To solve this issue, ActiveRecord is implemented which uses two methods: attr_protected and attr_accessibile.

Using attr_protected, you can declare a blacklist of variables you don’t want to be assigned and using attr_accessible, you can declare a list of variables that can be assigned.

By implementing above steps, you could prevent any mass assignment that could occur via your application’s forms; because if the form does not have the field for a given attribute, doesn’t mean a hacker can’t add it to the request.

From a security perspective, using attr_accessible and attr_protected forces you to think about what should be editable and how to protect the ways in which your class’s attributes are set.

Use Non-database-backed Models

In Rails app, Model is not restricted to associate with table. To organize application logic, write it down by creating a new model.

Virtual Attributes

If you are manipulating data before passing it to a model, use virtual attributes instead.

Virtual attributes are a simple own getter and setter methods.

For example
To set a user’s name:

[sourcecode language=”plain”]
@user = User.new(params[:user])
@user.first_name, @user.last_name = params[:user][:name].split(" ", 2)
[/sourcecode]

By using virtual method inside the model

[sourcecode language=”plain”]
def name=(value)
self.first_name, self.last_name = value.to_s.split(“ ”, 2)
end[/sourcecode]

Whenever you set the name attribute, your model will automatically set the first_name and last_name attributes for you, even though name doesn’t exist in the database.

Use Translations

Rails i18n framework makes it easy to declare the map of an abstract context to a string.

All you need to do is maintain a YAML file of translations, and use I18n.t / t in your code where there is data shown to the use.

I18n is useful to avail your app to more locales.

Using of after_commit callback

Use “after_commit” instead of using after_create/after_update/after_destroy callbacks to start background processes. Because, in relational database, several operations are wrapped in one unit and pass or fail of transaction depends upon all the operations.

If you use after_create/after_update/after_destroy in first model and if any error occurs in the second model then the background process will raise NotFoundError.

Use select in ActiveRecord association

Use select with has_many and belongs_to on Active Record Associations to speed up the query.

For example:

[sourcecode language=”plain”]
class Patient < ActiveRecord::Base
belongs_to :physician, :select => ‘id,name, surname’
end

class Physician < ActiveRecord::Base
has_many :patients, :select => ‘id,name, physician_id’
end
[/sourcecode]

Fix N+1 Queries

N+1 Queries is a serious database performance problem. Use “Bullet” gem to avoid N+1 query problem

Conclusion:

Employing the above mentioned Rails best practices would keep the code cleaner and reusable.

The application performance would increases tremendously and the maintenance of the code will be easier.