Discuz!官方免费开源建站系统

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索

[补丁] Oytktk的威望/阅读权限/体力插件 补充!

[复制链接]
beecheung 发表于 2005-9-14 19:41:33 | 显示全部楼层 |阅读模式
补充1:评分同时评积分和评威望

前提:安装了仿D4评分;
本部分参考tks999老大的评分又评现金的办法(只替换一个字段即可),tks999老大要见谅啊!


首先:
原oytktk的插件过程中对misc.php的修改不要进行.

进行了改回去就行了.

就是把

  1. UPDATE $table_members SET prestige=prestige$score
复制代码


改回成

  1. UPDATE $table_members SET credit=credit$score
复制代码


1、升级数据
  1. ALTER TABLE cdb_karmalog ADD prestige_rate tinyint(3) NOT NULL default '0';
复制代码


2、打开misc.php
查找
  1. $query = $db->query("SELECT m.adminid, u.groupid FROM $table_members m
  2.                                         LEFT JOIN $table_usergroups u ON type='member' AND m.credit$score>=u.creditshigher AND m.credit$score<u.creditslower
  3.                                         WHERE uid='$post[authorid]'");
复制代码


下面加入
  1. $query = $db->query("SELECT m.adminid, u.groupid FROM $table_members m
  2.                                         LEFT JOIN $table_usergroups u ON type='member' AND m.prestige$prestige_rate>=u.creditshigher AND m.prestige$prestige_rate<u.creditslower
  3.                                         WHERE uid='$post[authorid]'");
复制代码


3、查找
  1. $db->query("UPDATE $table_members SET credit=credit$score $groupidadd WHERE uid='$post[authorid]'", 'UNBUFFERED');
复制代码

下面加入
  1. $db->query("UPDATE $table_members SET prestige=prestige$prestige_rate $groupidadd WHERE uid='$post[authorid]'", 'UNBUFFERED');
复制代码


4、查找
  1. $score = intval($score);
  2.                 if($score >= 0) {
  3.                         $score = "+$score";
  4.                 }
复制代码

下面加入
  1. $prestige_rate = intval($prestige_rate);
  2.                 if($prestige_rate >= 0) {
  3.                         $prestige_rate = "+$prestige_rate";
  4.                 }
复制代码

5、查找
  1. $db->query("INSERT INTO $table_karmalog (uid, pid, dateline,
复制代码

后面加上
  1. prestige_rate,
复制代码


6、查找
  1. VALUES ('$discuz_uid', '$pid', '$timestamp',
复制代码

后面加上
  1. '$prestige_rate',
复制代码


7、查找
  1. $score = intval($score);
  2.         $offset = ceil($maxkarmarate / 6);
  3.         $minkarmarate = $offset - $maxkarmarate;
  4.         if($score < $minkarmarate || $score > $maxkarmarate) {
  5.                 showmessage('thread_karma_range_invalid');
  6.         }
复制代码

下面加入
  1. $prestige_rate = intval($prestige_rate);
  2.         $offset = ceil($maxkarmarate / 6);
  3.         $minkarmarate = $offset - $maxkarmarate;
  4.         if($prestige_rate < $minkarmarate || $prestige_rate > $maxkarmarate) {
  5.                 showmessage('thread_karma_range_invalid');
  6.         }
复制代码

8、查找
  1. $query = $db->query("SELECT SUM(score) FROM $table_karmalog WHERE uid='$discuz_uid' AND dateline>=".($timestamp-86400));
  2.     if($maxrateperday &&  $maxrateperday <= $db->result($query, 0)) {
  3.         showmessage('thread_karma_ctrl');
  4.     }
复制代码

下面加入
  1. $query = $db->query("SELECT SUM(prestige_rate) FROM $table_karmalog WHERE uid='$discuz_uid' AND dateline>=".($timestamp-86400));
  2.     if($maxrateperday &&  $maxrateperday <= $db->result($query, 0)) {
  3.         showmessage('thread_karma_ctrl');
  4.     }
复制代码


9、查找
  1.         $ratetimes = round($maxkarmarate / 5);
  2.             $db->query("UPDATE $table_posts SET rate=rate$score, ratetimes=ratetimes+$ratetimes WHERE pid='$pid'", 'UNBUFFERED');
复制代码

替换为
  1. $ratetimes = round($maxkarmarate / 5);
  2.                 $db->query("UPDATE $table_posts SET rate=rate$score+rate$prestige_rate, ratetimes=ratetimes+$ratetimes WHERE pid='$pid'", 'UNBUFFERED');
复制代码




10、打开karma.htm
查找
  1. <tr>
  2. <td bgcolor="{ALTBG1}" width="21%">{lang thread_rating}:</td>
  3. <td bgcolor="{ALTBG2}">{lang credit_title} <select name="score"><option value="0">0</option>$karmaoptions</select> {lang credit_unit}</td>
  4. </tr>
复制代码

下面加入
  1. <tr>
  2. <td bgcolor="{ALTBG1}" width="21%">{lang thread_rating}:</td>
  3. <td bgcolor="{ALTBG2}">威望 <select name="prestige_rate"><option value="0">0</option>$karmaoptions</select> {lang credit_unit}</td>
  4. </tr>
复制代码


打开messages.lang.php
11、查找
  1. 'thread_karma_succeed' => '感谢您的参与,$post[author] 的 $credittitle  $score  {$creditunit}。<br>现在将转入主题页面。',
复制代码

修改为
  1.         'thread_karma_succeed' => '感谢您的参与,$post[author] 的 $credittitle  $score {$creditunit};$prestige_title $prestige_rate {$prestigeunit}。<br>现在将转入主题页面。',
复制代码


~完~


==================================================

补充2:评分另页显示中加入威望

前提是要安装了tks999老大的评分另页显示插件.

在viewkarma.htm中加入一列
表头上填"威望"
调用内容填"$karma['prestige_rate']"即可.


==================================================

补充3:评分发短信通知作者中加入威望的分数.

前提是安装了评分发短信插件,我安装的是梦网提供的.

在pms.lang.php中

找到:

  1. [b]评分积分:[/b] {$score}
复制代码


在下面加:

  1. [b]评分威望:[/b] {$prestige_rate}
复制代码


即可!

==================================================

补充4:发贴时可填需要多少威望才能浏览的插件

因以前已有人发布这个,用的也是prestige作字段名,所以用以前发布的那个即可.

如果找不到,我转贴出来,作者刚才一时找不着了,在此表示道歉!


升级数据库


  1. ALTER TABLE `cdb_threads` ADD `prestigesrequire` smallint(6) unsigned NOT NULL default '0' AFTER creditsrequire
复制代码




第二次:


  1. ALTER TABLE `cdb_usergroups` ADD `allowsetviewprestigeperm` tinyint(1) NOT NULL default '0' AFTER allowsetviewperm
复制代码




1. include/common.php
查找:



  1. m.credit,
复制代码




后面加上:



  1. m.prestige,
复制代码




2. include/newthread.php
查找:



  1. $viewperm = $allowsetviewperm ? $viewperm : 0;
复制代码




在後面添加:



  1. $viewprestigeperm = $allowsetviewprestigeperm ? $viewprestigeperm : 0;
复制代码




查找:



  1. $db->query("INSERT INTO $table_threads (fid, creditsrequire, iconid, author, authorid, subject, dateline, lastpost, lastposter, displayorder, digest, poll, attachment)
复制代码




在creditsrequire, 後面加上  prestigesrequire,
查找:



  1. VALUES ('$fid', '$viewperm', '$iconid', '$discuz_user', '$discuz_uid', '$subject', '$timestamp', '$timestamp', '$discuz_user', '$displayorder', '$digest', '$poll', '".attachtype($last_attach_type, 'id')."')");
复制代码




'$viewperm', 後面加上 '$viewprestigeperm',
3. include/editpost.php
查找:



  1. $viewpermadd = ($allowsetviewperm && $isfirstpost) ? "creditsrequire='$viewperm'" : NULL;
复制代码




在後面添加:



  1. $viewprestigepermadd = ($allowsetviewprestigeperm && $isfirstpost) ? "prestigesrequire='$viewprestigeperm'" : NULL;
复制代码




查找:



  1. if($viewpermadd) {
  2.                         $db->query("UPDATE $table_threads SET $viewpermadd WHERE tid='$tid'", 'UNBUFFERED');
  3.                 }
复制代码




在下面加:


  1. if($viewprestigepermadd) {
  2.                         $db->query("UPDATE $table_threads SET $viewprestigepermadd WHERE tid='$tid'", 'UNBUFFERED');
  3.                 }
复制代码




4. viewthread.php
查找:



  1. if($thread['creditsrequire'] && $thread['creditsrequire'] > $credit && !$ismoderator && ($thread['authorid'] !=$discuz_uid)) {
  2.         showmessage('thread_nopermission', NULL, 'HALTED');
  3. }
复制代码




在後面添加:


  1. if($thread['prestigesrequire'] && $thread['prestigesrequire'] > $prestige && !$ismoderator && ($thread['authorid'] !=$discuz_uid)) {
  2.         showmessage('thread_noprestigepermission', NULL, 'HALTED');
  3. }
复制代码




5. templates/default/post_newthread.htm模版
查找:



  1. <!--{if $allowsetviewperm}-->
  2.         <tr>
  3.         <td bgcolor="{ALTBG1}">{lang creditsrequire_view} {lang credit_title}:</td>
  4.         <td bgcolor="{ALTBG2}" class="smalltxt"><input type="text" name="viewperm" size="6" value="$viewperm"> {lang credit_unit} (0 {lang is_unlimited})</td>
  5.         </tr>
  6. <!--{/if}-->
复制代码




在後面添加:



  1. <!--{if $allowsetviewprestigeperm}-->
  2.         <tr>
  3.         <td bgcolor="{ALTBG1}">{lang creditsrequire_view} {lang prestige_title}:</td>
  4.         <td bgcolor="{ALTBG2}" class="smalltxt"><input type="text" name="viewprestigeperm" size="6" value="$viewprestigeperm"> {lang prestige_unit} (0 {lang is_unlimited})</td>
  5.         </tr>
  6. <!--{/if}-->
复制代码




6. templates/default/post_editpost.htm模版
找到:



  1. <!--{if $allowsetviewperm && $isfirstpost}-->
  2.         <tr>
  3.         <td bgcolor="{ALTBG1}">{lang creditsrequire_view} {lang credit_title}:</td>
  4.         <td bgcolor="{ALTBG2}"><input type="text" name="viewperm" size="6" value="$thread[creditsrequire]"> {lang credit_unit} (0 {lang is_unlimited})</td>
  5.         </tr>
  6. <!--{/if}-->
复制代码




在后面添加:



  1. <!--{if $allowsetviewprestigeperm && $isfirstpost}-->
  2.         <tr>
  3.         <td bgcolor="{ALTBG1}">{lang creditsrequire_view} {lang prestige_title}:</td>
  4.         <td bgcolor="{ALTBG2}"><input type="text" name="viewprestigeperm" size="6" value="$thread[prestigesrequire]"> {lang prestige_unit} (0 {lang is_unlimited})</td>
  5.         </tr>
  6. <!--{/if}-->
复制代码




7. templates/default/forumdisplay.htm
找到:



  1. <!--{if $thread['creditsrequire']}-->
  2.                     - [{lang credit_title} <span class="bold">$thread[creditsrequire]</span>{lang credit_unit}]
  3.                     <!--{/if}-->
复制代码




在後面添加:



  1. <!--{if $thread['prestigesrequire']}-->
  2.                     - [{lang prestige_title} <span class="bold">$thread[prestigesrequire]</span>{lang prestige_unit}]
  3.                     <!--{/if}-->
复制代码




8. templates/default/viewthread.htm
找到:



  1. <!--{if $thread['creditsrequire']}-->   {lang creditsrequire_view} {lang credit_title} <span class="bold">$thread[creditsrequire]</span> {lang credit_unit}<!--{/if}-->
复制代码




在后面添加:



  1. <!--{if $thread['prestigesrequire']}-->   {lang creditsrequire_view} {lang prestige_title} <span class="bold">$thread[prestigesrequire]</span> {lang prestige_unit}<!--{/if}-->
复制代码




9. admin/groups.php
搜索:



  1. showsetting('usergroups_edit_set_view_perm', 'allowsetviewpermnew', $group['allowsetviewperm'], 'radio');
复制代码




在下面加:



  1. showsetting('usergroups_edit_set_viewprestige_perm', 'allowsetviewprestigepermnew', $group['allowsetviewprestigeperm'], 'radio');
复制代码




搜索:



  1. allowsetviewperm='$allowsetviewpermnew',
复制代码




在后加添加:



  1. allowsetviewprestigeperm='$allowsetviewprestigepermnew',
复制代码




10. admincp.lang.php
搜索:



  1. 'usergroups_edit_set_view_perm' => '允许设置帖子权限:',
  2.         'usergroups_edit_set_view_perm_comment' => '设置是否允许设置帖子需要指定积分以上才可游览',
复制代码




下面加:



  1. 'usergroups_edit_set_viewprestige_perm' => '允许设置帖子威望权限:',
  2.      'usergroups_edit_set_viewprestige_perm_comment' => '设置是否允许设置帖子需要指定威望以上才可游览',
复制代码




11. messages.lang.php
搜索:



  1. $prestigeunit = '级';
复制代码




在下面加:



  1. $prestige_title = '威望';
复制代码




搜索:



  1. 'thread_nopermission' => '对不起,本帖要求 $credittitle 高於 $thread[creditsrequire] $creditunit 才可游览,请返回。',
复制代码




在下面加:



  1. 'thread_noprestigepermission' => '对不起,本帖要求 $prestige_title 高於 $thread[prestigesrequire] $prestigeunit 才可游览,请返回。',
复制代码




~完成~

[ 本帖最后由 beecheung 于 2005-9-15 20:20 编辑 ]
oytktk 发表于 2005-9-14 19:42:37 | 显示全部楼层
我靠..终于让你搞出来了..顶!
回复

使用道具 举报

winter0706 发表于 2005-9-14 19:46:47 | 显示全部楼层
原帖由 oytktk 于 2005-9-14 19:42 发表
我靠..终于让你搞出来了..顶!

是"我日"
不是"我靠"
回复

使用道具 举报

oytktk 发表于 2005-9-14 19:54:46 | 显示全部楼层
原帖由 winter0706 于 2005-9-14 19:46 发表

是"我日"
不是"我靠"


谢谢提醒..日你一把~
回复

使用道具 举报

 楼主| beecheung 发表于 2005-9-14 19:57:20 | 显示全部楼层
两位都喜欢太阳啊
回复

使用道具 举报

秋舞叶 发表于 2005-9-14 19:57:35 | 显示全部楼层
回复

使用道具 举报

 楼主| beecheung 发表于 2005-9-14 19:58:10 | 显示全部楼层
唉....这张贴成了银贴了.
回复

使用道具 举报

七喜仔 发表于 2005-9-14 20:13:35 | 显示全部楼层
支持....
回复

使用道具 举报

oytktk 发表于 2005-9-14 20:21:47 | 显示全部楼层
都发现DZ这两天人好少!!
我再来支持一个!
回复

使用道具 举报

william0116 发表于 2005-9-14 22:01:45 | 显示全部楼层
已装好,但有个问题,就是图中的下拉我没有了.只有默认的"0",按下去也看不到下拉.不知那步出错.改动太多.看得有点头痛.不知有否人遇过提点一下
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|Discuz! 官方站 ( 皖ICP备16010102号 )star

GMT+8, 2024-12-22 20:48 , Processed in 0.029183 second(s), 3 queries , Gzip On, Redis On.

Powered by Discuz! X3.4

Copyright © 2001-2023, Tencent Cloud.

快速回复 返回顶部 返回列表