Block hotline contact nukevite 4.5

Hướng dẫn viết block Holine Contact nukeviet 4.5

Tạo file global.hotline_contact.ini

<?xml version="1.0" encoding="utf-8"?>
<block>
    <info>
        <name>Config Hotline Config</name>
        <author>DACLOI.,Jsc</author>
        <website> http://vncode.info</website>
        <description></description>
    </info>
    <config>
        <company_name></company_name>
        <company_sortname></company_sortname>
        <company_regcode></company_regcode>
        <company_regplace></company_regplace>
        <company_licensenumber></company_licensenumber>
        <company_responsibility></company_responsibility>
        <company_address></company_address>
        <company_zalo>https://zalo.me/2985205646891476753</company_zalo>
        <company_phone>0865436437</company_phone>
        <company_facebook>https://www.facebook.com/CongNhom</company_facebook>
        <company_maps>https://www.google.com/maps/place/C%C3%B4ng+ty+TNHH+ASUZAC+ACM/@10.9299135,106.722113,15z/data=!4m5!3m4!1s0x0:0xedc6fed0607d20c2!8m2!3d10.9299135!4d106.722113</company_maps>
    </config>
	<datafunction>nv_hotline_contact_config</datafunction>
    <submitfunction>nv_hotline_contact_submit</submitfunction>
</block>

Tiếp theo chúng ta tạo tiếp file global.hotline_contact.php

<?php

/**
 * @Project NUKEVIET 4.x
 * @Author VINADES.,JSC (contact@vinades.vn)
 * @Copyright (C) 2014 VINADES ., JSC. All rights reserved
 * @License GNU/GPL version 2 or any later version
 * @Createdate Jan 17, 2011 11:34:27 AM
 */

if (! defined('NV_MAINFILE')) {
    die('Stop!!!');
}

