lostyazilim
tr.link

Php'den anlayan bir bakabilirmi?

5 Mesajlar 799 Okunma
acebozum
tr.link

TuayPortal TuayPortal Sms Onayı Gerekli Telefon Onaysız
  • Üyelik 31.12.2016
  • Yaş/Cinsiyet 36 / K
  • Meslek Belli Olacak
  • Konum Aydın
  • Ad Soyad A** T**
  • Mesajlar 218
  • Beğeniler 27 / 33
  • Ticaret 1, (%100)
Wordpress siteme yorum için şikayet eklentisi yükledim alt yanıtla butonunun karşısına denk geliyor ama satır problemi var resimdeki gibi,



Eklentinin ilgili marctv-moderate.php kodları


/*
Plugin Name: Frontend Comment Moderation
Plugin URI: http://marc.tv/blog/marctv-wordpress-plugins/
Description: Grants visitors the ability to report inappropriate comments and admins to replace and trash them in the frontend.
Version: 1.3
Author: Marc Tönsing
Author URI: marc.tv
License URI: http://www.gnu.org/licenses/gpl-2.0.html
*/

class MarcTVModerateComments
{

private $version = '1.3';
private $pluginPrefix = 'marctv-moderate';
private $pluginUrl;
private $strings;

public function __construct()
{
$this->pluginUrl = plugins_url(false, __FILE__);

load_plugin_textdomain('marctv-moderate', false, dirname(plugin_basename(__FILE__)) . '/language/');

$this->strings = $this->getStrings();

if (is_admin()) {
$this->backendInit();
}

$this->frontendInit();

}

/**
* Defines what happens on plugin activation.
*/
public function activate()
{

/* if comment moderation text is not set get the localized string. */
if (!get_option('marctv-moderation-text')) {
/* Loading the textdomain. I could not figure out to prevent this here. */
load_plugin_textdomain('marctv-moderate', false, dirname(plugin_basename(__FILE__)) . '/languages/');

/* If the moderation text is empty fill it with the default text */
update_option('marctv-moderation-text', __('[incorrect topic]', 'marctv-moderate'));
}
}

/**
* Registers the reported comments page as a sub page to comments in admin.
*/
public function registerCommentsPage()
{
if (!($count = get_transient($this->pluginPrefix . '_count'))) {
$count = $this->getCount();
set_transient($this->pluginPrefix . '_count', $count, 30 * MINUTE_IN_SECONDS);
}
$bubble = '' . number_format_i18n($count) . '';
$text = $this->strings['menu_title'] . $bubble;

add_comments_page($this->strings['page_title'], $text, 'moderate_comments', $this->pluginPrefix . '_reported', array($this, 'commentsPage'));
}

/**
* Actions and filters for frontend.
*/
public function frontendInit()
{
add_filter('comment_text', array($this, 'printModerateLinks'),100,3);

add_action('wp_ajax_' . $this->pluginPrefix . '_trash', array($this, 'trashComment'));
add_action('wp_ajax_' . $this->pluginPrefix . '_replace', array($this, 'replaceComment'));
add_action('wp_ajax_' . $this->pluginPrefix . '_flag', array($this, 'flagComment'));
add_action('wp_ajax_nopriv_' . $this->pluginPrefix . '_flag', array($this, 'flagComment'));
add_action('wp_print_styles', array($this, 'enqueScripts'));

}


public function enqueScripts()
{

/* Load css and js for vistors */
wp_enqueue_script($this->pluginPrefix . '_script', $this->pluginUrl . '/marctv-moderate.js', array('jquery'), $this->version, true);

wp_enqueue_style($this->pluginPrefix . '_style', $this->pluginUrl . "/marctv-moderate.css", false, $this->version);

/* Load js for moderators and admins */
if (current_user_can('moderate_comments') && is_single()) {
wp_enqueue_script($this->pluginPrefix . '_admin_script', $this->pluginUrl . '/marctv-moderate-admin.js', array('jquery'), $this->version, true);
}

$translations = array(
'pluginprefix' => $this->pluginPrefix,
'ajaxurl' => admin_url('admin-ajax.php'),
'confirm_report' => $this->strings['confirm_report'],
'confirm_replace' => $this->strings['confirm_replace'],
'adminurl' => admin_url('admin-ajax.php'),
'trash_string' => $this->strings['trash'],
'untrash_string' => $this->strings['untrash'],
'trashing_string' => $this->strings['trashing'],
'untrashing_string' => $this->strings['untrashing'],
'error_string' => $this->strings['error'],
'replacing_string' => $this->strings['replacing'],
'reporting_string' => $this->strings['reporting'],
'replaced_string' => $this->strings['replace_success']
);


wp_localize_script($this->pluginPrefix . '_script', 'marctvmoderatejs', $translations);


}

/**
* Actions for backend.
*/
public function backendInit()
{
add_action('admin_menu', array($this, 'registerCommentsPage'));
add_action('admin_menu', array($this, 'registerSettingsPage'));
add_action('admin_action_' . $this->pluginPrefix . '_ignore', array($this, 'ignoreReport'));
add_action('admin_action_' . $this->pluginPrefix . '_replace', array($this, 'replaceCommentReport'));
add_action('admin_init', array($this, 'registerSettings'));
}


/**
* Add a menu item to the admin bar.
*/
public function registerSettingsPage()
{
add_options_page('MarcTV Moderate Comments', 'Moderate Comments', 'manage_options', $this->pluginPrefix, array($this, 'showSettingsPage'));
}

/**
* Includes the settings page.
*/
public function showSettingsPage()
{
include('pages/settings.php');
}

/**
* Sets all strings used by the plugin. Use the 'report_comments_strings' filter to modify them yourself.
* @return string
*/
public function getStrings()
{
$strings = array(
// Title for link in the menu.
'menu_title' => __('Reported', 'marctv-moderate'),
// Title for the reported comments page.
'page_title' => __('Reported comments', 'marctv-moderate'),
// Confirm dialog on front end for replace.
'confirm_replace' => __('Are you sure you want to replace this comment? This action can not be undone!', 'marctv-moderate'),
// Confirm dialog on front end for reporting.
'confirm_report' => __('Are you sure you want to report this comment?', 'marctv-moderate'),
// Message to show user after successfully reporting a comment.
'report_success' => __('The comment has been reported', 'marctv-moderate'),
// Message to show user after reporting a comment has failed.
'report_failed' => __('The comment has been reported', 'marctv-moderate'),
// Message to show user after successfully replacing a comment.
'replace_success' => __('The comment text has been replaced', 'marctv-moderate'),
// Message to show user after replacing a comment has failed.
'replace_failed' => __('The comment has already been replaced', 'marctv-moderate'),
// Text for the report link shown below each comment.
'report' => __('Report', 'marctv-moderate'),
// Text for the trash link shown below each comment.
'trash' => __('Trash', 'marctv-moderate'),
// Text for the replace link shown below each comment.
'untrash' => __('Untrash', 'marctv-moderate'),
// Text for the replace link shown below each comment.
'replace' => __('Replace', 'marctv-moderate'),
// Text in admin for link that deems the comment OK.
'ignore_report' => __('Comment is ok', 'marctv-moderate'),
// Action of moving a comment in the trash.
'trashing' => __('trashing', 'marctv-moderate'),
// Action of moving a comment out of the trash.
'untrashing' => __('untrashing', 'marctv-moderate'),
// Error message
'error' => __('an error occurred.', 'marctv-moderate'),
// Action while replacing a comment.
'replacing' => __('replacing', 'marctv-moderate'),
// Action while reporting a comment.
'reporting' => __('reporting', 'marctv-moderate'),
// Error message shown when a comment can't be found.
'invalid_comment' => __('The comment does not exist', 'marctv-moderate'),
// Header for settings field.
'settings_header' => __('Report Comments Settings', 'marctv-moderate'),
// Description for members only setting.
'settings_members_only' => __('Only logged in users may report comments', 'marctv-moderate')
);

return apply_filters('report_comments_strings', $strings);
}

/**
* Fetches comments flagged as reported and displays them in a table.
*/
public function commentsPage()
{
if (!current_user_can('moderate_comments')) {
die(__('Cheatin’ uh?'));
}

global $wpdb;

$comments = $wpdb->get_results(
$wpdb->prepare("
SELECT * FROM $wpdb->commentmeta
INNER JOIN $wpdb->comments on $wpdb->comments.comment_id = $wpdb->commentmeta.comment_id
WHERE $wpdb->comments.comment_approved = 1 AND meta_key = %s AND meta_value = 1 LIMIT 0, 25",
$this->pluginPrefix . '_reported')
);
$count = count($comments);
set_transient($this->pluginPrefix . '_count', $count, 1 * HOUR_IN_SECONDS);
include('pages/comments-list.php');
}

/**
* Returns how many reported comments are in the system.
* @return int
*/
private function getCount()
{
global $wpdb;

$comments = $wpdb->get_results(
$wpdb->prepare("
SELECT * FROM $wpdb->commentmeta
INNER JOIN $wpdb->comments on $wpdb->comments.comment_id = $wpdb->commentmeta.comment_id
WHERE $wpdb->comments.comment_approved = 1 AND meta_key = %s AND meta_value = 1 LIMIT 0, 10",
$this->pluginPrefix . '_reported')
);
return count($comments);
}

/**
* Flags a comment as reported. Won't flag a comment that has been flagged before and approved.
* @param int $id Comment id.
* @return bool
*/
private function flag($id)
{
$value = get_comment_meta($id, $this->pluginPrefix . '_reported', true);

if ($value < 0) {
return false;
}

$this->sendMail($id);

return add_comment_meta($id, $this->pluginPrefix . '_reported', true, true);
}

/**
* Send a notification mail
* @param int $comment_id
*/

private function sendMail($comment_id){

$email = get_option('marctv-notification-mail');

if (is_email($email)) {

$blogname = wp_specialchars_decode(get_option('blogname'), ENT_QUOTES);

$comment_url = get_comment_link($comment_id);

$admin_url = admin_url('edit-comments.php?page=marctv-moderate_reported');

$subject = '['.$blogname . '] '. __('New flagged comment', $this->pluginPrefix);

$body = __('Dear admin,', $this->pluginPrefix) . "\r\n\r\n";
$body .= __('this comment has been flagged by a user:', $this->pluginPrefix) . ' ' . $comment_url . "\r\n\r\n";
$body .= __('For more options please visit the comment moderation page:', $this->pluginPrefix) . ' ' . $admin_url . "\r\n\r\n";
$body .= __('kindest regards', $this->pluginPrefix) . "\r\n\r\n";
$body .= '- ' . __('Your', $this->pluginPrefix) . ' Frontend Comment Moderation Plugin';

wp_mail( $email, $subject, $body );
}
}

/**
* Ajax-callable function which flags a comment as reported.
* Dies with message to be displayed to user.
*/
public function flagComment()
{
$id = (int)$_POST['id'];
if (!wp_verify_nonce($_POST['_ajax_nonce'], "report-comment-" . $id) || $id != $_POST['id'] || !check_ajax_referer("report-comment-" . $id)) {
die(__('Cheatin’ uh?'));
}

if (get_option($this->pluginPrefix . '_members_only') && !is_user_logged_in()) {
die(__('Cheatin’ uh?'));
}

if (!$this->flag($id)) {
// This may happen when the comment has been reported once, but deemed ok by an admin, or
// when something went wrong. Either way, we won't bother the visitor with that information
// and we'll show the same message for both sucess and failed here by default.
die($this->strings['report_failed']);
}
die($this->strings['report_success']);
}

/**
* Ajax-callable function which replaces a comment with a defined text.
*/
public function replaceComment()
{
$id = (int)$_POST['id'];
if (!wp_verify_nonce($_POST['_ajax_nonce'], "replace-comment-" . $id) || $id != $_POST['id'] || !check_ajax_referer("replace-comment-" . $id)) {
die(__('Cheatin’ uh?'));
}

if (get_option($this->pluginPrefix . '_members_only') && !is_user_logged_in()) {
die(__('Cheatin’ uh?'));
}

/* Replace comment with moderation text */
$comment_arr = array();
$comment_arr['comment_ID'] = $id;
$comment_arr['comment_content'] = get_option('marctv-moderation-text');

if (!wp_update_comment($comment_arr)) {
die($this->strings['replace_failed']);
}

die($this->strings['replace_success']);
}

/**
* Ajax-callable function which puts a comment in the trash.
*/
public function trashComment()
{
$id = (int)$_POST['id'];

$comment_status = wp_get_comment_status($id);

if (!wp_verify_nonce($_POST['_ajax_nonce'], "trash-comment-" . $id) || $id != $_POST['id'] || !check_ajax_referer("trash-comment-" . $id)) {
die(__('Cheatin’ uh?'));
}

if (get_option($this->pluginPrefix . '_members_only') && !is_user_logged_in()) {
die(__('Cheatin’ uh?'));
}


switch ($comment_status) {
case 'approved':
if (wp_trash_comment($id)) {
die('trashed');
}
break;
case 'trash':
if (wp_untrash_comment($id)) {
die('untrashed');
}
break;
default:
die('error');
}
}

/**
* Constructs "report this comment" link.
* @return string
*/
private function getReportLink()
{
$id = get_comment_ID();
$class = $this->pluginPrefix . "-report";
$nonce = wp_create_nonce("report-comment-" . $id);

$link = sprintf('%s',
$nonce,
$id,
$class,
$this->strings['report']
);
return $link;
}

/**
* Constructs "trash this comment" link.
* @return string
*/
private function getTrashLink()
{
$id = get_comment_ID();
$class = $this->pluginPrefix . "-trash";
$nonce = wp_create_nonce("trash-comment-" . $id);
$link = sprintf('%s',
$nonce,
$id,
$class,
$this->strings['trash']
);
return $link;
}

/**
* Constructs "replace this comment" link.
* @return string
*/
private function getReplaceLink()
{
$id = get_comment_ID();
$class = $this->pluginPrefix . "-replace";
$nonce = wp_create_nonce("replace-comment-" . $id);
$link = sprintf('%s',
$nonce,
$id,
$class,
$this->strings['replace']
);
return $link;
}


/**
* Appends a "report this comment" link after the "reply" link below a comment.
*/
public function printModerateLinks($comment_reply_link)
{
if (is_single()) {
if (current_user_can('moderate_comments')) {
return $comment_reply_link . '';
} else {
if (get_option($this->pluginPrefix . '_members_only')) {
if (is_user_logged_in()) {
return $comment_reply_link . '';
}
} else {
return $comment_reply_link . '';
}
}
}
return $comment_reply_link;
}

/**
* Unflags the comment as reported.
*/
public function ignoreReport()
{
if (isset($_GET['c']) && isset($_GET['_wpnonce'])) {
if (!wp_verify_nonce($_GET['_wpnonce'], 'ignore-report_' . $_GET['c']) || !current_user_can('moderate_comments')) {
die(__('Cheatin’ uh?'));
}
$id = absint($_GET['c']);
if (!get_comment($id)) {
die($this->strings['invalid_comment']);
}
// We set the meta value to -1, and by that it wont be able to be reported again.
// Once deemed ok -> always ok.
# todo: add this as an option (being able to report the comment again or not)
update_comment_meta($id, $this->pluginPrefix . '_reported', -1);

wp_redirect($_SERVER['HTTP_REFERER']);
}
}

/**
* replaces the comment in the reported comments list.
*/
public function replaceCommentReport()
{
if (isset($_GET['c']) && isset($_GET['_wpnonce'])) {
if (!wp_verify_nonce($_GET['_wpnonce'], 'replace-comment-' . $_GET['c']) || !current_user_can('moderate_comments')) {
die(__('Cheatin’ uh?'));
}
$id = absint($_GET['c']);
if (!get_comment($id)) {
die($this->strings['invalid_comment']);
}

/* Replace comment with moderation text */
$comment_arr = array();
$comment_arr['comment_ID'] = $id;
$comment_arr['comment_content'] = get_option('marctv-moderation-text');

if (!wp_update_comment($comment_arr)) {
die($this->strings['replace_failed']);
}

// We set the meta value to -1, and by that it wont be able to be reported again.
// Once deemed ok -> always ok.
# todo: add this as an option (being able to report the comment again or not)
update_comment_meta($id, $this->pluginPrefix . '_reported', -1);

wp_redirect($_SERVER['HTTP_REFERER']);
}
}


/**
* Registers settings for plugin.
*/
public function registerSettings()
{
add_settings_section($this->pluginPrefix . '_settings',
$this->strings['settings_header'],
null,
'discussion'
);

add_settings_field($this->pluginPrefix . '_members_only',
$this->strings['settings_members_only'],
array($this, 'settingsCallback'),
'discussion',
$this->pluginPrefix . '_settings'
);

register_setting($this->pluginPrefix . '-settings-group', 'marctv-notification-mail');
register_setting($this->pluginPrefix . '-settings-group', 'marctv-moderation-text');
register_setting($this->pluginPrefix . '-settings-group', $this->pluginPrefix . '_members_only');
register_setting('discussion', $this->pluginPrefix . '_members_only');
}

/**
* Displays settings field
*/
public function settingsCallback()
{
?>
type="checkbox" pluginPrefix . '_members_only'), 'on') ?> />
}
}


