Site icon Hip-Hop Website Design and Development

Disable link after click by user meta data using js and php

I am working on a member site with a link, that after clicked, js will disable it. I would like the link to remain disabled permanently for the user after one click. I created php code that checks new user meta data to see if the user has clicked the link before and disable it if they have.

The first part of my code assumes that the user has already clicked. In that case the db is checked to see if "user_click" is not false and echos some js which adds the class that handles deactivating the button.

In the second part of my code it adds new user meta "user_click" (after and assuming the user has clicked the link). It checks if the class name "disabled" is present and if user meta "user_click" has not been created. If true then variable ‘$user_clicked’ is ran to add the meta data.

I realize that my issue here is that php runs at the beginning of the page load so the second part of my code never does anything. Which also means the first part does nothing too. I tried to use ‘Session_start()’ as a work around but it crashed the site.

I’m sure there is better way to do this, I’m just extremely stuck. Including my js code and php code. Your help is appreciated.

JS:

$("#no-link").click(function (event) {
if ($(this).hasClass("disabled")) {
    event.preventDefault();
}
$(this).addClass("disabled");
});

PHP:

function verifymetaStatus(){
$user_id = $current_user->ID; // logged in user's ID
$has_meta = get_user_meta( $user_id, 'user_click', true );

if (!$has_meta == 'false'){
    echo "<script>document.getElementById( '#no-link ').className = 'disabled'; </script>";
  }
}

function firstClick(){
$user_id = $current_user->ID; // logged in user's ID
$has_meta = get_user_meta( $user_id, 'user_click', true );
$user_clicked = add_user_meta ( $user_id, 'user_click', true );
$contains = str($html, 'class="disabled"') !== false;

if ( $contains && $has_meta == 'false'){
    $user_clicked;
}
}