if (! nv_function_exists('nv_hotline_contact')) {

    function nv_hotline_contact_config($module, $data_block, $lang_block)
    {

        global $lang_global, $selectthemes;

        // Find language file
        if (file_exists(NV_ROOTDIR . '/themes/' . $selectthemes . '/language/' . NV_LANG_INTERFACE . '.php')) {
            include NV_ROOTDIR . '/themes/' . $selectthemes . '/language/' . NV_LANG_INTERFACE . '.php';
        }
        $html .= '<div class="row">';
        $html .= '<div class="form-group">';
        $html .= '<label class="control-label col-sm-6">' . $lang_global['company_phone'] . ':</label>';
        $html .= '<div class="col-sm-18">
                    <input type="text" class="form-control margin-bottom" name="config_company_phone" value="' . $data_block['company_phone'] . '">
                    <button class="btn btn-default btn-xs" onclick="modalShow('' . $lang_global['phone_note_title'] . '','' . $lang_global['phone_note_content'] . '');return!1;">' . $lang_global['phone_note_title'] . '</button>
                  </div>';
        $html .= '</div>';
		$html .= '<div class="form-group">';
        $html .= '<label class="control-label col-sm-6">Chát Zalo:</label>';
        $html .= '<div class="col-sm-18"><input type="text" class="form-control" name="config_company_zalo" value="' . $data_block['company_zalo'] . '"><span>' . $lang_global['multi_note'] . '</span></div>';
        $html .= '</div>';
		$html .= '<div class="form-group">';
        $html .= '<label class="control-label col-sm-6">Chát Facebooks:</label>';
        $html .= '<div class="col-sm-18"><input type="text" class="form-control" name="config_company_facebook" value="' . $data_block['company_facebook'] . '"><span>' . $lang_global['multi_note'] . '</span></div>';
        $html .= '</div>';
        $html .= '<div class="form-group">';
        $html .= '<label class="control-label col-sm-6">Tìm Cửa Hàng Trên GoogleMaps:</label>';
        $html .= '<div class="col-sm-18"><input type="text" class="form-control" name="config_company_maps" value="' . $data_block['company_maps'] . '"><span>' . $lang_global['multi_note'] . '</span></div>';
        $html .= '</div>';
        $html .= '<tr class="hide">';
        $html .= '<div class="col-sm-18" colspan="2"><script type="text/javascript">
        $(document).ready(function() {
            $("#config_company_mapshow").on("change", function() {
                if ($(this).val() == "1") {
                    $("#config_company_maparea").removeClass("hidden");
                } else {
                    $("#config_company_maparea").addClass("hidden");
                }
            });
        });
        </script></div>';
        $html .= '</div>';

        return $html;
    }

    function nv_hotline_contact_submit()
    {
        global $nv_Request;

        $return = array();
        $return['error'] = array();
        $return['config']['company_zalo'] = $nv_Request->get_title('config_company_zalo', 'post');
        $return['config']['company_phone'] = $nv_Request->get_title('config_company_phone', 'post');
        $return['config']['company_facebook'] = $nv_Request->get_title('config_company_facebook', 'post');
        $return['config']['company_maps'] = $nv_Request->get_title('config_company_maps', 'post');

        return $return;
    }

    /**
     * nv_menu_theme_default_footer()
     *
     * @param mixed $block_config
     * @return
     */
    function nv_hotline_contact($block_config)
    {
        global $global_config, $lang_global;

        if (file_exists(NV_ROOTDIR . '/themes/' . $global_config['module_theme'] . '/blocks/global.hotline_contact.tpl')) {
            $block_theme = $global_config['module_theme'];
        } elseif (file_exists(NV_ROOTDIR . '/themes/' . $global_config['site_theme'] . '/blocks/global.hotline_contact.tpl')) {
            $block_theme = $global_config['site_theme'];
        } else {
            $block_theme = 'default';
        }

        $xtpl = new XTemplate('global.hotline_contact.tpl', NV_ROOTDIR . '/themes/' . $block_theme . '/blocks');
        $xtpl->assign('LANG', $lang_global);
        $xtpl->assign('NV_BASE_SITEURL', NV_BASE_SITEURL);
        $xtpl->assign('DATA', $block_config);
        if (! empty($block_config['company_phone'])) {
            $nums = array_map('trim', explode('|', nv_unhtmlspecialchars($block_config['company_phone'])));
            foreach ($nums as $k => $num) {
                unset($m);
                if (preg_match("/^(.*)s*[([0-9+.,;*#]+)]$/", $num, $m)) {
                    $xtpl->assign('PHONE', array( 'number' => nv_htmlspecialchars($m[1]), 'href' => $m[2] ));
                    $xtpl->parse('main.company_phone.item.href');
                    $xtpl->parse('main.company_phone.item.href2');
                } else {
                    $num = preg_replace("/[[^]]*]/", "", $num);
                    $xtpl->assign('PHONE', array( 'number' => nv_htmlspecialchars($num) ));
                }
                if ($k) {
                    $xtpl->parse('main.company_phone.item.comma');
                }
                $xtpl->parse('main.company_phone.item');
            }

            $xtpl->parse('main.company_phone');
        }
        if (! empty($block_config['company_zalo'])) {
            $webs = array_map('trim', explode(',', $block_config['company_zalo']));
            foreach ($webs as $k => $web) {
                if (! preg_match("/^http:///", $web)) {
                    $web = 'http://' . $web;
                }
                $xtpl->assign('ZALO', $web);
                if ($k) {
                    $xtpl->parse('main.company_zalo.item.comma');
                }
                $xtpl->parse('main.company_zalo.item');
            }
            $xtpl->parse('main.company_zalo');
        }
		if (! empty($block_config['company_facebook'])) {
            $webs = array_map('trim', explode(',', $block_config['company_facebook']));
            foreach ($webs as $k => $web) {
                if (! preg_match("/^http:///", $web)) {
                    $web = 'http://' . $web;
                }
                $xtpl->assign('FACEBOOKS', $web);
                if ($k) {
                    $xtpl->parse('main.company_facebook.item.comma');
                }
                $xtpl->parse('main.company_facebook.item');
            }
            $xtpl->parse('main.company_facebook');
        }
		if (! empty($block_config['company_maps'])) {
            $webs = array_map('trim', explode(',', $block_config['company_maps']));
            foreach ($webs as $k => $web) {
                if (! preg_match("/^http:///", $web)) {
                    $web = 'http://' . $web;
                }
                $xtpl->assign('MAPS', $web);
                if ($k) {
                    $xtpl->parse('main.company_maps.item.comma');
                }
                $xtpl->parse('main.company_maps.item');
            }
            $xtpl->parse('main.company_maps');
        }
		$xtpl->assign('SITE_LOGO', NV_MY_DOMAIN . NV_BASE_SITEURL . $global_config['site_logo']);
        $xtpl->parse('main');
        return $xtpl->text('main');
    }
}

