songxingwei 3 years ago
parent
commit
cd40335402
42 changed files with 4274 additions and 888 deletions
  1. 15 0
      .gitignore
  2. 238 194
      application/admin/view/config/info.html
  3. 204 168
      application/admin/view/config/system-config.html
  4. 59 2
      application/api/controller/Index.php
  5. 67 0
      application/api/controller/Pay.php
  6. 51 0
      application/api/controller/User.php
  7. 0 29
      application/common/library/Common.php
  8. 189 0
      application/common/library/WxMerchPay.php
  9. 391 0
      application/common/library/WxPay.php
  10. 38 0
      application/common/model/Article.php
  11. 38 0
      application/common/model/Banner.php
  12. 153 160
      application/common/model/ElectPool.php
  13. 23 0
      application/common/model/MoneyLog2.php
  14. 20 0
      application/common/model/PayCheck.php
  15. 141 7
      application/common/model/User.php
  16. 19 0
      application/common/model/UserRecharge.php
  17. 19 0
      application/common/model/UserWithdraw.php
  18. 125 0
      application/store/controller/Article.php
  19. 122 0
      application/store/controller/Banner.php
  20. 137 100
      application/store/controller/Member.php
  21. 127 0
      application/store/controller/UserRecharge.php
  22. 127 0
      application/store/controller/UserWithdraw.php
  23. 59 0
      application/store/view/article/form.html
  24. 72 0
      application/store/view/article/index.html
  25. 30 0
      application/store/view/article/index_search.html
  26. 30 0
      application/store/view/banner/form.html
  27. 56 0
      application/store/view/banner/index.html
  28. 15 0
      application/store/view/banner/index_search.html
  29. 34 43
      application/store/view/member/edit.html
  30. 7 1
      application/store/view/member/index.html
  31. 59 0
      application/store/view/user_recharge/form.html
  32. 62 0
      application/store/view/user_recharge/index.html
  33. 30 0
      application/store/view/user_recharge/index_search.html
  34. 59 0
      application/store/view/user_withdraw/form.html
  35. 62 0
      application/store/view/user_withdraw/index.html
  36. 30 0
      application/store/view/user_withdraw/index_search.html
  37. 2 1
      composer.json
  38. 1363 109
      composer.lock
  39. 0 0
      config/apidoc.php
  40. 0 0
      route/app.php
  41. 0 74
      vendor/bin/jp.php
  42. 1 0
      vendor/bin/jp.php

+ 15 - 0
.gitignore

@@ -0,0 +1,15 @@
+/.idea
+/runtime
+/safefile
+/nbproject
+/config/cert
+/composer.lock
+/public/upload
+/public/static/theme/css/console.custom.css
+/public/static/theme/css/console.custom.css.map
+/public/static/theme/css/console.form.css
+/public/static/theme/css/console.form.css.map
+/public/static/theme/css/console.layout.css
+/public/static/theme/css/console.layout.css.map
+/public/static/theme/css/console.layui.css
+/public/static/theme/css/console.layui.css.map

+ 238 - 194
application/admin/view/config/info.html

@@ -65,14 +65,14 @@
         <p class="help-block">微信开放平台的appsecret</p>
     </div>
 
-    <div class="layui-form-item">
-        <span class="color-green font-w7">注册赠送积分数量 RegisterGiveIntegral</span>
-        <label class="relative block">
-            <input readonly value="{:sysconf('register_give_integral')}" class="layui-input layui-bg-gray">
-            <a data-copy="{:sysconf('register_give_integral')}" class="fa fa-copy right-btn"></a>
-        </label>
-        <p class="help-block">注册赠送积分数量 0:不送</p>
-    </div>
+<!--    <div class="layui-form-item">-->
+<!--        <span class="color-green font-w7">注册赠送积分数量 RegisterGiveIntegral</span>-->
+<!--        <label class="relative block">-->
+<!--            <input readonly value="{:sysconf('register_give_integral')}" class="layui-input layui-bg-gray">-->
+<!--            <a data-copy="{:sysconf('register_give_integral')}" class="fa fa-copy right-btn"></a>-->
+<!--        </label>-->
+<!--        <p class="help-block">注册赠送积分数量 0:不送</p>-->
+<!--    </div>-->
 
     <div class="layui-form-item">
         <span class="color-green font-w7">想认识扣除积分 WantKnowIntegral</span>
@@ -83,153 +83,153 @@
         <p class="help-block">想认识扣除积分</p>
     </div>
 
-    <div class="layui-form-item">
-        <span class="color-green font-w7">积分获取联系方式扣除积分 IntegralContact</span>
-        <label class="relative block">
-            <input readonly value="{:sysconf('integral_contact')}" class="layui-input layui-bg-gray">
-            <a data-copy="{:sysconf('integral_contact')}" class="fa fa-copy right-btn"></a>
-        </label>
-        <p class="help-block">积分获取联系方式扣除积分</p>
-    </div>
-    <div class="layui-col-md12">
-        <div class="layui-col-md3">
-            <div class="layui-form-item">
-                <span class="color-green font-w7">分享次数(每天)(分享小程序) shareCountDay</span>
-                <label class="relative block">
-                    <input readonly value="{:sysconf('share_applet_count_day')}" class="layui-input layui-bg-gray">
-                    <a data-copy="{:sysconf('share_applet_count_day')}" class="fa fa-copy right-btn"></a>
-                </label>
-                <p class="help-block">一天分享几次有积分(分享小程序)</p>
-            </div>
-        </div>
-
-        <div class="layui-col-md3" style="margin-left: 10px">
-            <div class="layui-form-item">
-                <span class="color-green font-w7">分享一次获得多少积分(分享小程序) shareIntegral</span>
-                <label class="relative block">
-                    <input readonly value="{:sysconf('share_applet_integral')}" class="layui-input layui-bg-gray">
-                    <a data-copy="{:sysconf('share_applet_integral')}" class="fa fa-copy right-btn"></a>
-                </label>
-                <p class="help-block">分享一次获得多少积分(分享小程序)</p>
-            </div>
-        </div>
-
-        <div class="layui-col-md3" style="margin-left: 10px">
-            <div class="layui-form-item">
-                <span class="color-green font-w7">分享小程序标题 ShareAppletTitle</span>
-                <label class="relative block">
-                    <input readonly value="{:sysconf('share_applet_title')}" class="layui-input layui-bg-gray">
-                    <a data-copy="{:sysconf('share_applet_title')}" class="fa fa-copy right-btn"></a>
-                </label>
-                <p class="help-block">分享小程序标题</p>
-            </div>
-        </div>
-    </div>
-
-    <div class="layui-col-md12">
-        <div class="layui-col-md3">
-            <div class="layui-form-item">
-                <span class="color-green font-w7">分享次数(每天)(分享互选池) shareCountDay</span>
-                <label class="relative block">
-                    <input readonly value="{:sysconf('share_pool_count_day')}" class="layui-input layui-bg-gray">
-                    <a data-copy="{:sysconf('share_pool_count_day')}" class="fa fa-copy right-btn"></a>
-                </label>
-                <p class="help-block">一天分享几次有积分(分享互选池)</p>
-            </div>
-        </div>
-
-        <div class="layui-col-md3" style="margin-left: 10px">
-            <div class="layui-form-item ">
-                <span class="color-green font-w7">分享一次获得多少积分(分享互选池) shareIntegral</span>
-                <label class="relative block">
-                    <input readonly value="{:sysconf('share_pool_integral')}" class="layui-input layui-bg-gray">
-                    <a data-copy="{:sysconf('share_pool_integral')}" class="fa fa-copy right-btn"></a>
-                </label>
-                <p class="help-block">分享一次获得多少积分(分享互选池)</p>
-            </div>
-        </div>
-
-        <div class="layui-col-md3" style="margin-left: 10px">
-            <div class="layui-form-item">
-                <span class="color-green font-w7">分享互选池标题 SharePoolTitle</span>
-                <label class="relative block">
-                    <input readonly value="{:sysconf('share_pool_title')}" class="layui-input layui-bg-gray">
-                    <a data-copy="{:sysconf('share_pool_title')}" class="fa fa-copy right-btn"></a>
-                </label>
-                <p class="help-block">分享小程序标题</p>
-            </div>
-        </div>
-    </div>
-
-    <div class="layui-col-md12">
-        <div class="layui-col-md3">
-            <div class="layui-form-item">
-                <span class="color-green font-w7">分享次数(每天)(分享个人主页) shareCountDay</span>
-                <label class="relative block">
-                    <input readonly value="{:sysconf('share_myinfo_count_day')}" class="layui-input layui-bg-gray">
-                    <a data-copy="{:sysconf('share_myinfo_count_day')}" class="fa fa-copy right-btn"></a>
-                </label>
-                <p class="help-block">一天分享几次有积分(分享个人主页)</p>
-            </div>
-        </div>
-
-        <div class="layui-col-md3" style="margin-left: 10px">
-            <div class="layui-form-item ">
-                <span class="color-green font-w7">分享一次获得多少积分(分享个人主页) shareIntegral</span>
-                <label class="relative block">
-                    <input readonly value="{:sysconf('share_myinfo_integral')}" class="layui-input layui-bg-gray">
-                    <a data-copy="{:sysconf('share_myinfo_integral')}" class="fa fa-copy right-btn"></a>
-                </label>
-                <p class="help-block">分享一次获得多少积分(分享个人主页)</p>
-            </div>
-        </div>
-
-        <div class="layui-col-md3" style="margin-left: 10px">
-            <div class="layui-form-item">
-                <span class="color-green font-w7">分享个人主页标题 ShareMyinfoTitle</span>
-                <label class="relative block">
-                    <input readonly value="{:sysconf('share_myinfo_title')}" class="layui-input layui-bg-gray">
-                    <a data-copy="{:sysconf('share_myinfo_title')}" class="fa fa-copy right-btn"></a>
-                </label>
-                <p class="help-block">分享个人主页标题</p>
-            </div>
-        </div>
-    </div>
-
-    <div class="layui-col-md12">
-        <div class="layui-col-md3">
-            <div class="layui-form-item">
-                <span class="color-green font-w7">分享次数(每天)(分享他人主页) shareCountDay</span>
-                <label class="relative block">
-                    <input readonly value="{:sysconf('share_others_count_day')}" class="layui-input layui-bg-gray">
-                    <a data-copy="{:sysconf('share_others_count_day')}" class="fa fa-copy right-btn"></a>
-                </label>
-                <p class="help-block">一天分享几次有积分(分享他人主页)</p>
-            </div>
-        </div>
-
-        <div class="layui-col-md3" style="margin-left: 10px">
-            <div class="layui-form-item ">
-                <span class="color-green font-w7">分享一次获得多少积分(分享他人主页) shareIntegral</span>
-                <label class="relative block">
-                    <input readonly value="{:sysconf('share_others_integral')}" class="layui-input layui-bg-gray">
-                    <a data-copy="{:sysconf('share_others_integral')}" class="fa fa-copy right-btn"></a>
-                </label>
-                <p class="help-block">分享一次获得多少积分(分享他人主页)</p>
-            </div>
-        </div>
-
-        <div class="layui-col-md3" style="margin-left: 10px">
-            <div class="layui-form-item">
-                <span class="color-green font-w7">分享他人主页标题 ShareOthersTitle</span>
-                <label class="relative block">
-                    <input readonly value="{:sysconf('share_others_title')}" class="layui-input layui-bg-gray">
-                    <a data-copy="{:sysconf('share_others_title')}" class="fa fa-copy right-btn"></a>
-                </label>
-                <p class="help-block">分享他人主页标题</p>
-            </div>
-        </div>
-    </div>
+<!--    <div class="layui-form-item">-->
+<!--        <span class="color-green font-w7">积分获取联系方式扣除积分 IntegralContact</span>-->
+<!--        <label class="relative block">-->
+<!--            <input readonly value="{:sysconf('integral_contact')}" class="layui-input layui-bg-gray">-->
+<!--            <a data-copy="{:sysconf('integral_contact')}" class="fa fa-copy right-btn"></a>-->
+<!--        </label>-->
+<!--        <p class="help-block">积分获取联系方式扣除积分</p>-->
+<!--    </div>-->
+<!--    <div class="layui-col-md12">-->
+<!--        <div class="layui-col-md3">-->
+<!--            <div class="layui-form-item">-->
+<!--                <span class="color-green font-w7">分享次数(每天)(分享小程序) shareCountDay</span>-->
+<!--                <label class="relative block">-->
+<!--                    <input readonly value="{:sysconf('share_applet_count_day')}" class="layui-input layui-bg-gray">-->
+<!--                    <a data-copy="{:sysconf('share_applet_count_day')}" class="fa fa-copy right-btn"></a>-->
+<!--                </label>-->
+<!--                <p class="help-block">一天分享几次有积分(分享小程序)</p>-->
+<!--            </div>-->
+<!--        </div>-->
+
+<!--        <div class="layui-col-md3" style="margin-left: 10px">-->
+<!--            <div class="layui-form-item">-->
+<!--                <span class="color-green font-w7">分享一次获得多少积分(分享小程序) shareIntegral</span>-->
+<!--                <label class="relative block">-->
+<!--                    <input readonly value="{:sysconf('share_applet_integral')}" class="layui-input layui-bg-gray">-->
+<!--                    <a data-copy="{:sysconf('share_applet_integral')}" class="fa fa-copy right-btn"></a>-->
+<!--                </label>-->
+<!--                <p class="help-block">分享一次获得多少积分(分享小程序)</p>-->
+<!--            </div>-->
+<!--        </div>-->
+
+<!--        <div class="layui-col-md3" style="margin-left: 10px">-->
+<!--            <div class="layui-form-item">-->
+<!--                <span class="color-green font-w7">分享小程序标题 ShareAppletTitle</span>-->
+<!--                <label class="relative block">-->
+<!--                    <input readonly value="{:sysconf('share_applet_title')}" class="layui-input layui-bg-gray">-->
+<!--                    <a data-copy="{:sysconf('share_applet_title')}" class="fa fa-copy right-btn"></a>-->
+<!--                </label>-->
+<!--                <p class="help-block">分享小程序标题</p>-->
+<!--            </div>-->
+<!--        </div>-->
+<!--    </div>-->
+
+<!--    <div class="layui-col-md12">-->
+<!--        <div class="layui-col-md3">-->
+<!--            <div class="layui-form-item">-->
+<!--                <span class="color-green font-w7">分享次数(每天)(分享互选池) shareCountDay</span>-->
+<!--                <label class="relative block">-->
+<!--                    <input readonly value="{:sysconf('share_pool_count_day')}" class="layui-input layui-bg-gray">-->
+<!--                    <a data-copy="{:sysconf('share_pool_count_day')}" class="fa fa-copy right-btn"></a>-->
+<!--                </label>-->
+<!--                <p class="help-block">一天分享几次有积分(分享互选池)</p>-->
+<!--            </div>-->
+<!--        </div>-->
+
+<!--        <div class="layui-col-md3" style="margin-left: 10px">-->
+<!--            <div class="layui-form-item ">-->
+<!--                <span class="color-green font-w7">分享一次获得多少积分(分享互选池) shareIntegral</span>-->
+<!--                <label class="relative block">-->
+<!--                    <input readonly value="{:sysconf('share_pool_integral')}" class="layui-input layui-bg-gray">-->
+<!--                    <a data-copy="{:sysconf('share_pool_integral')}" class="fa fa-copy right-btn"></a>-->
+<!--                </label>-->
+<!--                <p class="help-block">分享一次获得多少积分(分享互选池)</p>-->
+<!--            </div>-->
+<!--        </div>-->
+
+<!--        <div class="layui-col-md3" style="margin-left: 10px">-->
+<!--            <div class="layui-form-item">-->
+<!--                <span class="color-green font-w7">分享互选池标题 SharePoolTitle</span>-->
+<!--                <label class="relative block">-->
+<!--                    <input readonly value="{:sysconf('share_pool_title')}" class="layui-input layui-bg-gray">-->
+<!--                    <a data-copy="{:sysconf('share_pool_title')}" class="fa fa-copy right-btn"></a>-->
+<!--                </label>-->
+<!--                <p class="help-block">分享小程序标题</p>-->
+<!--            </div>-->
+<!--        </div>-->
+<!--    </div>-->
+
+<!--    <div class="layui-col-md12">-->
+<!--        <div class="layui-col-md3">-->
+<!--            <div class="layui-form-item">-->
+<!--                <span class="color-green font-w7">分享次数(每天)(分享个人主页) shareCountDay</span>-->
+<!--                <label class="relative block">-->
+<!--                    <input readonly value="{:sysconf('share_myinfo_count_day')}" class="layui-input layui-bg-gray">-->
+<!--                    <a data-copy="{:sysconf('share_myinfo_count_day')}" class="fa fa-copy right-btn"></a>-->
+<!--                </label>-->
+<!--                <p class="help-block">一天分享几次有积分(分享个人主页)</p>-->
+<!--            </div>-->
+<!--        </div>-->
+
+<!--        <div class="layui-col-md3" style="margin-left: 10px">-->
+<!--            <div class="layui-form-item ">-->
+<!--                <span class="color-green font-w7">分享一次获得多少积分(分享个人主页) shareIntegral</span>-->
+<!--                <label class="relative block">-->
+<!--                    <input readonly value="{:sysconf('share_myinfo_integral')}" class="layui-input layui-bg-gray">-->
+<!--                    <a data-copy="{:sysconf('share_myinfo_integral')}" class="fa fa-copy right-btn"></a>-->
+<!--                </label>-->
+<!--                <p class="help-block">分享一次获得多少积分(分享个人主页)</p>-->
+<!--            </div>-->
+<!--        </div>-->
+
+<!--        <div class="layui-col-md3" style="margin-left: 10px">-->
+<!--            <div class="layui-form-item">-->
+<!--                <span class="color-green font-w7">分享个人主页标题 ShareMyinfoTitle</span>-->
+<!--                <label class="relative block">-->
+<!--                    <input readonly value="{:sysconf('share_myinfo_title')}" class="layui-input layui-bg-gray">-->
+<!--                    <a data-copy="{:sysconf('share_myinfo_title')}" class="fa fa-copy right-btn"></a>-->
+<!--                </label>-->
+<!--                <p class="help-block">分享个人主页标题</p>-->
+<!--            </div>-->
+<!--        </div>-->
+<!--    </div>-->
+
+<!--    <div class="layui-col-md12">-->
+<!--        <div class="layui-col-md3">-->
+<!--            <div class="layui-form-item">-->
+<!--                <span class="color-green font-w7">分享次数(每天)(分享他人主页) shareCountDay</span>-->
+<!--                <label class="relative block">-->
+<!--                    <input readonly value="{:sysconf('share_others_count_day')}" class="layui-input layui-bg-gray">-->
+<!--                    <a data-copy="{:sysconf('share_others_count_day')}" class="fa fa-copy right-btn"></a>-->
+<!--                </label>-->
+<!--                <p class="help-block">一天分享几次有积分(分享他人主页)</p>-->
+<!--            </div>-->
+<!--        </div>-->
+
+<!--        <div class="layui-col-md3" style="margin-left: 10px">-->
+<!--            <div class="layui-form-item ">-->
+<!--                <span class="color-green font-w7">分享一次获得多少积分(分享他人主页) shareIntegral</span>-->
+<!--                <label class="relative block">-->
+<!--                    <input readonly value="{:sysconf('share_others_integral')}" class="layui-input layui-bg-gray">-->
+<!--                    <a data-copy="{:sysconf('share_others_integral')}" class="fa fa-copy right-btn"></a>-->
+<!--                </label>-->
+<!--                <p class="help-block">分享一次获得多少积分(分享他人主页)</p>-->
+<!--            </div>-->
+<!--        </div>-->
+
+<!--        <div class="layui-col-md3" style="margin-left: 10px">-->
+<!--            <div class="layui-form-item">-->
+<!--                <span class="color-green font-w7">分享他人主页标题 ShareOthersTitle</span>-->
+<!--                <label class="relative block">-->
+<!--                    <input readonly value="{:sysconf('share_others_title')}" class="layui-input layui-bg-gray">-->
+<!--                    <a data-copy="{:sysconf('share_others_title')}" class="fa fa-copy right-btn"></a>-->
+<!--                </label>-->
+<!--                <p class="help-block">分享他人主页标题</p>-->
+<!--            </div>-->
+<!--        </div>-->
+<!--    </div>-->
 
     <div class="layui-col-md12">
         <div class="layui-col-md3">
@@ -339,15 +339,15 @@
     </div>
 
     <div class="layui-col-md12">