/* Activation */
register_activation_hook(
__FILE__,
array(
'MarcTVModerateComments',
'activate'
)
);

/**
* Initialize plugin.
*/
new MarcTVModerateComments();



Buda class-walker-comment.php kodlarım,


/**
* Comment API: Walker_Comment class
*
* @package WordPress
* @subpackage Comments
* @since 4.4.0
*/

/**
* Core walker class used to create an HTML list of comments.
*
* @since 2.7.0
*
* @see Walker
*/
class Walker_Comment extends Walker {

/**
* What the class handles.
*
* @since 2.7.0
* @access public
* @var string
*
* @see Walker::$tree_type
*/
public $tree_type = 'comment';

/**
* Database fields to use.
*
* @since 2.7.0
* @access public
* @var array
*
* @see Walker::$db_fields
* @todo Decouple this
*/
public $db_fields = array ('parent' => 'comment_parent', 'id' => 'comment_ID');

/**
* Starts the list before the elements are added.
*
* @since 2.7.0
* @access public
*
* @see Walker::start_lvl()
* @global int $comment_depth
*
* @param string $output Passed by reference. Used to append additional content.
* @param int $depth Optional. Depth of the current comment. Default 0.
* @param array $args Optional. Uses 'style' argument for type of HTML list. Default empty array.
*/
public function start_lvl( &$output, $depth = 0, $args = array() ) {
$GLOBALS['comment_depth'] = $depth + 1;

switch ( $args['style'] ) {
case 'div':
break;
case 'ol':
$output .= '
    ' . "\n";
    break;
    case 'ul':
    default:
    $output .= '
      ' . "\n";
      break;
      }
      }

