Wednesday, 19 December 2012

jQuery : Make Ajax Call PHP Script with JSON Return

User experience plays a vital role in excellent web design. AJAX allows you to run server-side validations, form submission, data retrieval, and other server-side stuff in the background (asynchronously) without interfering with the existing page where the request was made. It's a beautiful thing, but best of all it's not very difficult to do.

JSON its self is JavaScript Object Notation and a lightweight data-interchange format.Beside that JSON generate text-based open standard that readable for human. In this time, we'll try using JSON for data transfers and JQuery library for the tool and make AJAX connection.

Assume that we have structure file as below :


So let's move on to the script.

1. html


    JSON JQuery
    
    


    
Nama :
Alamat :
 
Atribut yang sudah terset adalah :
Tuesday, 18 December 2012

MySQL : Join Query

Cause lot of task in the office lately so I haven't had as much time to post any note, so here I would like to make a note about Join Query in MySQL.

The JOIN keyword is used in an SQL statement to query data from two or more tables, based on a relationship between certain columns in these tables. Tables in a database are often related to each other with keys. So we can get data easier to read as what we want.

Assume that we have table and we'll try to make a relation, we make a simple table which have structure as below :

Table user:
CREATE TABLE `user` (
`id_user` int(11) NOT NULL auto_increment,
`name` varchar(20) NOT NULL,
PRIMARY KEY  (`id_user`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;
Table user_description :
CREATE TABLE `user_description` (
`id_user` int(11) NOT NULL,
`address` varchar(50) NOT NULL,
`telephone` varchar(15) NOT NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1;
Data :
INSERT INTO `user` (`id_user`, `name`) VALUES
(1, 'anto purwanto'),
(2, 'johnny'),
(3, 'kartikarina');
INSERT INTO `user_description` (`id_user`, `address`, `telephone`) VALUES
(1, 'cimahi', '082550435544'),
(2, 'cibiru', '022 7823413'),
(4, 'tubagus ismail', '022 66224325');

Sunday, 25 November 2012

Bola Karet dan Bola Kaca Kehidupan

Hidup ini seperti pemain circus yang harus memutar sejumlah bola di udara, hanya saja sebagian dari bola-bola itu adalah bola karet dan sebagian yang lain adalah bola kaca. Bola-bola dari karet boleh saja dikorbankan untuk jatuh bila dipandang perlu, karena dia akan memantul dengan sendirinya dan dapat diambil kembali saat dibutuhkan. Bola-bola dari kaca tidak boleh jatuh sama sekali – karena sekali jatuh dia hancur, jadi dia harus selalu tertangkap tangan dan tidak boleh dikorbankan. Memahami mana yang bola karet dan mana yang bola kaca akan menentukan apa yang menjadi prioritas hidup kita.

Misalkan, kita sendiri adalah pemain circus itu dan kita bermain dengan lima bola,  sebut saja : pekerjaan, keluarga, pertemanan, kesehatan, keimanan. Mana diantara lima ‘bola’ ini yang bola karet dan mana yang ‘bola’ kaca bagi Anda ?. Setiap orang akan memiliki pilihannya sendiri.

Idealnya adalah kita perlakukan semuanya sebagai ‘bola kaca’ sehingga tidak ada satupun yang boleh jatuh. ‘Pemain circus’ yang pinter mungkin saja bisa melakukan ini, tetapi kebanyakan orang suatu saat akan terpaksa membiarkan salah satunya jatuh. Bila ini yang harus dilakukan, maka hanya bola karet-lah yang boleh jatuh.

Thursday, 22 November 2012

CSS : Vertical Centering Menu

Vertical centering has always been a fairly elusive goal when doing CSS layouts, but it’s still possible. Here, we'll make a simple center list menu where each list have centering orientation.

Then it's the preview of menu that would be made :
Firstly, we make html file :

After that, let's move out to make style :
body{
 font-size: 12px;
}
.menu{
 border: solid thin #f00;
 margin-top: 45px;
}
.wrapper{
 width: 960px;
 margin: auto;
}

ul#menu {
    text-align: center;
    height: 140px;
    display: table-cell;               /* make unorder list to be table-cell */
    margin: auto !important;
    width: 960px;
    background:  #8fcdea;
    margin: 0px;
    padding: 0px;
    vertical-align: middle;
}
#menu ul {
    display: table;
    margin: 0 auto;
}
#menu li {
    display: inline-block;            /* make list to inline-block */
    position: relative;
    width: auto;
}
#menu li li {
    display: block;
}
#menu ul {
    display: inline-block;
}
#menu li {
    display: inline;
}
#menu a {
    display: inline-block;
    border: solid thin #f00;
    height: 60px;
    display: table-cell;
    vertical-align: middle;    /* set list vertical align : middle */
}
#menu li:hover ul {
    left: 0;
    top: 1.3em;
}
#menu li {
    display: inline;
    margin-left: 0 !important;
    position: relative;
    width: auto;
}
#menu a {
    color: #000000;
    line-height: 1.6;
    padding: 0 2.5em;
    width: 6em;
    text-decoration: none;
}
#menu li li, #menu li li a {
    display: block;
    height: 1.5em;
}
#menu li li a {
    padding: 0;
    width: auto;
}
#menu li:hover ul {
    left: 0;
    top: 1.5em;
}
Note :