-        <div class="layui-col-md3">
-            <div class="layui-form-item">
-                <span class="color-green font-w7">积分获取联系方式开关</span>
-                <label class="relative block">
-                    <input readonly value="{:sysconf('integral_get_contact_switch')}" class="layui-input layui-bg-gray">
-                </label>
-                <p class="help-block">积分获取联系方式开关    1:开  0:关</p>
-            </div>
-        </div>
+<!--        <div class="layui-col-md3">-->
+<!--            <div class="layui-form-item">-->
+<!--                <span class="color-green font-w7">积分获取联系方式开关</span>-->
+<!--                <label class="relative block">-->
+<!--                    <input readonly value="{:sysconf('integral_get_contact_switch')}" class="layui-input layui-bg-gray">-->
+<!--                </label>-->
+<!--                <p class="help-block">积分获取联系方式开关    1:开  0:关</p>-->
+<!--            </div>-->
+<!--        </div>-->
 
         <div class="layui-col-md3">
             <div class="layui-form-item ">
@@ -424,14 +424,14 @@
         <p class="help-block">用户每周的收藏卡数量</p>
     </div>
 
-    <div class="layui-form-item">
-        <span class="color-green font-w7">想认识拒绝返积分百分比 notAgreeReturnIntegral</span>
-        <label class="relative block">
-            <input readonly value="{:sysconf('notAgreeReturnIntegral')}" class="layui-input layui-bg-gray">
-            <a data-copy="{:sysconf('notAgreeReturnIntegral')}" class="fa fa-copy right-btn"></a>
-        </label>
-        <p class="help-block">想认识拒绝返积分百分比,例如50%</p>
-    </div>
+<!--    <div class="layui-form-item">-->
+<!--        <span class="color-green font-w7">想认识拒绝返积分百分比 notAgreeReturnIntegral</span>-->
+<!--        <label class="relative block">-->
+<!--            <input readonly value="{:sysconf('notAgreeReturnIntegral')}" class="layui-input layui-bg-gray">-->
+<!--            <a data-copy="{:sysconf('notAgreeReturnIntegral')}" class="fa fa-copy right-btn"></a>-->
+<!--        </label>-->
+<!--        <p class="help-block">想认识拒绝返积分百分比,例如50%</p>-->
+<!--    </div>-->
 
     <div class="layui-form-item">
         <span class="color-green font-w7">举报动态内容 Report Content</span>
@@ -442,14 +442,14 @@
         <p class="help-block">动态、评论举报内容</p>
     </div>
 
-    <div class="layui-form-item">
-        <span class="color-green font-w7">拒绝申请理由 Reasons Inadequacy</span>
-        <label class="relative block">
-            <input readonly value="{:sysconf('reasons_inadequacy')}" class="layui-input layui-bg-gray">
-            <a data-copy="{:sysconf('reasons_inadequacy')}" class="fa fa-copy right-btn"></a>
-        </label>
-        <p class="help-block">拒绝申请理由</p>
-    </div>
+<!--    <div class="layui-form-item">-->
+<!--        <span class="color-green font-w7">拒绝申请理由 Reasons Inadequacy</span>-->
+<!--        <label class="relative block">-->
+<!--            <input readonly value="{:sysconf('reasons_inadequacy')}" class="layui-input layui-bg-gray">-->
+<!--            <a data-copy="{:sysconf('reasons_inadequacy')}" class="fa fa-copy right-btn"></a>-->
+<!--        </label>-->
+<!--        <p class="help-block">拒绝申请理由</p>-->
+<!--    </div>-->
     <div class="layui-form-item">
         <span class="color-green font-w7">举报用户类型 Report User Content</span>
         <label class="relative block">
@@ -460,33 +460,77 @@
     </div>
 
 
+<!--    <div class="layui-form-item">-->
+<!--        <span class="color-green font-w7">打招呼语句 Greet</span>-->
+<!--        <label class="relative block">-->
+<!--            <input readonly value="{:sysconf('greet')}" class="layui-input layui-bg-gray">-->
+<!--            <a data-copy="{:sysconf('greet')}" class="fa fa-copy right-btn"></a>-->
+<!--        </label>-->
+<!--        <p class="help-block">聊天打招呼语句</p>-->
+<!--    </div>-->
+
+<!--    <div class="layui-form-item">-->
+<!--        <span class="color-green font-w7">聊兴趣语句 Chatting</span>-->
+<!--        <label class="relative block">-->
+<!--            <input readonly value="{:sysconf('chatting')}" class="layui-input layui-bg-gray">-->
+<!--            <a data-copy="{:sysconf('chatting')}" class="fa fa-copy right-btn"></a>-->
+<!--        </label>-->
+<!--        <p class="help-block">聊天聊兴趣语句</p>-->
+<!--    </div>-->
+
+<!--    <div class="layui-form-item">-->
+<!--        <span class="color-green font-w7">聊过往语句 Talk Past</span>-->
+<!--        <label class="relative block">-->
+<!--            <input readonly value="{:sysconf('talk_past')}" class="layui-input layui-bg-gray">-->
+<!--            <a data-copy="{:sysconf('talk_past')}" class="fa fa-copy right-btn"></a>-->
+<!--        </label>-->
+<!--        <p class="help-block">聊天聊过往语句</p>-->
+<!--    </div>-->
+
+
+<!--    <div class="layui-form-item">-->
+<!--        <span class="color-green font-w7">付费查看需付多少 pay_check_money</span>-->
+<!--        <label class="relative block">-->
+<!--            <input readonly value="{:sysconf('pay_check_money')}" class="layui-input layui-bg-gray">-->
+<!--            <a data-copy="{:sysconf('pay_check_money')}" class="fa fa-copy right-btn"></a>-->
+<!--        </label>-->
+<!--        <p class="help-block">用户付费查看需付多少钱</p>-->
+<!--    </div>-->
+
+
     <div class="layui-form-item">
-        <span class="color-green font-w7">打招呼语句 Greet</span>
+        <span class="color-green font-w7">被查看用户获得多少 get_check_money</span>
         <label class="relative block">
-            <input readonly value="{:sysconf('greet')}" class="layui-input layui-bg-gray">
-            <a data-copy="{:sysconf('greet')}" class="fa fa-copy right-btn"></a>
+            <input readonly value="{:sysconf('get_check_money')}%" class="layui-input layui-bg-gray">
+            <a data-copy="{:sysconf('get_check_money')}" class="fa fa-copy right-btn"></a>
         </label>
-        <p class="help-block">聊天打招呼语句</p>
+        <p class="help-block">被查看用户获得多少钱  百分比%,例如:50块钱,50%返25块</p>
     </div>
 
     <div class="layui-form-item">
-        <span class="color-green font-w7">聊兴趣语句 Chatting</span>
+        <span class="color-green font-w7">提现服务费百分比 PoundageProportion</span>
         <label class="relative block">
-            <input readonly value="{:sysconf('chatting')}" class="layui-input layui-bg-gray">
-            <a data-copy="{:sysconf('chatting')}" class="fa fa-copy right-btn"></a>
+            <input readonly value="{:sysconf('poundage_proportion')}%" class="layui-input layui-bg-gray">
+            <a data-copy="{:sysconf('poundage_proportion')}" class="fa fa-copy right-btn"></a>
         </label>
-        <p class="help-block">聊天聊兴趣语句</p>
+        <p class="help-block">提现操作服务费百分比%</p>
     </div>
-
     <div class="layui-form-item">
-        <span class="color-green font-w7">聊过往语句 Talk Past</span>
+        <span class="color-green font-w7">提现最小金额 WithdrawMinPrice</span>
         <label class="relative block">
-            <input readonly value="{:sysconf('talk_past')}" class="layui-input layui-bg-gray">
-            <a data-copy="{:sysconf('talk_past')}" class="fa fa-copy right-btn"></a>
+            <input readonly value="{:sysconf('withdraw_min_price')}" class="layui-input layui-bg-gray">
+            <a data-copy="{:sysconf('withdraw_min_price')}" class="fa fa-copy right-btn"></a>
         </label>
-        <p class="help-block">聊天聊过往语句</p>
+        <p class="help-block">提现最小金额</p>
+    </div>
+    <div class="layui-form-item">
+        <span class="color-green font-w7">提现最大金额 WithdrawMaxPrice</span>
+        <label class="relative block">
+            <input readonly value="{:sysconf('withdraw_max_price')}" class="layui-input layui-bg-gray">
+            <a data-copy="{:sysconf('withdraw_max_price')}" class="fa fa-copy right-btn"></a>
+        </label>
+        <p class="help-block">提现最大金额</p>
     </div>
-
 
     <div class="layui-form-item">
         <span class="color-green font-w7">微信客服回复图片 BotImg</span>

+ 204 - 168
application/admin/view/config/system-config.html

@@ -39,13 +39,13 @@
             <p class="help-block">微信开放平台的appsecret</p>
         </div>
 
-        <div class="layui-form-item">
-            <label class="relative block">
-                <span class="color-green font-w7">注册赠送积分数量 RegisterGiveIntegral</span>
-                <input name="register_give_integral" required placeholder="请输入积分" value="{:sysconf('register_give_integral')}" class="layui-input">
-            </label>
-            <p class="help-block">注册赠送积分数量 0:不送</p>
-        </div>
+<!--        <div class="layui-form-item">-->
+<!--            <label class="relative block">-->
+<!--                <span class="color-green font-w7">注册赠送积分数量 RegisterGiveIntegral</span>-->
+<!--                <input name="register_give_integral" required placeholder="请输入积分" value="{:sysconf('register_give_integral')}" class="layui-input">-->
+<!--            </label>-->
+<!--            <p class="help-block">注册赠送积分数量 0:不送</p>-->
+<!--        </div>-->
 
         <div class="layui-form-item">
             <label class="relative block">
@@ -55,129 +55,129 @@
             <p class="help-block">想认识扣除积分</p>
         </div>
 
-        <div class="layui-form-item">
-            <label class="relative block">
-                <span class="color-green font-w7">积分获取联系方式扣除积分 IntegralContact</span>
-                <input name="integral_contact" required placeholder="请输入积分" value="{:sysconf('integral_contact')}" class="layui-input">
-            </label>
-            <p class="help-block">积分获取联系方式扣除积分</p>
-        </div>
-        <div class="layui-col-md12">
-            <div class="layui-col-md4">
-                <div class="layui-form-item">
-                    <label class="relative block">
-                        <span class="color-green font-w7">分享次数(每天)(分享小程序)</span>
-                        <input name="share_applet_count_day" required placeholder="请输入次数" value="{:sysconf('share_applet_count_day')}" class="layui-input">
-                    </label>
-                    <p class="help-block">一天分享几次有积分(分享小程序)</p>
-                </div>
-            </div>
-            <div class="layui-col-md4">
-                <div class="layui-form-item">
-                    <label class="relative block">
-                        <span class="color-green font-w7">分享一次获得多少积分(分享小程序)</span>
-                        <input name="share_applet_integral" required placeholder="请输入积分" value="{:sysconf('share_applet_integral')}" class="layui-input">
-                    </label>
-                    <p class="help-block">分享一次获得多少积分(分享小程序)</p>
-                </div>
-            </div>
-            <div class="layui-col-md4">
-                <div class="layui-form-item">
-                    <label class="relative block">
-                        <span class="color-green font-w7">分享小程序标题</span>
-                        <input name="share_applet_title" required placeholder="请输入标题" value="{:sysconf('share_applet_title')}" class="layui-input">
-                    </label>
-                    <p class="help-block">分享小程序标题</p>
-                </div>
-            </div>
-        </div>
-        <div class="layui-col-md12">
-            <div class="layui-col-md4">
-                <div class="layui-form-item">
-                    <label class="relative block">
-                        <span class="color-green font-w7">分享次数(每天)(分享互选池)</span>
-                        <input name="share_pool_count_day" required placeholder="请输入次数" value="{:sysconf('share_pool_count_day')}" class="layui-input">
-                    </label>
-                    <p class="help-block">一天分享几次有积分(分享互选池)</p>
-                </div>
-            </div>
-            <div class="layui-col-md4">
-                <div class="layui-form-item">
-                    <label class="relative block">
-                        <span class="color-green font-w7">分享一次获得多少积分(分享互选池)</span>
-                        <input name="share_pool_integral" required placeholder="请输入积分" value="{:sysconf('share_pool_integral')}" class="layui-input">
-                    </label>
-                    <p class="help-block">分享一次获得多少积分(分享互选池)</p>
-                </div>
-            </div>
-            <div class="layui-col-md4">
-                <div class="layui-form-item">
-                    <label class="relative block">
-                        <span class="color-green font-w7">分享互选池标题</span>
-                        <input name="share_pool_title" required placeholder="请输入标题" value="{:sysconf('share_pool_title')}" class="layui-input">
-                    </label>
-                    <p class="help-block">分享互选池标题</p>
-                </div>
-            </div>
-        </div>
-        <div class="layui-col-md12">
-            <div class="layui-col-md4">
-                <div class="layui-form-item">
-                    <label class="relative block">
-                        <span class="color-green font-w7">分享次数(每天)(分享个人主页)</span>
-                        <input name="share_myinfo_count_day" required placeholder="请输入次数" value="{:sysconf('share_myinfo_count_day')}" class="layui-input">
-                    </label>
-                    <p class="help-block">一天分享几次有积分(分享个人主页)</p>
-                </div>
-            </div>
-            <div class="layui-col-md4">
-                <div class="layui-form-item">
-                    <label class="relative block">
-                        <span class="color-green font-w7">分享一次获得多少积分(分享个人主页)</span>
-                        <input name="share_myinfo_integral" required placeholder="请输入积分" value="{:sysconf('share_myinfo_integral')}" class="layui-input">
-                    </label>
-                    <p class="help-block">分享一次获得多少积分(分享个人主页)</p>
-                </div>
-            </div>
-            <div class="layui-col-md4">
-                <div class="layui-form-item">
-                    <label class="relative block">
-                        <span class="color-green font-w7">分享个人主页标题</span>
-                        <input name="share_myinfo_title" required placeholder="请输入标题" value="{:sysconf('share_myinfo_title')}" class="layui-input">
-                    </label>
-                    <p class="help-block">分享个人主页标题</p>
-                </div>
-            </div>
-        </div>
-        <div class="layui-col-md12">
-            <div class="layui-col-md4">
-                <div class="layui-form-item">
-                    <label class="relative block">
-                        <span class="color-green font-w7">分享次数(每天)(分享他人主页)</span>
-                        <input name="share_others_count_day" required placeholder="请输入次数" value="{:sysconf('share_others_count_day')}" class="layui-input">
-                    </label>
-                    <p class="help-block">一天分享几次有积分(分享他人主页)</p>
-                </div>
-            </div>
-            <div class="layui-col-md4">
-                <div class="layui-form-item">
-                    <label class="relative block">
-                        <span class="color-green font-w7">分享一次获得多少积分(分享他人主页)</span>
-                        <input name="share_others_integral" required placeholder="请输入积分" value="{:sysconf('share_others_integral')}" class="layui-input">
-                    </label>
-                    <p class="help-block">分享一次获得多少积分(分享他人主页)</p>
-                </div>
-            </div>
-            <div class="layui-col-md4">
-                <div class="layui-form-item">
-                    <label class="relative block">
-                        <span class="color-green font-w7">分享他人主页标题</span>
-                        <input name="share_others_title" required placeholder="请输入标题" value="{:sysconf('share_others_title')}" class="layui-input">
-                    </label>
-                    <p class="help-block">分享他人主页标题</p>
-                </div>
-            </div>
-        </div>
+<!--        <div class="layui-form-item">-->
+<!--            <label class="relative block">-->
+<!--                <span class="color-green font-w7">积分获取联系方式扣除积分 IntegralContact</span>-->
+<!--                <input name="integral_contact" required placeholder="请输入积分" value="{:sysconf('integral_contact')}" class="layui-input">-->
+<!--            </label>-->
+<!--            <p class="help-block">积分获取联系方式扣除积分</p>-->
+<!--        </div>-->
+<!--        <div class="layui-col-md12">-->
+<!--            <div class="layui-col-md4">-->
+<!--                <div class="layui-form-item">-->
+<!--                    <label class="relative block">-->
+<!--                        <span class="color-green font-w7">分享次数(每天)(分享小程序)</span>-->
+<!--                        <input name="share_applet_count_day" required placeholder="请输入次数" value="{:sysconf('share_applet_count_day')}" class="layui-input">-->
+<!--                    </label>-->
+<!--                    <p class="help-block">一天分享几次有积分(分享小程序)</p>-->
+<!--                </div>-->
+<!--            </div>-->
+<!--            <div class="layui-col-md4">-->
+<!--                <div class="layui-form-item">-->
+<!--                    <label class="relative block">-->
+<!--                        <span class="color-green font-w7">分享一次获得多少积分(分享小程序)</span>-->
+<!--                        <input name="share_applet_integral" required placeholder="请输入积分" value="{:sysconf('share_applet_integral')}" class="layui-input">-->
+<!--                    </label>-->
+<!--                    <p class="help-block">分享一次获得多少积分(分享小程序)</p>-->
+<!--                </div>-->
+<!--            </div>-->
+<!--            <div class="layui-col-md4">-->
+<!--                <div class="layui-form-item">-->
+<!--                    <label class="relative block">-->
+<!--                        <span class="color-green font-w7">分享小程序标题</span>-->
+<!--                        <input name="share_applet_title" required placeholder="请输入标题" value="{:sysconf('share_applet_title')}" class="layui-input">-->
+<!--                    </label>-->
+<!--                    <p class="help-block">分享小程序标题</p>-->
+<!--                </div>-->
+<!--            </div>-->
+<!--        </div>-->
+<!--        <div class="layui-col-md12">-->
+<!--            <div class="layui-col-md4">-->
+<!--                <div class="layui-form-item">-->
+<!--                    <label class="relative block">-->
+<!--                        <span class="color-green font-w7">分享次数(每天)(分享互选池)</span>-->
+<!--                        <input name="share_pool_count_day" required placeholder="请输入次数" value="{:sysconf('share_pool_count_day')}" class="layui-input">-->
+<!--                    </label>-->
+<!--                    <p class="help-block">一天分享几次有积分(分享互选池)</p>-->
+<!--                </div>-->
+<!--            </div>-->
+<!--            <div class="layui-col-md4">-->
+<!--                <div class="layui-form-item">-->
+<!--                    <label class="relative block">-->
+<!--                        <span class="color-green font-w7">分享一次获得多少积分(分享互选池)</span>-->
+<!--                        <input name="share_pool_integral" required placeholder="请输入积分" value="{:sysconf('share_pool_integral')}" class="layui-input">-->
+<!--                    </label>-->
+<!--                    <p class="help-block">分享一次获得多少积分(分享互选池)</p>-->
+<!--                </div>-->
+<!--            </div>-->
+<!--            <div class="layui-col-md4">-->
+<!--                <div class="layui-form-item">-->
+<!--                    <label class="relative block">-->
+<!--                        <span class="color-green font-w7">分享互选池标题</span>-->
+<!--                        <input name="share_pool_title" required placeholder="请输入标题" value="{:sysconf('share_pool_title')}" class="layui-input">-->
+<!--                    </label>-->
+<!--                    <p class="help-block">分享互选池标题</p>-->
+<!--                </div>-->
+<!--            </div>-->
+<!--        </div>-->
+<!--        <div class="layui-col-md12">-->
+<!--            <div class="layui-col-md4">-->
+<!--                <div class="layui-form-item">-->
+<!--                    <label class="relative block">-->
+<!--                        <span class="color-green font-w7">分享次数(每天)(分享个人主页)</span>-->
+<!--                        <input name="share_myinfo_count_day" required placeholder="请输入次数" value="{:sysconf('share_myinfo_count_day')}" class="layui-input">-->
+<!--                    </label>-->
+<!--                    <p class="help-block">一天分享几次有积分(分享个人主页)</p>-->
+<!--                </div>-->
+<!--            </div>-->
+<!--            <div class="layui-col-md4">-->
+<!--                <div class="layui-form-item">-->
+<!--                    <label class="relative block">-->
+<!--                        <span class="color-green font-w7">分享一次获得多少积分(分享个人主页)</span>-->
+<!--                        <input name="share_myinfo_integral" required placeholder="请输入积分" value="{:sysconf('share_myinfo_integral')}" class="layui-input">-->
+<!--                    </label>-->
+<!--                    <p class="help-block">分享一次获得多少积分(分享个人主页)</p>-->
+<!--                </div>-->
+<!--            </div>-->
+<!--            <div class="layui-col-md4">-->
+<!--                <div class="layui-form-item">-->
+<!--                    <label class="relative block">-->
+<!--                        <span class="color-green font-w7">分享个人主页标题</span>-->
+<!--                        <input name="share_myinfo_title" required placeholder="请输入标题" value="{:sysconf('share_myinfo_title')}" class="layui-input">-->
+<!--                    </label>-->
+<!--                    <p class="help-block">分享个人主页标题</p>-->
+<!--                </div>-->
+<!--            </div>-->
+<!--        </div>-->
+<!--        <div class="layui-col-md12">-->
+<!--            <div class="layui-col-md4">-->
+<!--                <div class="layui-form-item">-->
+<!--                    <label class="relative block">-->
+<!--                        <span class="color-green font-w7">分享次数(每天)(分享他人主页)</span>-->
+<!--                        <input name="share_others_count_day" required placeholder="请输入次数" value="{:sysconf('share_others_count_day')}" class="layui-input">-->
+<!--                    </label>-->
+<!--                    <p class="help-block">一天分享几次有积分(分享他人主页)</p>-->
+<!--                </div>-->
+<!--            </div>-->
+<!--            <div class="layui-col-md4">-->
+<!--                <div class="layui-form-item">-->
+<!--                    <label class="relative block">-->
+<!--                        <span class="color-green font-w7">分享一次获得多少积分(分享他人主页)</span>-->
+<!--                        <input name="share_others_integral" required placeholder="请输入积分" value="{:sysconf('share_others_integral')}" class="layui-input">-->
+<!--                    </label>-->
+<!--                    <p class="help-block">分享一次获得多少积分(分享他人主页)</p>-->
+<!--                </div>-->
+<!--            </div>-->
+<!--            <div class="layui-col-md4">-->
+<!--                <div class="layui-form-item">-->
+<!--                    <label class="relative block">-->
+<!--                        <span class="color-green font-w7">分享他人主页标题</span>-->
+<!--                        <input name="share_others_title" required placeholder="请输入标题" value="{:sysconf('share_others_title')}" class="layui-input">-->
+<!--                    </label>-->
+<!--                    <p class="help-block">分享他人主页标题</p>-->
+<!--                </div>-->
+<!--            </div>-->
+<!--        </div>-->
 
         <div class="layui-col-md12">
             <div class="layui-col-md3">