      /**
      * Ends the list of items after the elements are added.
      *
      * @since 2.7.0
      * @access public
      *
      * @see Walker::end_lvl()
      * @global int $comment_depth
      *
      * @param string $output Passed by reference. Used to append additional content.
      * @param int $depth Optional. Depth of the current comment. Default 0.
      * @param array $args Optional. Will only append content if style argument value is 'ol' or 'ul'.
      * Default empty array.
      */
      public function end_lvl( &$output, $depth = 0, $args = array() ) {
      $GLOBALS['comment_depth'] = $depth + 1;

      switch ( $args['style'] ) {
      case 'div':
      break;
      case 'ol':
      $output .= "
\n";
break;
case 'ul':
default:
$output .= "\n";
break;
}
}

/**
* Traverses elements to create list from elements.
*
* This function is designed to enhance Walker::display_element() to
* display children of higher nesting levels than selected inline on
* the highest depth level displayed. This prevents them being orphaned
* at the end of the comment list.
*
* Example: max_depth = 2, with 5 levels of nested content.
* 1
* 1.1
* 1.1.1
* 1.1.1.1
* 1.1.1.1.1
* 1.1.2
* 1.1.2.1
* 2
* 2.2
*
* @since 2.7.0
* @access public
*
* @see Walker::display_element()
* @see wp_list_comments()
*
* @param WP_Comment $element Comment data object.
* @param array $children_elements List of elements to continue traversing. Passed by reference.
* @param int $max_depth Max depth to traverse.
* @param int $depth Depth of the current element.
* @param array $args An array of arguments.
* @param string $output Used to append additional content. Passed by reference.
*/
public function display_element( $element, &$children_elements, $max_depth, $depth, $args, &$output ) {
if ( !$element )
return;

$id_field = $this->db_fields['id'];
$id = $element->$id_field;

parent::display_element( $element, $children_elements, $max_depth, $depth, $args, $output );

/*
* If at the max depth, and the current element still has children, loop over those
* and display them at this level. This is to prevent them being orphaned to the end
* of the list.
*/
if ( $max_depth <= $depth + 1 && isset( $children_elements[$id]) ) {
foreach ( $children_elements[ $id ] as $child )
$this->display_element( $child, $children_elements, $max_depth, $depth, $args, $output );

unset( $children_elements[ $id ] );
}

}

/**
* Starts the element output.
*
* @since 2.7.0
* @access public
*
* @see Walker::start_el()
* @see wp_list_comments()
* @global int $comment_depth
* @global WP_Comment $comment
*
* @param string $output Used to append additional content. Passed by reference.
* @param WP_Comment $comment Comment data object.
* @param int $depth Optional. Depth of the current comment in reference to parents. Default 0.
* @param array $args Optional. An array of arguments. Default empty array.
* @param int $id Optional. ID of the current comment. Default 0 (unused).
*/
public function start_el( &$output, $comment, $depth = 0, $args = array(), $id = 0 ) {
$depth++;
$GLOBALS['comment_depth'] = $depth;
$GLOBALS['comment'] = $comment;

if ( !empty( $args['callback'] ) ) {
ob_start();
call_user_func( $args['callback'], $comment, $args, $depth );
$output .= ob_get_clean();
return;
}

if ( ( 'pingback' == $comment->comment_type || 'trackback' == $comment->comment_type ) && $args['short_ping'] ) {
ob_start();
$this->ping( $comment, $depth, $args );
$output .= ob_get_clean();
} elseif ( 'html5' === $args['format'] ) {
ob_start();
$this->html5_comment( $comment, $depth, $args );
$output .= ob_get_clean();
} else {
ob_start();
$this->comment( $comment, $depth, $args );
$output .= ob_get_clean();
}
}

/**
* Ends the element output, if needed.
*
* @since 2.7.0
* @access public
*
* @see Walker::end_el()
* @see wp_list_comments()
*
* @param string $output Used to append additional content. Passed by reference.
* @param WP_Comment $comment The current comment object. Default current comment.
* @param int $depth Optional. Depth of the current comment. Default 0.
* @param array $args Optional. An array of arguments. Default empty array.
*/
public function end_el( &$output, $comment, $depth = 0, $args = array() ) {
if ( !empty( $args['end-callback'] ) ) {
ob_start();
call_user_func( $args['end-callback'], $comment, $args, $depth );
$output .= ob_get_clean();
return;
}
if ( 'div' == $args['style'] )
$output .= "
\n";
else
$output .= "\n";
}

/**
* Outputs a pingback comment.
*
* @since 3.6.0
* @access protected
*
* @see wp_list_comments()
*
* @param WP_Comment $comment The comment object.
* @param int $depth Depth of the current comment.
* @param array $args An array of arguments.
*/
protected function ping( $comment, $depth, $args ) {
$tag = ( 'div' == $args['style'] ) ? 'div' : 'li';
?>
< id="comment-" >

', '' ); ?>

}

/**
* Outputs a single comment.
*
* @since 3.6.0
* @access protected
*
* @see wp_list_comments()
*
* @param WP_Comment $comment Comment to display.
* @param int $depth Depth of the current comment.
* @param array $args An array of arguments.
*/
protected function comment( $comment, $depth, $args ) {
if ( 'div' == $args['style'] ) {
$tag = 'div';
$add_below = 'comment';
} else {
$tag = 'li';
$add_below = 'div-comment';
}
?>
< has_children ? 'parent' : '', $comment ); ?> id="comment-">





/* translators: %s: comment author link */
printf( __( '%s says:' ),
sprintf( '%s', get_comment_author_link( $comment ) )
);
?>

comment_approved ) : ?>