if (defined('NV_SYSTEM')) {
    $content = nv_hotline_contact($block_config);
}

Xem Thêm : Hướng dẫn viết block vẽ bản đồ thống kê dịch bệnh covid tại Việt Nam

Tiếp theo tạo file global.hotline_contact.tpl

<!-- BEGIN: main -->
<style>
/*@media (min-width: 992px){
.fab-wrapper{
display: none !important;
}
}*/
.fab-wrapper {
position: fixed;
bottom: 24px;
right: 0;
z-index: 9999999;
}
.fab-checkbox {
display: none !important;
}
.fab-checkbox:checked~ .devvn_bg {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: rgba(0, 0, 0, 0.8);
z-index: 1;
}
.fab {
width: 60px;
max-width: unset;
height: 60px;
display: flex !important;
justify-content: center;
align-items: center;
margin: 0;
border-radius: 50%;
background: #d70018;
box-shadow: 0 3px 6px rgb(0 0 0 / 16%), 0 3px 6px rgb(0 0 0 / 23%);
position: absolute;
right: 10px;
bottom: 10px;
z-index: 1000;
overflow: hidden;
transform: rotate(
0deg
);
-webkit-transition: all .15s cubic-bezier(.15,.87,.45,1.23);
transition: all .15s cubic-bezier(.15,.87,.45,1.23);
}
.fab-checkbox:checked~.fab {
-webkit-transition: all .15s cubic-bezier(.15,.87,.45,1.23);
transition: all .15s cubic-bezier(.15,.87,.45,1.23);
}
[class*=icon-cps-] {
display: inline-block;
vertical-align: middle;
background-image: url()!important;
background-repeat: no-repeat;
background-size: 453px;
}
.icon-cps-fab-menu {
width: 50px;
height: 50px;
margin: 0 !important;
background-size: 694px;
background-position: -649px 0;
}
.fab-checkbox:checked~.fab .icon-cps-fab-menu {
width: 30px;
height: 30px;
margin: 0;
background-size: 615px;
background-position: -291px -70px;
}
.fab-wheel {
width: 300px;
height: 220px;
position: absolute;
bottom: 15px;
right: 15px;
transform: scale(0);
transform-origin: bottom right;
transition: all .3s ease;
z-index: 12;
}
.fab-checkbox:checked~.fab-wheel {
transform: scale(1);
}
.fab-wheel .fab-action {
display: flex;
align-items: center;
font-size: 14px;
font-weight: 700;
color: #fff;
position: absolute;
text-decoration: none;
}
.fab-wheel .fab-action-1 {
top: 0;
right: 0;
}
.fab-title {
float: left;
margin: 0 5px 0 0;
opacity: 0;
}
.fab-checkbox:checked~.fab-wheel .fab-title {
opacity: 1;
}
.fab-button {
width: 45px;
height: 45px;
display: flex;
justify-content: center;
align-items: center;
float: left;
padding: 4px;
border-radius: 50%;
background: #0f1941;
box-shadow: 0 1px 3px rgb(0 0 0 / 12%), 0 1px 2px rgb(0 0 0 / 24%);
font-size: 24px;
color: White;
transition: all 1s ease;
overflow: hidden;
}
.icon-cps-local {
width: 28px;
height: 28px;
background-position: 0px -49px;
}
.fab-wheel .fab-button-1 {
background: #dd5145;
}
.fab-wheel .fab-action-2 {
top: 40px;
left: 85px;
}
.fab-wheel .fab-button-2 {
background: #fb0;
}
.icon-cps-phone {
width: 28px;
height: 28px;
background-position: -51px -49px;
}
.fab-wheel .fab-action-3 {
left: 50px;
bottom: 70px;
}
.fab-wheel .fab-button-3 {
background: #0f9d58;
}
.icon-cps-chat {
width: 30px;
height: 30px;
background-position: -369px 0px;
}
.fab-wheel .fab-action-4 {
left: 0;
bottom: 0;
}
.fab-wheel .fab-button-4 {
background: #2f82fc;
}
.icon-cps-chat-zalo {
width: 30px;
height: 30px;
background-position: -362px -1px;
background-size: 515px;
}
.suggestions-chat-box {
min-width: 140px;
min-height: 50px;
display: flex;
justify-content: center;
align-items: center;
border: 1px solid #1d72e0;
border-radius: 10px;
background: #277cea;
box-shadow: 0 0.5rem 1rem rgb(0 0 0 / 15%);
font-size: 14px;
font-weight: 700;
color: #fff;
position: fixed;
right: 80px;
bottom: 7%;
z-index: 11;
}
.hidden {
display: none!important;
}
.align-items-center {
-ms-flex-align: center!important;
align-items: center!important;
-ms-flex-pack: distribute!important;
justify-content: space-around!important;
display: -ms-flexbox!important;
display: flex!important;
-webkit-box-align: center!important;
-ms-flex-align: center!important;
align-items: center!important;
}
.suggestions-chat-box #btnClose {
position: absolute;
top: 2px;
left: 2px;
}
i.icon-cps-face {
width: 28px;
height: 28px;
background-position: -177px 0px;
}
.fab-checkbox:not(:checked)~.fab {
animation-name: zoom;
-webkit-animation-name: zoom;
animation-delay: 0s;
-webkit-animation-delay: 0s;
animation-duration: 1.5s;
-webkit-animation-duration: 1.5s;
animation-iteration-count: infinite;
-webkit-animation-iteration-count: infinite;
cursor: pointer;
box-shadow: 0 0 0 0 #c31d1d;
}
@-webkit-keyframes tada {
0% {
-webkit-transform: scale(1);
transform: scale(1)
}
10%,20% {
-webkit-transform: scale(.9) rotate(-3deg);
transform: scale(.9) rotate(-3deg)
}
30%,50%,70%,90% {
-webkit-transform: scale(1.1) rotate(3deg);
transform: scale(1.1) rotate(3deg)
}
40%,60%,80% {
-webkit-transform: scale(1.1) rotate(-3deg);
transform: scale(1.1) rotate(-3deg)
}
100% {
-webkit-transform: scale(1) rotate(0);
transform: scale(1) rotate(0)
}
}
@keyframes tada {
0% {
-webkit-transform: scale(1);
-ms-transform: scale(1);
transform: scale(1)
}
10%,20% {
-webkit-transform: scale(.9) rotate(-3deg);
-ms-transform: scale(.9) rotate(-3deg);
transform: scale(.9) rotate(-3deg)
}
30%,50%,70%,90% {
-webkit-transform: scale(1.1) rotate(3deg);
-ms-transform: scale(1.1) rotate(3deg);
transform: scale(1.1) rotate(3deg)
}
40%,60%,80% {
-webkit-transform: scale(1.1) rotate(-3deg);
-ms-transform: scale(1.1) rotate(-3deg);
transform: scale(1.1) rotate(-3deg)
}
100% {
-webkit-transform: scale(1) rotate(0);
-ms-transform: scale(1) rotate(0);
transform: scale(1) rotate(0)
}
}
@-webkit-keyframes zoom {
0% {
transform: scale(.9)
}
70% {
transform: scale(1);
box-shadow: 0 0 0 15px transparent
}
100% {
transform: scale(.9);
box-shadow: 0 0 0 0 transparent
}
}
@keyframes zoom {
0% {
transform: scale(.9)
}
70% {
transform: scale(1);
box-shadow: 0 0 0 15px transparent
}
100% {
transform: scale(.9);
box-shadow: 0 0 0 0 transparent
}
}
.nki-chat-main-chatbox:before {
}
</style>
<div class="fab-wrapper">
<input id="fabCheckbox" type="checkbox" class="fab-checkbox">
<label class="fab" for="fabCheckbox">
<image src="https://www.asuzac-acm.com.vn/themes/acm-2020/images/icons/icon-contact.png" style="width: 55%;">
</label>
<div class="fab-wheel">
<!-- BEGIN: company_maps -->
<a class="fab-action fab-action-1" href="{MAPS}" rel="nofollow" target="_blank">
<span class="fab-title">Tìm cửa hàng</span>
<div class="fab-button fab-button-1"><i class="icon-cps-local"></i></div>
</a>
<!-- END: company_maps -->  
<!-- BEGIN: company_phone -->
<!-- BEGIN: item -->
<!-- BEGIN: href --><!-- END: href -->
<a class="fab-action fab-action-2" href="tel:{PHONE.number}" rel="nofollow">
<span class="fab-title">Gọi trực tiếp</span>
<div class="fab-button fab-button-2"><i class="icon-cps-phone"></i></div>
</a>
<!-- END: item -->
<!-- END: company_phone -->
<!-- BEGIN: company_facebook -->
<a class="fab-action fab-action-3" href="{FACEBOOKS}" target="_blank" rel="nofollow">
<span class="fab-title">Chat ngay</span>
<div class="fab-button fab-button-3"><i class="icon-cps-chat"></i></div>
</a>
<!-- END: company_facebook -->
<!-- BEGIN: company_zalo --> 
<a class="fab-action fab-action-4" href="{ZALO}" target="_blank" rel="nofollow">
<span class="fab-title">Chat trên Zalo</span>
<div class="fab-button fab-button-4"><i class="icon-cps-chat-zalo"></i></div>
</a>
<!-- END: company_zalo -->
</div>
<div class="suggestions-chat-box hidden" style="display: none;">
<div class="box-content d-flex justify-content-around align-items-center">
<i class="fa fa-times-circle" aria-hidden="true" id="btnClose" onclick="jQuery('.suggestions-chat-box').hide()"></i>
<p class="mb-0 font-14">Liên hệ ngay <i class="fa fa-hand-o-right" aria-hidden="true"></i></p>
</div>
</div>
<div class="devvn_bg" onclick="devvn()"></div>
</div>
<script>
function devvn(){
document.getElementById("fabCheckbox").checked = false;
}
</script>
<!-- END: main -->