@@ -271,18 +271,18 @@
         </div>
 
         <div class="layui-col-md12">
-            <div class="layui-col-md3">
-                <div class="layui-form-item">
-                    <label class="relative block">
-                        <span class="color-green font-w7">积分获取联系方式开关</span>
-                        <br/>
-                        <input type="radio" name="integral_get_contact_switch" value="1" lay-ignore> 开
-                        <input type="radio" name="integral_get_contact_switch" value="0" lay-ignore> 关
-
-                    </label>
-                    <p class="help-block">积分获取联系方式开关</p>
-                </div>
-            </div>
+<!--            <div class="layui-col-md3">-->
+<!--                <div class="layui-form-item">-->
+<!--                    <label class="relative block">-->
+<!--                        <span class="color-green font-w7">积分获取联系方式开关</span>-->
+<!--                        <br/>-->
+<!--                        <input type="radio" name="integral_get_contact_switch" value="1" lay-ignore> 开-->
+<!--                        <input type="radio" name="integral_get_contact_switch" value="0" lay-ignore> 关-->
+
+<!--                    </label>-->
+<!--                    <p class="help-block">积分获取联系方式开关</p>-->
+<!--                </div>-->
+<!--            </div>-->
             <div class="layui-col-md3">
                 <div class="layui-form-item">
                     <label class="relative block">
@@ -363,13 +363,13 @@
             <p class="help-block">用户每周的收藏卡数量</p>
         </div>
 
-        <div class="layui-form-item">
-            <label class="relative block">
-                <span class="color-green font-w7">想认识拒绝返积分百分比 notAgreeReturnIntegral</span>
-                <input name="notAgreeReturnIntegral" required placeholder="请输入想认识拒绝返积分百分比" value="{:sysconf('notAgreeReturnIntegral')}" class="layui-input">
-            </label>
-            <p class="help-block">想认识拒绝返积分百分比  %</p>
-        </div>
+<!--        <div class="layui-form-item">-->
+<!--            <label class="relative block">-->
+<!--                <span class="color-green font-w7">想认识拒绝返积分百分比 notAgreeReturnIntegral</span>-->
+<!--                <input name="notAgreeReturnIntegral" required placeholder="请输入想认识拒绝返积分百分比" value="{:sysconf('notAgreeReturnIntegral')}" class="layui-input">-->
+<!--            </label>-->
+<!--            <p class="help-block">想认识拒绝返积分百分比  %</p>-->
+<!--        </div>-->
 
         <div class="layui-form-item">
             <label class="relative block">
@@ -379,13 +379,13 @@
             <p class="help-block">动态、评论举报内容,以英文逗号隔开</p>
         </div>
 
-        <div class="layui-form-item">
-            <label class="relative block">
-                <span class="color-green font-w7">拒绝申请理由 Reasons Inadequacy</span>
-                <input name="reasons_inadequacy" required placeholder="请输入拒绝申请理由" value="{:sysconf('reasons_inadequacy')}" class="layui-input">
-            </label>
-            <p class="help-block">拒绝申请理由,以英文逗号隔开</p>
-        </div>
+<!--        <div class="layui-form-item">-->
+<!--            <label class="relative block">-->
+<!--                <span class="color-green font-w7">拒绝申请理由 Reasons Inadequacy</span>-->
+<!--                <input name="reasons_inadequacy" required placeholder="请输入拒绝申请理由" value="{:sysconf('reasons_inadequacy')}" class="layui-input">-->
+<!--            </label>-->
+<!--            <p class="help-block">拒绝申请理由,以英文逗号隔开</p>-->
+<!--        </div>-->
 
         <div class="layui-form-item">
             <label class="relative block">
@@ -395,30 +395,67 @@
             <p class="help-block">举报用户类型,以英文逗号隔开</p>
         </div>
 
+<!--        <div class="layui-form-item">-->
+<!--            <label class="relative block">-->
+<!--                <span class="color-green font-w7">打招呼语句 Greet</span>-->
+<!--                <input name="greet" required placeholder="请输入打招呼语句" value="{:sysconf('greet')}" class="layui-input">-->
+<!--            </label>-->
+<!--            <p class="help-block">聊天打招呼语句</p>-->
+<!--        </div>-->
+
+<!--        <div class="layui-form-item">-->
+<!--            <label class="relative block">-->
+<!--                <span class="color-green font-w7">聊兴趣语句 Chatting</span>-->
+<!--                <input name="chatting" required placeholder="请输入聊兴趣语句" value="{:sysconf('chatting')}" class="layui-input">-->
+<!--            </label>-->
+<!--            <p class="help-block">聊天聊兴趣语句</p>-->
+<!--        </div>-->
+
+<!--        <div class="layui-form-item">-->
+<!--            <label class="relative block">-->
+<!--                <span class="color-green font-w7">聊过往语句 Talk Past</span>-->
+<!--                <input name="talk_past" required placeholder="请输入聊兴趣语句" value="{:sysconf('talk_past')}" class="layui-input">-->
+<!--            </label>-->
+<!--            <p class="help-block">聊天聊过往语句</p>-->
+<!--        </div>-->
+
+<!--        <div class="layui-form-item">-->
+<!--            <label class="relative block">-->
+<!--                <span class="color-green font-w7">付费查看需付多少钱 pay_check_money</span>-->
+<!--                <input name="pay_check_money" required placeholder="请输入付费查看需付多少钱" value="{:sysconf('pay_check_money')}" class="layui-input">-->
+<!--            </label>-->
+<!--            <p class="help-block">付费查看需付多少钱</p>-->
+<!--        </div>-->
+
         <div class="layui-form-item">
             <label class="relative block">
-                <span class="color-green font-w7">打招呼语句 Greet</span>
-                <input name="greet" required placeholder="请输入打招呼语句" value="{:sysconf('greet')}" class="layui-input">
+                <span class="color-green font-w7">被查看用户获得多少百分比 get_check_money</span>
+                <input name="get_check_money" required placeholder="请输入被查看用户获得多少钱百分比" value="{:sysconf('get_check_money')}" class="layui-input">
             </label>
-            <p class="help-block">聊天打招呼语句</p>
+            <p class="help-block">被查看用户获得多少  百分比%</p>
         </div>
 
         <div class="layui-form-item">
             <label class="relative block">
-                <span class="color-green font-w7">聊兴趣语句 Chatting</span>
-                <input name="chatting" required placeholder="请输入聊兴趣语句" value="{:sysconf('chatting')}" class="layui-input">
+                <span class="color-green font-w7">提现服务费百分比 PoundageProportion</span>
+                <input name="poundage_proportion" required placeholder="请输入提现服务费百分比" value="{:sysconf('poundage_proportion')}" class="layui-input">
             </label>
-            <p class="help-block">聊天聊兴趣语句</p>
+            <p class="help-block">提现服务费百分比</p>
         </div>
-
         <div class="layui-form-item">
             <label class="relative block">
-                <span class="color-green font-w7">聊过往语句 Talk Past</span>
-                <input name="talk_past" required placeholder="请输入聊兴趣语句" value="{:sysconf('talk_past')}" class="layui-input">
+                <span class="color-green font-w7">提现最小金额 WithdrawMinPrice</span>
+                <input name="withdraw_min_price" required placeholder="请输入提现最小金额" value="{:sysconf('withdraw_min_price')}" class="layui-input">
             </label>
-            <p class="help-block">聊天聊过往语句</p>
+            <p class="help-block">提现最小金额</p>
+        </div>
+        <div class="layui-form-item">
+            <label class="relative block">
+                <span class="color-green font-w7">提现最大金额 WithdrawMaxPrice</span>
+                <input name="withdraw_max_price" required placeholder="请输入提现最大金额" value="{:sysconf('withdraw_max_price')}" class="layui-input">
+            </label>
+            <p class="help-block">提现最大金额</p>
         </div>
-
 
         <div class="layui-form-item">
             <span class="color-green label-required-prev">微信客服回复图片</span>
@@ -426,7 +463,6 @@
                 <td width="90px" required class="text-left"><input required name="bot_img" type="hidden" value="{:sysconf('bot_img')}"></td>
                 <script>$('[name="bot_img"]').uploadOneImage()</script>
             </table>
-
         </div>
 
 

+ 59 - 2
application/api/controller/Index.php

@@ -3,6 +3,8 @@
 
 namespace app\api\controller;
 
+use app\common\model\Article;
+use app\common\model\Banner;
 use app\common\model\Config;
 use app\common\model\ElectPool;
 use app\common\model\SearchHistory;
@@ -350,6 +352,25 @@ class Index extends Api
         }
     }
 
+
+
+
+
+    //付费查看提交
+    public function pay_check(){
+        $this->check_login();
+        $user_id = intval(input('user_id')); //用户ID
+        if (!$user_id) $this->error('用户ID为空!');
+        $result = ElectPool::payCheck($user_id);
+        if ($result['code']){
+            $this->success($result['msg'],$result['data']);
+        }else{
+            $this->error($result['msg']);
+        }
+    }
+
+
+
     /**
      * @title 不合适
      * @desc 不合适
@@ -397,8 +418,6 @@ class Index extends Api
 
 
 
-
-
     /**
      * 积分获取联系方式
      */
@@ -496,6 +515,44 @@ class Index extends Api
         }
     }
 
+    /**
+     * @title banner列表
+     * @desc banner列表
+     * @url /api/Index/banner_list
+     * @method POST
+     * @tag 基础
+     * @header
+     */
+    public function banner_list(){
+        $result = Banner::BannerList();
+        if ($result['code']){
+            $this->success($result['msg'],$result['data']);
+        }else{
+            $this->error($result['msg']);
+        }
+    }
+
+
+    /**
+     * @title 文章列表
+     * @desc 文章列表
+     * @url /api/Index/article_list
+     * @method POST
+     * @tag 基础
+     * @header
+     */
+    public function article_list(){
+        $result = Article::articleList();
+        if ($result['code']){
+            $this->success($result['msg'],$result['data']);
+        }else{
+            $this->error($result['msg']);
+        }
+    }
+
+
+
+
 
     /**
      * 特权过期脚本

+ 67 - 0
application/api/controller/Pay.php

@@ -0,0 +1,67 @@
+<?php
+
+namespace app\api\controller;
+
+use app\common\controller\Api;
+use app\common\library\AopClient;
+use app\common\model\Config;
+use app\common\model\User;
+use think\Db;
+use think\Request;
+
+/**
+ * 支付成功回调
+ */
+class Pay extends Api
+{
+    /**
+     * 微信支付--付费查看提交回调
+     */
+    public function pay_check_order(){
+        $payXml = file_get_contents("php://input");
+        //将xml格式转化为json格式
+        $jsonXml = json_encode(simplexml_load_string($payXml, 'SimpleXMLElement', LIBXML_NOCDATA));
+        //将json格式转成数组格式 $result['out_trade_no']
+        $result = json_decode($jsonXml, true);
+        if ($result['return_code'] == 'SUCCESS' && $result['result_code'] == 'SUCCESS') {
+            $order = Db::name('UserRecharge')->where('paid',0)->where('order_no',$result['out_trade_no'])->find();
+            if ($order){
+                Db::startTrans();
+                try {
+                    $da['pay_time'] = time();
+                    $da['paid'] = 1;
+                    $da['return_success_info'] = json_encode($result,true);
+                    Db::name('UserRecharge')->where('id',$order['id'])->update($da);
+                    User::integral($order['price'],$order['user_id'],'微信充值积分',1);
+                    $arr = array(
+                        'return_code' => 'SUCCESS',
+                        'return_msg'  => 'OK',
+                    );
+                    return $this->arrayToXml($arr);
+                }catch (Exception $e) {
+                    Db::rollback();
+                    file_put_contents("order_pay_error.txt", file_get_contents("php://input") . "\n" . json_encode($result) . "\n" . "\n", FILE_APPEND);
+                }
+            }
+        }
+    }
+
+
+    /**
+     * 数组转xml
+     * @ApiInternal
+     */
+    public function arrayToXml($arr)
+    {
+        $xml = "<xml>";
+        foreach ($arr as $key => $val) {
+            if (is_numeric($val)) {
+                $xml .= "<" . $key . ">" . $val . "</" . $key . ">";
+            } else
+                $xml .= "<" . $key . "><![CDATA[" . $val . "]]></" . $key . ">";
+        }
+        $xml .= "</xml>";
+        return $xml;
+    }
+
+}

+ 51 - 0
application/api/controller/User.php

@@ -469,6 +469,57 @@ class User extends Api
     }
 
 
+    /**
+     * @title 充值积分
+     * @desc 充值积分
+     * @url /api/User/user_recharge
+     * @method POST
+     * @tag 基础
+     * @header
+     *
+     * @param  name:integral type:int require:1 desc:充值积分数
+     */
+    public function user_recharge(){
+        $this->check_login();
+        $integral = input('integral');      //充值积分数
+        if (!$integral || $integral<=0) $this->error('积分数错误');
+        if ((floor($integral) - $integral) !==0){
+            $this->error('积分格式错误');
+        }
+        $result = Users::userRecharge($integral);
+        if ($result['code']){
+            $this->success($result['msg'],$result['data']);
+        }else{
+            $this->error($result['msg']);
+        }
+    }
+
+
+    /**
+     * @title 余额提现
+     * @desc 余额提现
+     * @url /api/User/user_withdraw
+     * @method POST
+     * @tag 基础
+     * @header
+     * @param  name:money type:int require:1 desc:提现金额
+     *
+     */
+    public function user_withdraw(){
+        $this->check_login();
+        $integral = input('integral');      //提现金额
+        if (!$integral || $integral<=0) $this->error('积分错误');
+        if ((floor($integral) - $integral) !==0){
+            $this->error('积分格式错误');
+        }
+        $result = Users::userWithdraw($integral);
+        if ($result['code']){
+            $this->success($result['msg']);
+        }else{
+            $this->error($result['msg']);
+        }
+    }
+
 
     /**
      * 退出登录

+ 0 - 29
application/common/library/Common.php

@@ -475,35 +475,6 @@ class Common
         return $Result['data'];
     }
 
-
-    /**
-     * 添加好友
-     */
-    static function add_friend($owner_username,$friend_username){
-        $param = array ();
-        $header = array(
-            'Authorization: Bearer '.self::getToken()
-        );
-        $url = "https://a1.easemob.com/1101210401193729/demo/users/".$owner_username."/contacts/users/".$friend_username;
-        $res = self::huanxin_curl_request($url,$param,$header,'POST');
-        $Result =  json_decode($res, true);
-    }
-
-
-    /**
-     * 移除好友
-     */
-    static function del_friend($owner_username,$friend_username){
-        $param = array ();
-        $header = array(
-            'Authorization: Bearer '.self::getToken()
-        );
-        $url = "https://a1.easemob.com/1101210401193729/demo/users/".$owner_username."/contacts/users/".$friend_username;
-        $res = self::huanxin_curl_request($url,$param,$header,'DELETE');
-        $Result =  json_decode($res, true);
-    }
-
-
     static function huanxin_curl_request($url, $body, $header = array(), $method = "POST") {
         array_push ( $header, 'Accept:application/json' );
         array_push ( $header, 'Content-Type:application/json' );

+ 189 - 0
application/common/library/WxMerchPay.php

@@ -0,0 +1,189 @@
+<?php
+namespace app\common\library;
+
+use think\Controller;
+use app\common\model\Config;
+
+class WxMerchPay extends Controller
+{
+    //企业付款到微信零钱,PHP接口调用方法
+    /*
+      配置参数
+      */
+    /*
+  配置参数
+  */
+    public function __construct()
+    {
+        $this->appid = Config::get_values('wechat_appid');
+        $this->api_key = Config::get_values('wechat_mch_key');
+        $this->mch_id = Config::get_values('wechat_mch_id');
+    }
+//    private $config = array(
+//        'appid' => "wx57f0ba125c0f9351" ,//"wxcf1dded808489e2c",    /*微信开放平台上的应用id*/
+//        'mch_id' => "1526848461",//"1440493402",   /*微信申请成功之后邮件中的商户id*/
+//        'api_key' => "quanminchuangquanminchuang123521"    /*在微信商户平台上自己设定的api密钥 32位*/
+//    );
+
+
+    /**
+     * [xmltoarray xml格式转换为数组]
+     * @param [type] $xml [xml]
+     * @return [type]  [xml 转化为array]
+     */
+    function xmltoarray($xml) {
+        //禁止引用外部xml实体
+        libxml_disable_entity_loader(true);
+        $xmlstring = simplexml_load_string($xml, 'SimpleXMLElement', LIBXML_NOCDATA);
+        $val = json_decode(json_encode($xmlstring),true);
+        return $val;
+    }
+
+    /**
+     * [arraytoxml 将数组转换成xml格式(简单方法):]
+     * @param [type] $data [数组]
+     * @return [type]  [array 转 xml]
+     */
+    function arraytoxml($data){
+        $str='<xml>';
+        foreach($data as $k=>$v) {
+            $str.='<'.$k.'>'.$v.'</'.$k.'>';
+        }
+        $str.='</xml>';
+        return $str;
+    }
+
+    /**
+     * [createNoncestr 生成随机字符串]
+     * @param integer $length [长度]
+     * @return [type]   [字母大小写加数字]
+     */
+    function createNoncestr($length =32){
+        $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYabcdefghijklmnopqrstuvwxyz0123456789";
+        $str ="";
+
+        for($i=0;$i<$length;$i++){
+            $str.= substr($chars, mt_rand(0, strlen($chars)-1), 1);
+        }
+        return $str;
+    }
+
+    /**
+     * [curl_post_ssl 发送curl_post数据]
+     * @param [type] $url  [发送地址]
+     * @param [type] $xmldata [发送文件格式]
+     * @param [type] $second [设置执行最长秒数]
+     * @param [type] $aHeader [设置头部]
+     * @return [type]   [description]
+     */
+    function curl_post_ssl($url, $xmldata, $second = 30, $aHeader = array()){
+        $isdir = dirname(__DIR__) . "/wxcert/";//证书位置;绝对路径
+        $ch = curl_init();//初始化curl
+        curl_setopt($ch, CURLOPT_TIMEOUT, $second);//设置执行最长秒数
+        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);//要求结果为字符串且输出到屏幕上
+        curl_setopt($ch, CURLOPT_URL, $url);//抓取指定网页
+        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);// 终止从服务端进行验证
+        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);//
+        curl_setopt($ch, CURLOPT_SSLCERTTYPE, 'PEM');//证书类型
+        curl_setopt($ch, CURLOPT_SSLCERT, $isdir . 'apiclient_cert.pem');//证书位置
+        curl_setopt($ch, CURLOPT_SSLKEYTYPE, 'PEM');//CURLOPT_SSLKEY中规定的私钥的加密类型
+        curl_setopt($ch, CURLOPT_SSLKEY, $isdir . 'apiclient_key.pem');//证书位置
+        curl_setopt($ch, CURLOPT_CAINFO, 'PEM');
+        curl_setopt($ch, CURLOPT_CAINFO, $isdir . 'rootca.pem');
+        if (count($aHeader) >= 1) {
+            curl_setopt($ch, CURLOPT_HTTPHEADER, $aHeader);//设置头部
+        }
+        curl_setopt($ch, CURLOPT_POST, 1);//post提交方式
+        curl_setopt($ch, CURLOPT_POSTFIELDS, $xmldata);//全部数据使用HTTP协议中的"POST"操作来发送
+
+        $data = curl_exec($ch);//执行回话
+        if ($data) {
+            curl_close($ch);
+            return $data;
+        } else {
+            $error = curl_errno($ch);
+            echo "call faild, errorCode:$error\n";
+            curl_close($ch);
+            return false;
+        }
+    }
+
+
+    /**
+     * [sendMoney 企业付款到零钱]
+     * @param [type] $amount  [发送的金额(分)目前发送金额不能少于1元]
+     * @param [type] $re_openid [发送人的 openid]
+     * @param string $desc  [企业付款描述信息 (必填)]
+     * @param string $check_name [收款用户姓名 (选填)]
+     * @return [type]    [description]
+     */
+    function sendMoney($amount,$re_openid,$partner_trade_no,$desc='测试',$check_name=''){
+
+        $total_amount = (100) * $amount;
+        $data=array(
+            'mch_appid'=> $this->appid,//商户账号appid
+            'mchid'=>  $this->mch_id,//商户号
+            'nonce_str'=>$this->createNoncestr(),//随机字符串
+            'partner_trade_no'=> $partner_trade_no,//商户订单号
+            'openid'=> $re_openid,//用户openid
+            'check_name'=>'NO_CHECK',//校验用户姓名选项,
+            're_user_name'=> $check_name,//收款用户姓名
+            'amount'=>$total_amount,//金额
+            'desc'=> $desc,//企业付款描述信息
+            'spbill_create_ip'=> request()->ip(),//Ip地址
+        );
+
+        //生成签名算法
+        $secrect_key=$this->api_key;///这个就是个API密码。MD5 32位。
+        $data=array_filter($data);
+        ksort($data);
+        $str='';
+        foreach($data as $k=>$v) {
+            $str.=$k.'='.$v.'&';
+        }
+        $str.='key='.$secrect_key;
+        $data['sign']=md5($str);
+        //生成签名算法
+
+        $xml=$this->arraytoxml($data);
+
+        $url='https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers'; //调用接口
+        $res=$this->curl_post_ssl($url,$xml);
+        $return=$this->xmltoarray($res);
+
+        return $return;
+
+//        print_r($return);
+//        die;
+        //返回来的结果是xml,最后转换成数组
+        /*
+        array(9) {
+         ["return_code"]=>
+         string(7) "SUCCESS"
+         ["return_msg"]=>
+         array(0) {
+         }
+         ["mch_appid"]=>
+         string(18) "wx57676786465544b2a5"
+         ["mchid"]=>
+         string(10) "143345612"
+         ["nonce_str"]=>
+         string(32) "iw6TtHdOySMAfS81qcnqXojwUMn8l8mY"
+         ["result_code"]=>
+         string(7) "SUCCESS"
+         ["partner_trade_no"]=>
+         string(18) "201807011410504098"
+         ["payment_no"]=>
+         string(28) "1000018301201807019357038738"
+         ["payment_time"]=>
+         string(19) "2018-07-01 14:56:35"
+        }
+        */
+
+
+//        $responseObj = simplexml_load_string($res, 'SimpleXMLElement', LIBXML_NOCDATA);
+       // echo $res= $responseObj->return_code; //SUCCESS 如果返回来SUCCESS,则发生成功,处理自己的逻辑
+      //  return $responseObj;
+    }
+
+}