The simple way if you want to center certain content vertically :
.container {
   min-height: 10em;  /* set your own height */
   display: table-cell;
   vertical-align: middle;
}
Done !
Tuesday, 20 November 2012

GIT : Make Local Metadata Repository

When you want to develop your application efficiently with your team work. Git is the best way and it brings plenty of advantageous when build your application. Here, we would make local repository and use some command git that would be used frequently for your further or other project.

Repository contains metadata file that have complete history and full revision about everything that happen to your git working directory. Metadata can reduce the size in the repository. the metadata ussualy like the following:


Let's move out and configure in Terminal :

1. Make a repository
server@server-comp:~$ cd ~/repository
server@server-comp:~/repository$ mkdir contoh   // create dir as contoh
server@server-comp:~/repository$ cd contoh      // enter contoh directory
server@server-comp:~/repository/contoh$ ls -al  // view content in directory
total 8
drwxrwxr-x  2 server server 4096 Nov 20 11:24 .
drwxrwxrwx 36 server server 4096 Nov 20 11:24 ..
server@server-comp:~/repository/contoh$ git init   // initialize as git repo
Initialized empty Git repository in /home/server/repository/contoh/.git/
server@server-comp:~/repository/contoh$ ls -al
total 12
drwxrwxr-x  3 server server 4096 Nov 20 11:25 .
drwxrwxrwx 36 server server 4096 Nov 20 11:24 ..
drwxrwxr-x  7 server server 4096 Nov 20 11:25 .git
server@server-comp:~/repository/contoh$ vim contoh.txt  // create first file, fill with anything and save
server@server-comp:~/repository/contoh$ ls -al
total 16
drwxrwxr-x  3 server server 4096 Nov 20 11:25 .
drwxrwxrwx 36 server server 4096 Nov 20 11:24 ..
-rw-rw-r--  1 server server   20 Nov 20 11:25 contoh.txt
drwxrwxr-x  7 server server 4096 Nov 20 11:25 .git
server@server-comp:~/repository/contoh$ git add contoh.txt // add file(s) in directory
server@server-comp:~/repository/contoh$ git commit -m "bikin contoh.txt" -a // make a commit
[master (root-commit) 5852652] bikin contoh.txt
 1 file changed, 1 insertion(+)
 create mode 100644 contoh.txt
If you do it correctly, there must be a .git file. Then we move .git out into other folder that represent contoh repository , for example, contoh.git.
Tuesday, 6 November 2012

Zend Framework 2 : Use Composer & Packagist PHP

Introduction

Composer is a tool for depedency management in PHP. It allows you to declare the dependent libraries in your project needs and it will install them in your project.

Composer is not a package manager but composer manages them (packages or libary) on a per-project basis, installing them in a directory (e.g vendor) inside your project. By default it will never install anything globally. thus , it's a dependency manager.

The problem that composer can solve are :

a) You have a project that depends on a number of libraries.
b) Some of those libraries depend on other libraries.
c) You declare the things you depend on.
d) Composer finds out which versions of which packages need to be installed, and installs them (meaning it download them into your project like apt-get command in ubuntu).

