“CI Chatsocket” Documentation by “Jay-r Simpron” v1.0


“CI Chatsocket”

Created: 25/08/2017
By: Jay-r Simpron
Email: ssj.simpron@gmail.com

Thank you for purchasing my library. If you have any questions that are beyond the scope of this help file, please feel free to email via my user page contact form here. Thank you so much!


Table of Contents

  1. Description
  2. Features and Functions
  3. Requirements
  4. Quick Start Guide
  5. Installation
  6. Console Configuration
  7. Node JS installation
  8. Overriding functions
  9. Sources Credit

A) Description - top

CodeIgniter is a proven, open source PHP web application framework that empowers the next generation of web apps and caters to everyone, from beginners to power users. "CI Chatsocket" is a chat application that uses Node JS and socket.io to communicate real time to each user. This library readily integrates with any existing Codeigniter website or application built with jQuery and Bootstrap.


B) Features and Functions - top

  1. Real time chat
  2. Can be installed on your existing CodeIgniter Website
  3. Private conversation
  4. Group conversation
  5. Manage group conversation users
  6. Preview image and mp4 videos
  7. Play youtube, vimeo directly if you paste a link
  8. Manage Users who you want to have this chat enabled.
  9. Convert links automatically.
  10. File attachment (gif|jpg|png|zip|zipx|rar|7z|pdf|doc|docx|txt|odt|mp3|mp4)
  11. Emoji (Icons)
  12. Search conversations

C) Requirements - top

  1. Server should have Node JS / can run Node JS
  2. Php 5.4 and above (Not yet tested in 5.3)
  3. MySQL server
  4. Codeigniter should be built with jQuery and Bootstrap for this application to work

D) Quick Start Guide - top

For you to understand how this application works, I have included the full CodeIgniter installation so that you can navigate and familiarize the configuration and the chat application

E) Installation - top

Information you need to know before going to setup this application from your existing codeigniter installation

  1. If you want to turn on the csrf_protection, I recommend you to turn off the csrf_regenerate to avoid conflict of the csrf token when multiple ajax is executed
  2. This application contains only two pages. The console configuration and the messages page.
  3. The console configuration will appear if you place the <?php csConsole(); ?> anywhere you want it to show.
    -You can see this code in the full codeigniter installation included on this item in application/modules/welcome/views/console.php file
  4. The messages page will appear if you place the <?php csMessagesPage(); ?> code anywhere you want it to show
    - You can see this code in the full codeigniter installation included on this item in application/modules/welcome/views/messages.php file
  5. Lastly, in order to show the chatbox tray, you need to place the <?php csChatbox(); ?> code before the body closing tag ()
    -You can see this code in the full codeigniter installation included on this item in application/views/view_html.php file


Complete all the steps below before navigating the web app.

There are four folders you can see when you download this item. The Chatsocket folder which is the library, the xwb_assets folder where the css and javascript is located, the full-ci which is the full CodeIgniter installation and the Documentation folder

Note:

Upload attachment won’t work in IE9.

If you are using community auth login, set that package to /config/autoload.php

$autoload['packages'] = array(APPPATH . 'third_party/community_auth/');



F) Console Configuration - top

  1. Go to the configuration page where <?php csConsole(); ?> is placed. You will see a page like the one illustrated below

  2. Input Description

    1. – This is the key of the codeigniter Session where the logged in User ID is stored. Choose and select the appropriate value.
    2. – The table from database where all the users is stored. Choose and select the appropriate value.
    3. – The field name of the user table where the User ID is stored. Choose and select the appropriate value.
    4. – The field name of the table where the user name is stored. This will be shown as a display name of your contacts. Choose and select the appropriate value.
      Configure if display name came from another table

      - You can touch this area only if the display name of the user is coming from the other table.

      1. – The table where the display name is located. Choose and select the appropriate value.
      2. – The field User ID relationship key of the other table from User Table's[B.] User ID[C.]. Choose and select the appropriate value.
      3. – The field of the display name of the other table. Choose and select the appropriate value.

    5. – Select or manage users where do you want to be able this chat application available.
    6. – The field from the Users Table[B.] where the picture file name is stored. Choose and select the appropriate value.
    7. – Click the “Browse” button then select the folder where all the profile picture is stored. This will be concatenated before the Picture File Name field[F.].
    8. – Set this input If the file name is located in the other table rather than the Users Table[B.]. Choose and select the appropriate value.
    9. - The field from the table[H.] where the picture file name is stored. Choose and select the appropriate value.
    10. – The field User ID relationship key for the other table of picture file name. Choose and select the appropriate value.

G) Node JS Installation - top



H) Overriding functions - top

Any functions you can see in the Chatsocket/helpers/chat_socket_helper.php can be overridden. Just create your own helper and add a function that is the same name with the function in chat_socket_helper.php. Place that helper in autoload. Refer into this web page for creating a helper CodeIgniter Helper.


I) Sources Credit - top

I used the following sources to build this library.

  1. - https://github.com/puikinsh/gentelella (demo)
  2. - https://jquery.com/
  3. - https://jqueryui.com/
  4. - http://getbootstrap.com/
  5. - http://fontawesome.io/
  6. - https://socket.io/
  7. - http://www.dropzonejs.com/
  8. - https://github.com/scaron/prettyphoto
  9. - https://github.com/mervick/emojionearea
  10. - https://select2.github.io/
  11. - http://bootboxjs.com/

If any of these is already loaded in your existing application, you can override the function csAddScript() located in chatsocket/helpers/chat_socket_helper.php as mentioned above[H.].


Once again, thank you so much for purchasing this library. As I mentioned, I'd be glad to help you if you have any questions relating to this library. No guarantees, but I'll do my best to assist. If you have a more general question relating to the library on CodeCanyon, you might consider visiting the forums and asking your question in the "Item Discussion" section.

I am also open for any suggestions for the future update

Jay-r Simpron

Go To Table of Contents