+ 391 - 0
application/common/library/WxPay.php

@@ -0,0 +1,391 @@
+<?php
+namespace app\common\library;
+
+use app\common\model\Config;
+use think\Controller;
+use think\Facade;
+use EasyWeChat\Factory;
+
+class WxPay extends Controller
+{
+    /*
+   配置参数
+   */
+    public function __construct()
+    {
+       // $this->appid = Config::get_values('small_wechat_id');
+        $this->appid = Config::get_values('wechat_appid');
+        $this->api_key = Config::get_values('wechat_mch_key');
+        $this->mch_id = Config::get_values('wechat_mch_id');
+
+    }
+//    private $config = array(
+//        'appid' => "wx57f0ba125c0f9351" ,//"wxcf1dded808489e2c",    /*微信开放平台上的应用id*/
+//        'mch_id' => "1526848461",//"1440493402",   /*微信申请成功之后邮件中的商户id*/
+//        'api_key' => "quanminchuangquanminchuang123521"    /*在微信商户平台上自己设定的api密钥 32位*/
+//    );
+
+    public function retrunconfig(){
+        $config = [
+            'app_id' => Config::get_values('small_wechat_id'),
+            'mch_id' =>Config::get_values('wechat_mch_id'),
+            'key' =>Config::get_values('wechat_mch_key')
+        ];
+        return $config;
+    }
+
+    public function retrunconfig2(){
+        $config = [
+            'app_id' => Config::get_values('wechat_appid'),
+            'mch_id' =>Config::get_values('wechat_mch_id'),
+            'key' =>Config::get_values('wechat_mch_key')
+        ];
+        return $config;
+    }
+
+    //获取预支付订单
+    public function getPrePayOrder($body, $out_trade_no, $total_fee, $notify_url,$come,$openid){
+
+        $url = "https://api.mch.weixin.qq.com/pay/unifiedorder";
+
+        $onoce_str = $this->getRandChar(32);
+
+        $data["appid"] =  $this->appid;
+        $data["body"] = $body;
+        $data["mch_id"] = $this->mch_id;
+        $data["nonce_str"] = $onoce_str;
+        $data["notify_url"] = $notify_url;
+        $data["out_trade_no"] = $out_trade_no;
+        $data["spbill_create_ip"] = $this->get_client_ip();
+        $data["total_fee"] = floatval($total_fee);
+        //$data["trade_type"] = $come=='weixin' ? "JSAPI" : "APP";
+        $data["trade_type"] = "APP";
+        $data['sign_type'] = "MD5";
+//        if ($come=='weixin'){
+//            $data['openid'] = $openid;
+//        }
+        $s = $this->getSign($data);
+
+        $data["sign"] = $s;
+
+        $xml = $this->arrayToXml($data);
+
+        $response = $this->postXmlCurl($xml, $url);
+
+        //将微信返回的结果xml转成数组
+       //return $this->xmlstr_to_array($response);
+        return $this->xmlToArray($response);
+    }
+
+
+    public function wxrefund($out_trade_no,$out_refund_no,$total_fee,$refund_fee)
+    {
+        $param = array(
+            'appid'=> $this->appid,
+            'mch_id'=> $this->mch_id,
+            'nonce_str'=>  $this->getRandChar(32),
+            'out_trade_no'=>$out_trade_no,
+            'out_refund_no'=>$out_refund_no,//订单号
+          //  'transaction_id'=> $transactionId,//微信订单号
+            'total_fee'=> $total_fee*100,
+            'refund_fee'=>$refund_fee*100
+        );
+
+        $param['sign'] = $this->getSign($param);
+        $xmldata = $this->arrayToXml($param);
+        $xmlresult = $this->postXmlSSLCurl($xmldata,'https://api.mch.weixin.qq.com/secapi/pay/refund');
+        $result = $this->xmlToArray($xmlresult);
+        return $result;
+    }
+
+
+    //执行第二次签名,才能返回给客户端使用
+    public function getOrder($prepayId){
+        $data["appid"] = $this->appid;
+        $data["noncestr"] = $this->getRandChar(32);
+        $data["package"] = "Sign=WXPay";
+       // $data['package'] = "prepay_id=".$prepayId;
+        $data["partnerid"] = $this->mch_id;
+        $data["prepayid"] = $prepayId;
+        $data["signType"] = "MD5";
+        $data["timestamp"] = '' . time() . '';
+        $s = $this->getSign($data, false);
+        $data["sign"] = $s;
+
+        return $data;
+    }
+
+    /*
+        生成签名
+    */
+    function getSign($Obj)
+    {
+        foreach ($Obj as $k => $v)
+        {
+            $Parameters[strtolower($k)] = $v;
+        }
+        //签名步骤一:按字典序排序参数
+        ksort($Parameters);
+        $String = $this->formatBizQueryParaMap($Parameters, false);
+        //echo "【string】 =".$String."</br>";
+        //签名步骤二:在string后加入KEY
+        $String = $String."&key=".$this->api_key;
+//        echo "<textarea style='width: 50%; height: 150px;'>$String</textarea> <br />";
+        //签名步骤三:MD5加密
+        $result_ = strtoupper(md5($String));
+        return $result_;
+    }
+
+
+
+
+    //获取指定长度的随机字符串
+    function getRandChar($length){
+        $str = null;
+        $strPol = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz";
+        $max = strlen($strPol)-1;
+
+        for($i=0;$i<$length;$i++){
+            $str.=$strPol[rand(0,$max)];//rand($min,$max)生成介于min和max两个数之间的一个随机整数
+        }
+
+        return $str;
+    }
+
+    //数组转xml
+    function arrayToXml($arr)
+    {
+        $xml = "<xml>";
+        foreach ($arr as $key=>$val)
+        {
+
+            if (is_numeric($val))
+            {
+                $xml.="<".$key.">".$val."</".$key.">";
+
+            }
+            else
+                $xml.="<".$key."><![CDATA[".$val."]]></".$key.">";
+        }
+        $xml.="</xml>";
+        return $xml;
+    }
+
+    //post https请求,CURLOPT_POSTFIELDS xml格式
+    function postXmlCurl($xml,$url,$second=30)
+    {
+        //初始化curl
+        $ch = curl_init();
+        //超时时间
+        curl_setopt($ch,CURLOPT_TIMEOUT,$second);
+        //这里设置代理,如果有的话
+        //curl_setopt($ch,CURLOPT_PROXY, '8.8.8.8');
+        //curl_setopt($ch,CURLOPT_PROXYPORT, 8080);
+        curl_setopt($ch,CURLOPT_URL, $url);
+        curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,FALSE);
+        curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,FALSE);
+        //设置header
+        curl_setopt($ch, CURLOPT_HEADER, FALSE);
+        //要求结果为字符串且输出到屏幕上
+        curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
+        //post提交方式
+        curl_setopt($ch, CURLOPT_POST, TRUE);
+        curl_setopt($ch, CURLOPT_POSTFIELDS, $xml);
+        //运行curl
+        $data = curl_exec($ch);
+        //返回结果
+        if($data)
+        {
+            curl_close($ch);
+            return $data;
+        }
+        else
+        {
+            $error = curl_errno($ch);
+            echo "curl出错,错误码:$error"."<br>";
+            echo "<a href='http://curl.haxx.se/libcurl/c/libcurl-errors.html'>错误原因查询</a></br>";
+            curl_close($ch);
+            return false;
+        }
+    }
+
+
+
+   //需要使用证书的请求
+    private function postXmlSSLCurl($xml,$url,$second=30)
+    {
+        $ch = curl_init();
+        //超时时间
+        curl_setopt($ch,CURLOPT_TIMEOUT,$second);
+        //这里设置代理,如果有的话
+        //curl_setopt($ch,CURLOPT_PROXY, '8.8.8.8');
+        //curl_setopt($ch,CURLOPT_PROXYPORT, 8080);
+        curl_setopt($ch,CURLOPT_URL, $url);
+        curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,FALSE);
+        curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,FALSE);
+        //设置header
+        curl_setopt($ch,CURLOPT_HEADER,FALSE);
+        //要求结果为字符串且输出到屏幕上
+        curl_setopt($ch,CURLOPT_RETURNTRANSFER,TRUE);
+        //设置证书
+        //使用证书:cert 与 key 分别属于两个.pem文件
+        //默认格式为PEM,可以注释
+        curl_setopt($ch,CURLOPT_SSLCERTTYPE,'PEM');
+        curl_setopt($ch,CURLOPT_SSLCERT, dirname(__DIR__) . '/wxcert/apiclient_cert.pem');
+        //默认格式为PEM,可以注释
+        curl_setopt($ch,CURLOPT_SSLKEYTYPE,'PEM');
+        curl_setopt($ch,CURLOPT_SSLKEY, dirname(__DIR__) . '/wxcert/apiclient_key.pem');
+        //post提交方式
+        curl_setopt($ch,CURLOPT_POST, true);
+        curl_setopt($ch,CURLOPT_POSTFIELDS,$xml);
+        $data = curl_exec($ch);
+        //返回结果
+        if($data){
+            curl_close($ch);
+            return $data;
+        }
+        else {
+            $error = curl_errno($ch);
+            echo "curl出错,错误码:$error"."<br>";
+            curl_close($ch);
+            return false;
+        }
+    }
+    /*
+        获取当前服务器的IP
+    */
+    function get_client_ip()
+    {
+        if ($_SERVER['REMOTE_ADDR']) {
+            $cip = $_SERVER['REMOTE_ADDR'];
+        } elseif (getenv("REMOTE_ADDR")) {
+            $cip = getenv("REMOTE_ADDR");
+        } elseif (getenv("HTTP_CLIENT_IP")) {
+            $cip = getenv("HTTP_CLIENT_IP");
+        } else {
+            $cip = "unknown";
+        }
+        return $cip;
+    }
+
+    //将数组转成uri字符串
+    function formatBizQueryParaMap($paraMap, $urlencode)
+    {
+        $buff = "";
+        ksort($paraMap);
+        foreach ($paraMap as $k => $v)
+        {
+            if($urlencode)
+            {
+                $v = urlencode($v);
+            }
+            $buff .= strtolower($k) . "=" . $v . "&";
+        }
+        $reqPar;
+        if (strlen($buff) > 0)
+        {
+            $reqPar = substr($buff, 0, strlen($buff)-1);
+        }
+        return $reqPar;
+    }
+
+    /**
+    xml转成数组
+     */
+//    function xmlstr_to_array($xmlstr) {
+//        $doc = new DOMDocument();
+//        $doc->loadXML($xmlstr);
+//        return $this->domnode_to_array($doc->documentElement);
+//    }
+    function domnode_to_array($node) {
+        $output = array();
+        switch ($node->nodeType) {
+            case XML_CDATA_SECTION_NODE:
+            case XML_TEXT_NODE:
+                $output = trim($node->textContent);
+                break;
+            case XML_ELEMENT_NODE:
+                for ($i=0, $m=$node->childNodes->length; $i<$m; $i++) {
+                    $child = $node->childNodes->item($i);
+                    $v = $this->domnode_to_array($child);
+                    if(isset($child->tagName)) {
+                        $t = $child->tagName;
+                        if(!isset($output[$t])) {
+                            $output[$t] = array();
+                        }
+                        $output[$t][] = $v;
+                    }
+                    elseif($v) {
+                        $output = (string) $v;
+                    }
+                }
+                if(is_array($output)) {
+                    if($node->attributes->length) {
+                        $a = array();
+                        foreach($node->attributes as $attrName => $attrNode) {
+                            $a[$attrName] = (string) $attrNode->value;
+                        }
+                        $output['@attributes'] = $a;
+                    }
+                    foreach ($output as $t => $v) {
+                        if(is_array($v) && count($v)==1 && $t!='@attributes') {
+                            $output[$t] = $v[0];
+                        }
+                    }
+                }
+                break;
+        }
+        return $output;
+    }
+//    public function xmltoarray( $xml )
+//    {
+//        $arr = $this->xml_to_array($xml);
+//        $key = array_keys($arr);
+//        return $arr[$key[0]];
+//    }
+
+    /**
+     * 	作用:将xml转为array
+     */
+    public function xmlToArray($xml)
+    {
+        //将XML转为array
+        $array_data = json_decode(json_encode(simplexml_load_string($xml, 'SimpleXMLElement', LIBXML_NOCDATA)), true);
+        return $array_data;
+    }
+
+
+    public function xml_to_array( $xml )
+    {
+        $reg = "/<(\\w+)[^>]*?>([\\x00-\\xFF]*?)<\\/\\1>/";
+        if(preg_match_all($reg, $xml, $matches))
+        {
+            $count = count($matches[0]);
+            $arr = array();
+            for($i = 0; $i < $count; $i++)
+            {
+                $key = $matches[1][$i];
+                $val = $this->xml_to_array( $matches[2][$i] );  // 递归
+                if(array_key_exists($key, $arr))
+                {
+                    if(is_array($arr[$key]))
+                    {
+                        if(!array_key_exists(0,$arr[$key]))
+                        {
+                            $arr[$key] = array($arr[$key]);
+                        }
+                    }else{
+                        $arr[$key] = array($arr[$key]);
+                    }
+                    $arr[$key][] = $val;
+                }else{
+                    $arr[$key] = $val;
+                }
+            }
+            return $arr;
+        }else{
+            return $xml;
+        }
+    }
+
+}

+ 38 - 0
application/common/model/Article.php

@@ -0,0 +1,38 @@
+<?php
+
+namespace app\common\model;
+
+use app\common\model\Sms;
+use app\common\library\Email;
+use phpDocumentor\Reflection\Type;
+use think\Model;
+use app\common\library\Common;
+use think\facade\Validate;
+use think\Request;
+use think\Db;
+
+/**
+ * 文章列表
+ */
+class Article Extends Model
+{
+    // 开启自动写入时间戳字段
+    protected $autoWriteTimestamp = 'TIMESTAMP';
+    // 定义时间戳字段名
+    protected $createTime = 'create_at';
+    protected $updateTime = false;
+
+
+    /**
+     * 文章列表
+     */
+    public static function articleList(){
+        $list = self::where('is_del',1)
+            ->where('is_show',1)
+            ->order('sort desc')
+            ->select();
+        return Common::return_success('成功',$list);
+    }
+
+
+}

+ 38 - 0
application/common/model/Banner.php

@@ -0,0 +1,38 @@
+<?php
+
+namespace app\common\model;
+
+use app\common\model\Sms;
+use app\common\library\Email;
+use phpDocumentor\Reflection\Type;
+use think\Model;
+use app\common\library\Common;
+use think\facade\Validate;
+use think\Request;
+use think\Db;
+
+/**
+ * banner
+ */
+class Banner Extends Model
+{
+    // 开启自动写入时间戳字段
+    protected $autoWriteTimestamp = 'TIMESTAMP';
+    // 定义时间戳字段名
+    protected $createTime = 'create_at';
+    protected $updateTime = false;
+
+
+    /**
+     * banner
+     */
+    public static function BannerList(){
+        $list = self::where('is_del',1)
+            ->where('is_show',1)
+            ->order('sort desc')
+            ->select();
+        return Common::return_success('成功',$list);
+    }
+
+
+}

+ 153 - 160
application/common/model/ElectPool.php

@@ -1,6 +1,8 @@
 <?php
 
 namespace app\common\model;
+use app\common\library\WxPay;
+use EasyWeChat\Factory;
 use think\Model;
 use app\common\library\Common;
 use think\Db;
@@ -482,7 +484,7 @@ class ElectPool Extends Model
             $touser['wechat_id'] = "";
             $touser['is_collection'] = false;
             $touser['is_shielding'] = false;
-            $touser['apply_state'] = 0;
+            $touser['apply_state'] = false;
             $touser['star_switch'] = false;
             $touser['star'] = false;
         }else{
@@ -507,27 +509,11 @@ class ElectPool Extends Model
             $touser['is_shielding'] = $info > 0 ? true : false;
 
             //查看申请状态
-
-            $apply = UserWantKnow::where('user_id',$user['id'])->where('to_user_id',$user_id)->where('state',2)->count();
+            $apply = UserWantKnow::where('user_id',$user['id'])->where('to_user_id',$user_id)->count();
             if (!$apply){
-                $apply = UserWantKnow::where('user_id',$user_id)->where('to_user_id',$user['id'])->where('state',2)->count();
-                if (!$apply){
-                    $apply = UserWantKnow::where('user_id',$user['id'])->where('to_user_id',$user_id)->where('state',1)->count();
-                    if (!$apply){
-                        $apply = UserWantKnow::where('user_id',$user_id)->where('to_user_id',$user['id'])->where('state',1)->count();
-                        if (!$apply){
-                            $touser['apply_state'] = 0;
-                        }else{
-                            $touser['apply_state'] = 1;
-                        }
-                    }else{
-                        $touser['apply_state'] = 1;
-                    }
-                }else{
-                    $touser['apply_state'] = 2;
-                }
+                $touser['apply_state'] = false;
             }else{
-                $touser['apply_state'] = 2;
+                $touser['apply_state'] = true;
             }
 
             //星标开关
@@ -537,6 +523,7 @@ class ElectPool Extends Model
             //是否星标好友
             $star2 = UserStar::where('user_id',$user['id'])->where('to_user_id',$user_id)->count();
             $touser['star'] = $star2 ? true : false;
+
         }
         return Common::return_success('成功',$touser);
     }