$add_below, 'depth' => $depth, 'max_depth' => $args['max_depth'] ) ) ); ?>

comment_reply_link( array_merge( $args, array(
'add_below' => $add_below,
'depth' => $depth,
'max_depth' => $args['max_depth'],
'before' => '
',
'after' => '
'
) ) );
?>




}

/**
* Outputs a comment in the HTML5 format.
*
* @since 3.6.0
* @access protected
*
* @see wp_list_comments()
*
* @param WP_Comment $comment Comment to display.
* @param int $depth Depth of the current comment.
* @param array $args An array of arguments.
*/
protected function html5_comment( $comment, $depth, $args ) {
$tag = ( 'div' === $args['style'] ) ? 'div' : 'li';
?>
< id="comment-" has_children ? 'parent' : '', $comment ); ?>>

}
}



Anlayan arkadaşlar bir zahmet bakabilirmi yanıtla butonu ile aynı satırda nasıl bulundurabilirim.
 

 

googleasistan
webimgo

omurolgunay omurolgunay WM Aracı Kullanıcı
  • Üyelik 08.12.2016
  • Yaş/Cinsiyet 31 / E
  • Meslek WordPress Developer
  • Konum İstanbul Avrupa
  • Ad Soyad Ö** O**
  • Mesajlar 236
  • Beğeniler 13 / 66
  • Ticaret 1, (%100)