Installation

First, you have to install curl on your pc by type command on your terminal :
 sudo apt-get install curl 
Then type command to get executetable composer.phar
 $ curl -s https://getcomposer.org/installer | php
This will just check a few PHP settings and then download composer.phar to your working directory. This file is the Composer binary. It is a PHAR (PHP archive), which is an archive format for PHP which can be run on the command line, amongst other things.
Monday, 5 November 2012

GIT : Introduction

GIT is an distributed modern version control system that designed to handle everything from small to very large projects with speed and efficiency. Git was designed and developed by Linus Torvalds for Linux kernel development. It has since been adopted by many other projects. Every Git working directory is a full-fledged repository with complete history and full revision tracking capabilities, not dependent on network access or a central server.

Version Control itself is a system that records changes to a file or set of files over time so that you can recall specific versions later. For examples, if you are a graphic or web designer and want to keep every version of an image or layout (which you would most certainly want to), a Version Control is a very wise thing to use. It allows you to revert files back to a previous state, revert the entire project back to a previous state, compare changes over time, see who last modified something that might be causing a problem, who introduced an issue and when, and sort of it.

So what git could do for us :

- Git could reverts files back to a previous state that you've made.
- Revert the entire project back to a previous state.
- Compare changes over time.
- See who last modified something that might be causing a problem.
- If you screw things up or lose file, you can easily recover that files.
Wednesday, 31 October 2012

Zend Framework 2 : Send Html Mail with Simple Template

Here is my experiment with some help from my friend, how to use zend framework 2 mail component to sent mail as html. Even though we don't have any mail server or we just don't want to think of how to set mail server but with this component we could send mail easily. In this section, we will utilize a reliable smtp server like Gmail. Then we just have to have an account on the web mail to use the service for send mail.

Before we move on to the code, make sure that openssl have activated on our php.ini configuration. By doing uncomment extension=php_openssl.dll.

Let's assume that we have a module called Email with structure as below


1. Make a template for mail

In view/email directory, there's a tpl directory contains template.phtml. template.phtml file is used for our template content mail that will be sent. Actually, you can make template mail wherever you want.

template.phtml


Greetings

ini template buat email !!
2. Call Namespace Zend Component
// for email library
use Zend\Mail;
use Zend\Mime\Part as MimePart;
use Zend\Mime\Message as MimeMessage;
3. Make action on your Controller to send mail
// setup SMTP options
$options = new Mail\Transport\SmtpOptions(array(
            'name' => 'localhost',
            'host' => 'smtp.gmail.com',
            'port'=> 587,
            'connection_class' => 'login',
            'connection_config' => array(
                'username' => 'put your gmail username ',
                'password' => 'put your gmail password',
                'ssl'=> 'tls',
            ),
));
                 
$this->renderer = $this->getServiceLocator()->get('ViewRenderer');
$content = $this->renderer->render('email/tpl/template', null);

// make a header as html
$html = new MimePart($content);
$html->type = "text/html";
$body = new MimeMessage();
$body->setParts(array($html,));

// instance mail 
$mail = new Mail\Message();
$mail->setBody($body); // will generate our code html from template.phtml
$mail->setFrom('sender email address','Sender Name');
$mail->setTo('some email addressed');
$mail->setSubject('Your Subject');

$transport = new Mail\Transport\Smtp($options);
$transport->send($mail);

Tuesday, 16 October 2012

Mari Menulis dengan Media Blog !

Berawal dari kebanyakan orang-orang hanya menghabiskan waktu didepan monitor dengan tidak melakukan hal yang lebih bermanfaat. Disini saya mencoba memberikan beberapa opsi dan alasan untuk mencoba sebuah kegiatan yang menarik yaitu menulis dimana salah satu media dan kegiatannya adalah nge-blog.

Jadi berikut beberapa alasan mengapa pentingnya menulis :

1. Dengan menulis kita bisa menjadi inspirasi buat yang lainnya.