@@ -727,63 +714,51 @@ class ElectPool Extends Model
 
 
             //消息推送
-            $elect_successful_switch1 = User::where('id',$info['user_id'])->value('elect_successful_switch');
-            if ($elect_successful_switch1==2){
-                $openid = User::where('id',$info['user_id'])->value('openid');
-                $template_id = "pF9lZHPpNpt7tudXDYiIbwLk5Y5G6qmKm6mHLnQWjTU";
-                $path = "";
-                $data = [
-                    'first'=>[
-                        "value"=>'你好,您的好友申请已通过!',
-                        "color"=>"#173177"
-                    ],
-                    'keyword1'=>[
-                        "value"=>'好友申请',
-                        "color"=>"#173177"
-                    ],
-                    'keyword2'=>[
-                        "value"=>'通过',
-                        "color"=>"#173177"
-                    ],
-                    'remark'=>[
-                        "value"=>'你申请的好友申请已通过,请查看',
-                        "color"=>"#173177"
-                    ]
-                ];
-                Common::sendTemplateMsg($openid,$template_id,$path,$data);
-            }
-
-
-            $elect_successful_switch = User::where('id',$info['to_user_id'])->value('elect_successful_switch');
-            if ($elect_successful_switch==2){
-                $openid2 = User::where('id',$info['to_user_id'])->value('openid');
-                $template_id2 = "Sz1eunRAh_jKR0_94dZU4jJB2WuRGqG0kyzsA-WYCLk";
-                $path2 = "";
-                $data2 = [
-                    'first'=>[
-                        "value"=>'通过审核!',
-                        "color"=>"#173177"
-                    ],
-                    'keyword1'=>[
-                        "value"=>date('Y-m-d H:i'),
-                        "color"=>"#173177"
-                    ],
-                    'keyword2'=>[
-                        "value"=>User::where('id',$info['user_id'])->value('nickname'),
-                        "color"=>"#173177"
-                    ],
-                    'remark'=>[
-                        "value"=>'好友申请已通过,请查看',
-                        "color"=>"#173177"
-                    ]
-                ];
-                Common::sendTemplateMsg($openid2,$template_id2,$path2,$data2);
-            }
-
+            $openid = User::where('id',$info['user_id'])->value('openid');
+            $template_id = "pF9lZHPpNpt7tudXDYiIbwLk5Y5G6qmKm6mHLnQWjTU";
+            $path = "";
+            $data = [
+                'first'=>[
+                    "value"=>'你好,您的好友申请已通过!',
+                    "color"=>"#173177"
+                ],
+                'keyword1'=>[
+                    "value"=>'好友申请',
+                    "color"=>"#173177"
+                ],
+                'keyword2'=>[
+                    "value"=>'通过',
+                    "color"=>"#173177"
+                ],
+                'remark'=>[
+                    "value"=>'你申请的好友申请已通过,请查看',
+                    "color"=>"#173177"
+                ]
+            ];
+            Common::sendTemplateMsg($openid,$template_id,$path,$data);
 
-            //环信添加好友
-            Common::add_friend('huxuanmao-'.$info['user_id'],'huxuanmao-'.$info['to_user_id']);
-            Common::add_friend('huxuanmao-'.$info['to_user_id'],'huxuanmao-'.$info['user_id']);
+            $openid2 = User::where('id',$info['to_user_id'])->value('openid');
+            $template_id2 = "Sz1eunRAh_jKR0_94dZU4jJB2WuRGqG0kyzsA-WYCLk";
+            $path2 = "";
+            $data2 = [
+                'first'=>[
+                    "value"=>'通过审核!',
+                    "color"=>"#173177"
+                ],
+                'keyword1'=>[
+                    "value"=>date('Y-m-d H:i'),
+                    "color"=>"#173177"
+                ],
+                'keyword2'=>[
+                    "value"=>User::where('id',$info['user_id'])->value('nickname'),
+                    "color"=>"#173177"
+                ],
+                'remark'=>[
+                    "value"=>'好友申请已通过,请查看',
+                    "color"=>"#173177"
+                ]
+            ];
+            Common::sendTemplateMsg($openid2,$template_id2,$path2,$data2);
 
             Db::commit();
             return Common::return_success('成功');
@@ -940,11 +915,6 @@ class ElectPool Extends Model
                     'sort'=>6
                 ]
             );