Eklentiyi aktif edin büyük ihtimalle css le halledilir. Aktif edin kontrol edelim
 

 

www.omurolgunay.com
www.klbtasarim.com
www.hareketlikablotasiyici.com

TuayPortal TuayPortal Sms Onayı Gerekli Telefon Onaysız
  • Üyelik 31.12.2016
  • Yaş/Cinsiyet 36 / K
  • Meslek Belli Olacak
  • Konum Aydın
  • Ad Soyad A** T**
  • Mesajlar 218
  • Beğeniler 27 / 33
  • Ticaret 1, (%100)
eklenti aktif halde üstadım https://tuayportal.com/ddfasdfs/

abdullahtunc48@gmail.com sifre: abtu9211 kayıtlı olmayanlara görülmüyor.
 

 

omurolgunay omurolgunay WM Aracı Kullanıcı
  • Üyelik 08.12.2016
  • Yaş/Cinsiyet 31 / E
  • Meslek WordPress Developer
  • Konum İstanbul Avrupa
  • Ad Soyad Ö** O**
  • Mesajlar 236
  • Beğeniler 13 / 66
  • Ticaret 1, (%100)
p.marctv-moderate-links {
position: absolute;
}


Böyle yapsak bi sıkıntı çıkmaz heralde. Css dosyana ekleyip sağını solunu kontrol edersin.
 

 

www.omurolgunay.com
www.klbtasarim.com
www.hareketlikablotasiyici.com
wmaraci
wmaraci

TuayPortal TuayPortal Sms Onayı Gerekli Telefon Onaysız
  • Üyelik 31.12.2016
  • Yaş/Cinsiyet 36 / K
  • Meslek Belli Olacak
  • Konum Aydın
  • Ad Soyad A** T**
  • Mesajlar 218
  • Beğeniler 27 / 33
  • Ticaret 1, (%100)
Üstadım çok teşekkür ederim css işe yaradı elinize kolunuza sağlık.
 

 

Site Ayarları
  • Tema Seçeneği
  • Site Sesleri
  • Bildirimler
  • Özel Mesaj Al