Yap, menulis merupakan sarana menyebarkan inspirasi. Contoh buku "The Old New Land" yang ditulis Theodore Herzl adalah suatu buku sastra karya seorang yahudi, gara-gara buku fiksi tersebut, jutaan orang Yahudi terinspirasi untuk mendirikan sebuah negara Israel. Dimana, jutaan orang yahudi yang kala itu tersebar di berbagai belahan dunia beramai-ramai datang ke negara Islam yang terdapat kiblat pertama, Al Aqsha, Palestina. Hal tersebut merupakan hal yang luar biasa dimana cuma berawal dari pemikiran yang diwujudkan dengan tulisan dan dengan bantuan media lainnya, orang-orang yahudi tersebut berusaha mewujudkan negara tersebut hanya berawal dari tulisan fiksi. Terlepas dari konspirasi & cara mereka yang sangat tidak berperikemanusiaan dalam proses mencapai tujuan tersebut.

Zend Framework 2 : Using Classmap Generator

Since version 5, PHP has given support that very varied in OOP. One of them by overloading feature implemented on PHP 5.1.2. This feature really helps the efficiency of the writing of the code becomes more compact (so we don't need to use require or include  to load a class).

In Zend Framework 2, there is Zend\Loader\Autoloader component for autoloading of Zend Framework and your own classes. It provides functionality through two classes: StandardAutoloader and ClassMapAutoloader. here, I would explain about classmap generator that could generate Classmap Autoloader in Zend Framework .The class map autoloader its self is a high performance autoloader. It uses class maps, which are simply associative arrays of each classname to the name of the file disk that contains that class.

The contents of classmap autoloader usually like this :
   return array(
    'ZendSkeletonModule\Module'                        => __DIR__ . '/Module.php',
    'ZendSkeletonModule\Controller\SkeletonController' => __DIR__ . '/src/ZendSkeletonModule/Controller/SkeletonController.php',
    'ZendSkeletonModuleTest\Framework\TestCase'        => __DIR__ . '/tests/ZendSkeletonModule/Framework/TestCase.php',
    'ZendSkeletonModuleTest\SampleTest'                => __DIR__ . '/tests/ZendSkeletonModule/SampleTest.php',
);
The problem basically if our class in our application are pretty much. We would be getting tired and bored to write it manually. So Zend Framework 2 provides classMap generator that already exist in the vendor\ZF2\bin folder if you download ZendSkeletonApplication.

Assume that we have a structure module directory as below:


Well, the file autoload_classmap is in our module folder. So we just have to execute file ../../vendor/ZendFramework/bin/classmap_generator.php as below :
 server@server-comp:/var/www/ZendSkeletonApplication/module/Test$ php ../../vendor/ZF2/bin/classmap_generator.php -w -l ./ \ -o ./autoload_classmap.php
PHP Warning:  Module 'pdo_pgsql' already loaded in Unknown on line 0
Creating class file map for library in '/var/www/ZendSkeletonApplication/module/Test'...
Wrote classmap file to '/var/www/ZendSkeletonApplication/module/Test/autoload_classmap.php'
server@server-comp:/var/www/ZendSkeletonApplication/module/Test$ 
then if you do it correctly, the file autoload_classmap would change become like this :
 return array(
    'Test\Module'                    => __DIR__ . '/Module.php',
    'Test\Controller\TestController' => __DIR__ . '/src/Test/Controller/TestController.php',
    'Test\Model\ContohModel'         => __DIR__ . '/src/Test/Model/ContohModel.php',
);
Done !

Reference :
  1. http://samsonasik.wordpress.com/2012/03/15/zend-framework-2-classmap-generator/
  2. http://akrabat.com/zend-framework-2/using-zendloaderautoloader/

Monday, 15 October 2012

Create Easy CSS3 Radio Buttons

Ever wondered how to style radio buttons, but without any JavaScript? Thanks to CSS3 you can!

Here is the way !
In this time, we will make a simple question with lists of options.
  1. HTML
    • Your Question ??
  2. CSS
  3. .list_question {
        width: 300px;
        height: auto;
        margin: 0px auto;
        background: #0096F4;
        color: #fff;
        padding: 10px;
        border-radius: 6px 6px 6px 6px;
    }
    .list_question ul li {
        list-style: decimal;
        background: none;
        padding: 0px;
        margin: 0px;
    }
    .list_question ul.choices{
        list-style: none;
        margin: 0px;
        margin-left: -35px;
        padding: 0px;
    }
    .list_question ul.choices li{
        list-style: none;
    }
    .list_question ul{
        margin: 0px;
    }
    
    /* check radio button*/
    
    .radio {
        cursor: pointer;
        display: inline-block;
        font: 15px/41px sans-serif;
        padding-right: 20px;
    }
    .radio:hover .inner {
        opacity: 0.5;
    }
    .radio input {
        display: none;
    }
    .radio input:checked + .outer .inner {
        opacity: 1;
    }
    .radio .outer {
        background:url("images/check_radio_sheet.png") -38px top no-repeat;
        display: block;
        float: left;
        margin: 10px;
        width:19px;
        height:19px;
    }
    .radio .inner {
        -moz-transition: opacity 0.5s ease 0s;
        background:url("images/check_radio_sheet.png") -57px top no-repeat;
        border-radius: 20px 20px 20px 20px;
        display: block;
        opacity: 0;
        width:19px;
        height:19px;
    }
    
    Here is my image background for radio button:


  4. Let's preview the result ! here's mine.


In this post, I also put style transition animation when the cursor hovering on the radio. Once again, it's pure css without any javascript.
Done !

Source :
  1. http://webdesign.tutsplus.com/tutorials/htmlcss-tutorials/quick-tip-easy-css3-checkboxes-and-radio-buttons/
Monday, 8 October 2012

Hidup Ini

peliknya hidup ini, tergores hidup warna warni
dalam kehampaan jiwa yang sepi..
membunuh bongkahan awan hitam tersipu layu
keindahan hidup merayu merdu

dan aku terkikis debu membatu.
jiwa liar terpaku membisu
entah kemana yang ingin dituju
dengan mencari sisa kehidupan masa lalu

kilauan asam yang terpatri
berhembus alunan sampan yang tertatih
membawa angan hingga ketepian

kusodorkan bunga harapan
yang berbalaskan keresahan
dalam hati ku berdendang sepi
tapak hidup yang harus ku jalani

harapan tak pernah sirna
selama hujan mengikis keliru hati
helaian tanya ku berdoa
demi hak yang terbagi
ku genggam asa untuk masa yang abadi

aku manusia dengan ironi

Pengenalan CURL

CURL adalah suatu command line (jadi kayak command cmd ato terminal) tool yang sangat terkenal. curl memungkinkan kita melakukan komunikasi langsung dengan berbagai protokol terkenal di internet.

Curl mendukung protokol FTP (File Transfer Protocol) , FTPS (FTP/SSL), HTTP (Hyper Text Transfer Protocol), HTTPS (HTTP/SSL) , SCP (Secure Copy Protocol), SFTP (Secure FTP), TFTP (Trivial FTP), Telnet, dan sebagainya.Untuk lebih lengkapnya bisa dilihat di website CURL . Sering sekali kita sebagai programmer PHP ingin menggunakan protokol-protokol ini secara customized dan belum ada library php yang mendukungnya. Untuk itu modul curl/libcurl adalah solusi yang paling cocok untuk kita.

Setting CURL untuk Web

Untuk mengaktifkan curl pada distribusi PHP kita, maka perlu kita pastikan bahwa library curl sudah ada dan kita perlu edit file php.ini. Setting CURL distribusi php dari paket XAMPP windows. Asumsi bahwa distribusi XAMPP telah terinstall di komputer kita.
Edit file php.ini yang terdapat pada folder apache/bin/php.ini dan cari baris dengan entri seperti dibawah ini :
;extension = php_curl.dll 
kemudian di hilangkan tanda titik koma di depan sehingga menjadi
extension = php_curl.dll
Kemudian coba di test configurasi curl anda dengan menggunakan php_info() function dan lihat apakah modul curl sudah diload dengan baik. Apabila modul tersebut telah aktif maka pada informasi php_info() akan terlihat baris modul curl telah aktif.

Thursday, 4 October 2012

Zend Framework 2 : Instalation and Make a Module

On 3 March 2012, Zend has released zend framework version 2.0. In zend framework 2.0, you will feel the different from previous version (Zend Framework version 1). Some of the different are zend framework 2 is more solid coding and  better performance. Btw, if you wanna try it you should use PHP version 5.3.For installing Zend Framework 2, we could clone GIT version of ZendSkeletonApplication as the basic foundation from our application.
Ok here we go.

First, clone the skeleton by using terminal or everything that could clone it :
git clone --recursive git://github.com/zendframework/ZendSkeletonApplication.git
After we clone, there must be a structure directory like this :


Tuesday, 2 October 2012

Ubuntu Terminal Command

Lately, I usually use ubuntu to help doing some task on my office. Actually, I could install windows operating system on my pc, but I've decided to use and try non privacy protection software such microsoft so I consider to use open source software exactly Ubuntu for doing my job.

On ubuntu its self, we know about terminal program that functionality could execute instruction. It could be more interactive than GUI, and quicker to be executed. You can try terminal program on your ubuntu and start running some of command.

Here is the list of some useful command in terminal that you could try and use for some task, but before that you could press Ctrl+Alt+T to open Terminal .

Auto Generate Image CSS

When we would make image gallery on our site, we want every image looks neat and but sometimes to make it, we have to make a php class to generate and make it as thumbnail picture. But I have alternative solution to make gallery image neat looking without php class just by using css.

Here is a trick that could be solve the problem,

Firstly, we make an html file with div name class img_box
After that we put css code to manipulate the image and img_box div
       
    
Then here we go, we could see the preview in the browser. For example, I put my preview image like this :


source image  :
  1. http://jonasdero.deviantart.com/?rnrd=6690#/d5ff1qw
  2. http://jonasdero.deviantart.com/?rnrd=6690#/d5ewhkw 
  3. http://jonasdero.deviantart.com/?rnrd=6690#/d5gctpk

Cross Browser Font Style Using CSS3

Sometimes on our website, we want to use several even more different and particular font that doesn't installed on the operating system. The solution that usually we use for solve that problem is we use static image to display the character which use that font. But after being supported CSS3 by many browser then we could use better option by using inclusion of a particular font on the server side and accessed via css web pages.

So here's the example for call a particular font that stored on the server command with CSS3 :
@font-face {
    font-family: MyFontName;
    src: url("path/to/font.ttf")
}

Next for for, calling that fonts we could do as usual.
.style1 {
    font-family: MyFontName, Arial, Tahoma, Verdana;
}

Note : for internet explorer, font that could be used not TTF (TrueType Font) but use EOT (Embedded OpenType) format. To change font a TTF become an EOT we could use ttf2eot application that provided by google or other application. 

Reference :
  1. http://batikpress.com/2012/02/cross-browser-font-style-menggunakan-css3.html 
Monday, 1 October 2012

Introduction of Zend Framework

In this session, I would like to make a post about Zend Framework.

Zend Framework is an open source php framework, that could help you to build web faster and robust. This framework was created by the company main supporters of PHP. Zend also supporting web 2.0 and cloud computing technologies.

Reason why use Zend are :
  1. Free and open source framework (licensed under the New BSD License).
  2. Extreme Simplicity.
  3. High productivity.
  4. Flexible Architecture.
  5. Supported by more than 300 contributor, include IBM and other major companies. 
You can try and use this framework by download at:  http://framework.zend.com/. On that site you also can find the framework user community. For the requirements , Zend Framework requires PHP 5.2.4 or later since version 1.7.0. Previous versions required PHP 5.1.4 or later, although the ZF Programmer's Reference Guide strongly recommended PHP 5.2.3 or later for security and performance improvements included in these versions of PHP. Zend Framework 2.0 will require PHP 5.3.3 or later. For next posting, I'll focus on Zend Framework 2.0.

Beside that, make sure that on your pc have installed web server like Apache, database server like MySQL. The most important thing is zend framework is recommended to build the web with sufficient complexity.

So let's use Zend Framework !!  :D

References :
  1. http://www.phpeveryday.com/articles/Zend-Framework-Basic-Tutorial-P840.html
  2. http://en.wikipedia.org/wiki/Zend_Framework
Monday, 14 May 2012

First Attempt

hi, ini postingan pertama dalam blog baru..
Copyright © 2012 Clighter | Powered by Blogger