-
-            //环信删除好友
-            Common::del_friend('huxuanmao-'.$info['user_id'],'huxuanmao-'.$info['to_user_id']);
-            Common::del_friend('huxuanmao-'.$info['to_user_id'],'huxuanmao-'.$info['user_id']);
-
             Db::commit();
             return Common::return_success('成功');
         }catch (Exception $e) {
@@ -1004,95 +974,50 @@ class ElectPool Extends Model
             return Common::return_error('积分不足');
 
         //查看我是否已经喜欢过
-        $want_know = UserWantKnow::where('user_id',$user['id'])->where('to_user_id',$user_id)->whereIn('state','1,2')->count();
-        $want_know2 = UserWantKnow::where('to_user_id',$user['id'])->where('user_id',$user_id)->whereIn('state','1,2')->count();
-        if ($want_know || $want_know2)
+        $want_know = UserWantKnow::where('user_id',$user['id'])->where('to_user_id',$user_id)->count();
+        if ($want_know)
             return Common::return_error('已经认识过');
         $data['user_id'] = $user['id'];
         $data['to_user_id'] = $user_id;
         $data['pool_id'] = $pool_id;
-        $data['leave_message'] = $leave_message;
         Db::startTrans();
         try {
-            //扣除积分(如果被拒绝过,则积分翻倍)
-            $info = UserWantKnow::where('user_id',$user['id'])->where('to_user_id',$user_id)->where('state',3)->count();
-            if ($info > 0)
-                $integral = $integral * 2;
-            User::integral($integral,$user['id'],'想认识 '.$touser['nickname']);
+            User::integral($integral,$user['id'],'想查看 '.$touser['nickname'].'资料');
             $data['integral'] = $integral;
             $knowid = UserWantKnow::create($data);
-            $knowid = json_decode($knowid,true);
-            //查看对方是否也喜欢我
-            $want_know2 = UserWantKnow::where('user_id',$user_id)->where('to_user_id',$user['id'])->count();
-            //系统消息
-            if ($want_know2){
-                Message::create_message($user_id,'您与 '. $userinfo['nickname'] .' 互选成功','互选消息',2);
-                $nickname = User::where('id',$user_id)->value('nickname');
-                Message::create_message($user['id'],'您与 '. $nickname .' 互选成功','互选消息',2);
-            }
 
-            //记录
-            UserWantKnowRecord::create(
-                [
-                    'know_id'=>$knowid['id'],
-                    'user_id'=>$user['id'],
-                    'content'=>'发出申请',
-                    'sort'=>1
-                ]
-            );
 
-            UserWantKnowRecord::create(
-                [
-                    'know_id'=>$knowid['id'],
-                    'user_id'=>$user['id'],
-                    'content'=>'等待对方查看',
-                    'sort'=>2
-                ]
-            );
-
-            UserWantKnowRecord::create(
-                [
-                    'know_id'=>$knowid['id'],
-                    'user_id'=>$user_id,
-                    'content'=>'收到申请',
-                    'sort'=>1
-                ]
-            );
-
-
-            if ($touser['want_to_know_switch']==2){
-                //消息推送
-                $openid = User::where('id',$user_id)->value('openid');
-                $template_id = "50XKLuXe12kb_niiwvQ7xd4cjXBh_y_T7Oyp_HjGWzE";
-                $path = "";
-                $data = [
-                    'first'=>[
-                        "value"=>'你好,你有一条待处理的申请,请及时处理',
-                        "color"=>"#173177"
-                    ],
-                    'keyword1'=>[
-                        "value"=>'好友申请',
-                        "color"=>"#173177"
-                    ],
-                    'keyword2'=>[
-                        "value"=>$userinfo['nickname'],
-                        "color"=>"#173177"
-                    ],
-                    'keyword3'=>[
-                        "value"=>$userinfo['nickname'].'想认识你',
-                        "color"=>"#173177"
-                    ],
-                    'keyword4'=>[
-                        "value"=>date('Y-m-d H:i'),
-                        "color"=>"#173177"
-                    ],
-                    'remark'=>[
-                        "value"=>'收到好友申请通知,请查看',
-                        "color"=>"#173177"
-                    ]
-                ];
-                Common::sendTemplateMsg($openid,$template_id,$path,$data);
-            }
+            //消息推送
+//            $openid = User::where('id',$user_id)->value('openid');
+//            $template_id = "50XKLuXe12kb_niiwvQ7xd4cjXBh_y_T7Oyp_HjGWzE";
+//            $path = "";
+//            $data = [
+//                'first'=>[
+//                    "value"=>'你好,你有一条待处理的申请,请及时处理',
+//                    "color"=>"#173177"
+//                ],
+//                'keyword1'=>[
+//                    "value"=>'好友申请',
+//                    "color"=>"#173177"
+//                ],
+//                'keyword2'=>[
+//                    "value"=>$userinfo['nickname'],
+//                    "color"=>"#173177"
+//                ],
+//                'keyword3'=>[
+//                    "value"=>$userinfo['nickname'].'想认识你',
+//                    "color"=>"#173177"
+//                ],
+//                'keyword4'=>[
+//                    "value"=>date('Y-m-d H:i'),
+//                    "color"=>"#173177"
+//                ],
+//                'remark'=>[
+//                    "value"=>'收到好友申请通知,请查看',
+//                    "color"=>"#173177"
+//                ]
+//            ];
+//            Common::sendTemplateMsg($openid,$template_id,$path,$data);
 
 
             Db::commit();
@@ -1105,6 +1030,74 @@ class ElectPool Extends Model
 
 
 
+    /**
+     * 付费查看提交
+     */
+    public static function payCheck($user_id){
+        $user = app()->session->get('us');
+        $userinfo = User::get($user['id']);
+        $touser = Db::name('User')->where('id',$user_id)->find();
+        if (!$touser)
+            return Common::return_error('用户不存在');
+
+        $info = PayCheck::where('user_id',$user['id'])->where('to_user_id',$user_id)->where('paid',1)->find();
+        if ($info)
+            return Common::return_error('已经付费查看过');
+
+        //获取支付金额
+        $pay_money = Config::get_values('pay_check_money');
+        $wx = new WxPay();//实例化微信torganizationid支付控制器
+        $notify_url = 'https://'.$_SERVER['SERVER_NAME'].'/api/pay/pay_check_order';//回调地址
+        $config = $wx->retrunconfig();
+        $config['notify_url'] = $notify_url;
+        $order_no = Common::getNewOrderId($user['id']);
+        $body = '订单号' . $order_no;//支付说明
+        $total_fee = $pay_money * 100;//支付金额(乘以100)
+        Db::startTrans();
+        try{
+
+            $data['user_id'] = $user['id'];
+            $data['to_user_id'] = $user_id;
+            $data['order_no'] = $order_no;
+            $data['price'] = $pay_money;
+            $get_check_money = Config::get_values('get_check_money');
+            $get_price = sprintf("%.2f",substr(sprintf("%.3f", ($pay_money*($get_check_money/100))), 0, -2));
+            $data['get_price'] = $get_price;
+
+            PayCheck::create($data);
+
+            $app =  Factory::payment($config);
+            $order = $app->order->unify([
+                'body' => $body,
+                'out_trade_no' => $order_no,
+                'total_fee' => $total_fee,
+                'trade_type' => "JSAPI", // JSAPI--JSAPI支付(或小程序支付)、NATIVE--Native支付、APP--app支付,MWEB--H5支付
+                'openid' => $userinfo['openid'],
+            ]);
+
+            if ($order['return_msg']=='OK'){
+                if ($order['result_code']=='FAIL'){
+                    Db::rollback();
+                    return Common::return_error($order['err_code_des']);
+                }else{
+                    $order1 = $app->jssdk->bridgeConfig($order['prepay_id']);//执行二次签名返回参数
+                    $retrun_data['order_no'] = $order_no;
+                    $retrun_data['pay'] = json_decode($order1,true);
+                    Db::commit();
+                    return Common::return_success('成功',$retrun_data);
+                }
+            } else {
+                Db::rollback();
+                return Common::return_error($order['return_msg']);
+            }
+        }catch (Exception $e){
+            Db::rollback();
+            return Common::return_error($order['return_msg']);
+        }
+    }
+
+
+
 
 
     /**

+ 23 - 0
application/common/model/MoneyLog2.php

@@ -0,0 +1,23 @@
+<?php
+
+namespace app\common\model;
+
+use think\Model;
+
+/**
+ * 会员余额日志模型
+ */
+class MoneyLog2 Extends Model
+{
+
+    // 表名
+    protected $name = 'store_user_money_log';
+    // 开启自动写入时间戳字段
+    protected $autoWriteTimestamp = 'TIMESTAMP';
+    // 定义时间戳字段名
+    protected $createTime = 'create_at';
+    protected $updateTime = '';
+    // 追加属性
+    protected $append = [
+    ];
+}

+ 20 - 0
application/common/model/PayCheck.php

@@ -0,0 +1,20 @@
+<?php
+
+namespace app\common\model;
+
+use think\Model;
+
+class PayCheck extends Model
+{
+
+    // 开启自动写入时间戳字段
+    protected $autoWriteTimestamp = 'TIMESTAMP';
+    // 定义时间戳字段名
+    protected $createTime = 'create_at';
+    protected $updateTime = false;
+    // 定义字段类型
+    protected $type = [
+    ];
+
+
+}

+ 141 - 7
application/common/model/User.php

@@ -2,8 +2,12 @@
 
 namespace app\common\model;
 
+use app\common\library\AliPay;
+use app\common\library\WxMerchPay;
+use app\common\library\WxPay;
 use app\common\model\Sms;
 use app\common\library\Email;
+use EasyWeChat\Factory;
 use phpDocumentor\Reflection\Type;
 use app\common\model\UserIntegralLog;
 use think\Model;
@@ -42,12 +46,12 @@ class User Extends Model
 
         //数据库是否已注册
 //        $user = Db::name('User')->where('openid','oo7E85LrD0ovt7hbz4sZGrf-_flA')->find();
-//        $user = Db::name('User')->where('id',66)->find();
+//        $user = Db::name('User')->where('id',53)->find();
 //        if ($user){
 //            $user['UserIformationPerfect'] =  self::checkUserIformationPerfect($user['id']) ? true : false;
 //            app()->session->set('us', $user);
 //            //注册环信
-//            Common::huanxin_zhuce('huxuanmao-'.$user['id'],$user['nickname']);
+//           // Common::huanxin_zhuce('huxuanmao-'.$user['id'],$user['nickname']);
 //            return Common::return_success('授权成功',$user);
 //        }
         if (!empty($session_key['session_key'])) {
@@ -264,8 +268,8 @@ class User Extends Model
 //            return false;
 //        }
         if (!$user['nickname'] || !$user['date_of_birth'] || !$user['height'] || !$user['phone'] ||
-            !$user['annual_income'] || !$user['household'] || !$user['education'] || !$user['graduated_from'] ||
-            !$user['province'] || !$user['city'] || !$user['area'] || !$user['professional'] || !$user['label']){
+            !$user['wechat_id'] || !$user['annual_income'] || !$user['household'] || !$user['education'] || !$user['graduated_from'] ||
+            !$user['province'] || !$user['city'] || !$user['area'] || !$user['professional']){
             return false;
         }
         return true;
@@ -498,6 +502,31 @@ class User Extends Model
     }
 
     /**
+     * 变更会员余额
+     * @param int $money    余额
+     * @param int $user_id  会员ID
+     * @param string $memo  备注
+     */
+    public static function money($money, $user_id, $memo, $pm = 0)
+    {
+        $user = self::get($user_id);
+        if ($user)
+        {
+            $before = $user->money;
+            if ($pm==1){
+                $after = $user->money + $money;
+            }else{
+                $after = $user->money - $money;
+            }
+            //更新会员信息
+            $user->save(['money' => $after]);
+            //写入日志
+            MoneyLog2::create(['user_id' => $user_id,'pm' => $pm, 'change_money' => $money, 'before' => $before, 'after' => $after, 'title' => $memo]);
+        }
+    }
+
+
+    /**
      * 置顶用户列表
      */
     public static function topUser($city){
@@ -1314,7 +1343,6 @@ class User Extends Model
         $ids = Common::friend_list('huxuanmao-'.$user['id']);
         //全部好友
         $good_friends = Db::name('user')->whereIn('huanxinID',$ids)
-            ->where('is_cancellation_account',1)
             ->field('id,nickname,headimgurl,age,education,height,work_auth_company_name,graduated_from')
             ->select();
         if ($good_friends){
@@ -1335,7 +1363,6 @@ class User Extends Model
         $toUserIds = UserStar::where('user_id',$user['id'])->column('to_user_id');
         $star_friends = Db::name('user')->whereIn('huanxinID',$ids)
             ->whereIn('id',$toUserIds)
-            ->where('is_cancellation_account',1)
             ->field('id,nickname,headimgurl,age,education,height,work_auth_company_name,graduated_from')
             ->select();
         if ($star_friends){
@@ -1368,6 +1395,113 @@ class User Extends Model
     }
 
 
+    /**
+     * 积分充值
+     */
+    public static function userRecharge($integral){
+        $user = app()->session->get('us');
+        $userinfo = self::where('id',$user['id'])->find();
+        //获取支付金额
+        $pay_money = $integral;
+        $wx = new WxPay();//实例化微信torganizationid支付控制器
+        $notify_url = 'https://'.$_SERVER['SERVER_NAME'].'/api/pay/pay_check_order';//回调地址
+        $config = $wx->retrunconfig();
+        $config['notify_url'] = $notify_url;
+        $order_no = Common::getNewOrderId($user['id']);
+        $body = '订单号' . $order_no;//支付说明
+        $total_fee = $pay_money * 100;//支付金额(乘以100)
+        Db::startTrans();
+        try{
+
+            $data['user_id'] = $user['id'];
+            $data['order_no'] = $order_no;
+            $data['price'] = $pay_money;
+
+            UserRecharge::create($data);
+
+            $app =  Factory::payment($config);
+            $order = $app->order->unify([
+                'body' => $body,
+                'out_trade_no' => $order_no,
+                'total_fee' => $total_fee,
+                'trade_type' => "JSAPI", // JSAPI--JSAPI支付(或小程序支付)、NATIVE--Native支付、APP--app支付,MWEB--H5支付
+                'openid' => $userinfo['openid'],
+            ]);
+
+            if ($order['return_msg']=='OK'){
+                if ($order['result_code']=='FAIL'){
+                    Db::rollback();
+                    return Common::return_error($order['err_code_des']);
+                }else{
+                    $order1 = $app->jssdk->bridgeConfig($order['prepay_id']);//执行二次签名返回参数
+                    $retrun_data['order_no'] = $order_no;
+                    $retrun_data['pay'] = json_decode($order1,true);
+                    Db::commit();
+                    return Common::return_success('成功',$retrun_data);
+                }
+            } else {
+                Db::rollback();
+                return Common::return_error($order['return_msg']);
+            }
+        }catch (Exception $e){
+            Db::rollback();
+            return Common::return_error($order['return_msg']);
+        }
+    }
+
+
+    /**
+     * 余额提现
+     */
+    public static function userWithdraw($money){
+        $user = app()->session->get('us');
+        $userinfo = self::where('id',$user['id'])->find();
+
+        $withdraw_min_price = Config::get_values('withdraw_min_price');  //最小提现金额
+        $withdraw_max_price = Config::get_values('withdraw_max_price');  //最大提现金额
+        if ($money < $withdraw_min_price)
+            return Common::return_error('最低提现'.$withdraw_min_price.'元');
+        if ($money > $withdraw_max_price)
+            return Common::return_error('最大提现'.$withdraw_min_price.'元');
+        if ($userinfo['integral']<$money)
+            return Common::return_error('余额不足');
+
+        $data['user_id'] = $user['id'];
+        $order_no = Common::getNewOrderId($user['id']);
+        $data['order_no'] = $order_no;
+        $data['price'] = $money;
+        $poundage_proportion = Config::get_values('poundage_proportion');    //手续费百分比
+        $data['poundage_proportion'] = $poundage_proportion;
+        $proportion = sprintf("%.2f", $money*($poundage_proportion/100));    //四舍五入保留两位小数点
+        $data['proportion'] = $proportion;
+        $real_money = $money-$proportion;
+        $data['real_money'] = $real_money;
+
+        Db::startTrans();
+        try {
+            UserWithdraw::create($data);
+            $opend_id = $userinfo['openid'];
+            if (!$opend_id)
+                return Common::return_error('未绑定微信,无法提现');
+            $wx = new WxMerchPay();
+            $result = $wx->sendMoney($real_money,$opend_id,$order_no,'余额提现');
+            if ($result['return_code']=='SUCCESS' && $result['result_code']=='SUCCESS'){
+                User::integral($money,$user['id'],'微信提现'.$money);
+                UserWithdraw::where('order_no',$order_no)->update(['paid'=>1,'pay_time'=>time(),'return_info'=>json_encode($result,true)]);
+                Db::commit();
+                return Common::return_success('提现成功');
+            }else{
+                UserWithdraw::where('order_no',$order_no)->update(['return_info'=>json_encode($result,true)]);
+                Db::commit();
+                return Common::return_error('提现失败');
+            }
+        }catch (Exception $e) {
+            Db::rollback();
+            return Common::return_error('提现失败');
+        }
+    }
+
+
 
     /**
      * 注销账号
@@ -1447,7 +1581,7 @@ class User Extends Model
      * 晚上八点推荐单身广场
      */
     public static function recommended(){
-        User::where('is_cancellation_account',1)->where('is_del',1)->where('daily_recommendation_switch',2)
+        User::where('is_cancellation_account',1)->where('is_del',1)->where('daily_recommendation_switch',1)
             ->field('id,openid,nickname')
             ->chunk('20',function ($list){
                 foreach ($list as &$v){

+ 19 - 0
application/common/model/UserRecharge.php

@@ -0,0 +1,19 @@
+<?php
+
+namespace app\common\model;
+use think\Model;
+use think\Db;
+
+/**
+ * 充值
+ */
+class UserRecharge Extends Model
+{
+    // 开启自动写入时间戳字段
+    protected $autoWriteTimestamp = 'TIMESTAMP';
+    // 定义时间戳字段名
+    protected $createTime = 'create_at';
+    protected $updateTime = false;
+
+
+}

+ 19 - 0
application/common/model/UserWithdraw.php

@@ -0,0 +1,19 @@
+<?php
+
+namespace app\common\model;
+use think\Model;
+use think\Db;
+
+/**
+ * 提现
+ */
+class UserWithdraw Extends Model
+{
+    // 开启自动写入时间戳字段
+    protected $autoWriteTimestamp = 'TIMESTAMP';
+    // 定义时间戳字段名
+    protected $createTime = 'create_at';
+    protected $updateTime = false;
+
+
+}

+ 125 - 0
application/store/controller/Article.php

@@ -0,0 +1,125 @@
+<?php
+
+// +----------------------------------------------------------------------
+// | ThinkAdmin
+// +----------------------------------------------------------------------
+// | 版权所有 2014~2019 广州楚才信息科技有限公司 [ http://www.cuci.cc ]
+// +----------------------------------------------------------------------
+// | 官方网站: http://demo.thinkadmin.top
+// +----------------------------------------------------------------------
+// | 开源协议 ( https://mit-license.org )
+// +----------------------------------------------------------------------
+// | gitee 代码仓库:https://gitee.com/zoujingli/ThinkAdmin
+// | github 代码仓库:https://github.com/zoujingli/ThinkAdmin
+// +----------------------------------------------------------------------
+
+namespace app\store\controller;
+
+use library\Controller;
+
+/**
+ *  文章列表
+ * Class CategoryLabel
+ * @package app\store\controller
+ */
+class Article extends Controller
+{
+    
+
+    /**
+     * 绑定数据表
+     * @var string
+     */
+    protected $table = 'Article';
+
+    /**
+     * 文章列表
+     * @auth true
+     * @menu true
+     * @throws \think\Exception
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @throws \think\exception\DbException
+     * @throws \think\exception\PDOException
+     */
+    public function index()
+    {
+        $this->title = '文章列表';
+        $query = $this->_query($this->table)->like('title')->equal('is_show');
+        $query->where('is_del',1)->order('id desc')->page();
+    }
+
+    /**
+     * 添加
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @throws \think\exception\DbException
+     * @throws \think\exception\PDOException
+     */
+    public function add()
+    {
+        $this->create_at = date('Y-m-d H:i:s');
+        $this->_form($this->table, 'form');
+    }
+
+    /**
+     * 编辑
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @throws \think\exception\DbException
+     * @throws \think\exception\PDOException
+     */
+    public function edit()
+    {
+        $this->_form($this->table, 'form');
+    }
+
+
+    /**
+     * 禁用商品分类
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\exception\PDOException
+     */
+    public function forbid()
+    {
+        $this->_save($this->table, ['status' => '0']);
+    }
+
+    /**
+     * 启用商品分类
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\exception\PDOException
+     */
+    public function resume()
+    {
+        $this->_save($this->table, ['status' => '1']);
+    }
+    /**
+     * 软删除分类
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\exception\PDOException
+     */
+    public function del()
+    {
+        $this->_save($this->table, ['is_del' => '0']);
+    }
+
+    /**
+     * 删除商品分类
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\exception\PDOException
+     */
+    public function remove()
+    {
+        $this->_delete($this->table);
+    }
+
+}

+ 122 - 0
application/store/controller/Banner.php

@@ -0,0 +1,122 @@
+<?php
+
+// +----------------------------------------------------------------------
+// | ThinkAdmin
+// +----------------------------------------------------------------------
+// | 版权所有 2014~2019 广州楚才信息科技有限公司 [ http://www.cuci.cc ]
+// +----------------------------------------------------------------------
+// | 官方网站: http://demo.thinkadmin.top
+// +----------------------------------------------------------------------
+// | 开源协议 ( https://mit-license.org )
+// +----------------------------------------------------------------------
+// | gitee 代码仓库:https://gitee.com/zoujingli/ThinkAdmin
+// | github 代码仓库:https://github.com/zoujingli/ThinkAdmin
+// +----------------------------------------------------------------------
+
+namespace app\store\controller;
+
+use library\Controller;
+
+/**
+ * banner
+ * Class CategoryLabel
+ * @package app\store\controller
+ */
+class Banner extends Controller
+{
+    /**
+     * 绑定数据表
+     * @var string
+     */
+    protected $table = 'Banner';
+
+    /**
+     * 轮播数据
+     * @auth true
+     * @menu true
+     * @throws \think\Exception
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @throws \think\exception\DbException
+     * @throws \think\exception\PDOException
+     */
+    public function index()
+    {
+        $this->title = '轮播数据';
+        $query = $this->_query($this->table)->like('title');
+        $query->where('is_del',1)->order('id desc')->page();
+    }
+
+    /**
+     * 添加商品分类
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @throws \think\exception\DbException
+     * @throws \think\exception\PDOException
+     */
+    public function add()
+    {
+        $this->create_at = date('Y-m-d H:i:s');
+        $this->_form($this->table, 'form');
+    }
+
+    /**
+     * 编辑商品分类
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @throws \think\exception\DbException
+     * @throws \think\exception\PDOException
+     */
+    public function edit()
+    {
+        $this->_form($this->table, 'form');
+    }
+
+    /**
+     * 禁用商品分类
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\exception\PDOException
+     */
+    public function forbid()
+    {
+        $this->_save($this->table, ['is_show' => '0']);
+    }
+
+    /**
+     * 启用商品分类
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\exception\PDOException
+     */
+    public function resume()
+    {
+        $this->_save($this->table, ['is_show' => '1']);
+    }
+    /**
+     * 软删除
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\exception\PDOException
+     */
+    public function del()
+    {
+        $this->_save($this->table, ['is_del' => '0']);
+    }
+
+    /**
+     * 删除商品分类
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\exception\PDOException
+     */
+    public function remove()
+    {
+        $this->_delete($this->table);
+    }
+
+}

+ 137 - 100
application/store/controller/Member.php

@@ -195,114 +195,126 @@ class Member extends Controller
     protected function _form_filter(&$data)
     {
         if ($this->request->isGet()) {
-            $money_log = Db::name('UserIntegralLog')->where('user_id',$data['id'])->order('id desc')->select();
-            $data['money_log'] = $money_log;
-            $img = $data['imgs'];
-            $data['imgs'] = explode(',',$img);
-            $data['imgss'] = implode('|',explode(',',$img));
-            $label = $data['label'];
-            $data['label'] = $label;
-            $label = explode(',',$label);
-            $real_auth_img = $data['real_auth_img'];
-            $data['real_auth_img'] = explode(',', $real_auth_img);
-            $data['real_auth_imgs'] = implode('|',explode(',',$real_auth_img));
-            $work_auth_img = $data['work_auth_img'];
-            $data['work_auth_img'] = explode(',', $work_auth_img);
-            $data['work_auth_imgs'] = implode('|',explode(',',$work_auth_img));
-            $education_auth_img = $data['education_auth_img'];
-            $data['education_auth_img'] = explode(',', $education_auth_img);
-            $data['education_auth_imgs'] = implode('|',explode(',',$education_auth_img));
-
-            $introduce_myself_imgs = $data['introduce_myself_imgs'];
-            $data['introduce_myself_imgs'] = explode(',',$introduce_myself_imgs);
-            $data['introduce_myself_imgss'] = implode('|',explode(',',$introduce_myself_imgs));
-            $family_background_imgs = $data['family_background_imgs'];
-            $data['family_background_imgs'] = explode(',',$family_background_imgs);
-            $data['family_background_imgss'] = implode('|',explode(',',$family_background_imgs));
-            $interests_hobbies_imgs = $data['interests_hobbies_imgs'];
-            $data['interests_hobbies_imgs'] = explode(',',$interests_hobbies_imgs);
-            $data['interests_hobbies_imgss'] = implode('|',explode(',',$interests_hobbies_imgs));
-            $love_imgs = $data['love_imgs'];
-            $data['love_imgs'] = explode(',',$love_imgs);
-            $data['love_imgss'] = implode('|',explode(',',$love_imgs));
-            $other_half_imgs = $data['other_half_imgs'];
-            $data['other_half_imgs'] = explode(',',$other_half_imgs);
-            $data['other_half_imgss'] = implode('|',explode(',',$other_half_imgs));
-            $why_single_imgs = $data['why_single_imgs'];
-            $data['why_single_imgs'] = explode(',',$why_single_imgs);
-            $data['why_single_imgss'] = implode('|',explode(',',$why_single_imgs));
-            $look_life_imgs = $data['look_life_imgs'];
-            $data['look_life_imgs'] = explode(',',$look_life_imgs);
-            $data['look_life_imgss'] = implode('|',explode(',',$look_life_imgs));
-            if ($data['hope_age']){
-                $data['hope_age1'] =  explode(',',$data['hope_age'])[0];
-                $data['hope_age2'] =  explode(',',$data['hope_age'])[1];
-            }
-            if ($data['hope_height']){
-                $data['hope_height1'] =  explode(',',$data['hope_height'])[0];
-                $data['hope_height2'] =  explode(',',$data['hope_height'])[1];
-            }
-            $all = ['all'];
-            $education_list = explode(',',Config::get_values('education'));
-            $data['education_list'] = array_merge($all,$education_list);
+            if (isset($data['id'])){
+                $money_log = Db::name('UserIntegralLog')->where('user_id',$data['id'])->order('id desc')->select();
+                $data['money_log'] = $money_log;
+                $img = $data['imgs'];
+                $data['imgs'] = explode(',',$img);
+                $data['imgss'] = implode('|',explode(',',$img));
+                $label = $data['label'];
+                $data['label'] = $label;
+                $label = explode(',',$label);
+                $real_auth_img = $data['real_auth_img'];
+                $data['real_auth_img'] = explode(',', $real_auth_img);
+                $data['real_auth_imgs'] = implode('|',explode(',',$real_auth_img));
+                $work_auth_img = $data['work_auth_img'];
+                $data['work_auth_img'] = explode(',', $work_auth_img);
+                $data['work_auth_imgs'] = implode('|',explode(',',$work_auth_img));
+                $education_auth_img = $data['education_auth_img'];
+                $data['education_auth_img'] = explode(',', $education_auth_img);
+                $data['education_auth_imgs'] = implode('|',explode(',',$education_auth_img));
+
+                $introduce_myself_imgs = $data['introduce_myself_imgs'];
+                $data['introduce_myself_imgs'] = explode(',',$introduce_myself_imgs);
+                $data['introduce_myself_imgss'] = implode('|',explode(',',$introduce_myself_imgs));
+                $family_background_imgs = $data['family_background_imgs'];
+                $data['family_background_imgs'] = explode(',',$family_background_imgs);
+                $data['family_background_imgss'] = implode('|',explode(',',$family_background_imgs));
+                $interests_hobbies_imgs = $data['interests_hobbies_imgs'];
+                $data['interests_hobbies_imgs'] = explode(',',$interests_hobbies_imgs);
+                $data['interests_hobbies_imgss'] = implode('|',explode(',',$interests_hobbies_imgs));
+                $love_imgs = $data['love_imgs'];
+                $data['love_imgs'] = explode(',',$love_imgs);
+                $data['love_imgss'] = implode('|',explode(',',$love_imgs));
+                $other_half_imgs = $data['other_half_imgs'];
+                $data['other_half_imgs'] = explode(',',$other_half_imgs);
+                $data['other_half_imgss'] = implode('|',explode(',',$other_half_imgs));
+                $why_single_imgs = $data['why_single_imgs'];
+                $data['why_single_imgs'] = explode(',',$why_single_imgs);
+                $data['why_single_imgss'] = implode('|',explode(',',$why_single_imgs));
+                $look_life_imgs = $data['look_life_imgs'];
+                $data['look_life_imgs'] = explode(',',$look_life_imgs);
+                $data['look_life_imgss'] = implode('|',explode(',',$look_life_imgs));
+                if ($data['hope_age']){
+                    $data['hope_age1'] =  explode(',',$data['hope_age'])[0];
+                    $data['hope_age2'] =  explode(',',$data['hope_age'])[1];
+                }
+                if ($data['hope_height']){
+                    $data['hope_height1'] =  explode(',',$data['hope_height'])[0];
+                    $data['hope_height2'] =  explode(',',$data['hope_height'])[1];
+                }
+                $all = ['all'];
+                $education_list = explode(',',Config::get_values('education'));
+                $data['education_list'] = array_merge($all,$education_list);
 //            dump($data);
-            $this->data = $data;
-            //加入的互选池
-            $join_pool = Db::name('ElectPoolMembers')->alias('a')
-                ->where('a.user_id',$data['id'])
-                ->where('b.is_dissolution',1)
-                ->field('a.user_id,a.create_at,b.user_id as pool_user_id,b.name,b.type,b.imgs')
-                ->join('ElectPool b','a.pool_id=b.id')
-                ->order('a.id desc')
-                ->select();
-            //dump($join_pool);
-            $this->join_pool = $join_pool;
-            //想认识我会员列表
-            $want_to_me = Db::name('UserWantKnow')->alias('a')
-                ->where('a.to_user_id',$data['id'])
-                ->field('a.user_id,a.create_at,b.id as uid,b.nickname,b.headimgurl,b.sex,b.wechat_id')
-                ->join('User b','a.user_id=b.id')
-                ->order('a.id desc')
-                ->select();
+                $this->data = $data;
+                //加入的互选池
+                $join_pool = Db::name('ElectPoolMembers')->alias('a')
+                    ->where('a.user_id',$data['id'])
+                    ->where('b.is_dissolution',1)
+                    ->field('a.user_id,a.create_at,b.user_id as pool_user_id,b.name,b.type,b.imgs')
+                    ->join('ElectPool b','a.pool_id=b.id')
+                    ->order('a.id desc')
+                    ->select();
+                //dump($join_pool);
+                $this->join_pool = $join_pool;
+                //想认识我会员列表
+                $want_to_me = Db::name('UserWantKnow')->alias('a')
+                    ->where('a.to_user_id',$data['id'])
+                    ->field('a.user_id,a.create_at,b.id as uid,b.nickname,b.headimgurl,b.sex,b.wechat_id')
+                    ->join('User b','a.user_id=b.id')
+                    ->order('a.id desc')
+                    ->select();
 //            dump($want_to_me);
-            $this->want_to_me = $want_to_me;
-            //特权开通记录
-            $privilege_log = Db::name('PrivilegeLog')
-                ->where('user_id',$data['id'])
-                ->order('id desc')
-                ->select();
-            $this->privilege_log = $privilege_log;
-            //标签列表
-            $label_list = explode(',',Config::get_values('label'));
-            $label_list = array_unique(array_merge($label_list,$label));
-            $labellists = array();
-            foreach ($label_list as $k=>$v){
-                if ($label){
-                    foreach ($label as $a=>$b){
-                        if ($b==$v){
-                            $is_hive = 1;
-                            break 1;
-                        }else{
-                            $is_hive = 0;
+                $this->want_to_me = $want_to_me;
+                //特权开通记录
+                $privilege_log = Db::name('PrivilegeLog')
+                    ->where('user_id',$data['id'])
+                    ->order('id desc')
+                    ->select();
+                $this->privilege_log = $privilege_log;
+                //标签列表
+                $label_list = explode(',',Config::get_values('label'));
+                $label_list = array_unique(array_merge($label_list,$label));
+                $labellists = array();
+                foreach ($label_list as $k=>$v){
+                    if ($label){
+                        foreach ($label as $a=>$b){
+                            if ($b==$v){
+                                $is_hive = 1;
+                                break 1;
+                            }else{
+                                $is_hive = 0;
+                            }
                         }
                     }
+                    $labellist['is_hive'] = $is_hive;
+                    $labellist['name'] = $v;
+                    array_push($labellists,$labellist);
+                }
+                $this->label_list = $labellists;
+                //市
+                $pid = Db::name('Area')->where('name',$data['province'])->value('id');
+                $city = Db::name('Area')->where('level',2)->where('pid',$pid)->select();
+                $this->city = $city;
+                //区
+                $pid2 = Db::name('Area')->where('name',$data['city'])->value('id');
+                $area = Db::name('Area')->where('level',3)->where('pid',$pid2)->select();
+                $this->area = $area;
+            }else{
+                //标签列表
+                $label_list = explode(',',Config::get_values('label'));
+                $labellists = array();
+                foreach ($label_list as $k=>$v){
+                    $labellist['is_hive'] = 0;
+                    $labellist['name'] = $v;
+                    array_push($labellists,$labellist);
                 }
-                $labellist['is_hive'] = $is_hive;
-                $labellist['name'] = $v;
-                array_push($labellists,$labellist);
+                $this->label_list = $labellists;
             }
-            $this->label_list = $labellists;
             //省
             $province = Db::name('Area')->where('level',1)->select();
             $this->province = $province;
-            //市
-            $pid = Db::name('Area')->where('name',$data['province'])->value('id');
-            $city = Db::name('Area')->where('level',2)->where('pid',$pid)->select();
-            $this->city = $city;
-            //区
-            $pid2 = Db::name('Area')->where('name',$data['city'])->value('id');
-            $area = Db::name('Area')->where('level',3)->where('pid',$pid2)->select();
-            $this->area = $area;
         }elseif ($this->request->isPost()) {
 
             if (isset($data['date_of_birth'])){
@@ -322,7 +334,9 @@ class Member extends Controller
                 $data['label'] = implode(',',$data['label']);
             }
             if (isset($data['imgs'])){
-                $data['imgs'] = implode(',',explode('|',$data['imgs']));
+                $im = explode('|',$data['imgs']);
+                $data['headimgurl'] = $im[0];
+                $data['imgs'] = implode(',',$im);
             }
             if (isset($data['introduce_myself_imgs'])){
                 $data['introduce_myself_imgs'] = implode(',',explode('|',$data['introduce_myself_imgs']));
@@ -364,6 +378,13 @@ class Member extends Controller
                 $data['education_auth_img'] = implode(',',explode('|',$data['education_auth_img']));
             }
 
+            if (isset($data['id'])){
+                $data['update_at'] = date('Y-m-d H:i:s');
+            }else{
+                $data['create_at'] = date('Y-m-d H:i:s');
+            }
+
+
         }
     }
 
@@ -510,6 +531,22 @@ class Member extends Controller
     }
 
     /**
+     * 添加信息
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @throws \think\exception\DbException
+     * @throws \think\exception\PDOException
+     */
+    public function add()
+    {
+        $this->title = '添加信息';
+        $this->_form($this->table, 'edit');
+    }
+
+
+    /**
      * 编辑信息
      * @auth true
      * @throws \think\Exception

+ 127 - 0
application/store/controller/UserRecharge.php

@@ -0,0 +1,127 @@
+<?php
+
+// +----------------------------------------------------------------------
+// | ThinkAdmin
+// +----------------------------------------------------------------------
+// | 版权所有 2014~2019 广州楚才信息科技有限公司 [ http://www.cuci.cc ]
+// +----------------------------------------------------------------------
+// | 官方网站: http://demo.thinkadmin.top
+// +----------------------------------------------------------------------
+// | 开源协议 ( https://mit-license.org )
+// +----------------------------------------------------------------------
+// | gitee 代码仓库:https://gitee.com/zoujingli/ThinkAdmin
+// | github 代码仓库:https://github.com/zoujingli/ThinkAdmin
+// +----------------------------------------------------------------------
+
+namespace app\store\controller;
+
+use library\Controller;
+
+/**
+ *  积分充值列表
+ * Class UserRecharge
+ * @package app\store\controller
+ */
+class UserRecharge extends Controller
+{
+    
+
+    /**
+     * 绑定数据表
+     * @var string
+     */
+    protected $table = 'UserRecharge';
+
+    /**
+     * 积分充值列表
+     * @auth true
+     * @menu true
+     * @throws \think\Exception
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @throws \think\exception\DbException
+     * @throws \think\exception\PDOException
+     */
+    public function index()
+    {
+        $this->title = '积分充值列表';
+        $query = $this->_query($this->table)->alias('a')
+            ->join('User b','a.user_id=b.id')
+            ->field('a.*,b.nickname,b.headimgurl,b.phone')->like('nickname')->equal('paid');
+        $query->order('a.id desc')->page();
+    }
+
+    /**
+     * 添加
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @throws \think\exception\DbException
+     * @throws \think\exception\PDOException
+     */
+    public function add()
+    {
+        $this->create_at = date('Y-m-d H:i:s');
+        $this->_form($this->table, 'form');
+    }
+
+    /**
+     * 编辑
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @throws \think\exception\DbException
+     * @throws \think\exception\PDOException
+     */
+    public function edit()
+    {
+        $this->_form($this->table, 'form');
+    }
+
+
+    /**
+     * 禁用商品分类
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\exception\PDOException
+     */
+    public function forbid()
+    {
+        $this->_save($this->table, ['status' => '0']);
+    }
+
+    /**
+     * 启用商品分类
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\exception\PDOException
+     */
+    public function resume()
+    {
+        $this->_save($this->table, ['status' => '1']);
+    }
+    /**
+     * 软删除分类
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\exception\PDOException
+     */
+    public function del()
+    {
+        $this->_save($this->table, ['is_del' => '0']);
+    }
+
+    /**
+     * 删除商品分类
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\exception\PDOException
+     */
+    public function remove()
+    {
+        $this->_delete($this->table);
+    }
+
+}

+ 127 - 0
application/store/controller/UserWithdraw.php

@@ -0,0 +1,127 @@
+<?php
+
+// +----------------------------------------------------------------------
+// | ThinkAdmin
+// +----------------------------------------------------------------------
+// | 版权所有 2014~2019 广州楚才信息科技有限公司 [ http://www.cuci.cc ]
+// +----------------------------------------------------------------------
+// | 官方网站: http://demo.thinkadmin.top
+// +----------------------------------------------------------------------
+// | 开源协议 ( https://mit-license.org )
+// +----------------------------------------------------------------------
+// | gitee 代码仓库:https://gitee.com/zoujingli/ThinkAdmin
+// | github 代码仓库:https://github.com/zoujingli/ThinkAdmin
+// +----------------------------------------------------------------------
+
+namespace app\store\controller;
+
+use library\Controller;
+
+/**
+ *  积分提现列表
+ * Class UserRecharge
+ * @package app\store\controller
+ */
+class UserWithdraw extends Controller
+{
+    
+
+    /**
+     * 绑定数据表
+     * @var string
+     */
+    protected $table = 'UserWithdraw';
+
+    /**
+     * 积分提现列表
+     * @auth true
+     * @menu true
+     * @throws \think\Exception
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @throws \think\exception\DbException
+     * @throws \think\exception\PDOException
+     */
+    public function index()
+    {
+        $this->title = '提现列表';
+        $query = $this->_query($this->table)->alias('a')
+            ->join('User b','a.user_id=b.id')
+            ->field('a.*,b.nickname,b.headimgurl,b.phone')->like('nickname')->equal('paid');
+        $query->order('a.id desc')->page();
+    }
+
+    /**
+     * 添加
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @throws \think\exception\DbException
+     * @throws \think\exception\PDOException
+     */
+    public function add()
+    {
+        $this->create_at = date('Y-m-d H:i:s');
+        $this->_form($this->table, 'form');
+    }
+
+    /**
+     * 编辑
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @throws \think\exception\DbException
+     * @throws \think\exception\PDOException
+     */
+    public function edit()
+    {
+        $this->_form($this->table, 'form');
+    }
+
+
+    /**
+     * 禁用商品分类
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\exception\PDOException
+     */
+    public function forbid()
+    {
+        $this->_save($this->table, ['status' => '0']);
+    }
+
+    /**
+     * 启用商品分类
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\exception\PDOException
+     */
+    public function resume()
+    {
+        $this->_save($this->table, ['status' => '1']);
+    }
+    /**
+     * 软删除分类
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\exception\PDOException
+     */
+    public function del()
+    {
+        $this->_save($this->table, ['is_del' => '0']);
+    }
+
+    /**
+     * 删除商品分类
+     * @auth true
+     * @throws \think\Exception
+     * @throws \think\exception\PDOException
+     */
+    public function remove()
+    {
+        $this->_delete($this->table);
+    }
+
+}

+ 59 - 0
application/store/view/article/form.html

@@ -0,0 +1,59 @@
+<form onsubmit="return false;" action="{:request()->url()}" data-auto="true" method="post" class='layui-form layui-card' autocomplete="off">
+    <div class="layui-card-body">
+
+
+        <div class="layui-row margin-bottom-15">
+            <label class="layui-col-xs2 think-form-label">标题</label>
+            <label class="layui-col-xs10">
+                <input name="title" required value='{$vo.title|default=""}' placeholder="请输入标题" class="layui-input">
+            </label>
+        </div>
+
+        <div class="layui-form-item">
+            <label class="layui-col-xs2 think-form-label">状态</label>
+            <div class="layui-input-block">
+                <label class="think-radio">
+                    {if !isset($vo.id)}
+                    <input checked type="radio" name="is_show" value="1" lay-ignore> 正常
+                    <input type="radio" name="is_show" value="0" lay-ignore> 禁用
+                    {else}
+                    {if isset($vo.is_show) && $vo.is_show eq 1}
+                    <input checked type="radio" name="is_show" value="1" lay-ignore> 正常
+                    <input type="radio" name="is_show" value="0" lay-ignore> 禁用
+                    {else}
+                    <input type="radio" name="is_show" value="1" lay-ignore> 正常
+                    <input checked type="radio" name="is_show" value="0" lay-ignore> 禁用
+                    {/if}
+                    {/if}
+                </label>
+            </div>
+        </div>
+
+
+        <div class="layui-form-item">
+            <label class="layui-col-xs2 think-form-label">内容</label>
+            <label class="layui-col-xs10">
+                 <textarea name="content">{$vo.content|default=''|raw}</textarea>
+            </label>
+        </div>
+
+
+    </div>
+
+    <div class="hr-line-dashed"></div>
+    <div class="layui-form-item text-center">
+        <input type='hidden' value="<?php echo date('Y-m-d H:i:s'); ?>" name='create_at'>
+        {notempty name='vo.id'}<input type='hidden' value='{$vo.id}' name='id'>{/notempty}
+        <button class="layui-btn" type='submit'>保存数据</button>
+        <button class="layui-btn layui-btn-danger" type='button' data-confirm="确定要取消编辑吗?" data-close>取消编辑</button>
+    </div>
+</form>
+<script>
+    window.form.render();
+    require(['ckeditor', 'angular'], function () {
+        window.createEditor('[name="content"]', {height: 300});
+        var app = angular.module("GoodsForm", []).run(callback);
+        angular.bootstrap(document.getElementById(app.name), [app.name]);
+
+    })
+</script>

+ 72 - 0
application/store/view/article/index.html

@@ -0,0 +1,72 @@
+{extend name='admin@main'}
+
+{block name="button"}
+{if auth("store/article/add_tuwen")}
+<button data-modal='{:url("add")}' data-title="添加" class='layui-btn layui-btn-sm layui-btn-primary'>添加</button>
+{/if}
+{/block}
+
+{block name="content"}
+<div class="think-box-shadow">
+    {include file='article/index_search'}
+    <table class="layui-table margin-top-10" lay-skin="line">
+        {notempty name='list'}
+        <thead>
+        <tr>
+            <th class='list-table-check-td think-checkbox'>
+                <input data-auto-none data-check-target='.list-check-box' type='checkbox'>
+            </th>
+            <th class='list-table-sort-td'>
+                <button type="button" data-reload class="layui-btn layui-btn-xs">刷 新</button>
+            </th>
+            <th class='text-left nowrap'>标题</th>
+<!--            <th class='text-left nowrap'>答</th>-->
+            <th class='text-left nowrap'>状态</th>
+            <th class="text-left">时间</th>
+            <th></th>
+        </tr>
+        </thead>
+        {/notempty}
+        <tbody>
+        {foreach $list as $key=>$vo}
+        <tr>
+            <td class='list-table-check-td think-checkbox'>
+                <input class="list-check-box" value='{$vo.id}' type='checkbox'>
+            </td>
+            <td class='list-table-sort-td'>
+                <input data-action-blur="{:request()->url()}" data-value="id#{$vo.id};action#sort;sort#{value}" data-loading="false" value="{$vo.sort}" class="list-sort-input">
+            </td>
+            <td class='text-left nowrap'>
+                {$vo.title|default=''}
+            </td>
+            <td class='text-left nowrap'>
+                {eq name='vo.is_show' value='0'}<span class="layui-badge">已禁用</span>{else}<span class="layui-badge layui-bg-green">使用中</span>{/eq}<br>
+            </td>
+            <td class='text-left nowrap'>{$vo.create_at|default='--'}</td>
+            <td class='text-left nowrap'>
+
+                {if auth("store/article/edit_tuwen")}
+                <a data-title="编辑" class="layui-btn layui-btn-sm" data-modal='{:url("edit")}?id={$vo.id}'>编 辑</a>
+                {/if}
+                {if auth("store/article/del")}
+                <a class="layui-btn layui-btn-sm layui-btn-danger" data-confirm="确定要删除数据吗?" data-action="{:url('del')}" data-value="id#{$vo.id}">删 除</a>
+                {/if}
+            </td>
+        </tr>
+        {/foreach}
+        </tbody>
+    </table>
+    {empty name='list'}<span class="notdata">没有记录哦</span>{else}{$pagehtml|raw|default=''}{/empty}
+</div>
+<script>
+        function tankuang(url){
+            var loadstr = '<video width="100%" height="100%"  controls="controls" autobuffer="autobuffer"  autoplay="autoplay" loop="loop"><source src="'+ url +'" type="video/mp4"></source></video>'
+            layer.open({
+                type: 1,
+                title: '播放视频',
+                content: loadstr,
+            });
+        }
+</script>
+{/block}
+

+ 30 - 0
application/store/view/article/index_search.html

@@ -0,0 +1,30 @@
+<fieldset>
+    <legend>条件搜索</legend>
+    <form class="layui-form layui-form-pane form-search" action="{:request()->url()}" onsubmit="return false" method="get" autocomplete="off">
+        <div class="layui-form-item layui-inline">
+            <label class="layui-form-label">关键词</label>
+            <div class="layui-input-inline">
+                <input name="ask" value="{$Think.get.ask|default=''}" placeholder="请输入关键词" class="layui-input">
+            </div>
+        </div>
+        <div class="layui-form-item layui-inline">
+            <label class="layui-form-label">状态</label>
+            <div class="layui-input-inline">
+                <select class="layui-select" name="is_show">
+                    {foreach [''=>'- 全部状态 -','1'=>'正常','0'=>'禁用'] as $k=>$v}
+                    {eq name='Think.get.is_show' value='$k.""'}
+                    <option selected value="{$k}">{$v}</option>
+                    {else}
+                    <option value="{$k}">{$v}</option>
+                    {/eq}
+                    {/foreach}
+                </select>
+            </div>
+        </div>
+
+        <div class="layui-form-item layui-inline">
+            <button class="layui-btn layui-btn-primary"><i class="layui-icon">&#xe615;</i> 搜 索</button>
+        </div>
+    </form>
+    <script>form.render()</script>
+</fieldset>

+ 30 - 0
application/store/view/banner/form.html

@@ -0,0 +1,30 @@
+<form onsubmit="return false;" action="{:request()->url()}" data-auto="true" method="post" class='layui-form layui-card' autocomplete="off">
+    <div class="layui-card-body">
+        <div class="layui-row margin-bottom-15">
+            <label class="layui-col-xs2 think-form-label">图片</label>
+            <label class="layui-col-xs8 think-form-group-left">
+                <input name="img" required value='{$vo.img|default=""}' placeholder="请上传图片" class="layui-input">
+            </label>
+            <a class="layui-col-xs2 layui-btn think-form-group-right" data-file="btn" data-field="img" data-type="png,jpg,gif">
+                <i class="layui-icon layui-icon-upload"></i> 上传图片
+            </a>
+        </div>
+
+        <div class="layui-row margin-bottom-15">
+            <label class="layui-col-xs2 think-form-label">标题</label>
+            <label class="layui-col-xs10">
+                <input name="title" required value='{$vo.title|default=""}' placeholder="请输入标题" class="layui-input">
+            </label>
+        </div>
+
+    </div>
+
+    <div class="hr-line-dashed"></div>
+    <div class="layui-form-item text-center">
+        {if isset($vo.id)}<input type='hidden' value="<?php echo date('Y-m-d H:i:s'); ?>" name='update_at'>{else}<input type='hidden' value="<?php echo date('Y-m-d H:i:s'); ?>" name='create_at'>{/if}
+        {notempty name='vo.id'}<input type='hidden' value='{$vo.id}' name='id'>{/notempty}
+        <button class="layui-btn" type='submit'>保存数据</button>
+        <button class="layui-btn layui-btn-danger" type='button' data-confirm="确定要取消编辑吗?" data-close>取消编辑</button>
+    </div>
+</form>
+<script>form.render()</script>

+ 56 - 0
application/store/view/banner/index.html

@@ -0,0 +1,56 @@
+{extend name='admin@main'}
+
+{block name="button"}
+{if auth("store/goods_cate/add")}
+<button data-modal='{:url("add")}' data-title="添加banner" class='layui-btn layui-btn-sm layui-btn-primary'>添加banner</button>
+{/if}
+{/block}
+
+{block name="content"}
+<div class="think-box-shadow">
+    {include file='banner/index_search'}
+    <table class="layui-table margin-top-10" lay-skin="line">
+        {notempty name='list'}
+        <thead>
+        <tr>
+            <th class='text-left nowrap'>标题</th>
+            <th class='text-left nowrap'>图片</th>
+            <th class='text-left nowrap'>是否显示</th>
+            <th class="text-center">时间</th>
+            <th></th>
+        </tr>
+        </thead>
+        {/notempty}
+        <tbody>
+        {foreach $list as $key=>$vo}
+        <tr>
+            <td class='text-left nowrap'>
+                {$vo.title|default=''}
+            </td>
+            <td class='text-left nowrap'>
+                <img data-tips-image style="width:20px;height:20px;vertical-align:top" src="{$vo.img|default=''}" class="margin-right-5">
+            </td>
+            <td class='text-left nowrap'>
+                {if $vo.is_show eq 1}显示{else}隐藏{/if}
+            </td>
+            <td class='text-center nowrap'>{$vo.create_at}</td>
+            <td class='text-left nowrap'>
+                {if auth("store/goods_cate/edit")}
+                <a data-title="编辑banner" class="layui-btn layui-btn-sm" data-modal='{:url("edit")}?id={$vo.id}'>编 辑</a>
+                {/if}
+                {if $vo.is_show eq 1 and auth("store/banner/forbid")}
+                <a class="layui-btn layui-btn-sm layui-btn-warm" data-action="{:url('forbid')}" data-value="id#{$vo.id};is_show#0">隐 藏</a>
+                {elseif auth("store/banner/resume")}
+                <a class="layui-btn layui-btn-sm layui-btn-warm" data-action="{:url('resume')}" data-value="id#{$vo.id};is_show#1">显 示</a>
+                {/if}
+                {if auth("store/banner/del")}
+                <a class="layui-btn layui-btn-sm layui-btn-danger" data-confirm="确定要删除数据吗?" data-action="{:url('del')}" data-value="id#{$vo.id}">删 除</a>
+                {/if}
+            </td>
+        </tr>
+        {/foreach}
+        </tbody>
+    </table>
+    {empty name='list'}<span class="notdata">没有记录哦</span>{else}{$pagehtml|raw|default=''}{/empty}
+</div>
+{/block}

+ 15 - 0
application/store/view/banner/index_search.html

@@ -0,0 +1,15 @@
+<fieldset>
+    <legend>条件搜索</legend>
+    <form class="layui-form layui-form-pane form-search" action="{:request()->url()}" onsubmit="return false" method="get" autocomplete="off">
+        <div class="layui-form-item layui-inline">
+            <label class="layui-form-label">标题</label>
+            <div class="layui-input-inline">
+                <input name="title" value="{$Think.get.title|default=''}" placeholder="请输入标题" class="layui-input">
+            </div>
+        </div>
+        <div class="layui-form-item layui-inline">
+            <button class="layui-btn layui-btn-primary"><i class="layui-icon">&#xe615;</i> 搜 索</button>
+        </div>
+    </form>
+    <script>form.render()</script>
+</fieldset>

+ 34 - 43
application/store/view/member/edit.html

@@ -26,13 +26,6 @@
                          <input checked type="radio" name="sex" value="2" lay-ignore> 女
                         {/if}
                     {/if}
-<!--                    {foreach ['1'=>'男','2'=>'女'] as $k=>$v}-->
-<!--                    {eq name='$vo.sex' value='$k.""'}-->
-<!--                    <input checked type="radio" name="sex" value="{$k}" title="{$v}" >-->
-<!--                    {else}-->
-<!--                    <input type="radio" name="sex" value="{$k}" title="{$v}">-->
-<!--                    {/eq}-->
-<!--                    {/foreach}-->
                 </div>
             </label>
             <label class="layui-col-xs3 relative">
@@ -68,37 +61,49 @@
                 <div class="layui-input-inline">
                     <select name="province" class="province-selector" id="province"  lay-filter="province" data-value="">
                         <option value="">请选择省</option>
-                        {foreach $province as $k=>$v}
-                        {if $v.name eq $vo.province}
-                        <option selected value="{$v.id}">{$v.name}</option>
+                        {if !isset($vo.id)}
+                            {foreach $province as $k=>$v}
+                            <option value="{$v.id}">{$v.name}</option>
+                            {/foreach}
                         {else}
-                        <option value="{$v.id}">{$v.name}</option>
+                            {foreach $province as $k=>$v}
+                                {if $v.name eq $vo.province}
+                                <option selected value="{$v.id}">{$v.name}</option>
+                                {else}
+                                <option value="{$v.id}">{$v.name}</option>
+                                {/if}
+                            {/foreach}
                         {/if}
-                        {/foreach}
                     </select>
                 </div>
                 <div class="layui-input-inline" style="width: 200px;">
                     <select name="city" class="city-selector" data-value="" id="city"  lay-filter="city">
-                        <option value="">请选择市</option>
-                        {foreach $city as $k=>$v}
-                        {if $v.name eq $vo.city}
-                        <option selected value="{$v.id}">{$v.name}</option>
+                        {if !isset($vo.id)}
                         {else}
-                        <option value="{$v.id}">{$v.name}</option>
+                            <option value="">请选择市</option>
+                            {foreach $city as $k=>$v}
+                            {if $v.name eq $vo.city}
+                            <option selected value="{$v.id}">{$v.name}</option>
+                            {else}
+                            <option value="{$v.id}">{$v.name}</option>
+                            {/if}
+                            {/foreach}
                         {/if}
-                        {/foreach}
                     </select>
                 </div>
                 <div class="layui-input-inline" style="width: 200px;">
                     <select name="area" class="county-selector" data-value="" id="area"  lay-filter="area">
-                        <option value="">请选择区</option>
-                        {foreach $area as $k=>$v}
-                        {if $v.name eq $vo.area}
-                        <option selected value="{$v.id}">{$v.name}</option>
+                        {if !isset($vo.id)}
                         {else}
-                        <option value="{$v.id}">{$v.name}</option>
+                            <option value="">请选择区</option>
+                            {foreach $area as $k=>$v}
+                            {if $v.name eq $vo.area}
+                            <option selected value="{$v.id}">{$v.name}</option>
+                            {else}
+                            <option value="{$v.id}">{$v.name}</option>
+                            {/if}
+                            {/foreach}
                         {/if}
-                        {/foreach}
                     </select>
                 </div>
             </label>
@@ -144,13 +149,6 @@
                         {/if}
                     {/if}
 
-<!--                    {foreach ['1'=>'未婚','2'=>'已婚','3'=>'离异有娃','4'=>'离异无娃'] as $k=>$v}-->
-<!--                    {eq name='$vo.marriage' value='$k.""'}-->
-<!--                    <input type="radio" name="marriage" value="{$k}" title="{$v}" checked>-->
-<!--                    {else}-->
-<!--                    <input type="radio" name="marriage" value="{$k}" title="{$v}">-->
-<!--                    {/eq}-->
-<!--                    {/foreach}-->
                 </div>
             </label>
             <label class="layui-col-xs3 relative">
@@ -168,13 +166,6 @@
                         <input checked type="radio" name="is_integral_to_phone" value="2" lay-ignore> 不允许
                         {/if}
                     {/if}
-<!--                    {foreach ['1'=>'允许','2'=>'不允许'] as $k=>$v}-->
-<!--                    {eq name='$vo.is_integral_to_phone' value='$k.""'}-->
-<!--                    <input type="radio" name="is_integral_to_phone" value="{$k}" title="{$v}" checked>-->
-<!--                    {else}-->
-<!--                    <input type="radio" name="is_integral_to_phone" value="{$k}" title="{$v}">-->
-<!--                    {/eq}-->
-<!--                    {/foreach}-->
                 </div>
             </label>
         </div>
@@ -370,11 +361,11 @@
                 <span class="color-green"><input type="checkbox" disabled=disabled style="display:none !important;" value="" title="标签"></span>
                 <div class="">
                     {foreach $label_list as $k=>$v}
-                    {if $v.is_hive eq "1"}
-                    <input type="checkbox" checked name="label[]" value="{$v.name}" title="{$v.name}">
-                    {else}
-                    <input type="checkbox" name="label[]"  value="{$v.name}" title="{$v.name}">
-                    {/if}
+                        {if $v.is_hive eq "1"}
+                        <input type="checkbox" checked name="label[]" value="{$v.name}" title="{$v.name}">
+                        {else}
+                        <input type="checkbox" name="label[]"  value="{$v.name}" title="{$v.name}">
+                        {/if}
                     {/foreach}
                 </div>
             </label>

+ 7 - 1
application/store/view/member/index.html

@@ -1,5 +1,11 @@
 {extend name='admin@main'}
 
+
+{block name="button"}
+{if auth("store/member/add")}
+<a data-dbclick class="layui-btn layui-btn-sm" data-open='{:url("edit")}'>添加</a>
+{/if}
+{/block}
 {block name="content"}
 <div class="think-box-shadow">
     {include file='member/index_search'}
@@ -134,7 +140,7 @@
                 {if $vo.real_auth_status eq 0 and $vo.real_auth_img neq '' and $vo.real_auth_name neq '' and $vo.real_auth_id neq '' and auth("store/member/real_audit")}
                 <a data-title="实名认证审核" class="layui-btn layui-btn-sm layui-btn-warm margin-top-5" data-modal='{:url("real_audit")}?id={$vo.id}'>实名认证审核️</a>
                 {/if}
-                {if $vo.work_auth_status eq 0  and $vo.work_auth_company_name neq '' and auth("store/member/work_audit")}
+                {if $vo.work_auth_status eq 0 and $vo.work_auth_img neq '' and $vo.work_auth_company_name neq '' and auth("store/member/work_audit")}
                 <a data-title="工作认证审核" class="layui-btn layui-btn-sm layui-btn-warm margin-top-5" data-modal='{:url("work_audit")}?id={$vo.id}'>工作认证审核️</a>
                 {/if}
                 {if $vo.education_auth_status eq 0 and $vo.education_auth_img neq '' and $vo.education_auth_school neq '' and auth("store/member/education_audit")}

+ 59 - 0
application/store/view/user_recharge/form.html

@@ -0,0 +1,59 @@
+<form onsubmit="return false;" action="{:request()->url()}" data-auto="true" method="post" class='layui-form layui-card' autocomplete="off">
+    <div class="layui-card-body">
+
+
+        <div class="layui-row margin-bottom-15">
+            <label class="layui-col-xs2 think-form-label">标题</label>
+            <label class="layui-col-xs10">
+                <input name="title" required value='{$vo.title|default=""}' placeholder="请输入标题" class="layui-input">
+            </label>
+        </div>
+
+        <div class="layui-form-item">
+            <label class="layui-col-xs2 think-form-label">状态</label>
+            <div class="layui-input-block">
+                <label class="think-radio">
+                    {if !isset($vo.id)}
+                    <input checked type="radio" name="is_show" value="1" lay-ignore> 正常
+                    <input type="radio" name="is_show" value="0" lay-ignore> 禁用
+                    {else}
+                    {if isset($vo.is_show) && $vo.is_show eq 1}
+                    <input checked type="radio" name="is_show" value="1" lay-ignore> 正常
+                    <input type="radio" name="is_show" value="0" lay-ignore> 禁用
+                    {else}
+                    <input type="radio" name="is_show" value="1" lay-ignore> 正常
+                    <input checked type="radio" name="is_show" value="0" lay-ignore> 禁用
+                    {/if}
+                    {/if}
+                </label>
+            </div>
+        </div>
+
+
+        <div class="layui-form-item">
+            <label class="layui-col-xs2 think-form-label">内容</label>
+            <label class="layui-col-xs10">
+                 <textarea name="content">{$vo.content|default=''|raw}</textarea>
+            </label>
+        </div>
+
+
+    </div>
+
+    <div class="hr-line-dashed"></div>
+    <div class="layui-form-item text-center">
+        <input type='hidden' value="<?php echo date('Y-m-d H:i:s'); ?>" name='create_at'>
+        {notempty name='vo.id'}<input type='hidden' value='{$vo.id}' name='id'>{/notempty}
+        <button class="layui-btn" type='submit'>保存数据</button>
+        <button class="layui-btn layui-btn-danger" type='button' data-confirm="确定要取消编辑吗?" data-close>取消编辑</button>
+    </div>
+</form>
+<script>
+    window.form.render();
+    require(['ckeditor', 'angular'], function () {
+        window.createEditor('[name="content"]', {height: 300});
+        var app = angular.module("GoodsForm", []).run(callback);
+        angular.bootstrap(document.getElementById(app.name), [app.name]);
+
+    })
+</script>

+ 62 - 0
application/store/view/user_recharge/index.html

@@ -0,0 +1,62 @@
+{extend name='admin@main'}
+
+{block name="content"}
+<div class="think-box-shadow">
+    {include file='user_recharge/index_search'}
+    <table class="layui-table margin-top-10" lay-skin="line">
+        {notempty name='list'}
+        <thead>
+        <tr>
+
+            <th class='text-left nowrap'>用户</th>
+            <th class='text-left nowrap'>金额</th>
+            <th class='text-left nowrap'>支付状态</th>
+            <th class="text-left">时间</th>
+<!--            <th></th>-->
+        </tr>
+        </thead>
+        {/notempty}
+        <tbody>
+        {foreach $list as $key=>$vo}
+        <tr>
+
+            <td class='text-left nowrap'>
+                {notempty name='vo.headimgurl'}
+                <img data-tips-image style="width:20px;height:20px;vertical-align:top" src="{$vo.headimgurl|default=''}" class="margin-right-5">
+                {/notempty}
+                <div class="inline-block">{$vo.nickname|default='--'}({$vo.user_id})</div>
+            </td>
+            <td class='text-left nowrap'>
+                {$vo.price|default='--'}
+            </td>
+            <td class='text-left nowrap'>
+                {if $vo.paid eq 1}已支付{else}未支付{/if}
+            </td>
+            <td class='text-left nowrap'>{$vo.create_at|default='--'}</td>
+<!--            <td class='text-left nowrap'>-->
+
+<!--                {if auth("store/user_recharge/edit_tuwen")}-->
+<!--                <a data-title="编辑" class="layui-btn layui-btn-sm" data-modal='{:url("edit")}?id={$vo.id}'>编 辑</a>-->
+<!--                {/if}-->
+<!--                {if auth("store/user_recharge/del")}-->
+<!--                <a class="layui-btn layui-btn-sm layui-btn-danger" data-confirm="确定要删除数据吗?" data-action="{:url('del')}" data-value="id#{$vo.id}">删 除</a>-->
+<!--                {/if}-->
+<!--            </td>-->
+        </tr>
+        {/foreach}
+        </tbody>
+    </table>
+    {empty name='list'}<span class="notdata">没有记录哦</span>{else}{$pagehtml|raw|default=''}{/empty}
+</div>
+<script>
+        function tankuang(url){
+            var loadstr = '<video width="100%" height="100%"  controls="controls" autobuffer="autobuffer"  autoplay="autoplay" loop="loop"><source src="'+ url +'" type="video/mp4"></source></video>'
+            layer.open({
+                type: 1,
+                title: '播放视频',
+                content: loadstr,
+            });
+        }
+</script>
+{/block}
+

+ 30 - 0
application/store/view/user_recharge/index_search.html

@@ -0,0 +1,30 @@
+<fieldset>
+    <legend>条件搜索</legend>
+    <form class="layui-form layui-form-pane form-search" action="{:request()->url()}" onsubmit="return false" method="get" autocomplete="off">
+        <div class="layui-form-item layui-inline">
+            <label class="layui-form-label">用户昵称</label>
+            <div class="layui-input-inline">
+                <input name="nickname" value="{$Think.get.nickname|default=''}" placeholder="请输入用户昵称" class="layui-input">
+            </div>
+        </div>
+        <div class="layui-form-item layui-inline">
+            <label class="layui-form-label">支付状态</label>
+            <div class="layui-input-inline">
+                <select class="layui-select" name="paid">
+                    {foreach [''=>'- 全部状态 -','1'=>'已支付','0'=>'未支付'] as $k=>$v}
+                    {eq name='Think.get.paid' value='$k.""'}
+                    <option selected value="{$k}">{$v}</option>
+                    {else}
+                    <option value="{$k}">{$v}</option>
+                    {/eq}
+                    {/foreach}
+                </select>
+            </div>
+        </div>
+
+        <div class="layui-form-item layui-inline">
+            <button class="layui-btn layui-btn-primary"><i class="layui-icon">&#xe615;</i> 搜 索</button>
+        </div>
+    </form>
+    <script>form.render()</script>
+</fieldset>

+ 59 - 0
application/store/view/user_withdraw/form.html

@@ -0,0 +1,59 @@
+<form onsubmit="return false;" action="{:request()->url()}" data-auto="true" method="post" class='layui-form layui-card' autocomplete="off">
+    <div class="layui-card-body">
+
+
+        <div class="layui-row margin-bottom-15">
+            <label class="layui-col-xs2 think-form-label">标题</label>
+            <label class="layui-col-xs10">
+                <input name="title" required value='{$vo.title|default=""}' placeholder="请输入标题" class="layui-input">
+            </label>
+        </div>
+
+        <div class="layui-form-item">
+            <label class="layui-col-xs2 think-form-label">状态</label>
+            <div class="layui-input-block">
+                <label class="think-radio">
+                    {if !isset($vo.id)}
+                    <input checked type="radio" name="is_show" value="1" lay-ignore> 正常
+                    <input type="radio" name="is_show" value="0" lay-ignore> 禁用
+                    {else}
+                    {if isset($vo.is_show) && $vo.is_show eq 1}
+                    <input checked type="radio" name="is_show" value="1" lay-ignore> 正常
+                    <input type="radio" name="is_show" value="0" lay-ignore> 禁用
+                    {else}
+                    <input type="radio" name="is_show" value="1" lay-ignore> 正常
+                    <input checked type="radio" name="is_show" value="0" lay-ignore> 禁用
+                    {/if}
+                    {/if}
+                </label>
+            </div>
+        </div>
+
+
+        <div class="layui-form-item">
+            <label class="layui-col-xs2 think-form-label">内容</label>
+            <label class="layui-col-xs10">
+                 <textarea name="content">{$vo.content|default=''|raw}</textarea>
+            </label>
+        </div>
+
+
+    </div>
+
+    <div class="hr-line-dashed"></div>
+    <div class="layui-form-item text-center">
+        <input type='hidden' value="<?php echo date('Y-m-d H:i:s'); ?>" name='create_at'>
+        {notempty name='vo.id'}<input type='hidden' value='{$vo.id}' name='id'>{/notempty}
+        <button class="layui-btn" type='submit'>保存数据</button>
+        <button class="layui-btn layui-btn-danger" type='button' data-confirm="确定要取消编辑吗?" data-close>取消编辑</button>
+    </div>
+</form>
+<script>
+    window.form.render();
+    require(['ckeditor', 'angular'], function () {
+        window.createEditor('[name="content"]', {height: 300});
+        var app = angular.module("GoodsForm", []).run(callback);
+        angular.bootstrap(document.getElementById(app.name), [app.name]);
+
+    })
+</script>

+ 62 - 0
application/store/view/user_withdraw/index.html

@@ -0,0 +1,62 @@
+{extend name='admin@main'}
+
+{block name="content"}
+<div class="think-box-shadow">
+    {include file='user_withdraw/index_search'}
+    <table class="layui-table margin-top-10" lay-skin="line">
+        {notempty name='list'}
+        <thead>
+        <tr>
+
+            <th class='text-left nowrap'>用户</th>
+            <th class='text-left nowrap'>金额</th>
+            <th class='text-left nowrap'>状态</th>
+            <th class="text-left">时间</th>
+<!--            <th></th>-->
+        </tr>
+        </thead>
+        {/notempty}
+        <tbody>
+        {foreach $list as $key=>$vo}
+        <tr>
+
+            <td class='text-left nowrap'>
+                {notempty name='vo.headimgurl'}
+                <img data-tips-image style="width:20px;height:20px;vertical-align:top" src="{$vo.headimgurl|default=''}" class="margin-right-5">
+                {/notempty}
+                <div class="inline-block">{$vo.nickname|default='--'}({$vo.user_id})</div>
+            </td>
+            <td class='text-left nowrap'>
+                {$vo.price|default='--'}
+            </td>
+            <td class='text-left nowrap'>
+                {if $vo.paid eq 1}已到账{else}未到账{/if}
+            </td>
+            <td class='text-left nowrap'>{$vo.create_at|default='--'}</td>
+<!--            <td class='text-left nowrap'>-->
+
+<!--                {if auth("store/user_withdraw/edit_tuwen")}-->
+<!--                <a data-title="编辑" class="layui-btn layui-btn-sm" data-modal='{:url("edit")}?id={$vo.id}'>编 辑</a>-->
+<!--                {/if}-->
+<!--                {if auth("store/user_withdraw/del")}-->
+<!--                <a class="layui-btn layui-btn-sm layui-btn-danger" data-confirm="确定要删除数据吗?" data-action="{:url('del')}" data-value="id#{$vo.id}">删 除</a>-->
+<!--                {/if}-->
+<!--            </td>-->
+        </tr>
+        {/foreach}
+        </tbody>
+    </table>
+    {empty name='list'}<span class="notdata">没有记录哦</span>{else}{$pagehtml|raw|default=''}{/empty}
+</div>
+<script>
+        function tankuang(url){
+            var loadstr = '<video width="100%" height="100%"  controls="controls" autobuffer="autobuffer"  autoplay="autoplay" loop="loop"><source src="'+ url +'" type="video/mp4"></source></video>'
+            layer.open({
+                type: 1,
+                title: '播放视频',
+                content: loadstr,
+            });
+        }
+</script>
+{/block}
+

+ 30 - 0
application/store/view/user_withdraw/index_search.html

@@ -0,0 +1,30 @@
+<fieldset>
+    <legend>条件搜索</legend>
+    <form class="layui-form layui-form-pane form-search" action="{:request()->url()}" onsubmit="return false" method="get" autocomplete="off">
+        <div class="layui-form-item layui-inline">
+            <label class="layui-form-label">用户昵称</label>
+            <div class="layui-input-inline">
+                <input name="nickname" value="{$Think.get.nickname|default=''}" placeholder="请输入用户昵称" class="layui-input">
+            </div>
+        </div>
+        <div class="layui-form-item layui-inline">
+            <label class="layui-form-label">支付状态</label>
+            <div class="layui-input-inline">
+                <select class="layui-select" name="paid">
+                    {foreach [''=>'- 全部状态 -','1'=>'已支付','0'=>'未支付'] as $k=>$v}
+                    {eq name='Think.get.paid' value='$k.""'}
+                    <option selected value="{$k}">{$v}</option>
+                    {else}
+                    <option value="{$k}">{$v}</option>
+                    {/eq}
+                    {/foreach}
+                </select>
+            </div>
+        </div>
+
+        <div class="layui-form-item layui-inline">
+            <button class="layui-btn layui-btn-primary"><i class="layui-icon">&#xe615;</i> 搜 索</button>
+        </div>
+    </form>
+    <script>form.render()</script>
+</fieldset>

+ 2 - 1
composer.json

@@ -26,7 +26,8 @@
     "zhaolicheng89/payment": "^1.0",
     "alipaysdk/easysdk": "^2.0",
     "gdali/baiduyuyin-sdk": "dev-master",
-    "hg/apidoc": "1.1.x"
+    "hg/apidoc": "1.1.x",
+    "overtrue/wechat": "~4.0"
   },
   "repositories": {
     "packagist": {

File diff suppressed because it is too large
+ 1363 - 109
composer.lock


+ 0 - 0
config/apidoc.php


+ 0 - 0
route/app.php


+ 0 - 74
vendor/bin/jp.php

@@ -1,74 +0,0 @@
-#!/usr/bin/env php
-<?php
-
-if (file_exists(__DIR__ . '/../vendor/autoload.php')) {
-    require __DIR__ . '/../vendor/autoload.php';
-} elseif (file_exists(__DIR__ . '/../../../autoload.php')) {
-    require __DIR__ . '/../../../autoload.php';
-} elseif (file_exists(__DIR__ . '/../autoload.php')) {
-    require __DIR__ . '/../autoload.php';
-} else {
-    throw new RuntimeException('Unable to locate autoload.php file.');
-}
-
-use JmesPath\Env;
-use JmesPath\DebugRuntime;
-
-$description = <<<EOT
-Runs a JMESPath expression on the provided input or a test case.
-
-Provide the JSON input and expression:
-    echo '{}' | jp.php expression
-
-Or provide the path to a compliance script, a suite, and test case number:
-    jp.php --script path_to_script --suite test_suite_number --case test_case_number [expression]
-
-EOT;
-
-$args = [];
-$currentKey = null;
-for ($i = 1, $total = count($argv); $i < $total; $i++) {
-    if ($i % 2) {
-        if (substr($argv[$i], 0, 2) == '--') {
-            $currentKey = str_replace('--', '', $argv[$i]);
-        } else {
-            $currentKey = trim($argv[$i]);
-        }
-    } else {
-        $args[$currentKey] = $argv[$i];
-        $currentKey = null;
-    }
-}
-
-$expression = $currentKey;
-
-if (isset($args['file']) || isset($args['suite']) || isset($args['case'])) {
-    if (!isset($args['file']) || !isset($args['suite']) || !isset($args['case'])) {
-        die($description);
-    }
-    // Manually run a compliance test
-    $path = realpath($args['file']);
-    file_exists($path) or die('File not found at ' . $path);
-    $json = json_decode(file_get_contents($path), true);
-    $set = $json[$args['suite']];
-    $data = $set['given'];
-    if (!isset($expression)) {
-        $expression = $set['cases'][$args['case']]['expression'];
-        echo "Expects\n=======\n";
-        if (isset($set['cases'][$args['case']]['result'])) {
-            echo json_encode($set['cases'][$args['case']]['result'], JSON_PRETTY_PRINT) . "\n\n";
-        } elseif (isset($set['cases'][$args['case']]['error'])) {
-            echo "{$set['cases'][$argv['case']]['error']} error\n\n";
-        } else {
-            echo "NULL\n\n";
-        }
-    }
-} elseif (isset($expression)) {
-    // Pass in an expression and STDIN as a standalone argument
-    $data = json_decode(stream_get_contents(STDIN), true);
-} else {
-    die($description);
-}
-
-$runtime = new DebugRuntime(Env::createRuntime());
-$runtime($expression, $data);

+ 1 - 0
vendor/bin/jp.php

@@ -0,0 +1 @@
+../mtdowling/jmespath.php/bin/jp.php

Some files were not shown because too many files changed in this diff