Dưới đây là toàn bộ sourcode của Block Hotline contact . Nếu thấy bài viết hay và bổ ích, hãy like và share để ủng hộ VNCODE  phát triển mạnh mẽ hơn nhé

Nguồn: https://vncode.info
Danh mục: Block nukeviet

Related Posts

Hướng dẫn viết block vẽ bản đồ thống kê dịch bệnh covid tại Việt Nam

VNCode xin giới thiệu đến các bạn block thu thập thông tin tình hình dịch bệnh covid được cập nhật hàng ngày tại ncov, thanh niên,… Với…

Hướng dẫn thêm thống kê truy cập tháng trước vào block statics nukeviet

Hướng dẫn viết block hiển thị thống kê truy cập theo tháng Thêm phần code PHP dưới đây vào block global.counter.php  phía dưới  $xtpl->assign(‘IMG_PATH’, NV_STATIC_URL . ‘themes/’ . $block_theme…

Hướng dẫn thêm đọc bằng audio vào module news nukeviet

Hướng dẫn tạo nút audio tại nukeviet Thêm đoạn code phía dưới vào detail.tpl tìm file (DETAIL.publtime)Có thể bạn quan tâm Block hiệu ứng tuyết rơi nukeviet…

Block hiệu ứng tuyết rơi nukeviet 4.x

Hướng dẫn làm block nukeviet trang trí Giáng Sinh cho website của bạn như tạo tuyết rơi, khung cảnh chuông giáng sinh, cây thông….Có thể bạn quan…

Block nukeviet hiệu ứng cánh hoa mai rơi

VNCODE xin chia sẽ đến các bạn block tết với hiệu ứng cánh hoa mai và hoa anh đào rơi. Sourcode bao gồm hình ảnh câu đối,…

Chia sẻ block groups multi tabs module shops nukeviet miễn phí

Ứng dụng của blocks Multi Tabs trong module Shops Với ứng dụng Product Tabs, người bán có thể: thêm tab và điều chỉnh nội dung dễ dàng…