hrjy 3 rokov pred
rodič
commit
184dc2aff9
100 zmenil súbory, kde vykonal 29248 pridanie a 0 odobranie
  1. 3 0
      .constant
  2. 1 0
      .env
  3. 1 0
      .example.env
  4. 8 0
      .htaccess
  5. 62 0
      .idea/php.xml
  6. 6 0
      .idea/vcs.xml
  7. 8497 0
      .idea/workspace.xml
  8. 42 0
      .travis.yml
  9. 2 0
      .version
  10. 33 0
      LICENSE.txt
  11. 1 0
      app/.htaccess
  12. 24 0
      app/AppService.php
  13. 68 0
      app/ExceptionHandle.php
  14. 19 0
      app/Request.php
  15. 158 0
      app/admin/common.php
  16. 25 0
      app/admin/config/route.php
  17. 20 0
      app/admin/config/view.php
  18. 36 0
      app/admin/controller/AdminException.php
  19. 89 0
      app/admin/controller/AuthController.php
  20. 603 0
      app/admin/controller/Index.php
  21. 67 0
      app/admin/controller/Login.php
  22. 118 0
      app/admin/controller/SystemBasic.php
  23. 21 0
      app/admin/controller/Test.php
  24. 346 0
      app/admin/controller/agent/AgentManage.php
  25. 224 0
      app/admin/controller/article/Article.php
  26. 159 0
      app/admin/controller/article/ArticleCategory.php
  27. 196 0
      app/admin/controller/article/WechatNews.php
  28. 524 0
      app/admin/controller/auction/Auction.php
  29. 84 0
      app/admin/controller/auction/AuctionApply.php
  30. 259 0
      app/admin/controller/auction/AuctionBooking.php
  31. 282 0
      app/admin/controller/auction/AuctionGu.php
  32. 291 0
      app/admin/controller/auction/AuctionOrder.php
  33. 281 0
      app/admin/controller/auction/AuctionProduct.php
  34. 47 0
      app/admin/controller/auction/AuctionSite.php
  35. 130 0
      app/admin/controller/finance/Finance.php
  36. 154 0
      app/admin/controller/finance/UserExtract.php
  37. 141 0
      app/admin/controller/finance/UserRecharge.php
  38. 955 0
      app/admin/controller/order/StoreOrder.php
  39. 645 0
      app/admin/controller/order/combinationOrder.php
  40. 733 0
      app/admin/controller/record/Record.php
  41. 87 0
      app/admin/controller/record/StoreStatistics.php
  42. 175 0
      app/admin/controller/routine/RoutineTemplate.php
  43. 184 0
      app/admin/controller/setting/ShippingTemplates.php
  44. 222 0
      app/admin/controller/setting/SystemAdmin.php
  45. 151 0
      app/admin/controller/setting/SystemCity.php
  46. 376 0
      app/admin/controller/setting/SystemConfig.php
  47. 179 0
      app/admin/controller/setting/SystemConfigTab.php
  48. 127 0
      app/admin/controller/setting/SystemGroup.php
  49. 291 0
      app/admin/controller/setting/SystemGroupData.php
  50. 208 0
      app/admin/controller/setting/SystemMenus.php
  51. 130 0
      app/admin/controller/setting/SystemNotice.php
  52. 579 0
      app/admin/controller/setting/SystemPlat.php
  53. 142 0
      app/admin/controller/setting/SystemRole.php
  54. 65 0
      app/admin/controller/sms/SmsAdmin.php
  55. 140 0
      app/admin/controller/sms/SmsConfig.php
  56. 82 0
      app/admin/controller/sms/SmsPay.php
  57. 70 0
      app/admin/controller/sms/SmsPublicTemp.php
  58. 57 0
      app/admin/controller/sms/SmsRecord.php
  59. 97 0
      app/admin/controller/sms/SmsTemplateApply.php
  60. 1008 0
      app/admin/controller/store/CopyTaobao.php
  61. 198 0
      app/admin/controller/store/StoreCategory.php
  62. 154 0
      app/admin/controller/store/StoreInfoMana.php
  63. 724 0
      app/admin/controller/store/StoreProduct.php
  64. 175 0
      app/admin/controller/store/StoreProductReply.php
  65. 112 0
      app/admin/controller/store/StoreProductRule.php
  66. 86 0
      app/admin/controller/system/Clear.php
  67. 121 0
      app/admin/controller/system/Express.php
  68. 50 0
      app/admin/controller/system/SystemAttachment.php
  69. 248 0
      app/admin/controller/system/SystemCleardata.php
  70. 245 0
      app/admin/controller/system/SystemDatabackup.php
  71. 303 0
      app/admin/controller/system/SystemFile.php
  72. 39 0
      app/admin/controller/system/SystemLog.php
  73. 177 0
      app/admin/controller/system/SystemStore.php
  74. 198 0
      app/admin/controller/system/SystemStoreStaff.php
  75. 377 0
      app/admin/controller/system/SystemUpgradeclient.php
  76. 88 0
      app/admin/controller/system/SystemVerifyOrder.php
  77. 522 0
      app/admin/controller/ump/StoreBargain.php
  78. 572 0
      app/admin/controller/ump/StoreCombination.php
  79. 321 0
      app/admin/controller/ump/StoreCoupon.php
  80. 60 0
      app/admin/controller/ump/StoreCouponIssue.php
  81. 117 0
      app/admin/controller/ump/StoreCouponUser.php
  82. 592 0
      app/admin/controller/ump/StoreMix.php
  83. 592 0
      app/admin/controller/ump/StoreSeckill.php
  84. 78 0
      app/admin/controller/ump/UserPoint.php
  85. 862 0
      app/admin/controller/user/User.php
  86. 111 0
      app/admin/controller/user/UserAuth.php
  87. 101 0
      app/admin/controller/user/UserGroup.php
  88. 341 0
      app/admin/controller/user/UserLevel.php
  89. 303 0
      app/admin/controller/user/UserNotice.php
  90. 42 0
      app/admin/controller/wechat/Menus.php
  91. 195 0
      app/admin/controller/wechat/Reply.php
  92. 168 0
      app/admin/controller/wechat/StoreService.php
  93. 34 0
      app/admin/controller/wechat/WechatMessage.php
  94. 279 0
      app/admin/controller/wechat/WechatNewsCategory.php
  95. 135 0
      app/admin/controller/wechat/WechatTemplate.php
  96. 390 0
      app/admin/controller/wechat/WechatUser.php
  97. 7 0
      app/admin/controller/wechat/index.php
  98. 278 0
      app/admin/controller/widget/Images.php
  99. 75 0
      app/admin/controller/widget/Video.php
  100. 53 0
      app/admin/controller/widget/Widgets.php

+ 3 - 0
.constant

@@ -0,0 +1,3 @@
+<?php
+define('INSTALL_DATE',1647842104);
+define('SERIALNUMBER','TVQ2b7');

+ 1 - 0
.env

@@ -0,0 +1 @@
+APP_DEBUG = true

[APP]
DEFAULT_TIMEZONE = Asia/Shanghai

[DATABASE]
TYPE = mysql
HOSTNAME = 127.0.0.1
HOSTPORT = 3306
USERNAME = root
PASSWORD = 'root'
DATABASE = new_qudou
PREFIX = eb_
CHARSET = utf8
DEBUG = true

[LANG]
default_lang = zh-cn

+ 1 - 0
.example.env

@@ -0,0 +1 @@
+APP_DEBUG = true

[APP]
DEFAULT_TIMEZONE = Asia/Shanghai

[DATABASE]
TYPE = mysql
HOSTNAME = 127.0.0.1
DATABASE = test
USERNAME = username
PASSWORD = password
HOSTPORT = 3306
CHARSET = utf8
DEBUG = true

[LANG]
default_lang = zh-cn

+ 8 - 0
.htaccess

@@ -0,0 +1,8 @@
+<IfModule mod_rewrite.c>
+  Options +FollowSymlinks -Multiviews
+  RewriteEngine On
+
+  RewriteCond %{REQUEST_FILENAME} !-d
+  RewriteCond %{REQUEST_FILENAME} !-f
+  RewriteRule ^(.*)$ index.php/$1 [QSA,PT,L]
+</IfModule>

+ 62 - 0
.idea/php.xml

@@ -0,0 +1,62 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project version="4">
+  <component name="PhpIncludePathManager">
+    <include_path>
+      <path value="$PROJECT_DIR$/vendor/guzzle/guzzle" />
+      <path value="$PROJECT_DIR$/vendor/symfony/translation-contracts" />
+      <path value="$PROJECT_DIR$/vendor/symfony/polyfill-mbstring" />
+      <path value="$PROJECT_DIR$/vendor/firebase/php-jwt" />
+      <path value="$PROJECT_DIR$/vendor/symfony/polyfill-php70" />
+      <path value="$PROJECT_DIR$/vendor/symfony/var-dumper" />
+      <path value="$PROJECT_DIR$/vendor/symfony/event-dispatcher" />
+      <path value="$PROJECT_DIR$/vendor/symfony/polyfill-php72" />
+      <path value="$PROJECT_DIR$/vendor/symfony/http-foundation" />
+      <path value="$PROJECT_DIR$/vendor/symfony/translation" />
+      <path value="$PROJECT_DIR$/vendor/symfony/process" />
+      <path value="$PROJECT_DIR$/vendor/overtrue/wechat" />
+      <path value="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge" />
+      <path value="$PROJECT_DIR$/vendor/overtrue/socialite" />
+      <path value="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php" />
+      <path value="$PROJECT_DIR$/vendor/opis/closure" />
+      <path value="$PROJECT_DIR$/vendor/composer" />
+      <path value="$PROJECT_DIR$/vendor/psr/http-message" />
+      <path value="$PROJECT_DIR$/vendor/psr/simple-cache" />
+      <path value="$PROJECT_DIR$/vendor/psr/log" />
+      <path value="$PROJECT_DIR$/vendor/psr/cache" />
+      <path value="$PROJECT_DIR$/vendor/psr/container" />
+      <path value="$PROJECT_DIR$/vendor/pimple/pimple" />
+      <path value="$PROJECT_DIR$/vendor/spatie/macroable" />
+      <path value="$PROJECT_DIR$/vendor/ralouphie/getallheaders" />
+      <path value="$PROJECT_DIR$/vendor/qiniu/php-sdk" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-container" />
+      <path value="$PROJECT_DIR$/vendor/workerman/channel" />
+      <path value="$PROJECT_DIR$/vendor/xaboy/form-builder" />
+      <path value="$PROJECT_DIR$/vendor/monolog/monolog" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-queue" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-template" />
+      <path value="$PROJECT_DIR$/vendor/workerman/workerman" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-cache" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-view" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-image" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-captcha" />
+      <path value="$PROJECT_DIR$/vendor/doctrine/cache" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-helper" />
+      <path value="$PROJECT_DIR$/vendor/topthink/framework" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-factory" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-orm" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-log" />
+      <path value="$PROJECT_DIR$/vendor/nesbot/carbon" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-multi-app" />
+      <path value="$PROJECT_DIR$/vendor/paragonie/random_compat" />
+      <path value="$PROJECT_DIR$/vendor/dh2y/think-qrcode" />
+      <path value="$PROJECT_DIR$/vendor/league/flysystem" />
+      <path value="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter" />
+      <path value="$PROJECT_DIR$/vendor/phpoffice/phpexcel" />
+      <path value="$PROJECT_DIR$/vendor/guzzlehttp/psr7" />
+      <path value="$PROJECT_DIR$/vendor/guzzlehttp/promises" />
+      <path value="$PROJECT_DIR$/vendor/guzzlehttp/guzzle" />
+      <path value="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5" />
+    </include_path>
+  </component>
+  <component name="PhpProjectSharedConfiguration" php_language_level="7.1" />
+</project>

+ 6 - 0
.idea/vcs.xml

@@ -0,0 +1,6 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project version="4">
+  <component name="VcsDirectoryMappings">
+    <mapping directory="$PROJECT_DIR$" vcs="Git" />
+  </component>
+</project>

+ 8497 - 0
.idea/workspace.xml

@@ -0,0 +1,8497 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project version="4">
+  <component name="AutoImportSettings">
+    <option name="autoReloadType" value="SELECTIVE" />
+  </component>
+  <component name="ChangeListManager">
+    <list default="true" id="f1059816-03fc-437b-9cdc-1d5433440936" name="变更" comment="commit">
+      <change afterPath="$PROJECT_DIR$/.constant" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/.env" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/.example.env" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/.htaccess" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/.idea/php.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/.idea/vcs.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/.travis.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/.version" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/LICENSE.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/.htaccess" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/AppService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/ExceptionHandle.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/Request.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/common.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/config/route.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/config/view.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/AdminException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/AuthController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/Index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/Login.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/SystemBasic.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/Test.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/agent/AgentManage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/article/Article.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/article/ArticleCategory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/article/WechatNews.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/auction/Auction.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/auction/AuctionApply.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/auction/AuctionBooking.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/auction/AuctionGu.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/auction/AuctionOrder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/auction/AuctionProduct.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/auction/AuctionSite.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/finance/Finance.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/finance/UserExtract.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/finance/UserRecharge.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/order/StoreOrder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/order/combinationOrder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/record/Record.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/record/StoreStatistics.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/routine/RoutineTemplate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/setting/ShippingTemplates.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/setting/SystemAdmin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/setting/SystemCity.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/setting/SystemConfig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/setting/SystemConfigTab.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/setting/SystemGroup.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/setting/SystemGroupData.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/setting/SystemMenus.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/setting/SystemNotice.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/setting/SystemPlat.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/setting/SystemRole.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/sms/SmsAdmin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/sms/SmsConfig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/sms/SmsPay.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/sms/SmsPublicTemp.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/sms/SmsRecord.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/sms/SmsTemplateApply.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/store/CopyTaobao.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/store/StoreCategory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/store/StoreInfoMana.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/store/StoreProduct.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/store/StoreProductReply.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/store/StoreProductRule.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/system/Clear.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/system/Express.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/system/SystemAttachment.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/system/SystemCleardata.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/system/SystemDatabackup.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/system/SystemFile.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/system/SystemLog.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/system/SystemStore.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/system/SystemStoreStaff.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/system/SystemUpgradeclient.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/system/SystemVerifyOrder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/ump/StoreBargain.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/ump/StoreCombination.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/ump/StoreCoupon.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/ump/StoreCouponIssue.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/ump/StoreCouponUser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/ump/StoreMix.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/ump/StoreSeckill.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/ump/UserPoint.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/user/User.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/user/UserAuth.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/user/UserGroup.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/user/UserLevel.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/user/UserNotice.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/wechat/Menus.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/wechat/Reply.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/wechat/StoreService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/wechat/WechatMessage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/wechat/WechatNewsCategory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/wechat/WechatTemplate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/wechat/WechatUser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/wechat/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/widget/Images.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/widget/Video.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/controller/widget/Widgets.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/event.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/article/Article.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/article/ArticleCategory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/auction/Auction.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/auction/AuctionApply.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/auction/AuctionBooking.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/auction/AuctionGu.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/auction/AuctionOrder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/auction/AuctionProduct.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/auction/AuctionSite.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/finance/FinanceModel.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/order/StoreOrder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/order/StoreOrderCartInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/order/StoreOrderStatus.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/record/StoreStatistics.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/record/StoreVisit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/routine/RoutineFormId.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/routine/RoutineTemplate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/sms/SmsRecord.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/store/StoreCategory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/store/StoreCouponUser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/store/StoreDescription.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/store/StoreProduct.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/store/StoreProductAttr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/store/StoreProductAttrResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/store/StoreProductAttrValue.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/store/StoreProductCate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/store/StoreProductRelation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/store/StoreProductReply.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/store/StoreVisit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/Express.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/ShippingTemplates.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/ShippingTemplatesFree.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/ShippingTemplatesRegion.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemAdmin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemAttachment.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemAttachmentCategory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemAttachmentType.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemCity.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemConfig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemConfigTab.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemFile.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemGroup.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemGroupData.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemLog.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemMenus.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemNotice.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemRole.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemStore.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemStoreStaff.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemUserLevel.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemUserTask.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/system/SystemVerifyOrder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StoreBargain.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StoreBargainUser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StoreBargainUserHelp.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StoreCombination.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StoreCombinationAttr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StoreCombinationAttrResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StoreCombinationAttrValue.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StoreCoupon.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StoreCouponIssue.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StoreCouponIssueUser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StoreCouponUser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StoreMix.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StorePink.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StoreSeckill.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StoreSeckillAttr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StoreSeckillAttrResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StoreSeckillAttrValue.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/ump/StoreSeckillTime.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/user/User.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/user/UserAddress.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/user/UserBill.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/user/UserExtract.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/user/UserGroup.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/user/UserLevel.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/user/UserNotice.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/user/UserNoticeSee.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/user/UserPoint.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/user/UserRecharge.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/user/UserTaskFinish.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/wechat/StoreService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/wechat/StoreServiceLog.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/wechat/WechatMessage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/wechat/WechatNews.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/wechat/WechatNewsCategory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/wechat/WechatQrcode.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/wechat/WechatReply.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/wechat/WechatTemplate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/model/wechat/WechatUser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/provider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/readme.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/agent/agent_manage/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/agent/agent_manage/now_money.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/agent/agent_manage/stair.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/agent/agent_manage/stair_order.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/article/article/create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/article/article/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/article/article/relation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/article/article_category/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction/create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction/edit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction/fz.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction/product.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction/product_create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction/product_edit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction_apply/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction_booking/create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction_booking/edit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction_booking/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction_gu/create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction_gu/edit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction_gu/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction_order/create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction_order/edit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction_order/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction_product/create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction_product/edit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction_product/fz.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction_product/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/auction/auction_site/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/finance/finance/bill.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/finance/finance/bill1.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/finance/finance/commission_list.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/finance/finance/content_info.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/finance/user_extract/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/finance/user_recharge/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/index/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/index/main.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/login/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/order/store_order/express.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/order/store_order/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/order/store_order/order_goods.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/order/store_order/order_info.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/order/store_order/order_spread_user.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/order/store_order/order_status.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/order/store_order/orderchart.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/order/store_order/write_order.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/order/store_order_pink/order_status.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/public/404.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/public/500.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/public/common_form.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/public/container.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/public/edit_content.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/public/error.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/public/exception.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/public/form-builder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/public/frame_footer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/public/frame_head.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/public/head.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/public/inner_footer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/public/inner_page.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/public/layui.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/public/notice.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/public/style.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/public/success.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/chart_bargain.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/chart_cash.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/chart_combination.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/chart_coupon.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/chart_order.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/chart_product.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/chart_rebate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/chart_recharge.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/chart_score.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/chart_seckill.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/product_info.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/ranking_commission.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/ranking_point.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/ranking_saleslists.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/user_attr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/user_business_chart.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/user_chart.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/record/user_distribution_chart.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/record/store_statistics/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/routine/routine_template/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/shipping_templates/add.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/shipping_templates/city.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/shipping_templates/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_admin/admin_info.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_admin/create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_admin/edit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_admin/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_city/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_config/create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_config/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_config/index_alone.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_config_tab/create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_config_tab/create_base.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_config_tab/edit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_config_tab/edit_cinfig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_config_tab/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_config_tab/sonconfigtab.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_group/create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_group/edit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_group/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_group_data/create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_group_data/edit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_group_data/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_menus/edit_content.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_menus/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_notice/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_notice/message.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_plat/express_open.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_plat/forget.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_plat/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_plat/login.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_plat/meal.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_plat/modify.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_plat/register.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_plat/sms_open.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_plat/sms_temp.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_role/create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_role/edit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/setting/system_role/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/sms/sms_admin/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/sms/sms_config/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/sms/sms_pay/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/sms/sms_public_temp/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/sms/sms_record/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/sms/sms_template_apply/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/store/copy_taobao/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/store/copy_taobao/product.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/store/store_category/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/store/store_product/attr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/store/store_product/collect.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/store/store_product/create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/store/store_product/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/store/store_product/like.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/store/store_product/statistics.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/store/store_product_reply/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/store/store_product_reply/select.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/store/store_product_rule/create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/store/store_product_rule/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/system/clear/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/system/express/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/system/system_cleardata/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/system/system_databackup/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/system/system_file/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/system/system_file/opendir.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/system/system_file/openfile.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/system/system_log/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/system/system_notice/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/system/system_notice/message.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/system/system_store/add.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/system/system_store/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/system/system_store/select_address.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/system/system_store_staff/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/system/system_store_staff/select.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/system/system_upgradeclient/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/system/system_verify_order/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_bargain/attr_list.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_bargain/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_bargain/product_list.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_combination/attr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_combination/attr_list.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_combination/combina_list.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_combination/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_combination/order_pink.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_combination/product_list.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_coupon/create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_coupon/grant.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_coupon/grant_all.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_coupon/grant_group.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_coupon/grant_subscribe.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_coupon/grant_tag.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_coupon/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_coupon/select.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_coupon_issue/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_coupon_issue/issue_log.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_coupon_user/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_mix/attr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_mix/attr_list.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_mix/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_mix/product_list.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_seckill/attr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_seckill/attr_list.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_seckill/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/store_seckill/product_list.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/ump/user_point/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/user/user/group.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/user/user/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/user/user/rank.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/user/user/see.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/user/user/user_analysis.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/user/user_auth/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/user/user_group/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/user/user_level/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/user/user_level/tash.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/user/user_notice/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/user/user_notice/notice.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/user/user_notice/user.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/user/user_notice/user_create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/menus/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/reply/add_keyword.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/reply/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/reply/keyword.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/store_service/chat_list.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/store_service/chat_user.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/store_service/create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/store_service/edit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/store_service/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/store_service/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/wechat_message/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/wechat_news_category/append.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/wechat_news_category/create.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/wechat_news_category/edit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/wechat_news_category/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/wechat_news_category/select.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/wechat_news_category/send_news.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/wechat_template/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/wechat_user/group.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/wechat_user/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/wechat_user/now_money.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/wechat_user/stair.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/wechat/wechat_user/tag.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/widget/icon.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/widget/images.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/widget/video/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/widget/video/vedio.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/admin/view/widget/widgets/productlist.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/ApiExceptionHandle.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/common.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/config/route.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/AuthController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/BaiduController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/DouYiCantroller.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/PublicController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/ZjSMSServerService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/activity/StoreBargainController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/activity/StoreCombinationController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/activity/StoreSeckillController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/admin/StoreOrderController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/auction/AuctionController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/auction/AuctionOrderController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/auction/AuctionProductController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/order/StoreOrderController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/publics/ArticleCategoryController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/publics/ArticleController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/store/CategoryController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/store/StoreCartController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/store/StoreCouponsController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/store/StoreProductController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/user/StoreService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/user/UserBillController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/user/UserController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/user/UserExtractController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/user/UserLevelController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/user/UserRechargeController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/wechat/AuthController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/controller/wechat/WechatController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/event.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/api/provider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/common.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/event.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/http/middleware/AllowOriginMiddleware.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/http/middleware/AuthTokenMiddleware.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/http/middleware/CustomerMiddleware.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/http/validates/user/AddressValidate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/http/validates/user/RegisterValidates.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/http/validates/user/UserValidates.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/middleware.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/article/Article.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/article/ArticleCategory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/article/ArticleContent.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/auction/Auction.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/auction/AuctionApply.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/auction/AuctionBooking.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/auction/AuctionFrozen.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/auction/AuctionGu.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/auction/AuctionOrder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/auction/AuctionPay.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/auction/AuctionProduct.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/auction/AuctionTime.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/routine/RoutineCode.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/routine/RoutineFormId.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/routine/RoutineQrcode.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/routine/RoutineTemplate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreBargain.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreBargainUser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreBargainUserHelp.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreCart.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreCategory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreCombination.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreCoupon.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreCouponIssue.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreCouponIssueUser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreCouponUser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreOrder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreOrderCartInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreOrderStatus.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StorePink.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreProduct.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreProductAttr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreProductRelation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreProductReply.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreProductRule.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreSeckill.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreServiceLog.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/store/StoreVisit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/system/Cache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/system/Express.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/system/SystemCity.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/system/SystemGroupData.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/system/SystemStore.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/system/SystemStoreStaff.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/system/SystemUserLevel.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/system/SystemUserTask.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/user/User.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/user/UserAddress.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/user/UserBill.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/user/UserExtract.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/user/UserLevel.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/user/UserNotice.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/user/UserRecharge.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/user/UserSign.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/user/UserTaskFinish.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/user/UserToken.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/models/user/WechatUser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/provider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/service.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/app/wap/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/backup/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/build.example.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/composer.lock" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/app.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/cache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/captcha.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/console.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/cookie.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/database.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/filesystem.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/lang.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/log.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/pay.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/printer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/product.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/qrcode.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/queue.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/route.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/session.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/sms.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/template.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/trace.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/upload.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/view.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/config/workerman.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/basic/BaseAuth.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/basic/BaseController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/basic/BaseExpress.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/basic/BaseManager.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/basic/BaseMessage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/basic/BaseModel.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/basic/BasePay.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/basic/BasePrinter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/basic/BaseProduct.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/basic/BaseSms.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/basic/BaseSmss.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/basic/BaseStorage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/basic/BaseUpload.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/command/Queue.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/command/Timer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/command/Workerman.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/exceptions/AuthException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/exceptions/SmsException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/exceptions/TemplateException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/exceptions/UploadException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/interfaces/JobInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/interfaces/ListenerInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/interfaces/MiddlewareInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/interfaces/ProviderInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/jobs/OrderJob.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/jobs/TestJob.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/listeners/Listener.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/listeners/user/UserLogin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/repositories/CustomerRepository.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/repositories/MessageRepositories.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/repositories/NoticeRepositories.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/repositories/OrderRepository.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/repositories/PaymentRepositories.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/repositories/ProductRepositories.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/repositories/ShortLetterRepositories.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/repositories/UserRepository.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/AccessTokenServeService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/CacheService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/CrmebPlatService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/ExpressService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/FileService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/FormBuilder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/GroupDataService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/HttpService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/JsonService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/MiniProgramService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/MysqlBackupService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/PHPExcelService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/ProgramTemplateService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/QrcodeService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/SMSService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/SubscribeTemplateService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/SystemConfigService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/UpgradeService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/UtilService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/WechatService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/WechatTemplateService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/YLYService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/express/Express.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/express/storage/Express.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/printer/AccessToken.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/printer/Printer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/printer/storage/YiLianYun.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/product/Product.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/product/storage/Copy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/qrcode/Qrcode.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/sms/Sms.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/sms/storage/Aliyun.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/sms/storage/Sms.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/sms/storage/Yunxin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/subscribe/ProgramProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/subscribe/ProgramSubscribe.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/template/Template.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/template/storage/Subscribe.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/template/storage/Wechat.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/upload/Upload.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/upload/storage/Cos.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/upload/storage/Local.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/upload/storage/Oss.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/upload/storage/Qiniu.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/wechatlive/ProgramProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/wechatlive/ProgramWechatLive.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/workerman/ChannelService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/workerman/Response.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/workerman/WorkermanHandle.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/workerman/WorkermanService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/workerman/chat/ChatHandle.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/services/workerman/chat/ChatService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/subscribes/MaterialSubscribe.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/subscribes/MessageSubscribe.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/subscribes/OrderSubscribe.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/subscribes/ProductSubscribe.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/subscribes/SystemSubscribe.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/subscribes/TaskSubscribe.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/subscribes/UserSubscribe.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/traits/CurdControllerTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/traits/ErrorTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/traits/JobTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/traits/JwtAuthModelTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/traits/LogicTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/traits/ModelTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/utils/Canvas.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/utils/Hook.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/utils/Json.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/utils/Queue.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/crmeb/utils/Redis.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/.htaccess" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/favicon.ico" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/app.063d73b5.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-11f06038.2b656289.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-12b4ad50.527fb7b5.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-19b5e344.48798326.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-1e7725ab.b5ada5eb.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-22637d46.ab18b94f.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-243a9bb7.c25821e7.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-2539197c.bf372789.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-2ac48319.76f86e0e.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-2df2bc60.30674964.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-3383bac4.76c78fa8.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-3467d3c0.6f48bbde.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-36e2c60a.b7e5948b.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-41fea431.312c5aa9.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-46d8cc10.461d1dfa.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-47d0e48c.5dae48a7.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-4938e4b2.088453d8.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-4ca56ec5.f67527fa.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-56c4408f.cdcf3495.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-5bfab075.20e47d23.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-62a588bc.2a3db591.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-6381e1fd.672d3ed9.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-68fb707c.9f9f5260.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-6a1c774d.ef3500b3.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-6c1e6317.12862fbb.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-708dd8a7.8806647d.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-7215e7d0.439010b6.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-758d3b81.d9104d8f.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-79c30c7c.bb2dd156.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-aedf3bda.6fc90e66.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-b95bb1ec.c1c969b2.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-b99d1b9a.d02dea3c.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-c2eda708.5e093075.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-e05bc250.8f9ed549.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-ecd9fb16.f2c608d1.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-ffb6ef24.6900026e.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/chunk-vendors.b22a4577.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/css/login.090284eb.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/fonts/GuildfordProBook 5.d7582c72.otf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/fonts/iconfont.0b5c62e9.woff" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/fonts/iconfont.5315e22d.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/fonts/iconfont.9be78861.eot" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/404.c67ac50c.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/baokuan.6313c8c8.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/bargainBg.08e23e65.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/close.446e8669.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/commission.a895a872.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/coupon-window.8679fbfe.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/coupon1.7323df42.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/coupon2.6e69dcb5.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/cut-bg.ac7ab8f1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/cut1.40fda88f.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/cut2.7e39d604.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/examine.70b662a8.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/gift.bde2a03c.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/group.2ee29678.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/h5.d1ea1d34.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/iconfont.5893113a.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/index-bg.7128c2eb.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/light.90f47a4d.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/line.05bf1c84.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/live-logo.419313da.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/logo2.47964cc3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/money.136360a9.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/noAddress.d76a1cef.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/noCart.6f2abfef.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/noCollection.46d9f620.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/noCoupon.e524084b.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/noExpress.375a0428.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/noGood.7aec7edd.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/noNews.5f227afa.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/noOrder.90017ce2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/noSearch.72221156.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/one.2814de22.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/oneT.ec916ffb.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/open.7da41017.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/orderIndex.336341f0.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/orderTime.e95f9090.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/pricetitle.d0496d6f.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/promoter.af8f88db.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/promotionBg.79d3d197.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/recording.f7ef8fc2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/red-packets.5f46f82b.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/register.b978b022.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/registerw.b3c17e1c.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/scan.2ca2147e.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/score.30715cf5.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/sh.d28fb46a.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/share-info.fa0bedf8.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/sheet_google_64_indexed_128.04280c7a.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/support.37442214.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/three.2162defb.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/threeT.98629534.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/two.1ea1d146.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/twoT.d1361a7a.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/value.7469f35b.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/videos.5a8e6dc1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/writeOff.e1bf8d03.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/img/writeOffBg.592c0574.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/app.1369f474.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/app.1369f474.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-074d26c0.d9b0c8e3.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-074d26c0.d9b0c8e3.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-0b32185c.18b7fedc.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-0b32185c.18b7fedc.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-11f06038.a79081b8.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-11f06038.a79081b8.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-126715f2.239c6b7f.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-126715f2.239c6b7f.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-12b4ad50.4bb5bd1d.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-12b4ad50.4bb5bd1d.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-19b5e344.34a7d57c.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-19b5e344.34a7d57c.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-1e7725ab.cbc904d3.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-1e7725ab.cbc904d3.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-22637d46.781ae37a.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-22637d46.781ae37a.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-243a9bb7.68cae940.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-243a9bb7.68cae940.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2539197c.02f78bac.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2539197c.02f78bac.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2ac48319.43b250f5.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2ac48319.43b250f5.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0b995a.dda92ab9.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0b995a.dda92ab9.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0c09da.56ace22e.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0c09da.56ace22e.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0c1002.75fe3d4c.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0c1002.75fe3d4c.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0c4265.e0056573.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0c4265.e0056573.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0d0177.a094f8d4.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0d0177.a094f8d4.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0d3247.bb82e0a8.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0d3247.bb82e0a8.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0d6b8d.5d56fc1e.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0d6b8d.5d56fc1e.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0da964.a8ecb5f8.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0da964.a8ecb5f8.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0e2116.f7bbddf4.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0e2116.f7bbddf4.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0f0b4a.daea60bb.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d0f0b4a.daea60bb.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d21f45b.dc2b5e22.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d21f45b.dc2b5e22.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d5271a2.c3fdf8c6.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2d5271a2.c3fdf8c6.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2df2bc60.ec3c2e44.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-2df2bc60.ec3c2e44.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-3383bac4.38312fae.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-3383bac4.38312fae.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-3467d3c0.aea30e69.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-3467d3c0.aea30e69.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-36e2c60a.97f2d86e.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-36e2c60a.97f2d86e.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-3c12acd2.20f12ff9.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-3c12acd2.20f12ff9.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-41fea431.0dc64fba.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-41fea431.0dc64fba.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-46d8cc10.84a1e987.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-46d8cc10.84a1e987.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-47d0e48c.05d1a42a.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-47d0e48c.05d1a42a.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-4938e4b2.c4151a4f.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-4938e4b2.c4151a4f.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-4ca56ec5.e3d11491.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-4ca56ec5.e3d11491.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-4d3f5c13.fd506878.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-4d3f5c13.fd506878.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-56c4408f.27c08b1b.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-56c4408f.27c08b1b.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-5bfab075.79191bcc.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-5bfab075.79191bcc.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-61576808.739fcfd2.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-61576808.739fcfd2.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-62a588bc.198cd815.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-62a588bc.198cd815.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-6381e1fd.0a871beb.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-6381e1fd.0a871beb.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-68fb707c.b3a32724.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-68fb707c.b3a32724.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-6a1c774d.c65739aa.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-6a1c774d.c65739aa.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-6b2f5ef2.de0db93f.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-6b2f5ef2.de0db93f.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-6c1e6317.e684465e.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-6c1e6317.e684465e.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-708dd8a7.efc08d73.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-708dd8a7.efc08d73.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-715c4f57.72c022c8.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-715c4f57.72c022c8.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-7215e7d0.b4782f5e.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-7215e7d0.b4782f5e.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-758d3b81.783655b5.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-758d3b81.783655b5.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-79c30c7c.c092ebd6.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-79c30c7c.c092ebd6.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-7b11e4aa.23bc693e.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-7b11e4aa.23bc693e.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-7f08916c.678fe296.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-7f08916c.678fe296.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-9cb98e8c.9d391844.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-9cb98e8c.9d391844.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-aedf3bda.f68a8c22.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-aedf3bda.f68a8c22.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-b6e494f4.b318c1eb.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-b6e494f4.b318c1eb.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-b95bb1ec.af08502f.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-b95bb1ec.af08502f.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-b99d1b9a.94c89262.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-b99d1b9a.94c89262.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-c2eda708.016c0755.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-c2eda708.016c0755.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-c70af1fc.4655ca25.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-c70af1fc.4655ca25.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-d764fe90.784c418c.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-d764fe90.784c418c.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-e05bc250.766cd902.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-e05bc250.766cd902.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-e14b291c.2a3765cf.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-e14b291c.2a3765cf.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-ecd9fb16.ae7095c8.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-ecd9fb16.ae7095c8.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-ffb6ef24.2286a05d.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-ffb6ef24.2286a05d.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-vendors.476320e4.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/chunk-vendors.476320e4.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/login.c09c6bd4.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/h5/js/login.c09c6bd4.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/css/cmy.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/error/emptyCart.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/error/errorImage.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/error/missing-face.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/appleIcon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/bdsj.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/btncz.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/c3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/c5.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/c6.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/c7.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/c8.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/dsjh.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/fanhui.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/gou.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/i1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/i2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/i3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/i4.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/i5.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/i6.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/i7.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/i8.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/img01.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/img02.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/img03.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/img04.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/img05.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/img06.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/img07.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/img08.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/img09.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/img10.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/img11.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/img12.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/kf.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/search-h.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/select.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/selected.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/sh-log.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/shdz.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/skxx.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/tool-1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/tool-2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/tool-3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/tool-4.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/tool-5.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/tool-6.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/u1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/u2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/u3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/u4.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/u5.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/uqd.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/uset.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/icon/wenhao.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/add.7d26cf79.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/add.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/address.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/afternoon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/afternoonicon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/ali.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/aliD.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/arc.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/back.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/backb.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/bank.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/bankD.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/bargainBg.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/been.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/bo.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/busy.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/call.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/cart.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/copy.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/delete.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/deletes.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/djs.d2f3b826.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/djs.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/evening.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/eveningicon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/fanhui.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/gong.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/goodtitle.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/gssy.a2a2d026.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/gssy.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/hall-bg.3ea75ec4.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/hall-bg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/hallbanner.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/hell-main.80d55f64.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/hell-main.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/hinco.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/hinfo-bg.6ecb3a63.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/hinfo-bg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img009.609fc055.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img009.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img01.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img010.becc4342.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img010.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img02.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img03.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img04.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img05.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img06.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img07.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img08.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img09.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img10.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img11.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img12.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img13.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img14.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img15.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img16.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img39.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img43.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img45.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img57.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/img74.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index-inco1.5698ffac.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index-inco1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index-inco2.8e82eedb.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index-inco2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index-inco3.e613bbca.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index-inco3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index-inco4.8be0772c.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index-inco4.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index-inco5.e5293f07.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index-inco5.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index-inco6.53843f45.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index-inco6.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index-inco7.6f877b2e.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index-inco7.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index-inco8.4d26664d.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index-inco8.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index-product.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index11.b49260e0.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/index14.66eb5893.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/integration.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/jian.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/jiantou.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/jifen.543823a7.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/jifen.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/jingt.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/jt.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/kf.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/lc1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/lc2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/lc3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/lc4.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/left.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/leisure.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/ling.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/log.34930231.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/log.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/message.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/money-bg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/morningicon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/new.9426485c.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/new.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/order1.035b3598.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/order1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/order2.fadf2be3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/order2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/order99.ca07636b.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/order99.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/people.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/productIcon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/qd.f50ab39e.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/quan.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/quaninco.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/real.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/right-bottom.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/sOut.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/sOut1.b15336ad.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/sOut1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/search.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/seckill-inco.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/seckill.ccaa1dd0.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/seckill.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/serve.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/sfzfm.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/sfzzm.c3b5ee98.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/sfzzm.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/share.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/shu.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/shua.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/sign-popup.60216616.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/sign-popup.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/sign.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/sim-bg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/store1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/store2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/store3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/success.da050e54.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/success.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/tbg-left.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/tbg-right.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/tongz-bg.6ac35c7d.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/tongz-bg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/top-bg.f567826a.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/top-bg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/uqd.378c3eba.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/user-bg.b212fecf.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/user-bg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/vip.49884fd4.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/vip.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/xrtd-bg.c6c038c0.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/xrtd-bg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/xrtd-log.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/yongjin-bg.6e270cd5.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/yongjin-bg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/yuan.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/yue.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/yueD.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/zheng.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/zhihuanjuan.16b86e69.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/zhihuanjuan.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/img/返回 (7).png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/index.a5c69d49.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/index/index06.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/index/index10.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/index/index11.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/index/index13.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/index/index14.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/chunk-vendors.a9cbb497.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/index.4b0b0b40.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/index.7cef0702.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/index.86056633.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/index.a73fb3d8.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-cart-cart.37569835.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-cart-cart~pages-category-category~pages-hall-hall~pages-hall-halllist~pages-index-index~pages-~f079687e.12d8327a.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-cart-cart~pages-category-category~pages-hall-hall~pages-index-index~pages-money-money~pages-or~7b745277.a54346c4.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-cart-cart~pages-category-category~pages-hall-hall~pages-index-index~pages-money-money~pages-or~a7b79261.d35c3e34.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-category-category.9422e484.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-collection-bank.b44007ab.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-collection-bank.b893d5fa.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-collection-collection.58adc241.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-collection-wx.658a7575.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-collection-zfb.9e05d938.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-hall-gsell.eb30254a.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-hall-hall.e78d1d76.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-hall-hallinfo.31ec84cf.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-hall-halllist.c90e178e.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-hall-halllist~pages-hall-hallpay~pages-hall-porducthall~pages-set-addressManage~pages-set-user~4ab5ce4c.1dad1f05.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-hall-halllist~pages-index-index.bb6319d8.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-hall-hallpay.543f964d.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-hall-hallpay.78d27acc.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-hall-hallpay.7948884c.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-hall-hallpay.7a0ebad0.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-hall-history.0bb729b8.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-hall-porducthall.e6b4ccec.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-index-index.1c1b2afb.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-index-message.1342faa2.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-index-messageInfo.ac3d24e5.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-index-sign.2a4b1cd1.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-money-money.2209ceaa.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-money-moneyPwd.6bd501b9.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-money-pay.6f995cab.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-money-paySuccess.b9298eaf.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-money-qudou.06dc9bdd.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-money-qudou~pages-user-award~pages-user-myAppointment~pages-user-mygs~pages-user-myyue.227d03d9.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-money-recharge.508ee38f.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-money-success.60627518.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-money-wallet.1bfa3538.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-money-withdrawal.9d3c91ee.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-money-withdrawal~pages-order-evaluate~pages-order-expressInfo~pages-product-reply~pages-set-ad~0d48236a.60cea1b7.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-order-createOrder.8b1bec2a.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-order-evaluate.386f6aab.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-order-expressInfo.9a211d08.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-order-hallorderDetail.1857040e.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-order-hallorderDetail.539f4441.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-order-index.fd3b315b.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-order-order.2bf83aea.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-order-order.878313a0.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-order-order1.f32a7d4f.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-order-orderDetail.0585d5eb.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-order-orderRefund.b0ba1d9b.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-order-order~pages-order-order1~pages-product-classify~pages-product-zero.e19e6f29.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-product-classify.b68978c5.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-product-list.d557c3ce.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-product-new.c4ee82ef.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-product-product.8bcf8289.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-product-reply.a0257f30.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-product-search.b3473623.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-product-seckill.9f4f61b1.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-product-zero.da4e4a48.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-public-forget.3eaf8de7.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-public-login.3840809b.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-public-register.747441fa.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-public-wxLogin.f929c124.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-redirect-redirect.b1adb09a.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-set-address.f2cd093c.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-set-addressManage.c218abdd.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-set-addressManage~pages-set-set.c374ff2b.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-set-password.0c68d2c8.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-set-phone.a361c265.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-set-set.59701325.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-set-userinfo.fe23dc73.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-store-store.91e04ac0.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-store-storeInfo.90f598f9.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-user-approve.0c430e59.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-user-approve.48b55c43.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-user-approve.91e9a661.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-user-award.6b0b187b.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-user-gzsq.db73e273.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-user-myAppointment.2b4091b2.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-user-myfans.0f295b7c.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-user-mygs.2ebd258a.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-user-myproduct.263a7db6.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-user-myyue.2d8d786a.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-user-notice.5f2dc5ef.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-user-shareQrCode.23c92f5b.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-user-sqjl.76645800.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-user-user.49ef7549.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/js/pages-user-xrtd.683e0801.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/money/m01.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/money/m02.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/money/m03.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/money/m04.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/money/m05.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/tabBar/dingdan.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/tabBar/home.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/tabBar/qd.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/tabBar/tab-cart-current.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/tabBar/tab-cart.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/tabBar/tab-cate-current.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/tabBar/tab-cate.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/tabBar/tab-home-current.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/tabBar/tab-home.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/tabBar/tab-money-current.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/tabBar/tab-money.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/tabBar/tab-my-current.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/tabBar/tab-my.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/tabBar/tab-order-current.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/tabBar/tab-order.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/tabBar/tab-pink-current.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/tabBar/tab-pink.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/user/erweima.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/user/mybank.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/user/wx.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/user/zfb.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/index/static/yticon.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/.env" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/auto.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/config.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/crmeb.sql" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/css/install.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/images/install/bg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/images/install/btn.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/images/install/complete.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/images/install/header.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/images/install/icon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/images/install/icon_install.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/images/install/ignore.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/images/install/loading.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/images/install/logo.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/images/install/pop_loading.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/images/install/step.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/images/install/tab.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/images/install/tips_system.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/index_sae.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/install.lock" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/js/ajaxForm.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/js/jquery.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/js/validate.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/templates/footer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/templates/header.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/templates/s2_sae.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/templates/s3_sae.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/templates/step1.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/templates/step2.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/templates/step3.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/templates/step4.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/install/templates/step5.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/live-logo.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/nginx.htaccess" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/public" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/robots.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/router.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/css/animate.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/css/reset.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/exception.tpl" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/font/Alibaba-PuHuiTi-Regular.otf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/font/simsunb.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/js/media.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/axios.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/basket.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/better-scroll.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/censorwords/CensorWords" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/city.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/.editorconfig" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/.gitattributes" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/.npmignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/.travis.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/AUTHORS" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/CONTRIBUTING.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/comment/comment.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/comment/continuecomment.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/dialog/dialog.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/dialog/dialog.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/display/autorefresh.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/display/fullscreen.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/display/fullscreen.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/display/panel.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/display/placeholder.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/display/rulers.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/edit/closebrackets.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/edit/closetag.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/edit/continuelist.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/edit/matchbrackets.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/edit/matchtags.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/edit/trailingspace.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/fold/brace-fold.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/fold/comment-fold.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/fold/foldcode.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/fold/foldgutter.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/fold/foldgutter.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/fold/indent-fold.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/fold/markdown-fold.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/fold/xml-fold.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/hint/anyword-hint.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/hint/css-hint.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/hint/html-hint.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/hint/javascript-hint.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/hint/show-hint.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/hint/show-hint.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/hint/sql-hint.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/hint/xml-hint.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/lint/coffeescript-lint.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/lint/css-lint.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/lint/html-lint.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/lint/javascript-lint.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/lint/json-lint.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/lint/lint.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/lint/lint.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/lint/yaml-lint.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/merge/merge.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/merge/merge.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/mode/loadmode.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/mode/multiplex.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/mode/multiplex_test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/mode/overlay.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/mode/simple.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/runmode/colorize.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/runmode/runmode-standalone.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/runmode/runmode.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/runmode/runmode.node.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/scroll/annotatescrollbar.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/scroll/scrollpastend.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/scroll/simplescrollbars.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/scroll/simplescrollbars.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/search/jump-to-line.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/search/match-highlighter.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/search/matchesonscrollbar.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/search/matchesonscrollbar.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/search/search.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/search/searchcursor.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/selection/active-line.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/selection/mark-selection.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/selection/selection-pointer.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/tern/tern.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/tern/tern.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/tern/worker.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/addon/wrap/hardwrap.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/bin/authors.sh" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/bin/lint" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/bin/release" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/bin/source-highlight" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/bin/upload-release.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/activeline.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/anywordhint.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/bidi.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/btree.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/buffers.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/changemode.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/closebrackets.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/closetag.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/complete.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/emacs.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/folding.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/fullscreen.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/hardwrap.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/html5complete.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/indentwrap.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/lint.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/loadmode.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/marker.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/markselection.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/matchhighlighter.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/matchtags.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/merge.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/multiplex.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/mustache.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/panel.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/placeholder.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/preview.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/requirejs.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/resize.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/rulers.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/runmode.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/search.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/simplemode.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/simplescrollbars.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/spanaffectswrapping_shim.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/sublime.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/tern.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/theme.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/trailingspace.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/variableheight.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/vim.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/visibletabs.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/widget.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/demo/xmlcomplete.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/doc/activebookmark.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/doc/docs.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/doc/internals.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/doc/logo.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/doc/logo.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/doc/manual.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/doc/realworld.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/doc/releases.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/doc/reporting.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/doc/upgrade_v2.2.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/doc/upgrade_v3.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/doc/upgrade_v4.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/doc/yinyang.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/keymap/emacs.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/keymap/sublime.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/keymap/vim.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/lib/codemirror.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/lib/codemirror.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/apl/apl.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/apl/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/asciiarmor/asciiarmor.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/asciiarmor/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/asn.1/asn.1.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/asn.1/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/asterisk/asterisk.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/asterisk/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/brainfuck/brainfuck.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/brainfuck/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/clike/clike.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/clike/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/clike/scala.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/clike/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/clojure/clojure.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/clojure/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/clojure/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/cmake/cmake.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/cmake/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/cobol/cobol.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/cobol/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/coffeescript/coffeescript.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/coffeescript/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/commonlisp/commonlisp.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/commonlisp/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/crystal/crystal.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/crystal/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/css/css.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/css/gss.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/css/gss_test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/css/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/css/less.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/css/less_test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/css/scss.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/css/scss_test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/css/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/cypher/cypher.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/cypher/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/cypher/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/d/d.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/d/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/d/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/dart/dart.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/dart/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/diff/diff.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/diff/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/django/django.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/django/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/dockerfile/dockerfile.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/dockerfile/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/dockerfile/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/dtd/dtd.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/dtd/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/dylan/dylan.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/dylan/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/dylan/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/ebnf/ebnf.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/ebnf/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/ecl/ecl.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/ecl/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/eiffel/eiffel.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/eiffel/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/elm/elm.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/elm/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/erlang/erlang.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/erlang/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/factor/factor.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/factor/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/fcl/fcl.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/fcl/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/forth/forth.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/forth/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/fortran/fortran.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/fortran/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/gas/gas.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/gas/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/gfm/gfm.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/gfm/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/gfm/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/gherkin/gherkin.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/gherkin/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/go/go.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/go/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/groovy/groovy.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/groovy/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/haml/haml.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/haml/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/haml/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/handlebars/handlebars.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/handlebars/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/haskell-literate/haskell-literate.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/haskell-literate/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/haskell/haskell.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/haskell/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/haxe/haxe.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/haxe/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/htmlembedded/htmlembedded.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/htmlembedded/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/htmlmixed/htmlmixed.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/htmlmixed/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/http/http.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/http/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/idl/idl.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/idl/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/javascript/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/javascript/javascript.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/javascript/json-ld.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/javascript/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/javascript/typescript.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/jinja2/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/jinja2/jinja2.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/jsx/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/jsx/jsx.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/jsx/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/julia/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/julia/julia.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/livescript/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/livescript/livescript.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/lua/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/lua/lua.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/markdown/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/markdown/markdown.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/markdown/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/mathematica/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/mathematica/mathematica.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/mbox/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/mbox/mbox.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/meta.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/mirc/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/mirc/mirc.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/mllike/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/mllike/mllike.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/modelica/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/modelica/modelica.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/mscgen/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/mscgen/mscgen.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/mscgen/mscgen_test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/mscgen/msgenny_test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/mscgen/xu_test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/mumps/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/mumps/mumps.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/nginx/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/nginx/nginx.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/nsis/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/nsis/nsis.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/ntriples/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/ntriples/ntriples.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/octave/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/octave/octave.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/oz/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/oz/oz.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/pascal/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/pascal/pascal.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/pegjs/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/pegjs/pegjs.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/perl/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/perl/perl.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/php/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/php/php.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/php/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/pig/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/pig/pig.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/powershell/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/powershell/powershell.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/powershell/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/properties/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/properties/properties.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/protobuf/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/protobuf/protobuf.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/pug/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/pug/pug.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/puppet/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/puppet/puppet.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/python/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/python/python.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/python/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/q/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/q/q.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/r/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/r/r.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/rpm/changes/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/rpm/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/rpm/rpm.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/rst/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/rst/rst.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/ruby/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/ruby/ruby.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/ruby/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/rust/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/rust/rust.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/rust/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/sas/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/sas/sas.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/sass/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/sass/sass.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/sass/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/scheme/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/scheme/scheme.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/shell/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/shell/shell.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/shell/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/sieve/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/sieve/sieve.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/slim/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/slim/slim.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/slim/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/smalltalk/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/smalltalk/smalltalk.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/smarty/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/smarty/smarty.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/solr/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/solr/solr.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/soy/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/soy/soy.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/soy/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/sparql/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/sparql/sparql.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/spreadsheet/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/spreadsheet/spreadsheet.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/sql/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/sql/sql.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/stex/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/stex/stex.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/stex/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/stylus/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/stylus/stylus.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/swift/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/swift/swift.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/swift/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/tcl/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/tcl/tcl.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/textile/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/textile/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/textile/textile.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/tiddlywiki/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/tiddlywiki/tiddlywiki.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/tiddlywiki/tiddlywiki.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/tiki/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/tiki/tiki.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/tiki/tiki.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/toml/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/toml/toml.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/tornado/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/tornado/tornado.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/troff/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/troff/troff.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/ttcn-cfg/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/ttcn-cfg/ttcn-cfg.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/ttcn/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/ttcn/ttcn.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/turtle/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/turtle/turtle.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/twig/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/twig/twig.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/vb/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/vb/vb.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/vbscript/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/vbscript/vbscript.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/velocity/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/velocity/velocity.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/verilog/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/verilog/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/verilog/verilog.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/vhdl/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/vhdl/vhdl.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/vue/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/vue/vue.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/webidl/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/webidl/webidl.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/xml/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/xml/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/xml/xml.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/xquery/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/xquery/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/xquery/xquery.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/yacas/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/yacas/yacas.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/yaml-frontmatter/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/yaml-frontmatter/yaml-frontmatter.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/yaml/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/yaml/yaml.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/z80/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/mode/z80/z80.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/package.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/rollup.config.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/codemirror.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/display/Display.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/display/focus.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/display/gutters.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/display/highlight_worker.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/display/line_numbers.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/display/mode_state.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/display/operations.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/display/scroll_events.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/display/scrollbars.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/display/scrolling.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/display/selection.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/display/update_display.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/display/update_line.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/display/update_lines.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/display/view_tracking.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/edit/CodeMirror.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/edit/commands.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/edit/deleteNearSelection.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/edit/drop_events.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/edit/fromTextArea.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/edit/global_events.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/edit/key_events.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/edit/legacy.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/edit/main.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/edit/methods.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/edit/mouse_events.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/edit/options.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/edit/utils.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/input/ContentEditableInput.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/input/TextareaInput.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/input/indent.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/input/input.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/input/keymap.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/input/keynames.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/input/movement.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/line/highlight.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/line/line_data.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/line/pos.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/line/saw_special_spans.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/line/spans.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/line/utils_line.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/measurement/position_measurement.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/measurement/widgets.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/model/Doc.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/model/change_measurement.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/model/changes.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/model/chunk.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/model/document_data.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/model/history.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/model/line_widget.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/model/mark_text.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/model/selection.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/model/selection_updates.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/modes.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/util/StringStream.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/util/bidi.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/util/browser.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/util/dom.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/util/event.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/util/feature_detection.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/util/misc.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/src/util/operation_group.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/comment_test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/contenteditable_test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/doc_test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/driver.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/emacs_test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/html-hint-test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/lint.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/mode_test.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/mode_test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/multi_test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/phantom_driver.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/run.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/scroll_test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/search_test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/sql-hint-test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/sublime_test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/test/vim_test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/3024-day.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/3024-night.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/abcdef.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/ambiance-mobile.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/ambiance.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/base16-dark.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/base16-light.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/bespin.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/blackboard.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/cobalt.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/colorforth.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/darcula.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/dracula.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/duotone-dark.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/duotone-light.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/eclipse.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/elegant.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/erlang-dark.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/gruvbox-dark.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/hopscotch.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/icecoder.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/idea.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/isotope.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/lesser-dark.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/liquibyte.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/lucario.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/material.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/mbo.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/mdn-like.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/midnight.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/monokai.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/neat.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/neo.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/night.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/oceanic-next.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/panda-syntax.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/paraiso-dark.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/paraiso-light.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/pastel-on-dark.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/railscasts.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/rubyblue.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/seti.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/shadowfox.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/solarized.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/ssms.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/the-matrix.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/tomorrow-night-bright.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/tomorrow-night-eighties.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/ttcn.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/twilight.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/vibrant-ink.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/xq-dark.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/xq-light.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/yeti.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/codemirror/theme/zenburn.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/copy.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/daterangepicker/daterangepicker.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/daterangepicker/daterangepicker.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/echarts.common.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/echarts/echarts.common.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/echarts/theme/macarons.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/echarts/theme/westeros.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/form-create/form-create.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/form-create/province_city.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/form-create/province_city_area.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/helper.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iscroll5.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/iview.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/iview.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/iview.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/iview.min.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/cs-CZ.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/cs-CZ.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/de-DE.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/de-DE.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/el-GR.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/el-GR.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/en-US.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/en-US.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/es-ES.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/es-ES.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/fa-IR.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/fa-IR.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/fr-FR.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/fr-FR.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/hi-IN.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/hi-IN.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/id-ID.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/id-ID.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/it-IT.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/it-IT.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/ja-JP.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/ja-JP.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/ko-KR.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/ko-KR.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/nl-NL.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/nl-NL.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/pt-BR.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/pt-BR.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/pt-PT.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/pt-PT.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/ro-RO.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/ro-RO.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/ru-RU.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/ru-RU.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/sv-SE.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/sv-SE.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/th-TH.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/th-TH.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/tr-TR.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/tr-TR.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/uk-UA.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/uk-UA.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/vi-VN.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/vi-VN.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/zh-CN.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/zh-CN.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/zh-TW.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/locale/zh-TW.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/styles/fonts/ionicons.eot" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/styles/fonts/ionicons.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/styles/fonts/ionicons.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/styles/fonts/ionicons.woff" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/iview/dist/styles/iview.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/jquery-1.10.2.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/jquery-1.4.1.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/jquery-slide-up.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/jquery.downCount.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/jquery/jquery.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layer/layer-compiled.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layer/layer-compiled.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layer/layer.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layer/mobile/layer-compiled.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layer/mobile/layer-compiled.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layer/mobile/layer.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layer/mobile/need/layer.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layer/theme/default/icon-ext.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layer/theme/default/icon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layer/theme/default/layer.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layer/theme/default/loading-0.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layer/theme/default/loading-1.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layer/theme/default/loading-2.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/css/layui.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/css/layui.mobile.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/css/modules/code.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/css/modules/laydate/default/laydate.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/css/modules/layer/default/icon-ext.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/css/modules/layer/default/icon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/css/modules/layer/default/layer.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/css/modules/layer/default/loading-0.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/css/modules/layer/default/loading-1.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/css/modules/layer/default/loading-2.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/font/iconfont.eot" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/font/iconfont.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/font/iconfont.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/font/iconfont.woff" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/font/iconfont.woff2" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/0.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/1.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/10.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/11.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/12.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/13.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/14.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/15.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/16.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/17.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/18.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/19.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/2.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/20.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/21.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/22.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/23.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/24.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/25.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/26.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/27.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/28.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/29.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/3.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/30.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/31.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/32.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/33.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/34.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/35.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/36.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/37.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/38.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/39.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/4.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/40.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/41.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/42.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/43.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/44.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/45.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/46.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/47.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/48.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/49.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/5.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/50.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/51.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/52.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/53.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/54.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/55.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/56.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/57.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/58.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/59.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/6.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/60.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/61.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/62.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/63.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/64.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/65.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/66.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/67.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/68.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/69.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/7.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/70.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/71.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/8.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/images/face/9.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/carousel.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/code.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/colorpicker.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/element.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/flow.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/form.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/jquery.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/laydate.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/layedit.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/layer.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/laypage.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/laytpl.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/mobile.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/rate.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/slider.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/table.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/transfer.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/tree.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/upload.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/lay/modules/util.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/layui.all.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/layui.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui/selectM.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/css/layui.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/css/layui.mobile.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/css/modules/code.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/css/modules/laydate/default/laydate.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/css/modules/layer/default/icon-ext.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/css/modules/layer/default/icon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/css/modules/layer/default/layer.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/css/modules/layer/default/loading-0.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/css/modules/layer/default/loading-1.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/css/modules/layer/default/loading-2.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/font/iconfont.eot" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/font/iconfont.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/font/iconfont.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/font/iconfont.woff" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/0.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/1.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/10.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/11.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/12.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/13.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/14.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/15.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/16.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/17.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/18.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/19.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/2.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/20.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/21.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/22.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/23.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/24.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/25.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/26.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/27.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/28.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/29.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/3.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/30.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/31.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/32.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/33.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/34.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/35.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/36.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/37.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/38.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/39.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/4.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/40.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/41.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/42.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/43.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/44.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/45.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/46.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/47.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/48.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/49.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/5.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/50.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/51.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/52.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/53.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/54.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/55.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/56.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/57.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/58.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/59.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/6.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/60.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/61.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/62.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/63.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/64.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/65.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/66.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/67.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/68.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/69.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/7.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/70.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/71.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/8.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/images/face/9.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/lay/modules/carousel.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/lay/modules/code.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/lay/modules/element.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/lay/modules/flow.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/lay/modules/form.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/lay/modules/jquery.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/lay/modules/laydate.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/lay/modules/layedit.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/lay/modules/layer.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/lay/modules/laypage.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/lay/modules/laytpl.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/lay/modules/mobile.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/lay/modules/rate.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/lay/modules/table.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/lay/modules/tree.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/lay/modules/upload.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/lay/modules/util.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/layui.all.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/layui2/layui.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/lodash.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/moment.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/reg-verify.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/requirejs/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/requirejs/bin/r.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/requirejs/package.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/requirejs/require-basket-load-compiled.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/requirejs/require-basket-load-compiled.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/requirejs/require-basket-load.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/requirejs/require-compiled.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/requirejs/require-compiled.js.map" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/requirejs/require-css.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/requirejs/require.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/sweetalert2/sweetalert2.all.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/swiper/swiper-3.4.1.jquery.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/swiper/swiper-3.4.1.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/swiper/swiper.jquery.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/vant/vant.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/vant/vant.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/vue/dist/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/vue/dist/vue.common.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/vue/dist/vue.esm.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/vue/dist/vue.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/vue/dist/vue.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/vue/dist/vue.runtime.common.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/vue/dist/vue.runtime.esm.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/vue/dist/vue.runtime.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/vue/dist/vue.runtime.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/wxApi.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/ydui/cityselect.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/ydui/province_city.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/ydui/province_city_area.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/ydui/province_city_area2.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/ydui/province_city_area_id.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/ydui/province_city_id.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/ydui/ydui-px.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/ydui/ydui.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/plug/ydui/ydui2.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/poster/poster.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/qrcode/background.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/static/qrcode/follow.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/css/emoji-awesome/css/apple.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/css/emoji-awesome/css/emojione.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/css/emoji-awesome/css/facebook.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/css/emoji-awesome/css/google.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/css/emoji-awesome/css/messenger.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/css/emoji-awesome/css/twitter.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/css/emoji-awesome/img/sheet_apple_64_indexed_256colors.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/css/emoji-awesome/img/sheet_emojione_64_indexed_128.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/css/emoji-awesome/img/sheet_facebook_64_indexed_128.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/css/emoji-awesome/img/sheet_google_64_indexed_128.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/css/emoji-awesome/img/sheet_messenger_64_indexed_128.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/css/emoji-awesome/img/sheet_twitter_64_indexed_128.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/css/layui-admin.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/css/main.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/css/reset.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/css/style.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/font/iconfont.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/font/iconfont.eot" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/font/iconfont.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/font/iconfont.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/font/iconfont.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/font/iconfont.woff" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/M663 1125q-11 -1 -15.5 -10.5t-8.5 -9.5q-5 -1 -5 5q0 12 19 15h10zM750 1111q-4 -1 -11.5 6.5t-17.5 4.5q03F7DC5A5A" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/animate.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/bootstrap.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/demo/webuploader-demo.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/font-awesome.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/login.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/patterns/header-profile-skin-1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/patterns/header-profile-skin-3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/patterns/header-profile.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/patterns/shattered.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/awesome-bootstrap-checkbox/awesome-bootstrap-checkbox.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/blueimp/css/blueimp-gallery.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/blueimp/img/error.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/blueimp/img/error.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/blueimp/img/loading.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/blueimp/img/play-pause.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/blueimp/img/play-pause.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/blueimp/img/video-play.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/blueimp/img/video-play.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/bootstrap-table/bootstrap-table.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/chosen/chosen-sprite.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/chosen/chosen-sprite_402x.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/chosen/chosen.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/clockpicker/clockpicker.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/codemirror/ambiance.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/codemirror/codemirror.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/colorpicker/css/bootstrap-colorpicker.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/colorpicker/img/bootstrap-colorpicker/alpha-horizontal.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/colorpicker/img/bootstrap-colorpicker/alpha.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/colorpicker/img/bootstrap-colorpicker/hue-horizontal.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/colorpicker/img/bootstrap-colorpicker/hue.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/colorpicker/img/bootstrap-colorpicker/saturation.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/cropper/cropper.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/dataTables/dataTables.bootstrap.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/datapicker/datepicker3.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/dropzone/basic.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/dropzone/dropzone.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/footable/fonts/footable.eot" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/footable/fonts/footable.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/footable/fonts/footable.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/footable/fonts/footable.woff" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/footable/footable.core.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/fullcalendar/fullcalendar.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/fullcalendar/fullcalendar.print.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/iCheck/custom.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/iCheck/green.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/iCheck/green_402x.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/images/sort_asc.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/images/sort_desc.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/images/sprite-skin-flat.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/images/spritemap.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/images/spritemap_402x.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/ionRangeSlider/ion.rangeSlider.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/ionRangeSlider/ion.rangeSlider.skinFlat.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/jasny/jasny-bootstrap.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/jqgrid/ui.jqgrid.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/jsTree/32px.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/jsTree/style.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/jsTree/throbber.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/markdown/bootstrap-markdown.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/morris/morris-0.4.3.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/nouslider/jquery.nouislider.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/plyr/plyr.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/plyr/sprite.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/simditor/simditor.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/steps/jquery.steps.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/summernote/summernote-bs3.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/summernote/summernote.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/sweetalert/sweetalert.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/switchery/switchery.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/toastr/toastr.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/treeview/bootstrap-treeview.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/plugins/webuploader/webuploader.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/css/style.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/fonts/fontawesome-webfont.eot" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/fonts/fontawesome-webfont.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/fonts/fontawesome-webfont.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/fonts/fontawesome-webfont.woff" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/fonts/fontawesome-webfont.woff2" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/fonts/glyphicons-halflings-regular.eot" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/fonts/glyphicons-halflings-regular.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/fonts/glyphicons-halflings-regular.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/fonts/glyphicons-halflings-regular.woff" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/fonts/glyphicons-halflings-regular.woff2" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/a1.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/a2.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/a3.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/a4.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/a5.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/a6.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/a7.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/a8.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/a9.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/bg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/iconfont-logo.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/icons.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/index.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/index_4.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/loading-upload.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/locked.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/login-background.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/p1.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/p2.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/p3.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/p_big1.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/p_big2.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/p_big3.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/pay.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/profile.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/profile_big.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/profile_small.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/progress.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/qr_code.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/success.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/user.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/img/wenku_logo.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/ajaxfileupload.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/bootstrap.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/contabs.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/content.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/demo/bootstrap-table-demo.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/demo/bootstrap_table_test.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/demo/bootstrap_table_test2.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/demo/echarts-demo.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/demo/flot-demo.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/demo/form-advanced-demo.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/demo/form-validate-demo.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/demo/layer-demo.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/demo/morris-demo.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/demo/peity-demo.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/demo/photos.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/demo/rickshaw-demo.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/demo/table_base.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/demo/treeview-demo.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/demo/webuploader-demo.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/hplus.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/jquery-2.1.1.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/jquery-ui-1.10.4.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/jquery-ui.custom.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/jquery.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/beautifyhtml/beautifyhtml.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/blueimp/jquery.blueimp-gallery.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/bootstrap-table-mobile.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/bootstrap-table.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/accent-neutralise/bootstrap-table-accent-neutralise.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/accent-neutralise/bootstrap-table-accent-neutralise.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/angular/bootstrap-table-angular.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/angular/bootstrap-table-angular.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/cookie/bootstrap-table-cookie.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/cookie/bootstrap-table-cookie.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/editable/bootstrap-table-editable.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/editable/bootstrap-table-editable.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/export/bootstrap-table-export.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/export/bootstrap-table-export.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/filter-control/bootstrap-table-filter-control.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/filter-control/bootstrap-table-filter-control.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/filter/bootstrap-table-filter.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/filter/bootstrap-table-filter.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/flat-json/bootstrap-table-flat-json.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/flat-json/bootstrap-table-flat-json.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/group-by-v2/bootstrap-table-group-by.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/group-by-v2/bootstrap-table-group-by.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/group-by-v2/bootstrap-table-group-by.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/group-by/bootstrap-table-group-by.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/group-by/bootstrap-table-group-by.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/group-by/bootstrap-table-group-by.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/key-events/bootstrap-table-key-events.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/key-events/bootstrap-table-key-events.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/mobile/bootstrap-table-mobile.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/mobile/bootstrap-table-mobile.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/multiple-search/bootstrap-table-multiple-search.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/multiple-search/bootstrap-table-multiple-search.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/multiple-sort/bootstrap-table-multiple-sort.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/multiple-sort/bootstrap-table-multiple-sort.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/natural-sorting/bootstrap-table-natural-sorting.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/natural-sorting/bootstrap-table-natural-sorting.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/reorder-columns/bootstrap-table-reorder-columns.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/reorder-columns/bootstrap-table-reorder-columns.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/reorder-rows/bootstrap-table-reorder-rows.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/reorder-rows/bootstrap-table-reorder-rows.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/reorder-rows/bootstrap-table-reorder-rows.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/resizable/bootstrap-table-resizable.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/resizable/bootstrap-table-resizable.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/sticky-header/bootstrap-table-sticky-header.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/sticky-header/bootstrap-table-sticky-header.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/sticky-header/bootstrap-table-sticky-header.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/toolbar/bootstrap-table-toolbar.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/extensions/toolbar/bootstrap-table-toolbar.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/bootstrap-table/locale/bootstrap-table-zh-CN.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/chartJs/Chart.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/chosen/chosen.jquery.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/clockpicker/clockpicker.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/codemirror/codemirror.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/codemirror/mode/default.htm" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/codemirror/mode/javascript/default.htm" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/codemirror/mode/javascript/javascript.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/colorpicker/bootstrap-colorpicker.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/cropper/cropper.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/dataTables/dataTables.bootstrap.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/dataTables/jquery.dataTables.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/datapicker/bootstrap-datepicker.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/diff_match_patch/diff_match_patch.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/dropzone/dropzone.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/easypiechart/jquery.easypiechart.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/echarts/echarts-all.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/echarts/echarts-all.js.b" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/echarts/echarts-all.js.b1" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/fancybox/blank.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/fancybox/fancybox_loading.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/fancybox/fancybox_loading_402x.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/fancybox/fancybox_overlay.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/fancybox/fancybox_sprite.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/fancybox/fancybox_sprite_402x.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/fancybox/jquery.fancybox.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/fancybox/jquery.fancybox.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/flot/curvedLines.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/flot/jquery.flot.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/flot/jquery.flot.pie.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/flot/jquery.flot.resize.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/flot/jquery.flot.spline.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/flot/jquery.flot.symbol.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/flot/jquery.flot.tooltip.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/footable/footable.all.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/fullcalendar/fullcalendar.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/gritter/images/gritter-light.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/gritter/images/gritter.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/gritter/images/ie-spacer.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/gritter/jquery.gritter.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/gritter/jquery.gritter.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/iCheck/icheck.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/ionRangeSlider/ion.rangeSlider.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/jasny/jasny-bootstrap.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/jeditable/jquery.jeditable.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/jqgrid/i18n/grid.locale-cn.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/jqgrid/jquery.jqGrid.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/jquery-ui/jquery-ui.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/jsKnob/jquery.knob.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/jsTree/jstree.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/jvectormap/jquery-jvectormap-1.2.2.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/jvectormap/jquery-jvectormap-world-mill-en.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/layer/extend/layer.ext.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/layer/laydate/laydate.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/layer/laydate/need/laydate.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/layer/laydate/skins/default/icon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/layer/laydate/skins/default/laydate.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/layer/layer.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/layer/layim/data/chatlog.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/layer/layim/data/friend.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/layer/layim/data/group.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/layer/layim/data/groups.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/layer/layim/layim.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/layer/layim/layim.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/layer/layim/loading.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/layer/skin/layer.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/layer/skin/layer.ext.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/layer/skin/moon/style.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/markdown/bootstrap-markdown.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/markdown/bootstrap-markdown.zh.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/markdown/markdown.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/markdown/to-markdown.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/metisMenu/jquery.metisMenu.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/morris/morris.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/morris/morris.js.b" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/morris/raphael-2.1.0.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/nestable/jquery.nestable.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/nouslider/jquery.nouislider.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/pace/pace.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/peity/jquery.peity.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/plyr/plyr.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/preetyTextDiff/jquery.pretty-text-diff.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/prettyfile/bootstrap-prettyfile.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/rickshaw/rickshaw.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/rickshaw/vendor/d3.v3.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/simditor/hotkeys.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/simditor/module.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/simditor/simditor.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/simditor/uploader.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/slimscroll/jquery.slimscroll.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/sparkline/jquery.sparkline.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/staps/jquery.steps.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/suggest/bootstrap-suggest.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/suggest/data.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/summernote/summernote-zh-CN.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/summernote/summernote.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/sweetalert/sweetalert.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/switchery/switchery.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/toastr/toastr.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/treeview/bootstrap-treeview.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/validate/jquery.validate.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/validate/messages_zh.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/plugins/webuploader/webuploader.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/js/welcome.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/plugins/fullavatareditor/expressInstall.swf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/plugins/fullavatareditor/fullAvatarEditor.swf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/plugins/fullavatareditor/scripts/demo.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/plugins/fullavatareditor/scripts/fullAvatarEditor.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/plugins/fullavatareditor/scripts/fullAvatarEditor.js.b" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/plugins/fullavatareditor/scripts/jQuery.Cookie.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/plugins/fullavatareditor/scripts/swfobject.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/plugins/fullavatareditor/scripts/swfobject.js.b" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/frame/plugins/fullavatareditor/scripts/test.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/images/001.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/images/admin_logo.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/images/bg-logo.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/images/empty.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/images/empty_address.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/images/error.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/images/express_icon.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/images/head.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/images/index.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/images/logo.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/images/mobile_foot.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/images/mobile_head.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/images/plat_copy.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/images/plat_express.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/images/plat_sms.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/images/plat_user.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/js/common.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/js/jquery-1.11.2.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/js/layuiList.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/js/media.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/error/css/reset-2.0.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/error/css/style.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/error/images/01.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/error/images/01.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/error/images/02.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/error/images/03.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/error/images/04.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/error/images/back-icon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/error/images/failure-icon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/error/images/refresh-iocn.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/exception/css/style.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/exception/images/errorPageBorder.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/index/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/login/flaotfont.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/login/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/login/ios-parallax.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/success/css/reset-2.0.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/success/images/success-icon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/wechat/news/css/index.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/wechat/news/css/style.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/wechat/news/images/image.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/wechat/news_category/css/style.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/widget/aliyun-oss-sdk-4.4.4.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/widget/cos-js-sdk-v5.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/widget/images.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/widget/plupload.full.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/widget/qiniu-js-sdk-2.5.5.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/widget/vedio-upload.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/module/widget/videoUpload.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/requirejs/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/requirejs/bin/r.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/requirejs/package.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/requirejs/require.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/emotion/emotion.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/emotion/emotion.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/emotion/images/0.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/emotion/images/bface.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/emotion/images/cface.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/emotion/images/fface.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/emotion/images/jxface2.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/emotion/images/neweditor-tab-bg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/emotion/images/tface.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/emotion/images/wface.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/emotion/images/yface.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/formula/formula.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/formula/formula.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/formula/formula.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/formula/images/formula.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/image/image.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/image/image.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/image/images/close.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/image/images/upload1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/image/images/upload2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/link/link.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/map/map.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/map/map.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/video/images/center_focus.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/video/images/left_focus.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/video/images/none_focus.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/video/images/right_focus.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/video/video.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/dialogs/video/video.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/en.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/images/addimage.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/images/alldeletebtnhoverskin.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/images/alldeletebtnupskin.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/images/background.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/images/button.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/images/copy.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/images/deletedisable.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/images/deleteenable.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/images/imglabel.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/images/listbackground.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/images/localimage.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/images/music.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/images/rotateleftdisable.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/images/rotateleftenable.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/images/rotaterightdisable.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/images/rotaterightenable.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/en/images/upload.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/zh-cn/images/copy.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/zh-cn/images/imglabel.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/zh-cn/images/localimage.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/zh-cn/images/music.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/zh-cn/images/upload.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/lang/zh-cn/zh-cn.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/php1/Uploader.class.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/php1/getContent.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/php1/imageUp.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/themes/default/css/umeditor.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/themes/default/css/umeditor.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/themes/default/images/caret.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/themes/default/images/close.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/themes/default/images/icons.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/themes/default/images/icons.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/themes/default/images/ok.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/themes/default/images/pop-bg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/themes/default/images/spacer.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/themes/default/images/videologo.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/jquery.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/Symbola.eot" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/Symbola.otf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/Symbola.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/Symbola.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/Symbola.woff" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/stixgeneral-bundle/STIXFontLicense2010.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/stixgeneral-bundle/stixgeneral-webfont.eot" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/stixgeneral-bundle/stixgeneral-webfont.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/stixgeneral-bundle/stixgeneral-webfont.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/stixgeneral-bundle/stixgeneral-webfont.woff" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/stixgeneral-bundle/stixgeneralbol-webfont.eot" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/stixgeneral-bundle/stixgeneralbol-webfont.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/stixgeneral-bundle/stixgeneralbol-webfont.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/stixgeneral-bundle/stixgeneralbol-webfont.woff" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/stixgeneral-bundle/stixgeneralbolita-webfont.eot" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/stixgeneral-bundle/stixgeneralbolita-webfont.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/stixgeneral-bundle/stixgeneralbolita-webfont.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/stixgeneral-bundle/stixgeneralbolita-webfont.woff" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/stixgeneral-bundle/stixgeneralitalic-webfont.eot" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/stixgeneral-bundle/stixgeneralitalic-webfont.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/stixgeneral-bundle/stixgeneralitalic-webfont.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/font/stixgeneral-bundle/stixgeneralitalic-webfont.woff" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/mathquill.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/mathquill.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/mathquill/mathquill.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/third-party/template.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/umeditor.config.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/umeditor.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/umeditor/umeditor.min.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/plug/validate/jquery.validate.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/util/mpFrame-compiled.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/util/mpFrame.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/util/mpHelper.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/util/mpVueComponent.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/util/mpVuePackage-compiled.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/system/util/mpVuePackage.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/03/20220322/03a1c9a411aed3cb0232fe5771793d5b.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/03/20220322/28583c438c9ebaa76bed7f41a9ff5a6a.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/03/20220324/12caf37ef299e754bef1dc0c822c4235.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/03/20220324/b4e988cf1879112e475e7bb09afd1ddc.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/03/20220329/248bdd18296c9cfd6a742693e9d0202e.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/03/20220329/be72d031bc963f9384262fc88a7930f0.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/03/20220329/f819a983ff59af351a8c185dfd660cd6.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/03/20220330/9d482e7e7cf64d3f4349139810adf5e7.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/03/20220330/bc795a82ad34b70d7ee86777a7052150.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/03/20220331/041f97df2e2fd4c2cc1addefc8d33f97.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/04/20220401/ae1c915d75405aa6825d451c2c760294.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/04/20220402/099582ef41ed24cf0730c6af6e744b71.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/04/20220402/3eb87c183bdaf489088778e392620bab.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/04/20220402/4cb9a7bc0b3548f34d799c3fe918f279.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/04/20220402/6fd29e98f7825c16063d1ae7cf809186.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/04/20220402/c5765b19105d79268c3450446987b1e7.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/04/20220402/c5936852caf9657795b78cf4866cf92b.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/04/20220402/c96d33f5872ea061d90506ebea8dcccc.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/04/20220407/94a1e93f1936daa02db14e0e36f280fe.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/04/20220407/9f91fbefe54e131708261a0f6077407f.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/attach/2022/04/20220409/63c67e20489fdcf372fe34aa5978d2c6.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/config/file/20220421/36f34cde6fe63551524fd16b1ff7816b.pem" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/config/file/20220421/52200c654f7cfbf55550ad7dc133bdee.pem" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/10_0_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/10_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/10_product_detail_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/11_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/1280_product_detail_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/14_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/15_0_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/18_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/19_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/20_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/21_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/22_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/22_product_detail_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/23_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/24_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/25_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/26_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/27_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/29_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/31_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/32_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/34_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/36_product_detail_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/3_1_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/51_product_detail_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/58_product_detail_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/7_product_detail_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/qrcode/8_0_user_wap.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220329/81d236422cb93f296423c5e022b44adf.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220330/9e67dad2772a9b95a211ab4115679f90.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220331/3d8456d0f5059f0028ca976534ae5658.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220331/3fd687cca71d238c34c0bb5d8290a678.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220331/4946e636486a87f66b209e28b70f4116.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220331/8025d0dc64856e5a9586f06e6292e9a3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220331/8280cbea67be59309e001c41fb2812f3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220331/c0fd387600109ffa3af2d8e9de1be9a6.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220331/c667fa4119fc966df3241355c77643c5.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220331/c8b6eaadab68dadc3b094979b53132d9.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220401/04c2ac8c075dc621e18907233a181025.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220401/2460bc56e0ba45e710ee8e5830941128.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220401/3440922fe341dda1a36725d3211deb1a.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220401/482705ca0f2db88ced31e21e2cae31fe.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220401/5b5ce4022385e99971f0e151148f776e.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220401/605baaa505e98347b23924508ec6a522.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220401/914c3f3b75cf69bc01949828f3691efd.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220401/b8b8c1990f0686e36b42443c7e9e8678.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220401/b94fd66abbd38b2e5d6a127b6fd11214.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220401/d13159ae689609be721a107df9da464e.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220401/fe57867f5accab0084894bb3e8c4d5bb.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220402/4205a0b47903160b5a32a23dc553aa89.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220402/80b31222b8406dbeb5407d1df9f5f73c.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220403/07069c291313ea066498196718e8e59b.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220403/09bb4a2e7b7af63a67aeed7e07ae72cc.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220403/530b9c36eb4f4c10358e7d52b5c9afeb.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220403/8d1db178f4caf585110cfc9859b08e40.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220403/a56154bc4d313d52462aa8d7c307c1a0.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220406/4c68f08b8a2780083d3247ca4e585107.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220406/5b8c9f647fd6edfa55868687563db801.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220406/620ecdb4c625fbddeb14f3636f24af42.jpeg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220406/84d2589ed79de2793b5b5052ee7fffb1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220406/8724382ee067a3c081d8824dd581a699.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220407/019db4be5b32915fa878b3456a37b71b.jpeg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220407/143188ad1468e67603b1c24fd1ad1055.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220407/387f2f30710a2a25acc505b8a5fa50e4.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220407/4edf73b99835165610f78178cc94764f.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220407/519455b5dd109dbb6c8d9acecf0ca52b.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220407/792e86f36d94c7e1b3421a3328f74074.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220407/8922e7f4a1679490cd2b1adf34f0c38a.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220407/9117911835c40476fb652724d4737866.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220407/a5834d8f904cb1ce7cf752ae05d01862.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220407/a6b9925a1ac47a9021f23fa8e40f86c4.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220407/ece1f1672514229a338b8a4dbceeb212.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220408/360ae19990cc64f9b6f74ceff5d8797a.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220408/53db094b343c97bb5df0e9769a05f6c2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220408/a047390783c87242bb3186ca5bc2d204.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220408/aaba988131168b97325cfb5d44ec9190.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220408/c647dfd457553975927ef398a49f3b38.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220408/d5480abf85170ad31e540510d7b627c9.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220408/e34fec3ad67d3a583f6aba1920f8a187.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220408/eb62abfadf6e95d781541734ee33fa5f.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220408/fddc33787e2fc831a0cf1cb280a02178.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220409/0ac2d28052b605d8a36d4a33a8b1fc83.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220409/0edf3f864fb0f140f53fc71769c4266d.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220409/110cd2bfeec22efe939bf11d8aff9d8a.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220409/1fdd7e464e3d6b8de1f8e14893d5ceeb.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220409/2f91faa23aa6a94d2a9150ec8af30a8a.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220409/3e470dc7372d5ff50e9f7d047065cdce.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220409/4ccd458da19585533106e906c1948a5d.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220409/722ad4815b6de6080db26d3c62bbfc7a.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220409/9704f7708b147d278024bfae236f7981.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220409/9d0b6b1a010cce38466f7145174dc2c7.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220409/9ebfc862f5352cc77caa5afdf6b507c1.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220409/ab9d5d22abcb5df630cfe4f6d82aa8cb.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220409/e46a7223c52573effabc79d476842ab6.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220409/f09f4921a03afc17fc7970d07595d292.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220411/044f3570f543690655db76858e8ac9b1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220411/15eb50ad61200a2d7c7baa0bd28221d7.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220411/638d1b3e911ae162ac99df5aa9dbe3d2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220411/b045b21c651d456ab536e5092a8b0c43.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220411/c288836ee36d61a2cd1384b3190c4d22.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220411/d5d82a24fdd46ea2dad1d7341db2d889.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220411/e9911e863b4b97a8e9274ff2656e1691.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220411/f9577f52ea7aa33567b7160bb625a9ee.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220412/12010549301869be4f43d49d2fea36a1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220412/152af5c9b0a2beb62c75521de3174ed1.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220412/4430bdcd72ad14515aaade0c0b37c150.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220412/4c440aca255d7816e12ddb4b6f760fbe.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220412/7d52580234eaeca4cb0532a5b74b4165.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220412/9b0c1dcea543e4c8c95aba6743223b5d.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220412/f4255d58aac7d1fcf79d0344df0235d6.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220413/a1861185fe6f953a555cc0d082b23748.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220414/93189d62d4360f6413d90936625ece17.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220414/a38cd05e5ada46122287bc28ced42fd4.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220414/eab52302d9d46aed21f10baf1a9d01c6.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220414/ed7984a2503f90e105c68a48205602fd.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220415/18d8c27fc21ca870656e7a024f22040e.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220415/48e0c0a455b35eadb2ad06da88824888.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220415/7ab3ba9ffc59bda4bf35aee7614255fb.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/0022fafd26229a98529f10cfad8b3754.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/14537ed40806e7f14d28df97abd22e45.jpeg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/256db70dd79aa52337ff48b42e683ac9.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/25adaaeb5110d36dd33af59fdbc749b6.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/2707889b0d76961430fad75eef7c89d7.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/365ad315dbb7cca34461b5911d2c2dc3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/47ec97f850fa6f6c430867e52b1e01c1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/499f7b636607e83d4c61ec0810e3bb1c.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/5025fc374feb8f9f19a6dbf24b1b17a5.jpeg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/5965c4caa247b3df30976ccb6c700862.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/659f3c2169d58be4bd0a23e40d15d5bc.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/678c088635b6cd96992d3ddd8dc1dc0e.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/70360826b12fb3b6292eb735750a549f.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/722c5b831494217e93b7e844bb15e8f3.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/747e2c87847c624b3a2ce4b02af9b3c9.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/8ca7534c78448cb682a1ce459520c477.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/8ccdb75efc4148a386adf8281a2027e8.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/90736d78c47982d5a741bfcc20e379e0.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/921c2bbccb5cee1b41a7a4316bcd58b8.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/97d73d71e4b0785ae36c877b0680b259.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/a10da338e7e97323d3fff0880f6d920f.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/a3a28e5dc358ba9df2251b36d4e9c184.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/a6a35bece17eaa3d258ce372c2aa719f.jpeg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/a720f5cb9db32c1118a52862df37e17c.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/b323f2e68fd936765fe6af583f830ac1.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/b857d893e4bb1224d64a02ee1f90ce6d.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/b892bd9c1a3db68219f6e8c0ee9c3c35.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/cfb60926c13d6d8cf098b73ecbe3aff3.jpeg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/d82d53dbc39d35cacde735393e72434d.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/d8863afb6190c738945351fa95714631.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/f18c954f2c812d6730d9e2b6ee7952f8.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220417/fc3ce63a46ac3857ee698051d2292cb0.jpeg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220419/9ac505092a79bafe0b47bea2743a3091.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220426/18ea4324572a5378036c81de5c7bbc74.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220426/2584c36564c47dae3de58e2f720837e4.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220426/8de02fa8e5f16456efb75d8ba884fb32.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220426/9679d21fbbf26f4887629b016cab18c5.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220426/9bfa26b68d5b6d2d35e2e16ea90d4d88.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220426/d01d950ee601a45a305559ff25bf1852.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220426/e340549393e74f0b1e34e6ba6090ebda.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220427/c695ab9ee9c46db4f028d1d4f1b3221b.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220427/f25f1337288ea2aea2c2357c4df61870.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220430/5d31d444422d7e46db3077ccb8edd7e9.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220430/68ed07c5c0855e8995c748e5e14bb55f.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220430/a4017edd084a43c3a98d902273031f80.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220430/b1153c465d3e456fc0985de1a4228b42.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220430/ceb9dc363e1691fae9cec8de131ac6a1.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220430/e33ff9918192476c8dbe7e4a446d31a6.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220430/f14a2d5128c8766b643728ac713384e3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220504/0fa0dcc695e073e2447e11386d73ede3.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220504/1f39e8ca7e463d38f9d235015904d869.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220504/41e9036d2f44bb35b493094f7bca3d45.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/store/comment/20220504/4f27ab08c8d19cb9fea819024df6da32.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/0205220220407142525754878.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/1355920220407143014523717.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/1679020220407142855614870.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/17faf20220407142934752540.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/20b5e20220407145400265762.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/248e820220417115306624823.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/3530920220418201453835286.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/392522022042116433339392.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/3a2a920220407144919917614.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/3bf2920220417113849709162.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/4fc8420220407142808317632.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/50abc20220417115036319255.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/5b8e920220417114138730986.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/642e920220417112909428591.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/76dc620220417154247444630.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/77bb120220407143230258490.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/79fde20220407143037372769.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/7a61420220417120234433780.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/7a68420220417114756932281.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/7d54320220407142712453391.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/8a14620220407143835194078.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/9c3b120220421093600730966.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/a57d420220407143928483661.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/ab88b20220407144432728937.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/beda820220417114625154343.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/bee8b20220417121423963925.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/cf011202204071536362752.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/d035320220417114235174611.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/d380220220417102612487079.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/d5d7f20220417123139793102.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/d80742022040714303724290.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/df7e120220417114630430615.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/e6a4f2022041711445964255.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/ec8b520220407143240728956.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/f8c0c20220407143154756910.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/public/uploads/wap/spread/poster/faad92022041711481486862.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/route/api/route.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/route/app.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/route/wap/route.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/0187d0e3a11f06707fcfaf6a4d730db6.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/077bc43699fee47cab597abf54199da7.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/07fcf778cf7f3ae59e0816dc548172b6.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/0853616336235fd4f74c560d17e5edb8.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/0c3b41574b6e4206947a9b8156ee6592.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/0ee436697dcbfee103a2742c2b60b91f.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/16a102a584e5d2300c878cc4167c4d1d.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/17002d39107ebb9517ecd7e4f5ee0b11.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/1ad42d3d8849e0cf3613113c7fbcdc8f.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/1e2dc96b3d57dada2f0e0e1a2a424c99.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/1ea19daf52d3a80420f8d14f4c41448a.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/2513917fe9c3571078deb52521cd99c8.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/287e374167acdd64a499e521650916b7.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/2937de08e4065a026ef0e4000c18f0e3.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/2ca5a101c85ec8337022e5bee6d719b0.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/2f8a3efbe23b790e7a258d43c39cf68f.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/3842d4cff02ed8a8fdaa7dea044f6e6b.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/3ac1cf96481d3b196141e60cc7237c4f.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/3cc133a0a2a46bf5f1ff28a633161ab4.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/3e1d2e764dbbcc1a0a5690aa9ccdf781.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/3efff59657b97bd40e3b16001f333107.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/3fb1a933921fe1fef8ea5ebe530b4842.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/41804a3ede5d38c76655e9c89b9eee51.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/45db4fb773498717a3fd5e27f566f314.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/47e7841db05ce42e56c4afe9bc1c5fde.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/5435f22dcc53d6dd211a71551ce9d1c0.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/545657f1ad54e50f595a2ffc0bad6adf.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/560dc87b85112a97e70f4f7bed1c686b.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/594d25299dd84c1a24b90f2034d4d2d7.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/5a82649edd1b40af6f202faef65620f4.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/630e4716c60d29e67da0b344a62054a9.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/6be36a6b160c6d5f2cf7632e3d7f3d6d.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/6d3747d12327b7a737b81b743d7fc232.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/768bd31cfad350d4954f350156d70505.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/7774ce40cfe0c284fa3e21f4afd9ff55.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/78bbfd7eaff9b341c543c8c239cfe093.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/822777630548daa1ca8222e38dc1a1ae.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/84d61d0aef57f53004a41c9e30ac91fe.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/859c64b75d2c9f266b654a6d3feb693c.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/8afdce58c2dc33afb8e3839f8713559a.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/8dedc6b6698db05f257cc8abd7f83555.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/94e73b57d2d3812b99c242f4a263ea4b.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/95d3667eb2574449e04ea513d4600a99.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/96c8dd9ff7a16f6abe07d2524fea444f.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/9880952f3322a9c11557d8bdef363309.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/9ad67067080adbd051d2c412ba42881d.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/9dfdf9bc52bc53b5bd5a31c025971e91.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/a31b775477543b657d8300c5c3eaa66d.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/a5e290369d4af2c431b37f2d99f61762.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/a8e0849f12816922ddd99a622339ce2c.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/a98c59e87384e13f1b02591010192096.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/ac8cdde27fc053dc46496071d3e9e892.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/b3299715c4d3a9163dc77c443c9869fb.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/b36ecb9898a41dd116437f64aa3f7f14.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/b3ffa07e35bd7b91d38c544233766f58.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/b805f47273dee915ad9458585d3a5b4a.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/bac18b7847b665c7ca79c6c68575bad5.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/bce6f7de1f9ee52dabad47ee3064a419.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/bfcfe4fc86e1ea7546f6eec7a56bc4e7.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/c17c3780b823f79a26eeb4cc17847c7c.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/c5ee2fca9ee5a418de10d4105e0048bd.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/c70ace87bc52a5d3e58f590c6f66d0d1.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/c8a377f88d51e369115354584107e9f4.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/c9eaf4338b8787f9f4fdd4ad845cae24.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/ca9441041d2d9293819c73a21d60614a.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/cba55bc259381fa1d09b41941b4731ee.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/ce38b0d4dda5a13bfb2e9ea6ebff7c1b.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/cfc534345664061c1ca0aabe325fa59b.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/d04554c9949b5d6930e9f1ae8ea36009.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/d094045a1bc5443e76b5eae40a901ff4.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/d2376d24eab5339af95254c3a8e33f83.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/d5ccc5026f19ab3f146922861f37e83b.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/d7d372ab726862fb447d17cfe02c83d6.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/e1627a19ee00103b5ad3bbdca4ffc8ad.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/e2f22eab222d68b1f95792611fec88e0.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/e66a7e86418ca78e614700f0e3eeae59.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/e6c67a45361c7da8682c93920954edba.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/eda6d0cd8c23ae79a39c8fdfa6a9b382.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/f803db124a9edebbe4655b3f7bfe5cde.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/admin/temp/fb56d7b898b61886bc4f0f1ddfc1d741.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/api/cache/bydcust_/c4/ca4238a0b923820dcc509a6f75849b.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/api/cache/bydcust_/e4/da3b7fbbce2345d7772b0674a318d5.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/api/cache/e4/da3b7fbbce2345d7772b0674a318d5.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/09/6bb17f1bf03fded47bfa70729e3510.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/11/cc38f47f4d9f8be7456ef2056c3286.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/2e/26d95f3b2397f1dbd714cb44636198.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/3a/18e85fda2f43f200f015f30d0af45e.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/48/e345b986ae9584f9686dac64ea2c6a.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/4d/ebc178cbdb9b7d1fc736ef8ee65e51.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/4f/936acee258fd8bb4d5fbe7d9fb97f5.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/51/8849ffcbe3553d7ee96c613d31f3c8.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/52/6476cff4aaa4db3a4724f2dbee7c0f.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/54/6c774586a7a5959ded7079b90271c9.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/56/361894015cce55c8da8d9e1a6697d8.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/57/e5830fa228be4a7d40bf40abfb7a18.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/59/62ccd748530d5866ded674e0247788.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/6f/c49703830099c18aae200de958783b.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/71/07dcdcacdd4ba1ec66dbff844d1ae4.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/74/c0471301abcb86e3fdf4a0c46a7e8a.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/75/91ecebadc9b854574c6221d707d029.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/78/c9d11c271d269bfd2b8749f1724a44.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/88/9df53fba8b2f529d9948608798e517.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/8d/71058010e68ad14f0de1fbdddd0683.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/9e/7a327acb84b95c59a392bc1c60fcbc.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/a1/a5f10f4baaefe52f0f2787f4be6182.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/a6/d6181cf79cbad4a232ed9006617c00.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/a6/d6fa318cd29fa43f778749396e78b5.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/a7/53d3226685fd31b029614775beb88c.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/a7/abb0319db0768b1e786562aa961352.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/a9/939d920c0fa6b4fe0b897fb019672a.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/b2/45e4b4dacb3b4a2fde4a67b3057182.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/b6/2c1e2a759fad26f36b6705aeb096e7.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/cd/540c4ec89745fddd95da7acc0b5ffd.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/dc/99521f54ef0ca3db036ddf570eb97e.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/dd/ab1fa65e47c43b205805eef7a64cc9.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/e0/f15cee86afad4eabb0d5176f63c302.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/e5/98db37d6b441370f395aacdba4f72c.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/f2/0a2ecedf0731845e7d78ddb50c48da.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/cache/fa/22588887edd0328fff0e8630863f2b.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/07.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/08.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/09.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/11.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/12.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/13.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/14.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/15.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/17.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/18.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/19.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/20.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/22.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/23.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/25.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/26.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/27.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/28.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202204/29.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202205/05.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202205/06.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202205/10.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/log/202205/13.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/session/sess_bad423ffe97a0638e54b79b0586a0ae2" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/wap/temp/0942394b88f7fdf4300bcf3b00fe9499.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/runtime/wap/temp/43f4060bd8bd8b5fceb34acdc6d72ac6.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/think" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/.coveralls.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/.travis.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/LICENSE.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/README-CN.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/autoload.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/build-phar.sh" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/example.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/phpunit.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/samples/Bucket.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/samples/BucketCors.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/samples/BucketLifecycle.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/samples/BucketLogging.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/samples/BucketReferer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/samples/BucketWebsite.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/samples/Callback.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/samples/Common.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/samples/Config.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/samples/Image.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/samples/LiveChannel.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/samples/MultipartUpload.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/samples/Object.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/samples/RunAll.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/samples/Signature.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Core/MimeTypes.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Core/OssException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Core/OssUtil.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Http/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Http/RequestCore.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Http/RequestCore_Exception.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Http/ResponseCore.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/BucketInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/BucketListInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/CnameConfig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/CorsConfig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/CorsRule.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/GetLiveChannelHistory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/GetLiveChannelInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/GetLiveChannelStatus.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LifecycleAction.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LifecycleConfig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LifecycleRule.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/ListMultipartUploadInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/ListPartsInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LiveChannelConfig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LiveChannelHistory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LiveChannelInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LiveChannelListInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LoggingConfig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/ObjectInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/ObjectListInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/PartInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/PrefixInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/RefererConfig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/StorageCapacityConfig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/UploadInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/WebsiteConfig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/XmlConfig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/OssClient.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/AclResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/AppendResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/BodyResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/CallbackResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/CopyObjectResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/DeleteObjectsResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ExistResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetCnameResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetCorsResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLifecycleResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLiveChannelHistoryResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLiveChannelInfoResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLiveChannelStatusResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLocationResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLoggingResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetRefererResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetStorageCapacityResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetWebsiteResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/HeaderResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/InitiateMultipartUploadResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListBucketsResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListLiveChannelResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListMultipartUploadResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListObjectsResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListPartsResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/PutLiveChannelResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/PutSetDeleteResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/Result.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/SymlinkResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/UploadPartResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/AclResultTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/BodyResultTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/BucketCnameTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/BucketInfoTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/BucketLiveChannelTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/CallbackTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/CnameConfigTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/Common.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ContentTypeTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/CopyObjectResult.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/CorsConfigTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ExistResultTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetCorsResultTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetLifecycleResultTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetLoggingResultTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetRefererResultTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetWebsiteResultTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/HeaderResultTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/HttpTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/InitiateMultipartUploadResultTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/LifecycleConfigTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ListBucketsResultTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ListMultipartUploadResultTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ListObjectsResultTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ListPartsResultTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/LiveChannelXmlTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/LoggingConfigTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/MimeTypesTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ObjectAclTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketCorsTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketLifecycleTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketLoggingTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketRefererTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketStorageCapacityTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketWebsiteTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientImageTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientMultipartUploadTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientObjectTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientRestoreObjectTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientSignatureTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssExceptionTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssUtilTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/PutSetDeleteResultTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/RefererConfigTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/StorageCapacityTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/SymlinkTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/TestOssClientBase.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/UploadPartResultTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/WebsiteConfigTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/autoload.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/bin/var-dump-server" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/composer/ClassLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/composer/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/composer/autoload_classmap.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/composer/autoload_files.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/composer/autoload_namespaces.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/composer/autoload_psr4.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/composer/autoload_real.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/composer/autoload_static.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/composer/installed.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/QRcode.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/1533712618.png-errors.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/1533712621.png-errors.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/73_product_detail_3_is_promoter_1_wap.jpg-errors.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/75_product_detail_3_is_promoter_0_wap.jpg-errors.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/75_product_detail_3_is_promoter_1_wap.jpg-errors.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/75_product_detail_wap.jpg-errors.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/CHANGELOG" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/INSTALL" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/README" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/VERSION" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/bindings/tcpdf/qrcode.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_10.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_10.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_11.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_11.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_12.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_12.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_13.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_13.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_14.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_14.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_15.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_15.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_16.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_16.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_17.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_17.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_18.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_18.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_19.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_19.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_20.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_20.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_21.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_21.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_22.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_22.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_23.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_23.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_24.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_24.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_25.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_25.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_26.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_26.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_27.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_27.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_28.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_28.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_29.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_29.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_30.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_30.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_31.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_31.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_32.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_32.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_33.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_33.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_34.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_34.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_35.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_35.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_36.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_36.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_37.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_37.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_38.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_38.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_39.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_39.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_4.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_40.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_40.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_5.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_6.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_7.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_8.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_8.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_9.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/frame_9.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_101_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_105_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_109_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_113_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_117_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_121_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_125_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_129_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_133_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_137_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_141_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_145_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_149_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_153_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_157_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_161_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_165_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_169_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_173_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_177_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_21_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_25_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_29_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_33_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_37_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_41_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_45_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_49_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_53_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_57_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_61_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_65_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_69_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_73_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_77_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_81_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_85_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_89_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_93_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_0/mask_97_0.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_101_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_105_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_109_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_113_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_117_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_121_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_125_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_129_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_133_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_137_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_141_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_145_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_149_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_153_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_157_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_161_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_165_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_169_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_173_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_177_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_21_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_25_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_29_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_33_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_37_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_41_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_45_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_49_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_53_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_57_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_61_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_65_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_69_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_73_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_77_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_81_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_85_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_89_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_93_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_1/mask_97_1.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_101_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_105_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_109_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_113_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_117_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_121_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_125_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_129_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_133_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_137_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_141_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_145_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_149_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_153_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_157_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_161_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_165_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_169_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_173_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_177_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_21_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_25_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_29_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_33_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_37_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_41_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_45_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_49_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_53_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_57_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_61_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_65_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_69_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_73_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_77_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_81_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_85_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_89_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_93_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_2/mask_97_2.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_101_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_105_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_109_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_113_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_117_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_121_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_125_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_129_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_133_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_137_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_141_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_145_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_149_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_153_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_157_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_161_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_165_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_169_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_173_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_177_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_21_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_25_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_29_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_33_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_37_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_41_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_45_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_49_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_53_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_57_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_61_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_65_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_69_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_73_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_77_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_81_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_85_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_89_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_93_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_3/mask_97_3.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_101_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_105_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_109_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_113_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_117_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_121_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_125_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_129_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_133_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_137_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_141_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_145_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_149_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_153_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_157_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_161_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_165_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_169_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_173_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_177_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_21_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_25_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_29_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_33_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_37_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_41_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_45_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_49_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_53_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_57_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_61_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_65_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_69_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_73_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_77_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_81_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_85_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_89_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_93_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_4/mask_97_4.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_101_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_105_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_109_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_113_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_117_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_121_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_125_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_129_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_133_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_137_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_141_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_145_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_149_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_153_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_157_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_161_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_165_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_169_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_173_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_177_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_21_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_25_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_29_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_33_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_37_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_41_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_45_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_49_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_53_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_57_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_61_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_65_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_69_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_73_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_77_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_81_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_85_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_89_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_93_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_5/mask_97_5.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_101_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_105_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_109_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_113_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_117_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_121_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_125_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_129_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_133_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_137_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_141_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_145_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_149_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_153_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_157_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_161_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_165_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_169_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_173_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_177_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_21_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_25_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_29_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_33_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_37_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_41_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_45_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_49_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_53_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_57_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_61_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_65_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_69_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_73_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_77_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_81_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_85_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_89_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_93_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_6/mask_97_6.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_101_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_105_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_109_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_113_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_117_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_121_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_125_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_129_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_133_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_137_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_141_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_145_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_149_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_153_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_157_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_161_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_165_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_169_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_173_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_177_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_21_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_25_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_29_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_33_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_37_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_41_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_45_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_49_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_53_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_57_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_61_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_65_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_69_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_73_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_77_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_81_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_85_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_89_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_93_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/cache/mask_7/mask_97_7.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/phpqrcode.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/qrbitstream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/qrconfig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/qrconst.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/qrencode.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/qrimage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/qrinput.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/qrlib.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/qrmask.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/qrrscode.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/qrspec.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/qrsplit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/qrtools.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/tools/merge.bat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/tools/merge.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/tools/merge.sh" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/tools/merged_config.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/phpqrcode/tools/merged_header.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/dh2y/think-qrcode/src/simsun.ttc" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/.coveralls.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/.travis.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/UPGRADE.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/build.properties" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/build.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ApcCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ArrayCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/Cache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/CacheProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ChainCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ClearableCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/CouchbaseCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/FileCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/FilesystemCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/FlushableCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MemcacheCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MemcachedCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MongoDBCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MultiGetCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/PhpFileCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/PredisCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/RedisCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/RiakCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/SQLite3Cache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/Version.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/VoidCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/WinCacheCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/XcacheCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ZendDataCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/phpunit.xml.dist" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/ApcCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/ArrayCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/BaseFileCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/CacheProviderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/CacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/ChainCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/CouchbaseCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/FileCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/FilesystemCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/MemcacheCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/MemcachedCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/MongoDBCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/PhpFileCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/PredisCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/RedisCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/RiakCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/SQLite3CacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/VoidCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/WinCacheCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/XcacheCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/ZendDataCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/DoctrineTestCase.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/Doctrine/Tests/TestInit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/travis/php.ini" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/doctrine/cache/tests/travis/phpunit.travis.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/firebase/php-jwt/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/firebase/php-jwt/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/firebase/php-jwt/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/firebase/php-jwt/src/BeforeValidException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/firebase/php-jwt/src/ExpiredException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/firebase/php-jwt/src/JWT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/firebase/php-jwt/src/SignatureInvalidException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/.travis.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/UPGRADING.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/build.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/Makefile" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/_downloads/guzzle-schema-1.0.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/_static/guzzle-icon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/_static/homepage.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/_static/logo.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/_static/prettify.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/_static/prettify.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/_templates/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/_templates/leftbar.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/_templates/nav_links.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/batching/batching.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/conf.py" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/docs.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/getting-started/faq.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/getting-started/installation.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/getting-started/overview.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/http-client/client.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/http-client/entity-bodies.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/http-client/http-redirects.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/http-client/request.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/http-client/response.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/http-client/uri-templates.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/index.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/iterators/guzzle-iterators.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/iterators/resource-iterators.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/plugins/async-plugin.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/plugins/backoff-plugin.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/plugins/cache-plugin.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/plugins/cookie-plugin.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/plugins/creating-plugins.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/plugins/curl-auth-plugin.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/plugins/history-plugin.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/plugins/log-plugin.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/plugins/md5-validator-plugin.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/plugins/mock-plugin.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/plugins/oauth-plugin.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/plugins/plugins-list.rst.inc" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/plugins/plugins-overview.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/requirements.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/testing/unit-testing.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/webservice-client/guzzle-service-descriptions.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/webservice-client/using-the-service-builder.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/docs/webservice-client/webservice-client.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/phar-stub.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/phing/build.properties.dist" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/phing/imports/dependencies.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/phing/imports/deploy.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/phing/tasks/ComposerLintTask.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/phing/tasks/GuzzlePearPharPackageTask.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/phing/tasks/GuzzleSubSplitTask.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/phpunit.xml.dist" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Batch/AbstractBatchDecorator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Batch/Batch.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Batch/BatchBuilder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Batch/BatchClosureDivisor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Batch/BatchClosureTransfer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Batch/BatchCommandTransfer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Batch/BatchDivisorInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Batch/BatchInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Batch/BatchRequestTransfer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Batch/BatchSizeDivisor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Batch/BatchTransferInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Batch/Exception/BatchTransferException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Batch/ExceptionBufferingBatch.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Batch/FlushingBatch.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Batch/HistoryBatch.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Batch/NotifyingBatch.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Batch/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Cache/AbstractCacheAdapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Cache/CacheAdapterFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Cache/CacheAdapterInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Cache/ClosureCacheAdapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Cache/DoctrineCacheAdapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Cache/NullCacheAdapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Cache/Zf1CacheAdapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Cache/Zf2CacheAdapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Cache/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Common/AbstractHasDispatcher.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Common/Collection.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Common/Event.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Common/Exception/BadMethodCallException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Common/Exception/ExceptionCollection.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Common/Exception/GuzzleException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Common/Exception/InvalidArgumentException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Common/Exception/RuntimeException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Common/Exception/UnexpectedValueException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Common/FromConfigInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Common/HasDispatcherInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Common/ToArrayInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Common/Version.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Common/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/AbstractEntityBodyDecorator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/CachingEntityBody.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Client.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/ClientInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Curl/CurlHandle.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Curl/CurlMulti.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Curl/CurlMultiInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Curl/CurlMultiProxy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Curl/CurlVersion.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Curl/RequestMediator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/EntityBody.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/EntityBodyInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Exception/BadResponseException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Exception/ClientErrorResponseException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Exception/CouldNotRewindStreamException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Exception/CurlException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Exception/HttpException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Exception/MultiTransferException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Exception/RequestException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Exception/ServerErrorResponseException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Exception/TooManyRedirectsException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/IoEmittingEntityBody.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/AbstractMessage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/EntityEnclosingRequest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/EntityEnclosingRequestInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/Header.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/Header/CacheControl.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/Header/HeaderCollection.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/Header/HeaderFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/Header/HeaderFactoryInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/Header/HeaderInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/Header/Link.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/MessageInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/PostFile.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/PostFileInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/Request.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/RequestFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/RequestFactoryInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/RequestInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Message/Response.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Mimetypes.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/QueryAggregator/CommaAggregator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/QueryAggregator/DuplicateAggregator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/QueryAggregator/PhpAggregator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/QueryAggregator/QueryAggregatorInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/QueryString.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/ReadLimitEntityBody.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/RedirectPlugin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Resources/cacert.pem" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/StaticClient.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/Url.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Http/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Inflection/Inflector.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Inflection/InflectorInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Inflection/MemoizingInflector.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Inflection/PreComputedInflector.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Inflection/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Iterator/AppendIterator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Iterator/ChunkedIterator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Iterator/FilterIterator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Iterator/MapIterator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Iterator/MethodProxyIterator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Iterator/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Iterator/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Log/AbstractLogAdapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Log/ArrayLogAdapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Log/ClosureLogAdapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Log/LogAdapterInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Log/MessageFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Log/MonologLogAdapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Log/PsrLogAdapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Log/Zf1LogAdapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Log/Zf2LogAdapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Log/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Parser/Cookie/CookieParser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Parser/Cookie/CookieParserInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Parser/Message/AbstractMessageParser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Parser/Message/MessageParser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Parser/Message/MessageParserInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Parser/Message/PeclHttpMessageParser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Parser/ParserRegistry.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Parser/UriTemplate/PeclUriTemplate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Parser/UriTemplate/UriTemplate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Parser/UriTemplate/UriTemplateInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Parser/Url/UrlParser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Parser/Url/UrlParserInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Parser/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Async/AsyncPlugin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Async/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/AbstractBackoffStrategy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/AbstractErrorCodeBackoffStrategy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/BackoffLogger.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/BackoffPlugin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/BackoffStrategyInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/CallbackBackoffStrategy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/ConstantBackoffStrategy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/CurlBackoffStrategy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/ExponentialBackoffStrategy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/HttpBackoffStrategy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/LinearBackoffStrategy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/ReasonPhraseBackoffStrategy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/TruncatedBackoffStrategy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/CacheKeyProviderInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/CachePlugin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/CacheStorageInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/CallbackCanCacheStrategy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/CanCacheStrategyInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/DefaultCacheKeyProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/DefaultCacheStorage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/DefaultCanCacheStrategy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/DefaultRevalidation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/DenyRevalidation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/RevalidationInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/SkipRevalidation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cookie/Cookie.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cookie/CookieJar/ArrayCookieJar.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cookie/CookieJar/CookieJarInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cookie/CookieJar/FileCookieJar.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cookie/CookiePlugin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cookie/Exception/InvalidCookieException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cookie/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/CurlAuth/CurlAuthPlugin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/CurlAuth/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/ErrorResponse/ErrorResponseExceptionInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/ErrorResponse/ErrorResponsePlugin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/ErrorResponse/Exception/ErrorResponseException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/ErrorResponse/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/History/HistoryPlugin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/History/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Log/LogPlugin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Log/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Md5/CommandContentMd5Plugin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Md5/Md5ValidatorPlugin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Md5/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Mock/MockPlugin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Mock/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Oauth/OauthPlugin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/Oauth/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Plugin/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/AbstractConfigLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Builder/ServiceBuilder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Builder/ServiceBuilderInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Builder/ServiceBuilderLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/CachingConfigLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Client.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/ClientInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/AbstractCommand.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/ClosureCommand.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/CommandInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/CreateResponseClassEvent.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/DefaultRequestSerializer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/DefaultResponseParser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/Factory/AliasFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/Factory/CompositeFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/Factory/ConcreteClassFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/Factory/FactoryInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/Factory/MapFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/Factory/ServiceDescriptionFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/AbstractRequestVisitor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/BodyVisitor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/HeaderVisitor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/JsonVisitor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/PostFieldVisitor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/PostFileVisitor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/QueryVisitor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/RequestVisitorInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/ResponseBodyVisitor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/XmlVisitor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/AbstractResponseVisitor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/BodyVisitor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/HeaderVisitor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/JsonVisitor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/ReasonPhraseVisitor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/ResponseVisitorInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/StatusCodeVisitor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/XmlVisitor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/VisitorFlyweight.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/OperationCommand.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/OperationResponseParser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/RequestSerializerInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/ResponseClassInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Command/ResponseParserInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/ConfigLoaderInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Description/Operation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Description/OperationInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Description/Parameter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Description/SchemaFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Description/SchemaValidator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Description/ServiceDescription.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Description/ServiceDescriptionInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Description/ServiceDescriptionLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Description/ValidatorInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Exception/CommandException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Exception/CommandTransferException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Exception/DescriptionBuilderException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Exception/InconsistentClientTransferException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Exception/ResponseClassException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Exception/ServiceBuilderException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Exception/ServiceNotFoundException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Exception/ValidationException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/AbstractResourceIteratorFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/CompositeResourceIteratorFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/MapResourceIteratorFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/Model.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/ResourceIterator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/ResourceIteratorApplyBatched.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/ResourceIteratorClassFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/ResourceIteratorFactoryInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/ResourceIteratorInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Service/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Stream/PhpStreamRequestFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Stream/Stream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Stream/StreamInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Stream/StreamRequestFactoryInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/src/Guzzle/Stream/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/AbstractBatchDecoratorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchBuilderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchClosureDivisorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchClosureTransferTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchCommandTransferTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchRequestTransferTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchSizeDivisorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/ExceptionBufferingBatchTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/FlushingBatchTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/HistoryBatchTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/NotifyingBatchTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/CacheAdapterFactoryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/CacheAdapterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/ClosureCacheAdapterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/NullCacheAdapterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/Zf2CacheAdapterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/AbstractHasDispatcherTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/CollectionTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/EventTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/Exception/BatchTransferExceptionTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/Exception/ExceptionCollectionTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/VersionTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/GuzzleTestCase.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/AbstractEntityBodyDecoratorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/CachingEntityBodyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/ClientTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/CurlHandleTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/CurlMultiProxyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/CurlMultiTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/CurlVersionTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/RequestMediatorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/EntityBodyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Exception/CurlExceptionTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Exception/ExceptionTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Exception/MultiTransferExceptionTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/IoEmittingEntityBodyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/AbstractMessageTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/EntityEnclosingRequestTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/Header/HeaderFactoryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/Header/LinkTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/HeaderComparison.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/HeaderComparisonTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/HeaderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/PostFileTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/RequestFactoryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/RequestTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/ResponseTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/MimetypesTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/QueryAggregator/CommaAggregatorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/QueryAggregator/DuplicateAggregatorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/QueryAggregator/PhpAggregatorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/QueryStringTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/ReadLimitEntityBodyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/RedirectPluginTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Server.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/StaticClientTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/UrlTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/server.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Inflection/InflectorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Inflection/MemoizingInflectorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Inflection/PreComputedInflectorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/AppendIteratorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/ChunkedIteratorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/FilterIteratorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/MapIteratorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/MethodProxyIteratorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/ArrayLogAdapterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/ClosureLogAdapterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/MessageFormatterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/PsrLogAdapterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/Zf2LogAdapterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/CustomResponseModel.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/ErrorResponseMock.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/ExceptionMock.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/MockMulti.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/MockObserver.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/MockSubject.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/Cookie/CookieParserProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/Cookie/CookieParserTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/Message/MessageParserProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/Message/MessageParserTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/Message/PeclHttpMessageParserTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/ParserRegistryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/UriTemplate/AbstractUriTemplateTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/UriTemplate/PeclUriTemplateTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/UriTemplate/UriTemplateTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Async/AsyncPluginTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/AbstractBackoffStrategyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/BackoffLoggerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/BackoffPluginTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/CallbackBackoffStrategyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/ConstantBackoffStrategyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/CurlBackoffStrategyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/ExponentialBackoffStrategyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/HttpBackoffStrategyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/LinearBackoffStrategyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/ReasonPhraseBackoffStrategyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/TruncatedBackoffStrategyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/CachePluginTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/CallbackCanCacheStrategyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/DefaultCacheStorageTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/DefaultCanCacheStrategyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/DefaultRevalidationTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/DenyRevalidationTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/SkipRevalidationTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cookie/CookieJar/ArrayCookieJarTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cookie/CookieJar/FileCookieJarTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cookie/CookiePluginTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cookie/CookieTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/CurlAuth/CurlAuthPluginTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/ErrorResponse/ErrorResponsePluginTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/History/HistoryPluginTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Log/LogPluginTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Md5/CommandContentMd5PluginTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Md5/Md5ValidatorPluginTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Mock/MockPluginTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Oauth/OauthPluginTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/AbstractConfigLoaderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Builder/ServiceBuilderLoaderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Builder/ServiceBuilderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/CachingConfigLoaderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/ClientTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/AbstractCommandTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/ClosureCommandTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/CommandTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/DefaultRequestSerializerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/DefaultResponseParserTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/AliasFactoryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/CompositeFactoryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/ConcreteClassFactoryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/MapFactoryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/ServiceDescriptionFactoryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/AbstractVisitorTestCase.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/BodyVisitorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/HeaderVisitorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/JsonVisitorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/PostFieldVisitorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/PostFileVisitorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/QueryVisitorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/ResponseBodyVisitorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/XmlVisitorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/AbstractResponseVisitorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/BodyVisitorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/HeaderVisitorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/JsonVisitorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/ReasonPhraseVisitorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/StatusCodeVisitorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/XmlVisitorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/VisitorFlyweightTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/OperationCommandTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/OperationResponseParserTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/OperationTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/ParameterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/SchemaFormatterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/SchemaValidatorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/ServiceDescriptionLoaderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/ServiceDescriptionTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Exception/CommandTransferExceptionTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Exception/InconsistentClientTransferExceptionTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Exception/ValidationExceptionTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Command/IterableCommand.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Command/MockCommand.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Command/OtherCommand.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Command/Sub/Sub.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/MockClient.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Model/MockCommandIterator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/CompositeResourceIteratorFactoryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/MapResourceIteratorFactoryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/ModelTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/ResourceIteratorClassFactoryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/ResourceIteratorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Stream/PhpStreamRequestFactoryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/Stream/StreamTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/FileBody.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/description/bar.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/description/baz.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/description/foo.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/description/recursive.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/mock_response" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/services/json1.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/services/json2.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/services/services.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/test_service.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/test_service2.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/test_service_3.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzle/guzzle/tests/bootstrap.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/UPGRADING.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Client.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/ClientInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Cookie/CookieJar.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Cookie/CookieJarInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Cookie/FileCookieJar.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Cookie/SessionCookieJar.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Cookie/SetCookie.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Exception/BadResponseException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Exception/ClientException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Exception/ConnectException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Exception/GuzzleException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Exception/RequestException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Exception/SeekException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Exception/ServerException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Exception/TooManyRedirectsException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Exception/TransferException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Handler/CurlFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Handler/CurlFactoryInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Handler/CurlHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Handler/CurlMultiHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Handler/EasyHandle.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Handler/MockHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Handler/Proxy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Handler/StreamHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/HandlerStack.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/MessageFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Middleware.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/Pool.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/PrepareBodyMiddleware.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/RedirectMiddleware.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/RequestOptions.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/RetryMiddleware.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/TransferStats.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/UriTemplate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/functions.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/guzzle/src/functions_include.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/Makefile" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/src/AggregateException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/src/CancellationException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/src/Coroutine.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/src/EachPromise.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/src/FulfilledPromise.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/src/Promise.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/src/PromiseInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/src/PromisorInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/src/RejectedPromise.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/src/RejectionException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/src/TaskQueue.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/src/TaskQueueInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/src/functions.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/promises/src/functions_include.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/.editorconfig" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/AppendStream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/BufferStream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/CachingStream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/DroppingStream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/FnStream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/InflateStream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/LazyOpenStream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/LimitStream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/MessageTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/MultipartStream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/NoSeekStream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/PumpStream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/Request.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/Response.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/Rfc7230.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/ServerRequest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/Stream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/StreamDecoratorTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/StreamWrapper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/UploadedFile.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/Uri.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/UriNormalizer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/UriResolver.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/functions.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/guzzlehttp/psr7/src/functions_include.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/.editorconfig" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/.php_cs" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/.scrutinizer.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/.travis.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/clover/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/phpspec.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/phpunit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/phpunit.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/readme.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/spec/CachedAdapterSpec.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/src/CacheInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/src/CachedAdapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/src/Storage/AbstractCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/src/Storage/Adapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/src/Storage/Memcached.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/src/Storage/Memory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/src/Storage/Noop.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/src/Storage/PhpRedis.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/src/Storage/Predis.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/src/Storage/Psr6Cache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/src/Storage/Stash.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/tests/AdapterCacheTests.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/tests/InspectionTests.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/tests/MemcachedTests.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/tests/MemoryCacheTests.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/tests/NoopCacheTests.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/tests/PhpRedisTests.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/tests/PredisTests.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/tests/Psr6CacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter/tests/StashTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/deprecations.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Adapter/AbstractAdapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Adapter/AbstractFtpAdapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Adapter/CanOverwriteFiles.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Adapter/Ftp.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Adapter/Ftpd.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Adapter/Local.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Adapter/NullAdapter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Adapter/Polyfill/NotSupportingVisibilityTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Adapter/Polyfill/StreamedCopyTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Adapter/Polyfill/StreamedReadingTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Adapter/Polyfill/StreamedTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Adapter/Polyfill/StreamedWritingTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Adapter/SynologyFtp.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/AdapterInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Config.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/ConfigAwareTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Directory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Exception.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/File.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/FileExistsException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/FileNotFoundException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Filesystem.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/FilesystemInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/FilesystemNotFoundException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Handler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/MountManager.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/NotSupportedException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Plugin/AbstractPlugin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Plugin/EmptyDir.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Plugin/ForcedCopy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Plugin/ForcedRename.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Plugin/GetWithMetadata.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Plugin/ListFiles.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Plugin/ListPaths.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Plugin/ListWith.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Plugin/PluggableTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Plugin/PluginNotFoundException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/PluginInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/ReadInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/RootViolationException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/SafeStorage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/UnreadableFileException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Util.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Util/ContentListingFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Util/MimeType.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/league/flysystem/src/Util/StreamHasher.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/.php_cs" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/doc/01-usage.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/doc/02-handlers-formatters-processors.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/doc/03-utilities.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/doc/04-extending.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/doc/sockets.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/phpunit.xml.dist" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/ErrorHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Formatter/ChromePHPFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Formatter/ElasticaFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Formatter/FlowdockFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Formatter/FluentdFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Formatter/FormatterInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Formatter/GelfMessageFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Formatter/HtmlFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Formatter/JsonFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Formatter/LineFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Formatter/LogglyFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Formatter/LogstashFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Formatter/MongoDBFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Formatter/NormalizerFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Formatter/ScalarFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Formatter/WildfireFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/AbstractHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/AbstractProcessingHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/AbstractSyslogHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/AmqpHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/BrowserConsoleHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/BufferHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/ChromePHPHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/CouchDBHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/CubeHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/Curl/Util.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/DeduplicationHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/DoctrineCouchDBHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/DynamoDbHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/ElasticSearchHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/ErrorLogHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/FilterHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/FingersCrossed/ActivationStrategyInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/FingersCrossed/ChannelLevelActivationStrategy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/FingersCrossed/ErrorLevelActivationStrategy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/FingersCrossedHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/FirePHPHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/FleepHookHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/FlowdockHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/GelfHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/GroupHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/HandlerInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/HandlerWrapper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/HipChatHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/IFTTTHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/InsightOpsHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/LogEntriesHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/LogglyHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/MailHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/MandrillHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/MissingExtensionException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/MongoDBHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/NativeMailerHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/NewRelicHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/NullHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/PHPConsoleHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/PsrHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/PushoverHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/RavenHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/RedisHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/RollbarHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/RotatingFileHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/SamplingHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/Slack/SlackRecord.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/SlackHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/SlackWebhookHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/SlackbotHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/SocketHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/StreamHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/SwiftMailerHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/SyslogHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/SyslogUdp/UdpSocket.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/SyslogUdpHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/TestHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/WhatFailureGroupHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Handler/ZendMonitorHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Logger.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Processor/GitProcessor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Processor/IntrospectionProcessor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Processor/MemoryPeakUsageProcessor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Processor/MemoryProcessor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Processor/MemoryUsageProcessor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Processor/MercurialProcessor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Processor/ProcessIdProcessor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Processor/ProcessorInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Processor/PsrLogMessageProcessor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Processor/TagProcessor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Processor/UidProcessor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Processor/WebProcessor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Registry.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/ResettableInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/SignalHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/src/Monolog/Utils.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/ErrorHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Formatter/ChromePHPFormatterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Formatter/ElasticaFormatterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Formatter/FlowdockFormatterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Formatter/FluentdFormatterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Formatter/GelfMessageFormatterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Formatter/JsonFormatterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Formatter/LineFormatterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Formatter/LogglyFormatterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Formatter/LogstashFormatterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Formatter/MongoDBFormatterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Formatter/NormalizerFormatterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Formatter/ScalarFormatterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Formatter/WildfireFormatterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/AbstractHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/AbstractProcessingHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/AmqpHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/BrowserConsoleHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/BufferHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/ChromePHPHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/CouchDBHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/DeduplicationHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/DoctrineCouchDBHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/DynamoDbHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/ElasticSearchHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/ErrorLogHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/FilterHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/FingersCrossedHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/FirePHPHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/Fixtures/.gitkeep" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/FleepHookHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/FlowdockHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/GelfHandlerLegacyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/GelfHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/GelfMockMessagePublisher.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/GroupHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/HandlerWrapperTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/HipChatHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/InsightOpsHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/LogEntriesHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/MailHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/MockRavenClient.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/MongoDBHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/NativeMailerHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/NewRelicHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/NullHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/PHPConsoleHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/PsrHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/PushoverHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/RavenHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/RedisHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/RollbarHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/RotatingFileHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/SamplingHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/Slack/SlackRecordTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/SlackHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/SlackWebhookHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/SlackbotHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/SocketHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/StreamHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/SwiftMailerHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/SyslogHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/SyslogUdpHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/TestHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/UdpSocketTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/WhatFailureGroupHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Handler/ZendMonitorHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/LoggerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Processor/GitProcessorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Processor/IntrospectionProcessorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Processor/MemoryPeakUsageProcessorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Processor/MemoryUsageProcessorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Processor/MercurialProcessorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Processor/ProcessIdProcessorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Processor/PsrLogMessageProcessorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Processor/TagProcessorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Processor/UidProcessorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/Processor/WebProcessorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/PsrLogCompatTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/RegistryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/SignalHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/monolog/monolog/tests/Monolog/TestCase.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/.github/FUNDING.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/.github/ISSUE_TEMPLATE.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/.multi-tester.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/contributing.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/phpmd.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/readme.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Carbon.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/CarbonImmutable.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/CarbonInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/CarbonInterval.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/CarbonPeriod.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/CarbonTimeZone.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Exceptions/InvalidDateException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Factory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/FactoryImmutable.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/aa.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/aa_DJ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/aa_ER.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/aa_ER@saaho.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/aa_ET.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/af.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/af_NA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/af_ZA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/agq.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/agr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/agr_PE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ak.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ak_GH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/am.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/am_ET.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/an.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/an_ES.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/anp.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/anp_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_AE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_BH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_DJ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_DZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_EG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_EH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_ER.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_IL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_IQ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_JO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_KM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_KW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_LB.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_LY.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_MA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_MR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_OM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_PS.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_QA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_SA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_SD.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_SO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_SS.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_SY.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_Shakl.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_TD.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_TN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ar_YE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/as.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/as_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/asa.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ast.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ast_ES.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ayc.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ayc_PE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/az.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/az_AZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/az_Cyrl.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/az_IR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/az_Latn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bas.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/be.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/be_BY.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/be_BY@latin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bem.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bem_ZM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ber.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ber_DZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ber_MA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bez.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bg.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bg_BG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bhb.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bhb_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bho.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bho_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bi.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bi_VU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bm.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bn_BD.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bn_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bo_CN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bo_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/br.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/br_FR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/brx.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/brx_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bs.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bs_BA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bs_Cyrl.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/bs_Latn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/byn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/byn_ER.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ca.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ca_AD.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ca_ES.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ca_ES_Valencia.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ca_FR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ca_IT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ccp.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ccp_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ce.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ce_RU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/cgg.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/chr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/chr_US.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/cmn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/cmn_TW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/crh.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/crh_UA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/cs.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/cs_CZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/csb.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/csb_PL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/cu.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/cv.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/cv_RU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/cy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/cy_GB.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/da.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/da_DK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/da_GL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/dav.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/de.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/de_AT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/de_BE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/de_CH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/de_DE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/de_IT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/de_LI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/de_LU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/dje.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/doi.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/doi_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/dsb.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/dsb_DE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/dua.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/dv.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/dv_MV.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/dyo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/dz.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/dz_BT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ebu.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ee.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ee_TG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/el.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/el_CY.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/el_GR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_001.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_150.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_AG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_AI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_AS.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_AT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_AU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_BB.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_BE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_BI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_BM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_BS.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_BW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_BZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_CA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_CC.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_CH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_CK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_CM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_CX.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_CY.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_DE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_DG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_DK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_DM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_ER.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_FI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_FJ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_FK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_FM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_GB.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_GD.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_GG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_GH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_GI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_GM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_GU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_GY.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_HK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_IE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_IL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_IM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_IO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_ISO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_JE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_JM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_KE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_KI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_KN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_KY.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_LC.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_LR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_LS.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_MG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_MH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_MO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_MP.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_MS.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_MT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_MU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_MW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_MY.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_NA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_NF.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_NG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_NL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_NR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_NU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_NZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_PG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_PH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_PK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_PN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_PR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_PW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_RW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_SB.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_SC.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_SD.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_SE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_SG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_SH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_SI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_SL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_SS.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_SX.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_SZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_TC.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_TK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_TO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_TT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_TV.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_TZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_UG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_UM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_US.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_US_Posix.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_VC.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_VG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_VI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_VU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_WS.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_ZA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_ZM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/en_ZW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/eo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_419.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_AR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_BO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_BR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_BZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_CL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_CO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_CR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_CU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_DO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_EA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_EC.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_ES.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_GQ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_GT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_HN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_IC.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_MX.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_NI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_PA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_PE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_PH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_PR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_PY.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_SV.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_US.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_UY.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/es_VE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/et.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/et_EE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/eu.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/eu_ES.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ewo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fa.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fa_AF.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fa_IR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ff.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ff_CM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ff_GN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ff_MR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ff_SN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fi.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fi_FI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fil.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fil_PH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fo_DK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fo_FO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_BE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_BF.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_BI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_BJ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_BL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_CA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_CD.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_CF.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_CG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_CH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_CI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_CM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_DJ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_DZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_FR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_GA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_GF.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_GN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_GP.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_GQ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_HT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_KM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_LU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_MA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_MC.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_MF.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_MG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_ML.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_MQ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_MR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_MU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_NC.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_NE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_PF.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_PM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_RE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_RW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_SC.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_SN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_SY.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_TD.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_TG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_TN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_VU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_WF.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fr_YT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fur.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fur_IT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fy_DE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/fy_NL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ga.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ga_IE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/gd.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/gd_GB.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/gez.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/gez_ER.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/gez_ET.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/gl.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/gl_ES.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/gom.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/gom_Latn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/gsw.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/gsw_CH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/gsw_FR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/gsw_LI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/gu.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/gu_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/guz.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/gv.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/gv_GB.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ha.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ha_GH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ha_NE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ha_NG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/hak.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/hak_TW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/haw.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/he.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/he_IL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/hi.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/hi_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/hif.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/hif_FJ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/hne.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/hne_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/hr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/hr_BA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/hr_HR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/hsb.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/hsb_DE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ht.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ht_HT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/hu.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/hu_HU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/hy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/hy_AM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/i18n.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ia.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ia_FR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/id.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/id_ID.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ig_NG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ii.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ik.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ik_CA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/in.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/is.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/is_IS.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/it.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/it_CH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/it_IT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/it_SM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/it_VA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/iu.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/iu_CA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/iw.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ja.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ja_JP.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/jgo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/jmc.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/jv.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ka.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ka_GE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/kab.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/kab_DZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/kam.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/kde.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/kea.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/khq.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ki.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/kk.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/kk_KZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/kkj.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/kl.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/kl_GL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/kln.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/km.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/km_KH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/kn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/kn_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ko.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ko_KP.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ko_KR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/kok.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/kok_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ks.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ks_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ks_IN@devanagari.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ksb.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ksf.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ksh.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ku.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ku_TR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/kw.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/kw_GB.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ky.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ky_KG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lag.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lb.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lb_LU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lg.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lg_UG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/li.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/li_NL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lij.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lij_IT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lkt.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ln.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ln_AO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ln_CD.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ln_CF.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ln_CG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lo_LA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lrc.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lrc_IQ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lt.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lt_LT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lu.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/luo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/luy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lv.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lv_LV.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lzh.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/lzh_TW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mag.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mag_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mai.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mai_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mas.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mas_TZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/me.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mfe.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mfe_MU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mg.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mg_MG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mgh.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mgo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mhr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mhr_RU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mi.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mi_NZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/miq.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/miq_NI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mjw.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mjw_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mk.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mk_MK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ml.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ml_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mn_MN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mni.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mni_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mr_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ms.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ms_BN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ms_MY.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ms_SG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mt.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mt_MT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mua.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/my.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/my_MM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/mzn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nan.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nan_TW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nan_TW@latin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/naq.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nb.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nb_NO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nb_SJ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nd.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nds.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nds_DE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nds_NL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ne.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ne_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ne_NP.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nhn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nhn_MX.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/niu.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/niu_NU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nl.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nl_AW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nl_BE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nl_BQ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nl_CW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nl_NL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nl_SR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nl_SX.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nmg.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nn_NO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nnh.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/no.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nr_ZA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nso.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nso_ZA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nus.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/nyn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/oc.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/oc_FR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/om.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/om_ET.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/om_KE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/or.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/or_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/os.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/os_RU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pa.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pa_Arab.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pa_Guru.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pa_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pa_PK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pap.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pap_AW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pap_CW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pl.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pl_PL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/prg.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ps.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ps_AF.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pt.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pt_AO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pt_BR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pt_CH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pt_CV.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pt_GQ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pt_GW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pt_LU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pt_MO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pt_MZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pt_PT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pt_ST.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/pt_TL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/qu.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/qu_BO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/qu_EC.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/quz.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/quz_PE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/raj.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/raj_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/rm.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/rn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ro.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ro_MD.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ro_RO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/rof.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ru.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ru_BY.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ru_KG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ru_KZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ru_MD.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ru_RU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ru_UA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/rw.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/rw_RW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/rwk.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sa.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sa_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sah.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sah_RU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/saq.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sat.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sat_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sbp.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sc.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sc_IT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/scr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sd.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sd_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sd_IN@devanagari.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/se.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/se_FI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/se_NO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/se_SE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/seh.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ses.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sg.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sgs.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sgs_LT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sh.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/shi.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/shi_Latn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/shi_Tfng.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/shn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/shn_MM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/shs.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/shs_CA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/si.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/si_LK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sid.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sid_ET.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sk.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sk_SK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sl.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sl_SI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sm.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sm_WS.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/smn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/so.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/so_DJ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/so_ET.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/so_KE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/so_SO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sq.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sq_AL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sq_MK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sq_XK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sr_Cyrl.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sr_Cyrl_BA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sr_Cyrl_ME.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sr_Cyrl_XK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sr_Latn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sr_Latn_BA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sr_Latn_ME.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sr_Latn_XK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sr_ME.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sr_RS.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sr_RS@latin.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ss.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ss_ZA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/st.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/st_ZA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sv.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sv_AX.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sv_FI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sv_SE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sw.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sw_CD.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sw_KE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sw_TZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/sw_UG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/szl.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/szl_PL.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ta.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ta_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ta_LK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ta_MY.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ta_SG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tcy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tcy_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/te.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/te_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/teo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/teo_KE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tet.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tg.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tg_TJ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/th.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/th_TH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/the.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/the_NP.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ti.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ti_ER.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ti_ET.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tig_ER.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tk.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tk_TM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tl.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tl_PH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tlh.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tn_ZA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/to.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/to_TO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tpi.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tpi_PG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tr_CY.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tr_TR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ts.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ts_ZA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tt.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tt_RU.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tt_RU@iqtelif.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/twq.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tzl.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tzm.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/tzm_Latn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ug.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ug_CN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/uk.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/uk_UA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/unm.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/unm_US.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ur.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ur_IN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ur_PK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/uz.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/uz_Arab.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/uz_Cyrl.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/uz_Latn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/uz_UZ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/uz_UZ@cyrillic.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/vai.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/vai_Latn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/vai_Vaii.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ve.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/ve_ZA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/vi.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/vi_VN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/vo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/vun.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/wa.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/wa_BE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/wae.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/wae_CH.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/wal.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/wal_ET.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/wo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/wo_SN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/xh.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/xh_ZA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/xog.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/yav.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/yi.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/yi_US.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/yo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/yo_BJ.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/yo_NG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/yue.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/yue_HK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/yue_Hans.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/yue_Hant.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/yuw.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/yuw_PG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/zgh.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/zh.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/zh_CN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/zh_HK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/zh_Hans.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/zh_Hans_HK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/zh_Hans_MO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/zh_Hans_SG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/zh_Hant.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/zh_Hant_HK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/zh_Hant_MO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/zh_MO.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/zh_SG.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/zh_TW.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/zh_YUE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/zu.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Lang/zu_ZA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Language.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Laravel/ServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/List/languages.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/List/regions.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Traits/Boundaries.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Traits/Comparison.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Traits/Converter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Traits/Creator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Traits/Date.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Traits/Difference.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Traits/Localization.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Traits/Macro.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Traits/Modifiers.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Traits/Mutability.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Traits/Options.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Traits/Rounding.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Traits/Serialization.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Traits/Test.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Traits/Timestamp.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Traits/Units.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Traits/Week.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/nesbot/carbon/src/Carbon/Translator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/opis/closure/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/opis/closure/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/opis/closure/NOTICE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/opis/closure/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/opis/closure/autoload.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/opis/closure/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/opis/closure/functions.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/opis/closure/src/Analyzer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/opis/closure/src/ClosureContext.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/opis/closure/src/ClosureScope.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/opis/closure/src/ClosureStream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/opis/closure/src/ISecurityProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/opis/closure/src/ReflectionClosure.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/opis/closure/src/SecurityException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/opis/closure/src/SecurityProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/opis/closure/src/SelfReference.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/opis/closure/src/SerializableClosure.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/.php_cs" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/.travis.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/LICENSE.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/phpunit.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/AccessToken.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/AccessTokenInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/AuthorizeFailedException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/Config.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/FactoryInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/HasAttributes.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/InvalidArgumentException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/InvalidStateException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/ProviderInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/Providers/AbstractProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/Providers/DoubanProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/Providers/FacebookProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/Providers/GitHubProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/Providers/GoogleProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/Providers/LinkedinProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/Providers/QQProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/Providers/WeChatOpenPlatformProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/Providers/WeChatProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/Providers/WeWorkProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/Providers/WeiboProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/SocialiteManager.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/User.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/UserInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/src/WeChatComponentInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/tests/OAuthTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/tests/Providers/WeWorkProviderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/socialite/tests/WechatProviderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/.phplint.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/.styleci.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/BACKERS.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Broadcast/Broadcast.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Broadcast/LICENSE.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Broadcast/MessageBuilder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Broadcast/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Broadcast/Transformer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Broadcast/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Card/Card.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Card/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Card/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Card/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Comment/Comment.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Core/AbstractAPI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Core/AccessToken.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Core/Exception.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Core/Exceptions/FaultException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Core/Exceptions/HttpException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Core/Exceptions/InvalidArgumentException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Core/Exceptions/InvalidConfigException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Core/Exceptions/RuntimeException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Core/Exceptions/UnboundServiceException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Core/Http.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Core/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Core/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Core/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Device/Device.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Device/DeviceHttpException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Device/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Device/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Device/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Encryption/EncryptionException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Encryption/Encryptor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Encryption/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/Application.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/Config.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/BroadcastServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/CardServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/CommentServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/DeviceServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/FundamentalServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/JsServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/MaterialServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/MenuServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/MiniProgramServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/NoticeServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/OAuthServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/OpenPlatformServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/POIServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/PaymentServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/QRCodeServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/ReplyServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/SemanticServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/ServerServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/ShakeAroundServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/StaffServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/StatsServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/UrlServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Foundation/ServiceProviders/UserServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Fundamental/API.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Js/Js.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Js/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Js/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Js/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Material/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Material/Material.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Material/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Material/Temporary.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Material/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Menu/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Menu/Menu.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Menu/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Menu/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/AbstractMessage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/Article.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/Card.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/DeviceEvent.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/DeviceText.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/Image.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/Link.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/Location.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/Material.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/MiniProgramPage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/Music.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/News.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/Raw.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/ShortVideo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/Text.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/Transfer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/Video.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/Voice.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Message/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/MiniProgram/AccessToken.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/MiniProgram/Core/AbstractMiniProgram.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/MiniProgram/Encryption/Encryptor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/MiniProgram/Material/Temporary.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/MiniProgram/MiniProgram.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/MiniProgram/Notice/Notice.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/MiniProgram/QRCode/QRCode.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/MiniProgram/Server/Guard.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/MiniProgram/Sns/Sns.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/MiniProgram/Staff/Staff.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/MiniProgram/Stats/Stats.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Notice/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Notice/Notice.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Notice/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Notice/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/OpenPlatform/AccessToken.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/OpenPlatform/Api/AbstractOpenPlatform.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/OpenPlatform/Api/BaseApi.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/OpenPlatform/Api/PreAuthorization.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/OpenPlatform/Authorizer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/OpenPlatform/AuthorizerAccessToken.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/OpenPlatform/EventHandlers/Authorized.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/OpenPlatform/EventHandlers/ComponentVerifyTicket.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/OpenPlatform/EventHandlers/EventHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/OpenPlatform/EventHandlers/Unauthorized.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/OpenPlatform/EventHandlers/UpdateAuthorized.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/OpenPlatform/Guard.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/OpenPlatform/OpenPlatform.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/OpenPlatform/VerifyTicket.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/POI/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/POI/POI.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/POI/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/POI/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Payment/API.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Payment/CashCoupon/API.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Payment/CashCoupon/CashCoupon.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Payment/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Payment/LuckyMoney/API.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Payment/LuckyMoney/LuckyMoney.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Payment/Merchant.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Payment/MerchantPay/API.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Payment/MerchantPay/MerchantPay.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Payment/Notify.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Payment/Order.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Payment/Payment.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Payment/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Payment/RefundNotify.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Payment/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Payment/helpers.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/QRCode/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/QRCode/QRCode.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/QRCode/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/QRCode/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Reply/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Reply/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Reply/Reply.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Reply/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Semantic/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Semantic/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Semantic/Semantic.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Semantic/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Server/BadRequestException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Server/Guard.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Server/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Server/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Server/Transformer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Server/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/ShakeAround/Device.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/ShakeAround/Group.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/ShakeAround/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/ShakeAround/Material.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/ShakeAround/Page.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/ShakeAround/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/ShakeAround/Relation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/ShakeAround/ShakeAround.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/ShakeAround/Stats.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/ShakeAround/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Staff/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Staff/MessageBuilder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Staff/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Staff/Session.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Staff/Staff.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Staff/Transformer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Staff/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Stats/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Stats/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Stats/Stats.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Stats/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Store/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Store/Model/.gitkeep" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Store/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Store/Store.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Store/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Support/Arr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Support/Attribute.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Support/Collection.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Support/File.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Support/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Support/Log.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Support/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Support/Str.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Support/Traits/PrefixedContainer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Support/Url.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Support/XML.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Support/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Url/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Url/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Url/Url.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/Url/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/User/Group.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/User/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/User/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/User/Tag.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/User/User.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/overtrue/wechat/src/User/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/paragonie/random_compat/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/paragonie/random_compat/build-phar.sh" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/paragonie/random_compat/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/paragonie/random_compat/dist/random_compat.phar.pubkey" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/paragonie/random_compat/dist/random_compat.phar.pubkey.asc" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/paragonie/random_compat/lib/random.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/paragonie/random_compat/other/build_phar.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/paragonie/random_compat/psalm-autoload.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/paragonie/random_compat/psalm.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/.gitattributes" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/.travis.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Autoloader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/CachedObjectStorage/APC.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/CachedObjectStorage/CacheBase.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/CachedObjectStorage/DiscISAM.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/CachedObjectStorage/ICache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/CachedObjectStorage/Igbinary.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/CachedObjectStorage/Memcache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/CachedObjectStorage/Memory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/CachedObjectStorage/MemoryGZip.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/CachedObjectStorage/MemorySerialized.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/CachedObjectStorage/PHPTemp.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/CachedObjectStorage/SQLite.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/CachedObjectStorage/SQLite3.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/CachedObjectStorage/Wincache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/CachedObjectStorageFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/CalcEngine/CyclicReferenceStack.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/CalcEngine/Logger.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation/Database.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation/DateTime.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation/Engineering.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation/Exception.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation/ExceptionHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation/Financial.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation/FormulaParser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation/FormulaToken.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation/Function.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation/Functions.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation/Logical.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation/LookupRef.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation/MathTrig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation/Statistical.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation/TextData.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation/Token/Stack.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Calculation/functionlist.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Cell.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Cell/AdvancedValueBinder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Cell/DataType.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Cell/DataValidation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Cell/DefaultValueBinder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Cell/Hyperlink.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Cell/IValueBinder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Chart.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Chart/Axis.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Chart/DataSeries.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Chart/DataSeriesValues.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Chart/Exception.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Chart/GridLines.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Chart/Layout.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Chart/Legend.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Chart/PlotArea.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Chart/Properties.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Chart/Renderer/PHP Charting Libraries.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Chart/Renderer/jpgraph.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Chart/Title.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Comment.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/DocumentProperties.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/DocumentSecurity.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Exception.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/HashTable.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Helper/HTML.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/IComparable.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/IOFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/NamedRange.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Abstract.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/CSV.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/DefaultReadFilter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Excel2003XML.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Excel2007.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Excel2007/Chart.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Excel2007/Theme.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Excel5.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Excel5/Color.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Excel5/Color/BIFF5.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Excel5/Color/BIFF8.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Excel5/Color/BuiltIn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Excel5/ErrorCode.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Excel5/Escher.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Excel5/MD5.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Excel5/RC4.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Excel5/Style/Border.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Excel5/Style/FillPattern.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Exception.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/Gnumeric.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/HTML.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/IReadFilter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/IReader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/OOCalc.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Reader/SYLK.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/ReferenceHelper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/RichText.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/RichText/ITextElement.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/RichText/Run.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/RichText/TextElement.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Settings.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/CodePage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/Date.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/Drawing.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/Escher.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/Escher/DgContainer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/Escher/DgContainer/SpgrContainer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/Escher/DgContainer/SpgrContainer/SpContainer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/Escher/DggContainer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/Escher/DggContainer/BstoreContainer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/Escher/DggContainer/BstoreContainer/BSE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/Escher/DggContainer/BstoreContainer/BSE/Blip.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/Excel5.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/File.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/Font.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/JAMA/CHANGELOG.TXT" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/JAMA/CholeskyDecomposition.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/JAMA/EigenvalueDecomposition.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/JAMA/LUDecomposition.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/JAMA/Matrix.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/JAMA/QRDecomposition.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/JAMA/SingularValueDecomposition.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/JAMA/utils/Error.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/JAMA/utils/Maths.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/OLE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/OLE/ChainedBlockStream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/OLE/PPS.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/OLE/PPS/File.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/OLE/PPS/Root.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/OLERead.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/PCLZip/gnu-lgpl.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/PCLZip/pclzip.lib.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/PCLZip/readme.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/PasswordHasher.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/String.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/TimeZone.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/XMLWriter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/ZipArchive.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/ZipStreamWrapper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/trend/bestFitClass.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/trend/exponentialBestFitClass.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/trend/linearBestFitClass.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/trend/logarithmicBestFitClass.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/trend/polynomialBestFitClass.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/trend/powerBestFitClass.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Shared/trend/trendClass.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Style.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Style/Alignment.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Style/Border.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Style/Borders.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Style/Color.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Style/Conditional.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Style/Fill.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Style/Font.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Style/NumberFormat.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Style/Protection.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Style/Supervisor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/AutoFilter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/AutoFilter/Column.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/AutoFilter/Column/Rule.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/BaseDrawing.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/CellIterator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/Column.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/ColumnCellIterator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/ColumnDimension.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/ColumnIterator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/Dimension.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/Drawing.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/Drawing/Shadow.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/HeaderFooter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/HeaderFooterDrawing.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/MemoryDrawing.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/PageMargins.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/PageSetup.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/Protection.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/Row.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/RowCellIterator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/RowDimension.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/RowIterator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Worksheet/SheetView.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/WorksheetIterator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Abstract.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/CSV.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel2007.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel2007/Chart.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel2007/Comments.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel2007/ContentTypes.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel2007/DocProps.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel2007/Drawing.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel2007/Rels.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel2007/RelsRibbon.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel2007/RelsVBA.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel2007/StringTable.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel2007/Style.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel2007/Theme.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel2007/Workbook.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel2007/Worksheet.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel2007/WriterPart.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel5.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel5/BIFFwriter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel5/Escher.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel5/Font.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel5/Parser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel5/Workbook.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel5/Worksheet.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Excel5/Xf.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/Exception.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/HTML.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/IWriter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/OpenDocument.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/OpenDocument/Cell/Comment.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/OpenDocument/Content.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/OpenDocument/Meta.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/OpenDocument/MetaInf.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/OpenDocument/Mimetype.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/OpenDocument/Settings.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/OpenDocument/Styles.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/OpenDocument/Thumbnails.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/OpenDocument/WriterPart.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/PDF.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/PDF/Core.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/PDF/DomPDF.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/PDF/mPDF.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/Writer/PDF/tcPDF.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/bg/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/cs/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/cs/functions" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/da/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/da/functions" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/de/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/de/functions" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/en/uk/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/es/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/es/functions" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/fi/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/fi/functions" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/fr/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/fr/functions" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/hu/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/hu/functions" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/it/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/it/functions" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/nl/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/nl/functions" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/no/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/no/functions" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/pl/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/pl/functions" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/pt/br/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/pt/br/functions" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/pt/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/pt/functions" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/ru/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/ru/functions" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/sv/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/sv/functions" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/tr/config" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Classes/PHPExcel/locale/tr/functions" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Calculations/Database/DAVERAGE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Calculations/Database/DCOUNT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Calculations/Database/DGET.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Calculations/Database/DMAX.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Calculations/Database/DMIN.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Calculations/Database/DPRODUCT.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Calculations/Database/DSTDEV.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Calculations/Database/DSTDEVP.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Calculations/Database/DVAR.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Calculations/Database/DVARP.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Calculations/DateTime/DATE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Calculations/DateTime/DATEVALUE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Calculations/DateTime/TIME.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Calculations/DateTime/TIMEVALUE.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Calculations/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader01.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader02.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader03.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader04.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader05.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader06.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader07.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader08.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader09.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader10.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader11.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader12.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader13.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader14.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader15.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader16.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader17.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader18.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/exampleReader19.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/sampleData/example1.csv" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/sampleData/example1.tsv" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/sampleData/example1.xls" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/sampleData/example2.csv" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reader/sampleData/example2.xls" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reading WorkBook Data/exampleWorkBookReader01.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reading WorkBook Data/exampleWorkBookReader02.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reading WorkBook Data/exampleWorkBookReader03.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reading WorkBook Data/exampleWorkBookReader04.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reading WorkBook Data/sampleData/example1.xls" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reading WorkBook Data/sampleData/example1.xlsx" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/Reading WorkBook Data/sampleData/example2.xls" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Examples/index.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/FunctionListByCategory.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/FunctionListByName.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/Functionality Cross-Reference.xls" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/PHPExcel AutoFilter Reference developer documentation.doc" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/PHPExcel Function Reference developer documentation.doc" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/PHPExcel User Documentation - Reading Spreadsheet Files.doc" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/PHPExcel developer documentation.doc" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/Architecture.cd" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/Architecture.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/ClassDiagrams.csproj" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/ClassDiagrams.csproj.user" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/ClassDiagrams.sln" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/Classes/IReader.cs" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/Classes/IWriter.cs" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/Classes/PHPExcel.cs" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/Classes/PHPExcel_IOFactory.cs" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/Classes/PHPExcel_Reader_Excel2007.cs" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/Classes/PHPExcel_Reader_Excel5.cs" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/Classes/PHPExcel_Reader_Serialized.cs" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/Classes/PHPExcel_Writer_Excel2007.cs" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/Classes/PHPExcel_Writer_Serialized.cs" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/Classes/Worksheet.cs" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/Exports/Architecture.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/Exports/ReaderWriter.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/ReaderWriter.cd" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/assets/ClassDiagrams/ReaderWriter.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/CalculationEngine/FunctionReference/01-Introduction.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/CalculationEngine/FunctionReference/02-01-Date-and-Time-Handling.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/CalculationEngine/FunctionReference/02-General-Introduction.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/CalculationEngine/FunctionReference/03-01-Cube-Functions.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/CalculationEngine/FunctionReference/03-02-Database-Functions.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/CalculationEngine/FunctionReference/03-03-Date-and-Time-Functions.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/01-Autofilters.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/02-Setting-an-Autofilter.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/03-Autofilter-Expressions.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/04-01-Autofilter-Expressions-Simple.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/04-02-Autofilter-Expressions-Dategroup.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/04-03-Autofilter-Expressions-Custom.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/04-04-Autofilter-Expressions-Dynamic.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/04-05-Autofilter-Expressions-Topten.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/05-Executing-Autofilters.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/06-Autofilter-Sorting.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/images/01-01-autofilter.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/images/01-02-autofilter.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/images/01-03-filter-icon-1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/images/01-03-filter-icon-2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/images/01-04-autofilter.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/images/04-01-simple-autofilter.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/images/04-02-dategroup-autofilter.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/images/04-03-custom-autofilter-1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/images/04-03-custom-autofilter-2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/images/04-04-dynamic-autofilter.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/images/04-05-topten-autofilter-1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Features/Autofilters/images/04-05-topten-autofilter-2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Functions/FunctionListByCategory.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Functions/FunctionListByName.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/01-Getting-Started.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/02-Architecture.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/03-Creating-a-Spreadsheet.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/04-Configuration-Settings.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/05-Deleting-a-Workbook.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/06-Worksheets.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/07-Accessing-Cells.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/08-Recipes.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/09-Calculation-Engine.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/10-Reading-and-Writing.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/11-Appendices.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/images/01-schematic.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/images/02-readers-writers.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/images/07-simple-example-1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/images/07-simple-example-2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/images/07-simple-example-3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/images/07-simple-example-4.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/images/08-cell-comment.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/images/08-column-width.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/images/08-page-setup-margins.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/images/08-page-setup-scaling-options.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/images/08-styling-border-options.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/images/09-command-line-calculation.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/images/09-formula-in-cell-1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/Overview/images/09-formula-in-cell-2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/ReadingSpreadsheetFiles/01-File-Formats.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/ReadingSpreadsheetFiles/02-Security.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/ReadingSpreadsheetFiles/03-Loading-a-Spreadsheet.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/ReadingSpreadsheetFiles/04-Loading-with-a-Reader.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/ReadingSpreadsheetFiles/05-Reader-Options.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/ReadingSpreadsheetFiles/06-Error-Handling.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Documentation/markdown/ReadingSpreadsheetFiles/07-Helper-Methods.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/01pharSimple.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/01simple-download-ods.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/01simple-download-pdf.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/01simple-download-xls.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/01simple-download-xlsx.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/01simple.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/01simplePCLZip.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/02types-xls.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/02types.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/03formulas.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/04printing.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/05featuredemo.inc.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/05featuredemo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/06largescale-with-cellcaching-sqlite.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/06largescale-with-cellcaching-sqlite3.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/06largescale-with-cellcaching.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/06largescale-xls.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/06largescale.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/07reader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/07readerPCLZip.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/08conditionalformatting.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/08conditionalformatting2.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/09pagebreaks.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/10autofilter-selection-1.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/10autofilter-selection-2.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/10autofilter-selection-display.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/10autofilter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/11documentsecurity-xls.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/11documentsecurity.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/12cellProtection.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/13calculation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/13calculationCyclicFormulae.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/14excel5.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/15datavalidation-xls.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/15datavalidation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/16csv.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/17html.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/18extendedcalculation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/19namedrange.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/20readexcel5.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/21pdf.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/22heavilyformatted.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/23sharedstyles.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/24readfilter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/25inmemoryimage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/26utf8.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/27imagesexcel5.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/28iterator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/29advancedvaluebinder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/30template.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/31docproperties_write-xls.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/31docproperties_write.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/32chartreadwrite.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/33chartcreate-area.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/33chartcreate-bar-stacked.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/33chartcreate-bar.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/33chartcreate-column-2.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/33chartcreate-column.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/33chartcreate-composite.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/33chartcreate-line.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/33chartcreate-multiple-charts.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/33chartcreate-pie.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/33chartcreate-radar.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/33chartcreate-scatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/33chartcreate-stock.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/34chartupdate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/35chartrender.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/36chartreadwriteHTML.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/36chartreadwritePDF.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/37page_layout_view.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/38cloneWorksheet.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/39dropdown.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/40duplicateStyle.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/41password.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/42richText.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/43mergeWorkbooks.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/44worksheetInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/Excel2003XMLReader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/Excel2003XMLTest.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/GnumericReader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/GnumericTest.gnumeric" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/OOCalcReader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/OOCalcReaderPCLZip.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/OOCalcTest.ods" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/Quadratic.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/Quadratic2.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/SylkReader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/SylkTest.slk" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/XMLReader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/XMLTest.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/data/continents/Africa.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/data/continents/Asia.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/data/continents/Europe.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/data/continents/North America.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/data/continents/Oceania.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/data/continents/South America.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/images/paid.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/images/phpexcel_logo.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/Examples/runall.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/changelog.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/install.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/phpoffice/phpexcel/license.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/.travis.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/CHANGELOG" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/README.rst" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/config.m4" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/config.w32" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/php_pimple.h" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/pimple.c" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/pimple_compat.h" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/001.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/002.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/003.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/004.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/005.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/006.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/007.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/008.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/009.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/010.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/011.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/012.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/013.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/014.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/015.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/016.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/017.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/017_1.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/018.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/019.phpt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/bench.phpb" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/ext/pimple/tests/bench_shared.phpb" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/phpunit.xml.dist" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/Container.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/Exception/ExpectedInvokableException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/Exception/FrozenServiceException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/Exception/InvalidServiceIdentifierException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/Exception/UnknownIdentifierException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/Psr11/Container.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/Psr11/ServiceLocator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/ServiceIterator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/ServiceProviderInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/Tests/Fixtures/Invokable.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/Tests/Fixtures/NonInvokable.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/Tests/Fixtures/PimpleServiceProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/Tests/Fixtures/Service.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/Tests/PimpleServiceProviderInterfaceTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/Tests/PimpleTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/Tests/Psr11/ContainerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/Tests/Psr11/ServiceLocatorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/pimple/pimple/src/Pimple/Tests/ServiceIteratorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/cache/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/cache/LICENSE.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/cache/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/cache/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/cache/src/CacheException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/cache/src/CacheItemInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/cache/src/CacheItemPoolInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/cache/src/InvalidArgumentException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/container/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/container/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/container/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/container/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/container/src/ContainerExceptionInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/container/src/ContainerInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/container/src/NotFoundExceptionInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/http-message/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/http-message/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/http-message/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/http-message/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/http-message/src/MessageInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/http-message/src/RequestInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/http-message/src/ResponseInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/http-message/src/ServerRequestInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/http-message/src/StreamInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/http-message/src/UploadedFileInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/http-message/src/UriInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/log/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/log/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/log/Psr/Log/AbstractLogger.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/log/Psr/Log/InvalidArgumentException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/log/Psr/Log/LogLevel.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/log/Psr/Log/LoggerAwareInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/log/Psr/Log/LoggerAwareTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/log/Psr/Log/LoggerInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/log/Psr/Log/LoggerTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/log/Psr/Log/NullLogger.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/log/Psr/Log/Test/LoggerInterfaceTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/log/Psr/Log/Test/TestLogger.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/log/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/log/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/simple-cache/.editorconfig" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/simple-cache/LICENSE.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/simple-cache/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/simple-cache/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/simple-cache/src/CacheException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/simple-cache/src/CacheInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/psr/simple-cache/src/InvalidArgumentException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/.travis.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/phpunit.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/abortMultipartUpload.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/catchException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/completeMultipartUpload.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/copyObject.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/createBucket.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/createMultipartUpload.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/deleteBucket.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/deleteBucketCors.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/deleteBucketLifecycle.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/deleteObject.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/getBucketAcl.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/getBucketCors.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/getBucketLifecycle.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/getObject.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/headBucket.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/headObject.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/listBucket.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/listMultipartUploads.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/listObjects.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/listParts.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/putBucketAcl.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/putBucketCors.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/putBucketLifecycle.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/putObject.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/restoreObject.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/upload.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/sample/uploadPart.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/BucketStyleListener.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/Client.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/Command.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/Copy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/Exception/BucketAlreadyExistsException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/Exception/BucketNotEmptyException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/Exception/CosException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/Exception/CurlException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/Exception/InvalidArgumentException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/Exception/NoSuchBucketException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/Exception/NoSuchKeyException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/Exception/NoSuchUploadException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/Exception/ServiceResponseException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/ExceptionListener.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/ExceptionParser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/Md5Listener.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/MultipartUpload.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/Service.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/Signature.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/SignatureListener.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/Tests/Test.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/Tests/TestHelper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/TokenListener.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5/src/Qcloud/Cos/UploadBodyListener.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/.scrutinizer.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/.travis.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/CONTRIBUTING.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/autoload.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/docs/rtc/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/docs/rtc/example.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/docs/sms/example.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/bucket_lifecycleRule.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/cdn_get_bandwidth.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/cdn_get_flux.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/cdn_get_log_list.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/cdn_refresh_urls_dirs.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/cdn_timestamp_antileech.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/delete_bucket.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/delete_bucketEvent.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/delete_bucketLifecycleRule.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/get_bucketEvents.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/get_bucketLifecycleRules.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/get_bucketList.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/get_bucketQuota.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/get_bucketinfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/get_bucketinfos.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/get_corsRules.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/image_url_builder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/persistent_fop_init.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/persistent_fop_status.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/pfop_mkzip.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/pfop_vframe.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/pfop_video_avthumb.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/pfop_watermark.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/php-logo.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/prefop.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/pulpvideo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/put_bucketAccessMode.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/put_bucketAccessStyleMode.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/put_bucketEvent.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/put_bucketMaxAge.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/put_bucketQuota.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/put_referAntiLeech.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/qetag.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_batch_change_mime.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_batch_change_type.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_batch_copy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_batch_delete.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_batch_delete_after_days.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_batch_move.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_batch_stat.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_bucket_domains.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_buckets.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_change_mime.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_change_status.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_change_type.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_copy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_delete.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_delete_after_days.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_download_urls.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_fetch.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_move.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_prefetch.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_pub_domain.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rs_stat.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rsf_list_bucket.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rsf_list_files.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/rsf_v2list_bucket.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/saveas.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/update_bucketEvent.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/update_bucketLifecycleRule.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/upload_and_callback.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/upload_and_pfop.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/upload_mgr_init.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/upload_multi_demos.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/upload_simple_file.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/upload_tokens.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/examples/upload_verify_callback.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/phpunit.xml.dist" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Auth.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Cdn/CdnManager.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Config.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Etag.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Http/Client.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Http/Error.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Http/Request.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Http/Response.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Processing/ImageUrlBuilder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Processing/Operation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Processing/PersistentFop.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Region.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Rtc/AppClient.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Sms/Sms.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Storage/ArgusManager.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Storage/BucketManager.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Storage/FormUploader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Storage/ResumeUploader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Storage/UploadManager.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/Zone.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/src/Qiniu/functions.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/test-env.sh" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/tests/Qiniu/Tests/AuthTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/tests/Qiniu/Tests/Base64Test.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/tests/Qiniu/Tests/BucketTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/tests/Qiniu/Tests/CdnManagerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/tests/Qiniu/Tests/Crc32Test.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/tests/Qiniu/Tests/DownloadTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/tests/Qiniu/Tests/EtagTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/tests/Qiniu/Tests/FopTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/tests/Qiniu/Tests/FormUpTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/tests/Qiniu/Tests/HttpTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/tests/Qiniu/Tests/ImageUrlBuilderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/tests/Qiniu/Tests/PfopTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/tests/Qiniu/Tests/ResumeUpTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/tests/Qiniu/Tests/ZoneTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/qiniu/php-sdk/tests/bootstrap.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/ralouphie/getallheaders/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/ralouphie/getallheaders/.travis.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/ralouphie/getallheaders/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/ralouphie/getallheaders/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/ralouphie/getallheaders/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/ralouphie/getallheaders/phpunit.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/ralouphie/getallheaders/src/getallheaders.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/ralouphie/getallheaders/tests/GetAllHeadersTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/services.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/spatie/macroable/.styleci.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/spatie/macroable/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/spatie/macroable/CONTRIBUTING.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/spatie/macroable/LICENSE.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/spatie/macroable/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/spatie/macroable/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/spatie/macroable/config/.gitkeep" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/spatie/macroable/src/Macroable.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/ContainerAwareEventDispatcher.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/Debug/TraceableEventDispatcher.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/Debug/TraceableEventDispatcherInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/Debug/WrappedListener.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/DependencyInjection/RegisterListenersPass.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/Event.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/EventDispatcher.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/EventDispatcherInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/EventSubscriberInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/GenericEvent.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/ImmutableEventDispatcher.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/Tests/AbstractEventDispatcherTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/Tests/ContainerAwareEventDispatcherTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/Tests/Debug/TraceableEventDispatcherTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/Tests/DependencyInjection/RegisterListenersPassTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/Tests/EventDispatcherTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/Tests/EventTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/Tests/GenericEventTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/Tests/ImmutableEventDispatcherTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/event-dispatcher/phpunit.xml.dist" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/AcceptHeader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/AcceptHeaderItem.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/ApacheRequest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/BinaryFileResponse.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Cookie.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Exception/ConflictingHeadersException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Exception/RequestExceptionInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Exception/SuspiciousOperationException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/ExpressionRequestMatcher.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/File/Exception/AccessDeniedException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/File/Exception/FileException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/File/Exception/FileNotFoundException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/File/Exception/UnexpectedTypeException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/File/Exception/UploadException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/File/File.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/File/MimeType/ExtensionGuesser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/File/MimeType/ExtensionGuesserInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/File/MimeType/FileBinaryMimeTypeGuesser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/File/MimeType/FileinfoMimeTypeGuesser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/File/MimeType/MimeTypeExtensionGuesser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/File/MimeType/MimeTypeGuesser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/File/MimeType/MimeTypeGuesserInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/File/Stream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/File/UploadedFile.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/FileBag.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/HeaderBag.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/IpUtils.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/JsonResponse.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/ParameterBag.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/RedirectResponse.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Request.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/RequestMatcher.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/RequestMatcherInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/RequestStack.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Response.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/ResponseHeaderBag.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/ServerBag.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Attribute/AttributeBag.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Attribute/AttributeBagInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Attribute/NamespacedAttributeBag.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Flash/AutoExpireFlashBag.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Flash/FlashBag.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Flash/FlashBagInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Session.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/SessionBagInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/SessionBagProxy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/SessionInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/Handler/AbstractSessionHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/Handler/MemcacheSessionHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/Handler/MemcachedSessionHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/Handler/MongoDbSessionHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/Handler/NativeFileSessionHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/Handler/NativeSessionHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/Handler/NullSessionHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/Handler/PdoSessionHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/Handler/StrictSessionHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/Handler/WriteCheckSessionHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/MetadataBag.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/MockArraySessionStorage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/MockFileSessionStorage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/NativeSessionStorage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/PhpBridgeSessionStorage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/Proxy/AbstractProxy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/Proxy/NativeProxy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/Proxy/SessionHandlerProxy.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Session/Storage/SessionStorageInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/StreamedResponse.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/AcceptHeaderItemTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/AcceptHeaderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/ApacheRequestTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/BinaryFileResponseTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/CookieTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/ExpressionRequestMatcherTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/File/FakeFile.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/File/FileTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/File/Fixtures/.unknownextension" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/File/Fixtures/case-sensitive-mime-type.xlsm" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/File/Fixtures/directory/.empty" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/File/Fixtures/other-file.example" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/File/Fixtures/test" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/File/Fixtures/test.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/File/MimeType/MimeTypeTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/File/UploadedFileTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/FileBagTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Fixtures/response-functional/common.inc" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_max_age.expected" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_max_age.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_raw_urlencode.expected" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_raw_urlencode.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_samesite_lax.expected" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_samesite_lax.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_samesite_strict.expected" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_samesite_strict.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_urlencode.expected" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_urlencode.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Fixtures/response-functional/invalid_cookie_name.expected" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Fixtures/response-functional/invalid_cookie_name.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/HeaderBagTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/IpUtilsTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/JsonResponseTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/ParameterBagTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/RedirectResponseTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/RequestMatcherTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/RequestStackTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/RequestTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/ResponseFunctionalTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/ResponseHeaderBagTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/ResponseTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/ResponseTestCase.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/ServerBagTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Attribute/AttributeBagTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Attribute/NamespacedAttributeBagTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Flash/AutoExpireFlashBagTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Flash/FlashBagTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/SessionTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/AbstractSessionHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/common.inc" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/empty_destroys.expected" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/empty_destroys.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/read_only.expected" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/read_only.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/regenerate.expected" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/regenerate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/storage.expected" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/storage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/with_cookie.expected" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/with_cookie.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/with_cookie_and_session.expected" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/with_cookie_and_session.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/MemcacheSessionHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/MemcachedSessionHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/MongoDbSessionHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/NativeFileSessionHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/NativeSessionHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/NullSessionHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/PdoSessionHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/StrictSessionHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Handler/WriteCheckSessionHandlerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/MetadataBagTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/MockArraySessionStorageTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/MockFileSessionStorageTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/NativeSessionStorageTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/PhpBridgeSessionStorageTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Proxy/AbstractProxyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Proxy/NativeProxyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/Session/Storage/Proxy/SessionHandlerProxyTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/StreamedResponseTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/schema/http-status-codes.rng" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/Tests/schema/iana-registry.rng" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/http-foundation/phpunit.xml.dist" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-mbstring/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-mbstring/Mbstring.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-mbstring/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-mbstring/Resources/unidata/lowerCase.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-mbstring/Resources/unidata/titleCaseRegexp.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-mbstring/Resources/unidata/upperCase.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-mbstring/bootstrap.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-mbstring/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-php70/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-php70/Php70.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-php70/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-php70/Resources/stubs/ArithmeticError.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-php70/Resources/stubs/AssertionError.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-php70/Resources/stubs/DivisionByZeroError.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-php70/Resources/stubs/Error.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-php70/Resources/stubs/ParseError.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-php70/Resources/stubs/SessionUpdateTimestampHandlerInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-php70/Resources/stubs/TypeError.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-php70/bootstrap.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-php70/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-php72/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-php72/Php72.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-php72/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-php72/bootstrap.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/polyfill-php72/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Exception/ExceptionInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Exception/InvalidArgumentException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Exception/LogicException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Exception/ProcessFailedException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Exception/ProcessSignaledException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Exception/ProcessTimedOutException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Exception/RuntimeException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/ExecutableFinder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/InputStream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/PhpExecutableFinder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/PhpProcess.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Pipes/AbstractPipes.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Pipes/PipesInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Pipes/UnixPipes.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Pipes/WindowsPipes.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Process.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/ProcessUtils.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Tests/ErrorProcessInitiator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Tests/ExecutableFinderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Tests/KillableProcessWithOutput.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Tests/NonStopableProcess.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Tests/PhpExecutableFinderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Tests/PhpProcessTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Tests/PipeStdinInStdoutStdErrStreamSelect.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Tests/ProcessFailedExceptionTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Tests/ProcessTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/Tests/SignalListener.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/process/phpunit.xml.dist" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/.php_cs.dist" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/.travis.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/Factory/DiactorosFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/Factory/HttpFoundationFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/Factory/PsrHttpFactory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/HttpFoundationFactoryInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/HttpMessageFactoryInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/Tests/Factory/AbstractHttpMessageFactoryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/Tests/Factory/DiactorosFactoryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/Tests/Factory/HttpFoundationFactoryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/Tests/Factory/PsrHttpFactoryTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/Tests/Fixtures/Message.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/Tests/Fixtures/Response.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/Tests/Fixtures/ServerRequest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/Tests/Fixtures/Stream.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/Tests/Fixtures/UploadedFile.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/Tests/Fixtures/Uri.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/Tests/Functional/CovertTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge/phpunit.xml.dist" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation-contracts/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation-contracts/LocaleAwareInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation-contracts/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation-contracts/Test/TranslatorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation-contracts/TranslatorInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation-contracts/TranslatorTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation-contracts/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Catalogue/AbstractOperation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Catalogue/MergeOperation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Catalogue/OperationInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Catalogue/TargetOperation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Command/XliffLintCommand.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/DataCollector/TranslationDataCollector.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/DataCollectorTranslator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/DependencyInjection/TranslationDumperPass.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/DependencyInjection/TranslationExtractorPass.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/DependencyInjection/TranslatorPass.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/DependencyInjection/TranslatorPathsPass.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Dumper/CsvFileDumper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Dumper/DumperInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Dumper/FileDumper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Dumper/IcuResFileDumper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Dumper/IniFileDumper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Dumper/JsonFileDumper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Dumper/MoFileDumper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Dumper/PhpFileDumper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Dumper/PoFileDumper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Dumper/QtFileDumper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Dumper/XliffFileDumper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Dumper/YamlFileDumper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Exception/ExceptionInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Exception/InvalidArgumentException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Exception/InvalidResourceException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Exception/LogicException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Exception/NotFoundResourceException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Exception/RuntimeException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Extractor/AbstractFileExtractor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Extractor/ChainExtractor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Extractor/ExtractorInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Extractor/PhpExtractor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Extractor/PhpStringTokenParser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Formatter/ChoiceMessageFormatterInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Formatter/IntlFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Formatter/IntlFormatterInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Formatter/MessageFormatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Formatter/MessageFormatterInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/IdentityTranslator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Interval.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Loader/ArrayLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Loader/CsvFileLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Loader/FileLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Loader/IcuDatFileLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Loader/IcuResFileLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Loader/IniFileLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Loader/JsonFileLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Loader/LoaderInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Loader/MoFileLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Loader/PhpFileLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Loader/PoFileLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Loader/QtFileLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Loader/XliffFileLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Loader/YamlFileLoader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/LoggingTranslator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/MessageCatalogue.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/MessageCatalogueInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/MessageSelector.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/MetadataAwareInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/PluralizationRules.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Reader/TranslationReader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Reader/TranslationReaderInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Resources/bin/translation-status.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Resources/data/parents.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Resources/schemas/xliff-core-1.2-strict.xsd" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Resources/schemas/xliff-core-2.0.xsd" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Resources/schemas/xml.xsd" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Catalogue/AbstractOperationTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Catalogue/MergeOperationTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Catalogue/TargetOperationTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Command/XliffLintCommandTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/DataCollector/TranslationDataCollectorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/DataCollectorTranslatorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/DependencyInjection/TranslationDumperPassTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/DependencyInjection/TranslationExtractorPassTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/DependencyInjection/TranslationPassTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/DependencyInjection/TranslationPathsPassTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/DependencyInjection/fixtures/ControllerArguments.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/DependencyInjection/fixtures/ServiceArguments.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/DependencyInjection/fixtures/ServiceMethodCalls.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/DependencyInjection/fixtures/ServiceProperties.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/DependencyInjection/fixtures/ServiceSubscriber.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Dumper/CsvFileDumperTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Dumper/FileDumperTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Dumper/IcuResFileDumperTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Dumper/IniFileDumperTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Dumper/JsonFileDumperTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Dumper/MoFileDumperTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Dumper/PhpFileDumperTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Dumper/PoFileDumperTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Dumper/QtFileDumperTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Dumper/XliffFileDumperTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Dumper/YamlFileDumperTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Extractor/PhpExtractorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Formatter/IntlFormatterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Formatter/MessageFormatterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/IdentityTranslatorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/IntervalTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Loader/CsvFileLoaderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Loader/IcuDatFileLoaderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Loader/IcuResFileLoaderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Loader/IniFileLoaderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Loader/JsonFileLoaderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Loader/LocalizedTestCase.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Loader/MoFileLoaderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Loader/PhpFileLoaderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Loader/PoFileLoaderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Loader/QtFileLoaderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Loader/XliffFileLoaderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Loader/YamlFileLoaderTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/LoggingTranslatorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/MessageCatalogueTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/MessageSelectorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/PluralizationRulesTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/TranslatorCacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/TranslatorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Util/ArrayConverterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/Writer/TranslationWriterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/empty-translation.mo" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/empty-translation.po" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/empty.csv" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/empty.ini" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/empty.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/empty.mo" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/empty.po" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/empty.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/empty.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/encoding.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/escaped-id-plurals.po" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/escaped-id.po" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/extractor/resource.format.engine" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/extractor/this.is.a.template.format.engine" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/extractor/translation.html.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/fuzzy-translations.po" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/invalid-xml-resources.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/malformed.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/messages.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/messages_linear.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/non-valid.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/non-valid.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/plurals.mo" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/plurals.po" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resname.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resourcebundle/corrupted/resources.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resourcebundle/dat/en.res" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resourcebundle/dat/en.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resourcebundle/dat/fr.res" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resourcebundle/dat/fr.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resourcebundle/dat/packagelist.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resourcebundle/dat/resources.dat" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resourcebundle/res/en.res" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources-2.0+intl-icu.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources-2.0-clean.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources-2.0-multi-segment-unit.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources-2.0.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources-clean.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources-multi-files.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources-notes-meta.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources-target-attributes.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources-tool-info.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources.csv" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources.dump.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources.ini" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources.mo" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources.po" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources.ts" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/resources.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/valid.csv" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/with-attributes.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/withdoctype.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Tests/fixtures/withnote.xlf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Translator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/TranslatorBagInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/TranslatorInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Util/ArrayConverter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Util/XliffUtils.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Writer/TranslationWriter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/Writer/TranslationWriterInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/translation/phpunit.xml.dist" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/CHANGELOG.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/AmqpCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/ArgsStub.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/Caster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/ClassStub.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/ConstStub.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/CutArrayStub.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/CutStub.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/DOMCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/DateCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/DoctrineCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/DsCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/DsPairStub.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/EnumStub.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/ExceptionCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/FrameStub.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/GmpCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/IntlCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/LinkStub.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/MemcachedCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/PdoCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/PgSqlCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/ProxyManagerCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/RedisCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/ReflectionCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/ResourceCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/SplCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/StubCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/SymfonyCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/TraceStub.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/XmlReaderCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Caster/XmlResourceCaster.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Cloner/AbstractCloner.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Cloner/ClonerInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Cloner/Cursor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Cloner/Data.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Cloner/DumperInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Cloner/Stub.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Cloner/VarCloner.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Command/Descriptor/CliDescriptor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Command/Descriptor/DumpDescriptorInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Command/Descriptor/HtmlDescriptor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Command/ServerDumpCommand.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Dumper/AbstractDumper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Dumper/CliDumper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Dumper/ContextProvider/CliContextProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Dumper/ContextProvider/ContextProviderInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Dumper/ContextProvider/RequestContextProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Dumper/ContextProvider/SourceContextProvider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Dumper/DataDumperInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Dumper/HtmlDumper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Dumper/ServerDumper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Exception/ThrowingCasterException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Resources/bin/var-dump-server" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Resources/css/htmlDescriptor.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Resources/functions/dump.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Resources/js/htmlDescriptor.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Server/Connection.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Server/DumpServer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Test/VarDumperTestTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Caster/CasterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Caster/DateCasterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Caster/ExceptionCasterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Caster/GmpCasterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Caster/IntlCasterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Caster/MemcachedCasterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Caster/PdoCasterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Caster/RedisCasterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Caster/ReflectionCasterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Caster/SplCasterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Caster/StubCasterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Caster/XmlReaderCasterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Cloner/DataTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Cloner/VarClonerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Command/Descriptor/CliDescriptorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Command/Descriptor/HtmlDescriptorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Dumper/CliDumperTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Dumper/FunctionsTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Dumper/HtmlDumperTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Dumper/ServerDumperTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Fixtures/FooInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Fixtures/GeneratorDemo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Fixtures/NotLoadableClass.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Fixtures/Twig.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Fixtures/dumb-var.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Fixtures/dump_server.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Fixtures/xml_reader.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Server/ConnectionTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/Tests/Test/VarDumperTestTraitTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/VarDumper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/symfony/var-dumper/phpunit.xml.dist" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/.travis.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/CONTRIBUTING.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/LICENSE.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/logo.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/phpunit.xml.dist" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/helper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/lang/zh-cn.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/App.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Cache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Config.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Console.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Container.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Cookie.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Db.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Env.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Event.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Exception.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Facade.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/File.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Filesystem.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Http.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Lang.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Log.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Manager.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Middleware.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Pipeline.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Request.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Response.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Route.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Service.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Session.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/Validate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/View.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/cache/Driver.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/cache/TagSet.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/cache/driver/File.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/cache/driver/Memcache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/cache/driver/Memcached.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/cache/driver/Redis.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/cache/driver/Wincache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/Command.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/Input.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/Output.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/Table.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/bin/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/bin/hiddeninput.exe" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/Clear.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/Help.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/Lists.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/Make.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/RouteList.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/RunServer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/ServiceDiscover.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/VendorPublish.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/Version.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/Command.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/Controller.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/Event.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/Listener.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/Middleware.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/Model.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/Service.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/Subscribe.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/Validate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/stubs/command.stub" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/stubs/controller.api.stub" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/stubs/controller.plain.stub" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/stubs/controller.stub" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/stubs/event.stub" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/stubs/listener.stub" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/stubs/middleware.stub" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/stubs/model.stub" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/stubs/service.stub" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/stubs/subscribe.stub" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/make/stubs/validate.stub" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/optimize/Route.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/command/optimize/Schema.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/input/Argument.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/input/Definition.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/input/Option.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/output/Ask.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/output/Descriptor.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/output/Formatter.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/output/Question.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/output/descriptor/Console.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/output/driver/Buffer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/output/driver/Console.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/output/driver/Nothing.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/output/formatter/Stack.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/output/formatter/Style.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/output/question/Choice.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/console/output/question/Confirmation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/contract/CacheHandlerInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/contract/LogHandlerInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/contract/ModelRelationInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/contract/SessionHandlerInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/contract/TemplateHandlerInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/event/AppInit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/event/HttpEnd.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/event/HttpRun.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/event/LogWrite.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/event/RouteLoaded.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/exception/ClassNotFoundException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/exception/ErrorException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/exception/FileException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/exception/FuncNotFoundException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/exception/Handle.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/exception/HttpException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/exception/HttpResponseException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/exception/InvalidArgumentException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/exception/RouteNotFoundException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/exception/ValidateException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/facade/App.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/facade/Cache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/facade/Config.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/facade/Console.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/facade/Cookie.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/facade/Env.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/facade/Event.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/facade/Filesystem.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/facade/Lang.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/facade/Log.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/facade/Middleware.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/facade/Request.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/facade/Route.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/facade/Session.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/facade/Validate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/facade/View.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/file/UploadedFile.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/filesystem/CacheStore.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/filesystem/Driver.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/filesystem/driver/Local.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/initializer/BootService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/initializer/Error.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/initializer/RegisterService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/log/Channel.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/log/ChannelSet.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/log/driver/File.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/log/driver/Socket.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/middleware/AllowCrossDomain.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/middleware/CheckRequestCache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/middleware/FormTokenCheck.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/middleware/LoadLangPack.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/middleware/SessionInit.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/response/File.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/response/Html.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/response/Json.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/response/Jsonp.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/response/Redirect.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/response/View.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/response/Xml.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/route/Dispatch.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/route/Domain.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/route/Resource.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/route/Rule.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/route/RuleGroup.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/route/RuleItem.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/route/RuleName.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/route/Url.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/route/dispatch/Callback.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/route/dispatch/Controller.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/route/dispatch/Redirect.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/route/dispatch/Response.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/route/dispatch/Url.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/route/dispatch/View.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/service/ModelService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/service/PaginatorService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/service/ValidateService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/session/Store.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/session/driver/Cache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/session/driver/File.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/validate/ValidateRule.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/think/view/driver/Php.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/src/tpl/think_exception.tpl" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/tests/AppTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/tests/CacheTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/tests/ConfigTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/tests/ContainerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/tests/DbTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/tests/EnvTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/tests/EventTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/tests/FilesystemTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/tests/HttpTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/tests/LogTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/tests/MiddlewareTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/tests/SessionTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/tests/ViewTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/framework/tests/bootstrap.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-cache/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-cache/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-cache/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-cache/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-cache/src/CacheManager.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-cache/src/cache/CacheItem.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-cache/src/cache/Driver.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-cache/src/cache/TagSet.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-cache/src/cache/driver/File.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-cache/src/cache/driver/Memcache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-cache/src/cache/driver/Memcached.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-cache/src/cache/driver/Redis.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-cache/src/cache/driver/Wincache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-cache/src/exception/InvalidArgumentException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-cache/src/facade/Cache.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/assets/bgs/1.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/assets/bgs/2.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/assets/bgs/3.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/assets/bgs/4.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/assets/bgs/5.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/assets/bgs/6.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/assets/bgs/7.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/assets/bgs/8.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/assets/ttfs/1.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/assets/ttfs/2.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/assets/ttfs/3.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/assets/ttfs/4.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/assets/ttfs/5.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/assets/ttfs/6.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/assets/zhttfs/1.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/src/Captcha.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/src/CaptchaController.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/src/CaptchaService.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/src/facade/Captcha.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-captcha/src/helper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-container/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-container/.travis.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-container/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-container/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-container/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-container/phpunit.xml.dist" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-container/src/Container.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-container/src/Facade.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-container/src/exception/ClassNotFoundException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-container/tests/ContainerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-container/tests/bootstrap.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-factory/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-factory/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-factory/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-factory/src/Factory.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-helper/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-helper/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-helper/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-helper/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-helper/src/Collection.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-helper/src/contract/Arrayable.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-helper/src/contract/Jsonable.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-helper/src/helper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-helper/src/helper/Arr.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-helper/src/helper/Str.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/.travis.yml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/phpunit.xml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/src/Image.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/src/image/Exception.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/src/image/gif/Decoder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/src/image/gif/Encoder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/src/image/gif/Gif.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/tests/CropTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/tests/FlipTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/tests/InfoTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/tests/RotateTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/tests/TestCase.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/tests/TextTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/tests/ThumbTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/tests/WaterTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/tests/autoload.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/tests/images/test.bmp" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/tests/images/test.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/tests/images/test.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/tests/images/test.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/tests/images/test.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-image/tests/tmp/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-log/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-log/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-log/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-log/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-log/src/LogManager.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-log/src/facade/Log.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-log/src/log/driver/File.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-log/src/log/driver/Socket.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-multi-app/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-multi-app/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-multi-app/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-multi-app/src/MultiApp.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-multi-app/src/Service.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-multi-app/src/Url.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-multi-app/src/command/Build.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-multi-app/src/command/stubs/controller.stub" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/DbManager.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/Model.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/Paginator.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/BaseQuery.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/Builder.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/CacheItem.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/Connection.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/ConnectionInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/Fetch.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/Mongo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/PDOConnection.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/Query.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/Raw.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/Where.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/builder/Mongo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/builder/Mysql.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/builder/Oracle.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/builder/Pgsql.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/builder/Sqlite.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/builder/Sqlsrv.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/concern/AggregateQuery.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/concern/JoinAndViewQuery.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/concern/ModelRelationQuery.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/concern/ParamsBind.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/concern/ResultOperation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/concern/TableFieldInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/concern/TimeFieldQuery.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/concern/Transaction.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/concern/WhereQuery.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/connector/Mongo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/connector/Mysql.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/connector/Oracle.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/connector/Pgsql.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/connector/Sqlite.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/connector/Sqlsrv.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/connector/pgsql.sql" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/exception/BindParamException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/exception/DataNotFoundException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/exception/DbException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/exception/InvalidArgumentException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/exception/ModelEventException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/exception/ModelNotFoundException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/db/exception/PDOException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/facade/Db.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/Collection.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/Pivot.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/Relation.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/concern/Attribute.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/concern/Conversion.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/concern/ModelEvent.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/concern/OptimLock.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/concern/RelationShip.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/concern/SoftDelete.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/concern/TimeStamp.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/relation/BelongsTo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/relation/BelongsToMany.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/relation/HasMany.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/relation/HasManyThrough.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/relation/HasOne.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/relation/HasOneThrough.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/relation/MorphMany.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/relation/MorphOne.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/relation/MorphTo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/model/relation/OneToOne.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-orm/src/paginator/driver/Bootstrap.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/phpunit.xml.dist" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/Queue.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/common.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/config.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/facade/Queue.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/CallQueuedHandler.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/Connector.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/FailedJob.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/InteractsWithTime.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/Job.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/Listener.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/Queueable.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/Service.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/ShouldQueue.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/Worker.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/command/FailedTable.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/command/FlushFailed.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/command/ForgetFailed.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/command/ListFailed.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/command/Listen.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/command/Restart.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/command/Retry.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/command/Table.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/command/Work.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/command/stubs/failed_jobs.stub" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/command/stubs/jobs.stub" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/connector/Database.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/connector/Redis.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/connector/Sync.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/event/JobExceptionOccurred.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/event/JobFailed.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/event/JobProcessed.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/event/JobProcessing.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/event/WorkerStopping.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/exception/MaxAttemptsExceededException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/failed/Database.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/failed/None.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/job/Database.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/job/Redis.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/src/queue/job/Sync.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/tests/DatabaseConnectorTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/tests/ListenerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/tests/QueueTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/tests/TestCase.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/tests/WorkerTest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-queue/tests/bootstrap.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-template/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-template/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-template/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-template/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-template/src/Template.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-template/src/facade/Template.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-template/src/template/TagLib.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-template/src/template/driver/File.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-template/src/template/exception/TemplateNotFoundException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-template/src/template/taglib/Cx.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-view/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-view/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-view/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-view/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/topthink/think-view/src/Think.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/channel/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/channel/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/channel/src/Client.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/channel/src/Server.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/channel/test/server.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman.log" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Autoloader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Connection/AsyncTcpConnection.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Connection/AsyncUdpConnection.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Connection/ConnectionInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Connection/TcpConnection.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Connection/UdpConnection.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Events/Ev.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Events/Event.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Events/EventInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Events/Libevent.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Events/React/Base.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Events/React/ExtEventLoop.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Events/React/ExtLibEventLoop.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Events/React/StreamSelectLoop.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Events/Select.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Events/Swoole.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Lib/Constants.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Lib/Timer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/MIT-LICENSE.txt" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Protocols/Frame.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Protocols/Http.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Protocols/Http/mime.types" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Protocols/ProtocolInterface.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Protocols/Text.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Protocols/Websocket.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Protocols/Ws.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/WebServer.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/Worker.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/workerman/workerman/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/images/components.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/images/demo02.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/images/demo03.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/images/demo04.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/Form.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/FormComponentDriver.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/Helper.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/Json.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/Cascader.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/Checkbox.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/Col.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/ColorPicker.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/DatePicker.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/FormStyle.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/Frame.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/Hidden.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/Input.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/InputNumber.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/Option.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/Radio.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/Rate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/Row.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/Select.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/Slider.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/Switches.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/TimePicker.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/Tree.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/TreeData.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/Upload.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/components/Validate.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/exception/FormBuilderException.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/interfaces/FormComponentInterFace.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/component/CallPropsTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/component/ComponentOptionsTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormCascaderTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormCheckBoxTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormColorPickerTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormDatePickerTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormFrameTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormHiddenTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormInputNumberTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormInputTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormOptionTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormRadioTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormRateTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormSelectTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormSliderTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormStyleTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormSwitchesTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormTimePickerTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormTreeTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormUploadTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/traits/form/FormValidateTrait.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/view/form.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/xaboy/form-builder/src/view/formScript.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/.env" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/.env.production" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/.eslintignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/README.en.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/babel.config.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/package-lock.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/package.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/public/favicon.ico" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/public/index.html" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/public/live-logo.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/App.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/api/activity.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/api/admin.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/api/order.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/api/public.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/api/store.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/api/user.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/css/GuildfordProBook 5.otf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/css/base.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/css/reset.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/css/style.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/css/swiper.min.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/iconfont/iconfont.css" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/iconfont/iconfont.eot" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/iconfont/iconfont.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/iconfont/iconfont.svg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/iconfont/iconfont.ttf" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/iconfont/iconfont.woff" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/iconfont/iconfont.woff2" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/404.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/accountBg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/address.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/adver.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/alter.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/angle.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/assemble.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/balance.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/banner.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/banner2.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/banners.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/baokuan.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/bargain.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/bargain.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/bargainBg.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/brass.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/brass.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/bronze.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/bronze.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/calendar_all.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/close.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/collection.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/commission.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/coupon-window.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/coupon-window2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/coupon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/coupon1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/coupon2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/customer.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/cut-bg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/cut1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/cut2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/del.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/dfh.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/dfh001.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/dfk.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/dfk001.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/diamonds.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/diamonds.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/down.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/dpj.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/dpj001.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/dsh.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/dsh001.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/enter.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/err.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/ewm.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/examine.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/extension.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/face.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/figure.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/gift.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/gold.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/gold.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/group.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/h5.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/horn.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/index-bg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/integralbg.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/keyboard.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/left.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/light.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/line.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/ling.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/live-logo.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/lock.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/lock2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/logo.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/logo2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/medal01.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/medal02.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/medal03.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/member.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/memberCenter.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/money.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/nav1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/nav2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/nav3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/nav4.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/news.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/newsBg.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/noAddress.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/noCart.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/noCollection.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/noCoupon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/noEvaluate.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/noExpress.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/noGood.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/noNews.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/noOrder.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/noPictrue.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/noSearch.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/noShopper.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/one.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/oneT.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/open.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/orderIcon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/orderIndex.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/orderTime.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/ordinary.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/ordinary.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/plus.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/poster-close.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/poster.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/posters.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/posters2.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/pricetitle.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/promoter.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/promotionBg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/public.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/record1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/record2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/record3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/record4.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/recording.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/red-packets.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/redBg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/register.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/registerB.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/registerw.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/rushBuy.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/rushBuyBg.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/scan.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/score.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/sh.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/share-info.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/shop-details-bg.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/signal.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/signal2.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/silver.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/silver.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/sort1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/sort2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/sort3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/spike.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/stars1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/stars2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/stars3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/start.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/support.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/switch.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/three.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/threeT.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/time.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/transparent.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/two.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/twoT.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/up.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/vacancy.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/value.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/videos.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/vip.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/voice.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/writeOff.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/writeOffBg.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/images/ywc001.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/js/area.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/js/media_750.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/assets/logo.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/AddressWindow.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/CountDown.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/CouponListWindow.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/CouponPop.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/CouponWindow.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/Footer.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/GeneralWindow.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/GoodList.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/HelloWorld.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/Home.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/Loading.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/OrderGoods.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/Payment.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/PriceChange.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/ProductConSwiper.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/ProductWindow.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/PromotionGood.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/Recommend.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/ShareInfo.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/ShareRedPackets.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/StorePoster.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/SwitchWindow.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/UserEvaluation.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/components/WriteOff.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/libs/chat.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/libs/login.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/libs/order.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/libs/wechat.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/main.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/mixins/SendVerifyCode.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/router/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/router/module/activity.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/router/module/admin.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/router/module/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/router/module/order.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/router/module/user.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/store/getters.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/store/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/store/modules/app.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/store/modules/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/utils/bc.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/utils/dialog.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/utils/emoji.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/utils/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/utils/loading.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/utils/request.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/utils/store/cookie.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/utils/store/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/utils/store/localStorage.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/utils/validate.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/Loading.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/NotDefined.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/activity/BargainRecord.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/activity/DargainDetails.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/activity/GoodsBargain.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/activity/GoodsGroup.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/activity/GoodsSeckill.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/activity/GroupDetails.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/activity/GroupRule.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/activity/Poster.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/activity/SeckillDetails.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/home/Index.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/order/GoodsReturn.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/order/Logistics.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/order/MyOrder.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/order/OrderDetails.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/order/OrderSubmission.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/order/PaymentStatus.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/order/ReturnList.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/orderAdmin/AdminOrder.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/orderAdmin/AdminOrderList.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/orderAdmin/GoodsDeliver.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/orderAdmin/OrderCancellation.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/orderAdmin/OrderIndex.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/orderAdmin/Statistics.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/shop/EvaluateList.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/shop/GoodSearch.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/shop/GoodsClass.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/shop/GoodsCollection.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/shop/GoodsCon.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/shop/GoodsEvaluate.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/shop/GoodsList.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/shop/GoodsPromotion.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/shop/HotNewGoods.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/shop/ShoppingCart.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/shop/StoreList.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/shop/news/NewsDetail.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/shop/news/NewsList.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/BindingPhone.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/ChangePassword.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/CustomerList.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/CustomerService.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/Login.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/PersonalData.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/Recharge.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/Register.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/RetrievePassword.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/User.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/UserAccount.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/UserBill.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/UserVip.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/address/AddAddress.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/address/AddressManagement.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/coupon/GetCoupon.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/coupon/UserCoupon.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/promotion/CashAudit.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/promotion/CashRecord.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/promotion/CommissionDetails.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/promotion/CommissionRank.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/promotion/Poster.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/promotion/PromoterList.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/promotion/PromoterOrder.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/promotion/PromoterRank.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/promotion/UserCash.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/promotion/UserPromotion.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/signIn/Integral.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/signIn/Sign.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/src/views/user/signIn/SignRecord.vue" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/H5/vue.config.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/README.en.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/api/activity.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/api/admin.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/api/api.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/api/order.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/api/store.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/api/user.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/app.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/app.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/app.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/address-window/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/address-window/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/address-window/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/address-window/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/authorize/authorize.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/authorize/authorize.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/authorize/authorize.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/authorize/authorize.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/coupon-list-window/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/coupon-list-window/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/coupon-list-window/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/coupon-list-window/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/coupon-window/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/coupon-window/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/coupon-window/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/coupon-window/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/general-window/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/general-window/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/general-window/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/general-window/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/goodList/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/goodList/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/goodList/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/goodList/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/home/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/home/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/home/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/home/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/navbar/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/navbar/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/navbar/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/navbar/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/orderGoods/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/orderGoods/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/orderGoods/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/orderGoods/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/payment/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/payment/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/payment/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/payment/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/price-change/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/price-change/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/price-change/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/price-change/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/product-window/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/product-window/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/product-window/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/product-window/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/productConSwiper/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/productConSwiper/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/productConSwiper/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/productConSwiper/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/promotionGood/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/promotionGood/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/promotionGood/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/promotionGood/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/recommend/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/recommend/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/recommend/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/recommend/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/share-red-packets/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/share-red-packets/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/share-red-packets/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/share-red-packets/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/swipers/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/swipers/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/swipers/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/swipers/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/userEvaluation/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/userEvaluation/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/userEvaluation/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/userEvaluation/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/write-off/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/write-off/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/write-off/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/components/write-off/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/config.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/css/animate.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/css/guildford.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/css/style.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/font/iconfont.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/1-001.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/1-002.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/2-001.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/2-002.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/3-001.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/3-002.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/4-001.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/4-002.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/accountBg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/address.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/alter.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/angle.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/balance.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/bargain.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/bargainBg.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/close.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/code_1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/code_2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/collection.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/commission.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/coupon-window.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/coupon-window2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/coupon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/coupon2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/customer.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/dfh.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/dfk.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/down.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/dpj.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/dsh.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/examine.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/extension.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/gift.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/horn.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/left.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/light.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/line.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/ling.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/lock.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/lock2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/logo.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/medal01.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/medal02.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/medal03.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/member.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/memberCenter.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/money.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/news.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/noAddress.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/noCart.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/noCollection.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/noCoupon.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/noEvaluate.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/noNews.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/noOrder.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/noSearch.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/noShopper.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/one.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/open.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/orderTime.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/phone_1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/poster-close.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/posterbackgd.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/priceTag.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/promoter.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/promotionBg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/qh.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/record1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/record2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/record3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/record4.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/red-packets.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/redBg.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/rushBuy.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/scan.gif" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/score.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/sh.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/sort1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/sort2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/sort3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/spot.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/stars1.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/stars2.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/stars3.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/stop.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/support.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/three.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/time.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/transparent.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/two.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/up.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/vacancy.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/value.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/vip.png" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/images/writeOff.jpg" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_bargain/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_bargain/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_bargain/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_bargain/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_bargain_details/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_bargain_details/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_bargain_details/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_bargain_details/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_combination/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_combination/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_combination/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_combination/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_combination_details/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_combination_details/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_combination_details/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_combination_details/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_combination_status/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_combination_status/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_combination_status/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_combination_status/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_seckill/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_seckill/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_seckill/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_seckill/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_seckill_details/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_seckill_details/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_seckill_details/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/goods_seckill_details/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/poster-poster/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/poster-poster/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/poster-poster/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/poster-poster/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/user_goods_bargain_list/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/user_goods_bargain_list/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/user_goods_bargain_list/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/activity/user_goods_bargain_list/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/components/calendar/calendar.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/components/calendar/calendar.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/components/calendar/calendar.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/components/calendar/calendar.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/components/ec-canvas/ec-canvas.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/components/ec-canvas/ec-canvas.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/components/ec-canvas/ec-canvas.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/components/ec-canvas/ec-canvas.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/components/ec-canvas/echarts.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/components/ec-canvas/wx-canvas.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_cancellation/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_cancellation/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_cancellation/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_cancellation/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_deliver/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_deliver/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_deliver/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_deliver/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_details/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_details/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_details/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_details/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_list/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_list/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_list/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_list/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_statistics/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_statistics/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_statistics/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_statistics/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_statistics_time/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_statistics_time/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_statistics_time/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/admin/order_statistics_time/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/cash-audit/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/cash-audit/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/cash-audit/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/cash-audit/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/commission_rank/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/commission_rank/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/commission_rank/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/commission_rank/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/first-new-product/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/first-new-product/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/first-new-product/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/first-new-product/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_cate/goods_cate.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_cate/goods_cate.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_cate/goods_cate.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_cate/goods_cate.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_comment_con/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_comment_con/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_comment_con/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_comment_con/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_comment_list/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_comment_list/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_comment_list/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_comment_list/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_details/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_details/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_details/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_details/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_details_store/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_details_store/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_details_store/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_details_store/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_list/goods_list.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_list/goods_list.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_list/goods_list.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_list/goods_list.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_logistics/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_logistics/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_logistics/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_logistics/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_return/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_return/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_return/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_return/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_search/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_search/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_search/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/goods_search/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/index/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/index/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/index/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/index/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/news_details/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/news_details/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/news_details/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/news_details/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/news_list/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/news_list/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/news_list/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/news_list/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_addcart/order_addcart.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_addcart/order_addcart.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_addcart/order_addcart.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_addcart/order_addcart.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_cancellation/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_cancellation/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_cancellation/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_cancellation/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_confirm/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_confirm/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_confirm/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_confirm/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_details/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_details/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_details/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_details/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_list/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_list/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_list/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_list/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_pay_status/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_pay_status/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_pay_status/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/order_pay_status/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/promoter-list/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/promoter-list/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/promoter-list/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/promoter-list/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/promoter-order/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/promoter-order/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/promoter-order/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/promoter-order/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/promoter_rank/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/promoter_rank/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/promoter_rank/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/promoter_rank/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/promotional-items/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/promotional-items/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/promotional-items/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/promotional-items/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user/user.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user/user.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user/user.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user/user.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_address/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_address/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_address/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_address/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_address_list/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_address_list/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_address_list/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_address_list/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_bill/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_bill/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_bill/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_bill/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_cash/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_cash/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_cash/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_cash/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_coupon/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_coupon/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_coupon/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_coupon/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_get_coupon/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_get_coupon/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_get_coupon/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_get_coupon/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_goods_collection/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_goods_collection/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_goods_collection/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_goods_collection/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_info/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_info/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_info/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_info/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_integral/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_integral/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_integral/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_integral/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_money/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_money/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_money/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_money/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_payment/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_payment/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_payment/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_payment/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_phone/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_phone/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_phone/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_phone/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_pwd_edit/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_pwd_edit/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_pwd_edit/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_pwd_edit/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_return_list/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_return_list/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_return_list/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_return_list/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_sgin/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_sgin/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_sgin/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_sgin/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_sgin_list/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_sgin_list/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_sgin_list/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_sgin_list/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_spread_code/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_spread_code/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_spread_code/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_spread_code/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_spread_money/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_spread_money/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_spread_money/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_spread_money/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_spread_user/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_spread_user/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_spread_user/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_spread_user/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_vip/index.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_vip/index.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_vip/index.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/pages/user_vip/index.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/project.config.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/sitemap.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/utils/Server.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/utils/SubscribeMessage.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/utils/autuLogin.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/utils/request.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/utils/util.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/utils/wxh.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/wxParse/html2json.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/wxParse/htmlparser.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/wxParse/showdown.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/wxParse/wxDiscode.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/wxParse/wxParse.js" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/wxParse/wxParse.wxml" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/view/xcx/wxParse/wxParse.wxss" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/workerman.bat" afterDir="false" />
+    </list>
+    <option name="SHOW_DIALOG" value="false" />
+    <option name="HIGHLIGHT_CONFLICTS" value="true" />
+    <option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
+    <option name="LAST_RESOLUTION" value="IGNORE" />
+  </component>
+  <component name="ComposerSettings" doNotAsk="true" synchronizationState="SYNCHRONIZE">
+    <pharConfigPath>$PROJECT_DIR$/composer.json</pharConfigPath>
+    <execution />
+  </component>
+  <component name="Git.Settings">
+    <option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$" />
+  </component>
+  <component name="MarkdownSettingsMigration">
+    <option name="stateVersion" value="1" />
+  </component>
+  <component name="PhpWorkspaceProjectConfiguration">
+    <include_path>
+      <path value="$PROJECT_DIR$/vendor/guzzle/guzzle" />
+      <path value="$PROJECT_DIR$/vendor/symfony/translation-contracts" />
+      <path value="$PROJECT_DIR$/vendor/symfony/polyfill-mbstring" />
+      <path value="$PROJECT_DIR$/vendor/firebase/php-jwt" />
+      <path value="$PROJECT_DIR$/vendor/symfony/polyfill-php70" />
+      <path value="$PROJECT_DIR$/vendor/symfony/var-dumper" />
+      <path value="$PROJECT_DIR$/vendor/symfony/event-dispatcher" />
+      <path value="$PROJECT_DIR$/vendor/symfony/polyfill-php72" />
+      <path value="$PROJECT_DIR$/vendor/symfony/http-foundation" />
+      <path value="$PROJECT_DIR$/vendor/symfony/translation" />
+      <path value="$PROJECT_DIR$/vendor/symfony/process" />
+      <path value="$PROJECT_DIR$/vendor/overtrue/wechat" />
+      <path value="$PROJECT_DIR$/vendor/symfony/psr-http-message-bridge" />
+      <path value="$PROJECT_DIR$/vendor/overtrue/socialite" />
+      <path value="$PROJECT_DIR$/vendor/aliyuncs/oss-sdk-php" />
+      <path value="$PROJECT_DIR$/vendor/opis/closure" />
+      <path value="$PROJECT_DIR$/vendor/composer" />
+      <path value="$PROJECT_DIR$/vendor/psr/http-message" />
+      <path value="$PROJECT_DIR$/vendor/psr/simple-cache" />
+      <path value="$PROJECT_DIR$/vendor/psr/log" />
+      <path value="$PROJECT_DIR$/vendor/psr/cache" />
+      <path value="$PROJECT_DIR$/vendor/psr/container" />
+      <path value="$PROJECT_DIR$/vendor/pimple/pimple" />
+      <path value="$PROJECT_DIR$/vendor/spatie/macroable" />
+      <path value="$PROJECT_DIR$/vendor/ralouphie/getallheaders" />
+      <path value="$PROJECT_DIR$/vendor/qiniu/php-sdk" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-container" />
+      <path value="$PROJECT_DIR$/vendor/workerman/channel" />
+      <path value="$PROJECT_DIR$/vendor/xaboy/form-builder" />
+      <path value="$PROJECT_DIR$/vendor/monolog/monolog" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-queue" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-template" />
+      <path value="$PROJECT_DIR$/vendor/workerman/workerman" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-cache" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-view" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-image" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-captcha" />
+      <path value="$PROJECT_DIR$/vendor/doctrine/cache" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-helper" />
+      <path value="$PROJECT_DIR$/vendor/topthink/framework" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-factory" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-orm" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-log" />
+      <path value="$PROJECT_DIR$/vendor/nesbot/carbon" />
+      <path value="$PROJECT_DIR$/vendor/topthink/think-multi-app" />
+      <path value="$PROJECT_DIR$/vendor/paragonie/random_compat" />
+      <path value="$PROJECT_DIR$/vendor/dh2y/think-qrcode" />
+      <path value="$PROJECT_DIR$/vendor/league/flysystem" />
+      <path value="$PROJECT_DIR$/vendor/league/flysystem-cached-adapter" />
+      <path value="$PROJECT_DIR$/vendor/phpoffice/phpexcel" />
+      <path value="$PROJECT_DIR$/vendor/guzzlehttp/psr7" />
+      <path value="$PROJECT_DIR$/vendor/guzzlehttp/promises" />
+      <path value="$PROJECT_DIR$/vendor/guzzlehttp/guzzle" />
+      <path value="$PROJECT_DIR$/vendor/qcloud/cos-sdk-v5" />
+    </include_path>
+  </component>
+  <component name="ProjectId" id="2Ap0Bk4WgjCFcHH4WGoP2lyesjb" />
+  <component name="ProjectLevelVcsManager" settingsEditedManually="true" />
+  <component name="ProjectViewState">
+    <option name="hideEmptyMiddlePackages" value="true" />
+    <option name="showLibraryContents" value="true" />
+  </component>
+  <component name="PropertiesComponent">
+    <property name="RunOnceActivity.OpenProjectViewOnStart" value="true" />
+    <property name="RunOnceActivity.ShowReadmeOnStart" value="true" />
+    <property name="WebServerToolWindowFactoryState" value="false" />
+    <property name="last_opened_file_path" value="$PROJECT_DIR$" />
+    <property name="node.js.detected.package.eslint" value="true" />
+    <property name="node.js.detected.package.tslint" value="true" />
+    <property name="node.js.selected.package.eslint" value="(autodetect)" />
+    <property name="node.js.selected.package.tslint" value="(autodetect)" />
+    <property name="settings.editor.selected.configurable" value="project.propVCSSupport.DirectoryMappings" />
+    <property name="vue.rearranger.settings.migration" value="true" />
+  </component>
+  <component name="SpellCheckerSettings" RuntimeDictionaries="0" Folders="0" CustomDictionaries="0" DefaultDictionary="应用程序级" UseSingleDictionary="true" transferred="true" />
+  <component name="TaskManager">
+    <task active="true" id="Default" summary="默认任务">
+      <changelist id="f1059816-03fc-437b-9cdc-1d5433440936" name="变更" comment="" />
+      <created>1655691089765</created>
+      <option name="number" value="Default" />
+      <option name="presentableId" value="Default" />
+      <updated>1655691089765</updated>
+      <workItem from="1655691096585" duration="960000" />
+      <workItem from="1655796449076" duration="3448000" />
+      <workItem from="1655875274346" duration="50000" />
+      <workItem from="1655875364003" duration="124000" />
+      <workItem from="1655875509999" duration="1390000" />
+    </task>
+    <task id="LOCAL-00001" summary="commit">
+      <created>1655876099366</created>
+      <option name="number" value="00001" />
+      <option name="presentableId" value="LOCAL-00001" />
+      <option name="project" value="LOCAL" />
+      <updated>1655876099366</updated>
+    </task>
+    <task id="LOCAL-00002" summary="commit">
+      <created>1655876232110</created>
+      <option name="number" value="00002" />
+      <option name="presentableId" value="LOCAL-00002" />
+      <option name="project" value="LOCAL" />
+      <updated>1655876232110</updated>
+    </task>
+    <option name="localTasksCounter" value="3" />
+    <servers />
+  </component>
+  <component name="TypeScriptGeneratedFilesManager">
+    <option name="version" value="3" />
+  </component>
+  <component name="Vcs.Log.Tabs.Properties">
+    <option name="TAB_STATES">
+      <map>
+        <entry key="MAIN">
+          <value>
+            <State />
+          </value>
+        </entry>
+      </map>
+    </option>
+  </component>
+  <component name="VcsManagerConfiguration">
+    <option name="CHECK_NEW_TODO" value="false" />
+    <ignored-roots>
+      <path value="$PROJECT_DIR$" />
+    </ignored-roots>
+    <MESSAGE value="commit" />
+    <option name="LAST_COMMIT_MESSAGE" value="commit" />
+  </component>
+</project>

+ 42 - 0
.travis.yml

@@ -0,0 +1,42 @@
+sudo: false
+
+language: php
+
+branches:
+  only:
+    - stable
+
+cache:
+  directories:
+    - $HOME/.composer/cache
+
+before_install:
+  - composer self-update
+
+install:
+  - composer install --no-dev --no-interaction --ignore-platform-reqs
+  - zip -r --exclude='*.git*' --exclude='*.zip' --exclude='*.travis.yml' ThinkPHP_Core.zip .
+  - composer require --update-no-dev --no-interaction "topthink/think-image:^1.0"
+  - composer require --update-no-dev --no-interaction "topthink/think-migration:^1.0"
+  - composer require --update-no-dev --no-interaction "topthink/think-captcha:^1.0"
+  - composer require --update-no-dev --no-interaction "topthink/think-mongo:^1.0"
+  - composer require --update-no-dev --no-interaction "topthink/think-worker:^1.0"
+  - composer require --update-no-dev --no-interaction "topthink/think-helper:^1.0"
+  - composer require --update-no-dev --no-interaction "topthink/think-queue:^1.0"
+  - composer require --update-no-dev --no-interaction "topthink/think-angular:^1.0"
+  - composer require --dev --update-no-dev --no-interaction "topthink/think-testing:^1.0"
+  - zip -r --exclude='*.git*' --exclude='*.zip' --exclude='*.travis.yml' ThinkPHP_Full.zip .
+
+script:
+  - php think unit
+
+deploy:
+  provider: releases
+  api_key:
+    secure: TSF6bnl2JYN72UQOORAJYL+CqIryP2gHVKt6grfveQ7d9rleAEoxlq6PWxbvTI4jZ5nrPpUcBUpWIJHNgVcs+bzLFtyh5THaLqm39uCgBbrW7M8rI26L8sBh/6nsdtGgdeQrO/cLu31QoTzbwuz1WfAVoCdCkOSZeXyT/CclH99qV6RYyQYqaD2wpRjrhA5O4fSsEkiPVuk0GaOogFlrQHx+C+lHnf6pa1KxEoN1A0UxxVfGX6K4y5g4WQDO5zT4bLeubkWOXK0G51XSvACDOZVIyLdjApaOFTwamPcD3S1tfvuxRWWvsCD5ljFvb2kSmx5BIBNwN80MzuBmrGIC27XLGOxyMerwKxB6DskNUO9PflKHDPI61DRq0FTy1fv70SFMSiAtUv9aJRT41NQh9iJJ0vC8dl+xcxrWIjU1GG6+l/ZcRqVx9V1VuGQsLKndGhja7SQ+X1slHl76fRq223sMOql7MFCd0vvvxVQ2V39CcFKao/LB1aPH3VhODDEyxwx6aXoTznvC/QPepgWsHOWQzKj9ftsgDbsNiyFlXL4cu8DWUty6rQy8zT2b4O8b1xjcwSUCsy+auEjBamzQkMJFNlZAIUrukL/NbUhQU37TAbwsFyz7X0E/u/VMle/nBCNAzgkMwAUjiHM6FqrKKBRWFbPrSIixjfjkCnrMEPw=
+  file:
+    - ThinkPHP_Core.zip
+    - ThinkPHP_Full.zip
+  skip_cleanup: true
+  on:
+    tags: true

+ 2 - 0
.version

@@ -0,0 +1,2 @@
+version=CRMEB-DT v3.2.9
+version_code=134

+ 33 - 0
LICENSE.txt

@@ -0,0 +1,33 @@
+版权所有 (c)2017-2027,西安众邦网络科技有限公司 保留所有权利。
+感谢您选择CrmEb开源客户管理+电商系统(简称CRMEB),CRMEB是国内最稳定、最强大、最先进的互联网电商平台解决方案之一,CRMEB基于 PHP + MySQL 的技术,采用ThinkPHP5.0框架开发。
+为了使你正确并合法的使用本软件,请你在使用前务必阅读清楚下面的协议条款:
+本授权协议适用且仅适用于CRMEB任何版本,CRMEB官方对本授权协议的最终解释权和修改权。
+
+一、协议许可的权利
+1、您可以在完全遵守本最终用户授权协议的基础上,将本软件应用于非商业用途,而不必支付软件版权授权费用。
+2、您可以在协议规定的约束和限制范围内修改 CRMEB 源代码或界面风格以适应您的网站要求。
+3、您拥有使用本软件构建的网站全部内容所有权,并独立承担与这些内容的相关法律义务。
+4、获得商业授权之后,您可以将本软件应用于商业用途,同时依据所购买的授权类型中确定的技术支持内容。商业授权用户享有反映和提出意见的权力,相关意见将被作为首要考虑,但没有一定被采纳的承诺或保证。
+
+二、协议许可的权利和限制
+1、未获商业授权之前,不得删除网站底部及相应的官方版权信息和链接。购买商业授权请联系西安众邦网络科技有限公司了解最新说明。CRMEB著作权已在中华人民共和国国家版权局注册(中国国家版权局著作权登记号 2018SR024463),著作权受到法律和国际公约保护。
+2、未经官方许可,不得对本软件或与之关联的商业授权进行出租、出售、抵押或发放子许可证。
+3、不管你的网站是否整体使用 CRMEB ,还是部份栏目使用 CRMEB,在你使用了 CRMEB 的网站主页上必须加上 CRMEB 官方网址(www.crmeb.com)的链接。
+4、未经官方许可,禁止在 CRMEB 的整体或任何部分基础上以发展任何派生版本、修改版本或第三方版本用于重新分发。
+5、如果您未能遵守本协议的条款,您的授权将被终止,所被许可的权利将被收回,并承担相应法律责任。
+
+三、有限担保和免责声明
+1、本软件及所附带的文件是作为不提供任何明确的或隐含的赔偿或担保的形式提供的。 
+2、用户出于自愿而使用本软件,您必须了解使用本软件的风险,在尚未购买产品技术服务之前,我们不承诺对免费用户提供任何形式的技术支持、使用担保,也不承担任何因使用本软件而产生问题的相关责任。
+3、电子文本形式的授权协议如同双方书面签署的协议一样,具有完全的和等同的法律效力。您一旦开始确认本协议并安装 CRMEB,即被视为完全理解并接受本协议的各项条款,在享有上述条款授予的权力的同时,受到相关的约束和限制。协议许可范围以外的行为,将直接违反本授权协议并构成侵权,我们有权随时终止授权,责令停止损害,并保留追究相关责任的权力。
+
+协议发布时间: 2017年8月01日
+版本最新更新: 2019年8月15日 By CRMEB
+
+CRMEB官方网站:http://www.crmeb.com
+CRMEB演示站:http://demo.crmeb.com
+-----------------------------------------------------
+运营团队: 众邦科技
+电   话: 400-8888-794
+邮   箱: admin@xazbkj.com
+网   址: http://www.xazbkj.com

+ 1 - 0
app/.htaccess

@@ -0,0 +1 @@
+deny from all

+ 24 - 0
app/AppService.php

@@ -0,0 +1,24 @@
+<?php
+
+namespace app;
+
+use crmeb\services\SystemConfigService;
+use crmeb\services\GroupDataService;
+use crmeb\utils\Json;
+use think\facade\Db;
+use think\Service;
+
+class AppService extends Service
+{
+
+    public $bind = [
+        'json' => Json::class,
+        'sysConfig' => SystemConfigService::class,
+        'sysGroupData' => GroupDataService::class
+    ];
+
+    public function boot()
+    {
+
+    }
+}

+ 68 - 0
app/ExceptionHandle.php

@@ -0,0 +1,68 @@
+<?php
+// +----------------------------------------------------------------------
+// | ThinkPHP [ WE CAN DO IT JUST THINK ]
+// +----------------------------------------------------------------------
+// | Copyright (c) 2006~2019 http://thinkphp.cn All rights reserved.
+// +----------------------------------------------------------------------
+// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
+// +----------------------------------------------------------------------
+// | Author: liu21st <liu21st@gmail.com>
+// +----------------------------------------------------------------------
+
+namespace app;
+
+use think\db\exception\DataNotFoundException;
+use think\db\exception\ModelNotFoundException;
+use think\exception\Handle;
+use think\exception\HttpException;
+use think\exception\HttpResponseException;
+use think\exception\ValidateException;
+use think\Response;
+use Throwable;
+
+/**
+ * 应用异常处理类
+ */
+class ExceptionHandle extends Handle
+{
+    /**
+     * 不需要记录信息(日志)的异常类列表
+     * @var array
+     */
+    protected $ignoreReport = [
+        HttpException::class,
+        HttpResponseException::class,
+        ModelNotFoundException::class,
+        DataNotFoundException::class,
+        ValidateException::class,
+    ];
+
+    /**
+     * 记录异常信息(包括日志或者其它方式记录)
+     *
+     * @access public
+     * @param  Throwable $exception
+     * @return void
+     */
+    public function report(Throwable $exception): void
+    {
+        // 使用内置的方式记录异常日志
+        parent::report($exception);
+    }
+
+    /**
+     * Render an exception into an HTTP response.
+     *
+     * @access public
+     * @param \think\Request   $request
+     * @param Throwable $e
+     * @return Response
+     */
+    public function render($request, Throwable $e): Response
+    {
+        // 添加自定义异常处理机制
+
+        // 其他错误交给系统处理
+        return parent::render($request, $e);
+    }
+}

+ 19 - 0
app/Request.php

@@ -0,0 +1,19 @@
+<?php
+// +----------------------------------------------------------------------
+// | ThinkPHP [ WE CAN DO IT JUST THINK ]
+// +----------------------------------------------------------------------
+// | Copyright (c) 2006~2019 http://thinkphp.cn All rights reserved.
+// +----------------------------------------------------------------------
+// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
+// +----------------------------------------------------------------------
+// | Author: liu21st <liu21st@gmail.com>
+// +----------------------------------------------------------------------
+
+namespace app;
+
+use Spatie\Macroable\Macroable;
+
+class Request extends \think\Request
+{
+    use Macroable;
+}

+ 158 - 0
app/admin/common.php

@@ -0,0 +1,158 @@
+<?php
+// +----------------------------------------------------------------------
+// | ThinkPHP [ WE CAN DO IT JUST THINK ]
+// +----------------------------------------------------------------------
+// | Copyright (c) 2006-2016 http://thinkphp.cn All rights reserved.
+// +----------------------------------------------------------------------
+// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
+// +----------------------------------------------------------------------
+// | Author: 流年 <liu21st@gmail.com>
+// +----------------------------------------------------------------------
+
+// 应用公共文件
+if (!function_exists('attr_format')) {
+    /**
+     * 格式化属性
+     * @param $arr
+     * @return array
+     */
+    function attr_format($arr)
+    {
+        $data = [];
+        $res = [];
+        $count = count($arr);
+        if ($count > 1) {
+            for ($i = 0; $i < $count - 1; $i++) {
+                if ($i == 0) $data = $arr[$i]['detail'];
+                //替代变量1
+                $rep1 = [];
+                foreach ($data as $v) {
+                    foreach ($arr[$i + 1]['detail'] as $g) {
+                        //替代变量2
+                        $rep2 = ($i != 0 ? '' : $arr[$i]['value'] . '_$_') . $v . '-$-' . $arr[$i + 1]['value'] . '_$_' . $g;
+                        $tmp[] = $rep2;
+                        if ($i == $count - 2) {
+                            foreach (explode('-$-', $rep2) as $k => $h) {
+                                //替代变量3
+                                $rep3 = explode('_$_', $h);
+                                //替代变量4
+                                $rep4['detail'][$rep3[0]] = isset($rep3[1]) ? $rep3[1] : '';
+                            }
+                            if($count == count($rep4['detail']))
+                                $res[] = $rep4;
+                        }
+                    }
+                }
+                $data = isset($tmp) ? $tmp : [];
+            }
+        } else {
+            $dataArr = [];
+            foreach ($arr as $k => $v) {
+                foreach ($v['detail'] as $kk => $vv) {
+                    $dataArr[$kk] = $v['value'] . '_' . $vv;
+                    $res[$kk]['detail'][$v['value']] = $vv;
+                }
+            }
+            $data[] = implode('-', $dataArr);
+        }
+        return [$data, $res];
+    }
+}
+if (!function_exists('get_month')) {
+    /**
+     * 格式化月份
+     * @param string $time
+     * @param int $ceil
+     * @return array
+     */
+    function get_month($time = '', $ceil = 0)
+    {
+        if (empty($time)) {
+            $firstday = date("Y-m-01", time());
+            $lastday = date("Y-m-d", strtotime("$firstday +1 month -1 day"));
+        } else if ($time == 'n') {
+            if ($ceil != 0)
+                $season = ceil(date('n') / 3) - $ceil;
+            else
+                $season = ceil(date('n') / 3);
+            $firstday = date('Y-m-01', mktime(0, 0, 0, ($season - 1) * 3 + 1, 1, date('Y')));
+            $lastday = date('Y-m-t', mktime(0, 0, 0, $season * 3, 1, date('Y')));
+        } else if ($time == 'y') {
+            $firstday = date('Y-01-01');
+            $lastday = date('Y-12-31');
+        } else if ($time == 'h') {
+            $firstday = date('Y-m-d', strtotime('this week +' . $ceil . ' day')) . ' 00:00:00';
+            $lastday = date('Y-m-d', strtotime('this week +' . ($ceil + 1) . ' day')) . ' 23:59:59';
+        }
+        return array($firstday, $lastday);
+    }
+}
+if (!function_exists('clearfile')) {
+    /**删除目录下所有文件
+     * @param $path 目录或者文件路径
+     * @param string $ext
+     * @return bool
+     */
+    function clearfile($path, $ext = '*.log')
+    {
+        $files = (array)glob($path . DS . '*');
+        foreach ($files as $path) {
+            if (is_dir($path)) {
+                $matches = glob($path . '/' . $ext);
+                if (is_array($matches)) {
+                    array_map('unlink', $matches);
+                }
+                rmdir($path);
+            } else {
+                unlink($path);
+            }
+        }
+        return true;
+    }
+}
+if (!function_exists('get_this_class_methods')) {
+    /**获取当前类方法
+     * @param $class
+     * @return array
+     */
+    function get_this_class_methods($class, $unarray = [])
+    {
+        $arrayall = get_class_methods($class);
+        if ($parent_class = get_parent_class($class)) {
+            $arrayparent = get_class_methods($parent_class);
+            $arraynow = array_diff($arrayall, $arrayparent);//去除父级的
+        } else {
+            $arraynow = $arrayall;
+        }
+        return array_diff($arraynow, $unarray);//去除无用的
+    }
+}
+
+if (!function_exists('verify_domain')) {
+
+    /**
+     * 验证域名是否合法
+     * @param string $domain
+     * @return bool
+     */
+    function verify_domain(string $domain): bool
+    {
+        $res = "/^(?=^.{3,255}$)(http(s)?:\/\/)(www\.)?[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(\.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+(:\d+)*(\/\w+\.\w+)*$/";
+        if (preg_match($res, $domain))
+            return true;
+        else
+            return false;
+    }
+}
+
+if (!function_exists('pr')) {
+    function pr($var, $int = '')
+    {
+        $template = PHP_SAPI !== 'cli' ? '<pre>%s</pre>' : "\n%s\n";
+        printf($template, print_r($var, true));
+        if (!empty($int)) {
+            exit($int);
+        }
+
+    }
+}

+ 25 - 0
app/admin/config/route.php

@@ -0,0 +1,25 @@
+<?php
+// +----------------------------------------------------------------------
+// | ThinkPHP [ WE CAN DO IT JUST THINK ]
+// +----------------------------------------------------------------------
+// | Copyright (c) 2006~2018 http://thinkphp.cn All rights reserved.
+// +----------------------------------------------------------------------
+// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
+// +----------------------------------------------------------------------
+// | Author: liu21st <liu21st@gmail.com>
+// +----------------------------------------------------------------------
+
+// +----------------------------------------------------------------------
+// | 应用设置
+// +----------------------------------------------------------------------
+
+return [
+    // 是否强制使用路由
+    'url_route_must'        => false,
+    // 合并路由规则
+    'route_rule_merge'      => true,
+    // 路由是否完全匹配
+    'route_complete_match'  => false,
+    // 是否自动转换URL中的控制器和操作名
+    'url_convert'           => true,
+];

+ 20 - 0
app/admin/config/view.php

@@ -0,0 +1,20 @@
+<?php
+// +----------------------------------------------------------------------
+// | 模板设置
+// +----------------------------------------------------------------------
+
+return [
+    // 模板后缀
+    'view_suffix'  => 'php',
+    // 模板路径
+    'view_path'    => app_path('view'),
+    // 视图输出字符串内容替换
+    'tpl_replace_string'       => [
+        '{__PUBLIC_PATH}' =>  '/',              //public 目录
+        '{__STATIC_PATH}' =>  '/static/',       //全局静态目录
+        '{__PLUG_PATH}'   =>  '/static/plug/',  //全局静态插件
+        '{__ADMIN_PATH}'  =>  '/system/',        //后台目录
+        '{__FRAME_PATH}'  =>  '/system/frame/',  //后台框架
+        '{__MODULE_PATH}' =>  '/system/module/', //后台模块
+    ]
+];

+ 36 - 0
app/admin/controller/AdminException.php

@@ -0,0 +1,36 @@
+<?php
+/**
+ *
+ * @author: xaboy<365615158@qq.com>
+ * @day: 2018/01/10
+ */
+
+namespace app\admin\controller;
+
+use think\exception\Handle;
+use think\exception\ValidateException;
+use think\Response;
+use Throwable;
+
+/**
+ * 后台异常处理
+ *
+ * Class AdminException
+ * @package app\admin\controller
+ */
+class AdminException extends Handle
+{
+
+    public function render($request, Throwable $e): Response
+    {
+        // 参数验证错误
+        if ($e instanceof ValidateException) {
+            return app('json')->make(422, $e->getError());
+        }
+        if ($e instanceof \Exception && request()->isAjax()) {
+            return app('json')->fail($e->getMessage(), ['code' => $e->getCode(), 'line' => $e->getLine(), 'message' => $e->getMessage(), 'file' => $e->getFile()]);
+        }
+
+        return parent::render($request, $e);
+    }
+}

+ 89 - 0
app/admin/controller/AuthController.php

@@ -0,0 +1,89 @@
+<?php
+
+namespace app\admin\controller;
+
+use app\admin\model\system\SystemAdmin;
+use app\admin\model\system\SystemMenus;
+use app\admin\model\system\SystemRole;
+use think\facade\Route as Url;
+
+/**
+ * 基类 所有控制器继承的类
+ * Class AuthController
+ * @package app\admin\controller
+ */
+class AuthController extends SystemBasic
+{
+    /**
+     * 当前登陆管理员信息
+     * @var
+     */
+    protected $adminInfo;
+
+    /**
+     * 当前登陆管理员ID
+     * @var
+     */
+    protected $adminId;
+
+    /**
+     * 当前管理员权限
+     * @var array
+     */
+    protected $auth = [];
+
+    protected $skipLogController = ['index', 'common'];
+
+    protected function initialize()
+    {
+        parent::initialize();
+        if (!SystemAdmin::hasActiveAdmin()) return $this->redirect(Url::buildUrl('login/index')->suffix(false)->build());
+        try {
+            $adminInfo = SystemAdmin::activeAdminInfoOrFail();
+        } catch (\Exception $e) {
+            return $this->failed(SystemAdmin::getErrorInfo($e->getMessage()), Url::buildUrl('login/index')->suffix(false)->build());
+        }
+        $this->adminInfo = $adminInfo;
+        $this->adminId = $adminInfo['id'];
+        $this->getActiveAdminInfo();
+        $this->auth = SystemAdmin::activeAdminAuthOrFail();
+        $this->adminInfo->level === 0 || $this->checkAuth();
+        $this->assign('_admin', $this->adminInfo);
+        $type = 'system';
+        event('AdminVisit', [$this->adminInfo, $type]);
+    }
+
+
+    protected function checkAuth($action = null, $controller = null, $module = null, array $route = [])
+    {
+        static $allAuth = null;
+        if ($allAuth === null) $allAuth = SystemRole::getAllAuth();
+        if ($module === null) $module = app('http')->getName();
+        if ($controller === null) $controller = $this->request->controller();
+        if ($action === null) $action = $this->request->action();
+        if (!count($route)) $route = $this->request->route();
+        array_shift($route);
+        if (in_array(strtolower($controller), $this->skipLogController, true)) return true;
+        $nowAuthName = SystemMenus::getAuthName($action, $controller, $module, $route);
+        $baseNowAuthName = SystemMenus::getAuthName($action, $controller, $module, []);
+        //积分设置的父类 不是系统设置  但是 $baseNowAuthName   确实验证得 系统设置权限
+        if ((in_array($nowAuthName, $allAuth) && !in_array($nowAuthName, $this->auth)) || (in_array($baseNowAuthName, $allAuth) && ($nowAuthName != 'admin/setting.systemconfig/index/type/3/tab_id/11' && !in_array($baseNowAuthName, $this->auth))))
+            exit($this->failed('没有权限访问!'));
+        return true;
+    }
+
+
+    /**
+     * 获得当前用户最新信息
+     * @return SystemAdmin
+     */
+    protected function getActiveAdminInfo()
+    {
+        $adminId = $this->adminId;
+        $adminInfo = SystemAdmin::getValidAdminInfoOrFail($adminId);
+        if (!$adminInfo) $this->failed(SystemAdmin::getErrorInfo('请登陆!'));
+        $this->adminInfo = $adminInfo;
+        SystemAdmin::setLoginInfo($adminInfo);
+        return $adminInfo;
+    }
+}

+ 603 - 0
app/admin/controller/Index.php

@@ -0,0 +1,603 @@
+<?php
+
+namespace app\admin\controller;
+
+use FormBuilder\Json;
+use think\facade\Config;
+use app\admin\model\order\StoreOrder as StoreOrderModel;//订单
+use app\admin\model\system\{SystemConfig, SystemMenus, SystemRole};
+use app\admin\model\user\{User, UserExtract as UserExtractModel, User as UserModel};
+use app\admin\model\store\{StoreProduct, StoreProductReply as StoreProductReplyModel, StoreProduct as ProductModel};
+
+/**
+ * 首页控制器
+ * Class Index
+ * @package app\admin\controller
+ *
+ */
+class Index extends AuthController
+{
+    public function index()
+    {
+        //获取当前登录后台的管理员信息
+        $adminInfo = $this->adminInfo->toArray();
+        $roles = explode(',', $adminInfo['roles']);
+        $site_logo = SystemConfig::getOneConfig('menu_name', 'site_logo')->toArray();
+
+        $this->assign([
+            'menuList' => SystemMenus::menuList(),
+            'site_logo' => json_decode($site_logo['value'], true),
+            'new_order_audio_link' => sys_config('new_order_audio_link'),
+            'role_name' => SystemRole::where('id', $roles[0])->field('role_name')->find(),
+            'workermanPort' => Config::get('workerman.admin.port')
+        ]);
+        return $this->fetch();
+    }
+
+    //后台首页内容
+    public function main()
+    {
+        /*首页第一行统计*/
+        $now_month = strtotime(date('Y-m'));//本月
+        $pre_month = strtotime(date('Y-m', strtotime('-1 month')));//上月
+        $now_day = strtotime(date('Y-m-d'));//今日
+        $pre_day = strtotime(date('Y-m-d', strtotime('-1 day')));//昨天时间戳
+        $beforyester_day = strtotime(date('Y-m-d', strtotime('-2 day')));//前天时间戳
+        //待发货数量
+        $topData['orderDeliveryNum'] = StoreOrderModel::where('status', 0)
+            ->where('paid', 1)
+            ->where('refund_status', 0)
+            ->where('shipping_type', 1)
+            ->where('is_del', 0)
+            ->count();
+        //退换货订单数
+        $topData['orderRefundNum'] = StoreOrderModel::where('paid', 1)
+            ->where('refund_status', 'IN', '1')
+            ->count();
+        //库存预警
+        $replenishment_num = sys_config('store_stock') > 0 ? sys_config('store_stock') : 20;//库存预警界限
+        $topData['stockProduct'] = StoreProduct::where('stock', '<=', $replenishment_num)->where('is_show', 1)->where('is_del', 0)->count();
+        //待处理提现
+        $topData['treatedExtract'] = UserExtractModel::where('status', 0)->count();
+
+
+        //订单数->昨日
+        $now_day_order_p = StoreOrderModel::where('paid', 1)->whereTime('pay_time', 'yesterday')->count();
+        $pre_day_order_p = StoreOrderModel::where('paid', 1)->where('pay_time', '>', $pre_day)->where('pay_time', '<', $now_day)->count();
+        $first_line['d_num'] = [
+            'data' => $now_day_order_p ? $now_day_order_p : 0,
+            'percent' => abs($now_day_order_p - $pre_day_order_p),
+            'is_plus' => $now_day_order_p - $pre_day_order_p > 0 ? 1 : ($now_day_order_p - $pre_day_order_p == 0 ? -1 : 0)
+        ];
+
+        //交易额->昨天
+        $now_month_order_p = StoreOrderModel::where('paid', 1)->whereTime('pay_time', 'yesterday')->sum('pay_price');
+        $pre_month_order_p = StoreOrderModel::where('paid', 1)->where('pay_time', '>', $beforyester_day)->where('pay_time', '<', $pre_day)->sum('pay_price');
+        $first_line['d_price'] = [
+            'data' => $now_month_order_p > 0 ? $now_month_order_p : 0,
+            'percent' => abs($now_month_order_p - $pre_month_order_p),
+            'is_plus' => $now_month_order_p - $pre_month_order_p > 0 ? 1 : ($now_month_order_p - $pre_month_order_p == 0 ? -1 : 0)
+        ];
+
+        //交易额->月
+        $now_month_order_p = StoreOrderModel::where('paid', 1)->whereTime('pay_time', 'month')->sum('pay_price');
+        $pre_month_order_p = StoreOrderModel::where('paid', 1)->where('pay_time', '>', $pre_month)->where('pay_time', '<', $now_month)->value('sum(pay_price)');
+        $first_line['m_price'] = [
+            'data' => $now_month_order_p > 0 ? $now_month_order_p : 0,
+            'percent' => abs($now_month_order_p - $pre_month_order_p),
+            'is_plus' => $now_month_order_p - $pre_month_order_p > 0 ? 1 : ($now_month_order_p - $pre_month_order_p == 0 ? -1 : 0)
+        ];
+
+        //新粉丝->日
+        $now_day_user = User::where('add_time', '>', $now_day)->count();
+        $pre_day_user = User::where('add_time', '>', $pre_day)->where('add_time', '<', $now_day)->count();
+        $pre_day_user = $pre_day_user ? $pre_day_user : 0;
+        $first_line['day'] = [
+            'data' => $now_day_user ? $now_day_user : 0,
+            'percent' => abs($now_day_user - $pre_day_user),
+            'is_plus' => $now_day_user - $pre_day_user > 0 ? 1 : ($now_day_user - $pre_day_user == 0 ? -1 : 0)
+        ];
+
+        //新粉丝->月
+        $now_month_user = User::where('add_time', '>', $now_month)->count();
+        $pre_month_user = User::where('add_time', '>', $pre_month)->where('add_time', '<', $now_month)->count();
+        $first_line['month'] = [
+            'data' => $now_month_user ? $now_month_user : 0,
+            'percent' => abs($now_month_user - $pre_month_user),
+            'is_plus' => $now_month_user - $pre_month_user > 0 ? 1 : ($now_month_user - $pre_month_user == 0 ? -1 : 0)
+        ];
+
+        //本月订单总数
+        $now_order_info_c = StoreOrderModel::where('add_time', '>', $now_month)->count();
+        $pre_order_info_c = StoreOrderModel::where('add_time', '>', $pre_month)->where('add_time', '<', $now_month)->count();
+        $order_info['first'] = [
+            'data' => $now_order_info_c ? $now_order_info_c : 0,
+            'percent' => abs($now_order_info_c - $pre_order_info_c),
+            'is_plus' => $now_order_info_c - $pre_order_info_c > 0 ? 1 : ($now_order_info_c - $pre_order_info_c == 0 ? -1 : 0)
+        ];
+
+        //上月订单总数
+        $second_now_month = strtotime(date('Y-m', strtotime('-1 month')));
+        $second_pre_month = strtotime(date('Y-m', strtotime('-2 month')));
+        $now_order_info_c = StoreOrderModel::where('add_time', '>', $pre_month)->where('add_time', '<', $now_month)->count();
+        $pre_order_info_c = StoreOrderModel::where('add_time', '>', $second_pre_month)->where('add_time', '<', $second_now_month)->count();
+        $order_info["second"] = [
+            'data' => $now_order_info_c ? $now_order_info_c : 0,
+            'percent' => abs($now_order_info_c - $pre_order_info_c),
+            'is_plus' => $now_order_info_c - $pre_order_info_c > 0 ? 1 : ($now_order_info_c - $pre_order_info_c == 0 ? -1 : 0)
+        ];
+        $second_line['order_info'] = $order_info;
+
+
+        $this->assign([
+            'first_line' => $first_line,
+            'second_line' => $second_line,
+            'topData' => $topData,
+        ]);
+        return $this->fetch();
+    }
+
+    /**
+     * 订单图表
+     */
+    public function orderchart()
+    {
+        header('Content-type:text/json');
+        $cycle = $this->request->param('cycle') ?: 'thirtyday';//默认30天
+        $datalist = [];
+        $where = ['is_del' => 0, 'paid' => 1, 'refund_status' => 0];
+        switch ($cycle) {
+            case 'thirtyday':
+                $datebefor = date('Y-m-d 00:00:00', strtotime('-30 day'));
+                $dateafter = date('Y-m-d 23:59:59');
+                //上期
+                $pre_datebefor = date('Y-m-d', strtotime('-60 day'));
+                $pre_dateafter = date('Y-m-d', strtotime('-30 day'));
+                for ($i = -30; $i < 1; $i++) {
+                    $datalist[date('m-d', strtotime($i . ' day'))] = date('m-d', strtotime($i . ' day'));
+                }
+                $order_list = StoreOrderModel::where('add_time', 'between time', [$datebefor, $dateafter])
+                    ->where($where)
+                    ->field("FROM_UNIXTIME(add_time,'%m-%d') as day,count(*) as count,sum(pay_price) as price")
+                    ->group("FROM_UNIXTIME(add_time, '%Y%m%d')")
+                    ->order('add_time asc')
+                    ->select()->toArray();
+                if (empty($order_list)) return Json::fail('无数据');
+                foreach ($order_list as $k => &$v) {
+                    $order_list[$v['day']] = $v;
+                }
+                $cycle_list = [];
+                foreach ($datalist as $dk => $dd) {
+                    if (!empty($order_list[$dd])) {
+                        $cycle_list[$dd] = $order_list[$dd];
+                    } else {
+                        $cycle_list[$dd] = ['count' => 0, 'day' => $dd, 'price' => ''];
+                    }
+                }
+                $chartdata = [];
+                $data = [];//临时
+                $chartdata['yAxis']['maxnum'] = 0;//最大值数量
+                $chartdata['yAxis']['maxprice'] = 0;//最大值金额
+                foreach ($cycle_list as $k => $v) {
+                    $data['day'][] = $v['day'];
+                    $data['count'][] = $v['count'];
+                    $data['price'][] = round($v['price'], 2);
+                    if ($chartdata['yAxis']['maxnum'] < $v['count'])
+                        $chartdata['yAxis']['maxnum'] = $v['count'];//日最大订单数
+                    if ($chartdata['yAxis']['maxprice'] < $v['price'])
+                        $chartdata['yAxis']['maxprice'] = $v['price'];//日最大金额
+                }
+                $chartdata['legend'] = ['订单金额', '订单数'];//分类
+                $chartdata['xAxis'] = $data['day'];//X轴值
+                //,'itemStyle'=>$series
+                $series = ['normal' => ['label' => ['show' => true, 'position' => 'top']]];
+                $chartdata['series'][] = ['name' => $chartdata['legend'][0], 'type' => 'bar', 'itemStyle' => $series, 'data' => $data['price']];//分类1值
+                $chartdata['series'][] = ['name' => $chartdata['legend'][1], 'type' => 'bar', 'itemStyle' => $series, 'data' => $data['count']];//分类2值
+                //统计总数上期
+                $pre_total = StoreOrderModel::where('add_time', 'between time', [$pre_datebefor, $pre_dateafter])
+                    ->where($where)
+                    ->field("count(*) as count,sum(pay_price) as price")
+                    ->find();
+                if ($pre_total) {
+                    $chartdata['pre_cycle']['count'] = [
+                        'data' => $pre_total['count'] ?: 0
+                    ];
+                    $chartdata['pre_cycle']['price'] = [
+                        'data' => $pre_total['price'] ?: 0
+                    ];
+                }
+                //统计总数
+                $total = StoreOrderModel::where('add_time', 'between time', [$datebefor, $dateafter])
+                    ->where($where)
+                    ->field("count(*) as count,sum(pay_price) as price")
+                    ->find();
+                if ($total) {
+                    $cha_count = intval($pre_total['count']) - intval($total['count']);
+                    //$pre_total['count'] = $pre_total['count'] == 0 ? 1 : $pre_total['count'];
+                    $chartdata['cycle']['count'] = [
+                        'data' => $total['count'] ?: 0,
+                        'percent' => intval($pre_total['count']) == 0 ? 100 : round((abs($cha_count) / intval($pre_total['count']) * 100), 2),
+                        'is_plus' => $cha_count > 0 ? -1 : ($cha_count == 0 ? 0 : 1)
+                    ];
+                    $cha_price = round($pre_total['price'], 2) - round($total['price'], 2);
+                    //$pre_total['price'] = $pre_total['price'] == 0 ? 1 : $pre_total['price'];
+                    $chartdata['cycle']['price'] = [
+                        'data' => $total['price'] ?: 0,
+                        'percent' => (intval($pre_total['price']) == 0 || !$pre_total['price'] || $pre_total['price'] == 0.00) ? 100 : round(abs($cha_price) / $pre_total['price'] * 100, 2),
+                        'is_plus' => $cha_price > 0 ? -1 : ($cha_price == 0 ? 0 : 1)
+                    ];
+                }
+                return app('json')->success('ok', $chartdata);
+                break;
+            case 'week':
+                $weekarray = array(['周日'], ['周一'], ['周二'], ['周三'], ['周四'], ['周五'], ['周六']);
+                $datebefor = date('Y-m-d 00:00:00)', strtotime('-1 week Monday'));
+                $dateafter = date('Y-m-d 23:59:59', strtotime('-1 week Sunday'));
+                $order_list = StoreOrderModel::where('add_time', 'between time', [$datebefor, $dateafter])
+                    ->where($where)
+                    ->field("FROM_UNIXTIME(add_time,'%w') as day,count(*) as count,sum(pay_price) as price")
+                    ->group("FROM_UNIXTIME(add_time, '%Y%m%e')")
+                    ->order('add_time asc')
+                    ->select()->toArray();
+                //数据查询重新处理
+                $new_order_list = [];
+                foreach ($order_list as $k => $v) {
+                    $new_order_list[$v['day']] = $v;
+                }
+                $now_datebefor = date('Y-m-d 00:00:00', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600));
+                $now_dateafter = date('Y-m-d 23:59:59', strtotime("+1 day"));
+                $now_order_list = StoreOrderModel::where('add_time', 'between time', [$now_datebefor, $now_dateafter])
+                    ->where($where)
+                    ->field("FROM_UNIXTIME(add_time,'%w') as day,count(*) as count,sum(pay_price) as price")
+                    ->group("FROM_UNIXTIME(add_time, '%Y%m%e')")
+                    ->order('add_time asc')
+                    ->select()->toArray();
+                //数据查询重新处理 key 变为当前值
+                $new_now_order_list = [];
+                foreach ($now_order_list as $k => $v) {
+                    $new_now_order_list[$v['day']] = $v;
+                }
+                foreach ($weekarray as $dk => $dd) {
+                    if (!empty($new_order_list[$dk])) {
+                        $weekarray[$dk]['pre'] = $new_order_list[$dk];
+                    } else {
+                        $weekarray[$dk]['pre'] = ['count' => 0, 'day' => $weekarray[$dk][0], 'price' => '0'];
+                    }
+                    if (!empty($new_now_order_list[$dk])) {
+                        $weekarray[$dk]['now'] = $new_now_order_list[$dk];
+                    } else {
+                        $weekarray[$dk]['now'] = ['count' => 0, 'day' => $weekarray[$dk][0], 'price' => '0'];
+                    }
+                }
+                $chartdata = [];
+                $data = [];//临时
+                $chartdata['yAxis']['maxnum'] = 0;//最大值数量
+                $chartdata['yAxis']['maxprice'] = 0;//最大值金额
+                foreach ($weekarray as $k => $v) {
+                    $data['day'][] = $v[0];
+                    $data['pre']['count'][] = $v['pre']['count'];
+                    $data['pre']['price'][] = round($v['pre']['price'], 2);
+                    $data['now']['count'][] = $v['now']['count'];
+                    $data['now']['price'][] = round($v['now']['price'], 2);
+                    if ($chartdata['yAxis']['maxnum'] < $v['pre']['count'] || $chartdata['yAxis']['maxnum'] < $v['now']['count']) {
+                        $chartdata['yAxis']['maxnum'] = $v['pre']['count'] > $v['now']['count'] ? $v['pre']['count'] : $v['now']['count'];//日最大订单数
+                    }
+                    if ($chartdata['yAxis']['maxprice'] < $v['pre']['price'] || $chartdata['yAxis']['maxprice'] < $v['now']['price']) {
+                        $chartdata['yAxis']['maxprice'] = $v['pre']['price'] > $v['now']['price'] ? $v['pre']['price'] : $v['now']['price'];//日最大金额
+                    }
+                }
+                $chartdata['legend'] = ['上周金额', '本周金额', '上周订单数', '本周订单数'];//分类
+                $chartdata['xAxis'] = $data['day'];//X轴值
+                //,'itemStyle'=>$series
+                $series = ['normal' => ['label' => ['show' => true, 'position' => 'top']]];
+                $chartdata['series'][] = ['name' => $chartdata['legend'][0], 'type' => 'bar', 'itemStyle' => $series, 'data' => $data['pre']['price']];//分类1值
+                $chartdata['series'][] = ['name' => $chartdata['legend'][1], 'type' => 'bar', 'itemStyle' => $series, 'data' => $data['now']['price']];//分类1值
+                $chartdata['series'][] = ['name' => $chartdata['legend'][2], 'type' => 'line', 'itemStyle' => $series, 'data' => $data['pre']['count']];//分类2值
+                $chartdata['series'][] = ['name' => $chartdata['legend'][3], 'type' => 'line', 'itemStyle' => $series, 'data' => $data['now']['count']];//分类2值
+
+                //统计总数上期
+                $pre_total = StoreOrderModel::where('add_time', 'between time', [$datebefor, $dateafter])
+                    ->where($where)
+                    ->field("count(*) as count,sum(pay_price) as price")
+                    ->find();
+                if ($pre_total) {
+                    $chartdata['pre_cycle']['count'] = [
+                        'data' => $pre_total['count'] ?: 0
+                    ];
+                    $chartdata['pre_cycle']['price'] = [
+                        'data' => $pre_total['price'] ?: 0
+                    ];
+                }
+                //统计总数
+                $total = StoreOrderModel::where('add_time', 'between time', [$now_datebefor, $now_dateafter])
+                    ->where($where)
+                    ->field("count(*) as count,sum(pay_price) as price")
+                    ->find();
+                if ($total) {
+                    $cha_count = intval($pre_total['count']) - intval($total['count']);
+                    //$pre_total['count'] = $pre_total['count'] == 0 ? 1 : $pre_total['count'];
+                    $chartdata['cycle']['count'] = [
+                        'data' => $total['count'] ?: 0,
+                        'percent' => intval($pre_total['count']) == 0 ? 100 : round((abs($cha_count) / intval($pre_total['count']) * 100), 2),
+                        'is_plus' => $cha_count > 0 ? -1 : ($cha_count == 0 ? 0 : 1)
+                    ];
+                    $cha_price = round($pre_total['price'], 2) - round($total['price'], 2);
+                    //$pre_total['price'] = $pre_total['price'] == 0 ? 1 : $pre_total['price'];
+                    $chartdata['cycle']['price'] = [
+                        'data' => $total['price'] ?: 0,
+                        'percent' => (intval($pre_total['price']) == 0 || !$pre_total['price'] || $pre_total['price'] == 0.00) ? 100 : round(abs($cha_price) / $pre_total['price'] * 100, 2),
+                        'is_plus' => $cha_price > 0 ? -1 : ($cha_price == 0 ? 0 : 1)
+                    ];
+                }
+                return app('json')->success('ok', $chartdata);
+                break;
+            case 'month':
+                $weekarray = array('01' => ['1'], '02' => ['2'], '03' => ['3'], '04' => ['4'], '05' => ['5'], '06' => ['6'], '07' => ['7'], '08' => ['8'], '09' => ['9'], '10' => ['10'], '11' => ['11'], '12' => ['12'], '13' => ['13'], '14' => ['14'], '15' => ['15'], '16' => ['16'], '17' => ['17'], '18' => ['18'], '19' => ['19'], '20' => ['20'], '21' => ['21'], '22' => ['22'], '23' => ['23'], '24' => ['24'], '25' => ['25'], '26' => ['26'], '27' => ['27'], '28' => ['28'], '29' => ['29'], '30' => ['30'], '31' => ['31']);
+
+                $datebefor = date('Y-m-01 00:00:00', strtotime('-1 month'));
+                $dateafter = date('Y-m-d 23:59:59', strtotime(date('Y-m-01')));
+                $order_list = StoreOrderModel::where('add_time', 'between time', [$datebefor, $dateafter])
+                    ->where($where)
+                    ->field("FROM_UNIXTIME(add_time,'%d') as day,count(*) as count,sum(pay_price) as price")
+                    ->group("FROM_UNIXTIME(add_time, '%Y%m%e')")
+                    ->order('add_time asc')
+                    ->select()->toArray();
+                //数据查询重新处理
+                $new_order_list = [];
+                foreach ($order_list as $k => $v) {
+                    $new_order_list[$v['day']] = $v;
+                }
+                $now_datebefor = date('Y-m-01 00:00:00');
+                $now_dateafter = date('Y-m-d 23:59:59', strtotime("+1 day"));
+                $now_order_list = StoreOrderModel::where('add_time', 'between time', [$now_datebefor, $now_dateafter])
+                    ->where($where)
+                    ->field("FROM_UNIXTIME(add_time,'%d') as day,count(*) as count,sum(pay_price) as price")
+                    ->group("FROM_UNIXTIME(add_time, '%Y%m%e')")
+                    ->order('add_time asc')
+                    ->select()->toArray();
+                //数据查询重新处理 key 变为当前值
+                $new_now_order_list = [];
+                foreach ($now_order_list as $k => $v) {
+                    $new_now_order_list[$v['day']] = $v;
+                }
+                foreach ($weekarray as $dk => $dd) {
+                    if (!empty($new_order_list[$dk])) {
+                        $weekarray[$dk]['pre'] = $new_order_list[$dk];
+                    } else {
+                        $weekarray[$dk]['pre'] = ['count' => 0, 'day' => $weekarray[$dk][0], 'price' => '0'];
+                    }
+                    if (!empty($new_now_order_list[$dk])) {
+                        $weekarray[$dk]['now'] = $new_now_order_list[$dk];
+                    } else {
+                        $weekarray[$dk]['now'] = ['count' => 0, 'day' => $weekarray[$dk][0], 'price' => '0'];
+                    }
+                }
+                $chartdata = [];
+                $data = [];//临时
+                $chartdata['yAxis']['maxnum'] = 0;//最大值数量
+                $chartdata['yAxis']['maxprice'] = 0;//最大值金额
+                foreach ($weekarray as $k => $v) {
+                    $data['day'][] = $v[0];
+                    $data['pre']['count'][] = $v['pre']['count'];
+                    $data['pre']['price'][] = round($v['pre']['price'], 2);
+                    $data['now']['count'][] = $v['now']['count'];
+                    $data['now']['price'][] = round($v['now']['price'], 2);
+                    if ($chartdata['yAxis']['maxnum'] < $v['pre']['count'] || $chartdata['yAxis']['maxnum'] < $v['now']['count']) {
+                        $chartdata['yAxis']['maxnum'] = $v['pre']['count'] > $v['now']['count'] ? $v['pre']['count'] : $v['now']['count'];//日最大订单数
+                    }
+                    if ($chartdata['yAxis']['maxprice'] < $v['pre']['price'] || $chartdata['yAxis']['maxprice'] < $v['now']['price']) {
+                        $chartdata['yAxis']['maxprice'] = $v['pre']['price'] > $v['now']['price'] ? $v['pre']['price'] : $v['now']['price'];//日最大金额
+                    }
+
+                }
+                $chartdata['legend'] = ['上月金额', '本月金额', '上月订单数', '本月订单数'];//分类
+                $chartdata['xAxis'] = $data['day'];//X轴值
+                //,'itemStyle'=>$series
+                $series = ['normal' => ['label' => ['show' => true, 'position' => 'top']]];
+                $chartdata['series'][] = ['name' => $chartdata['legend'][0], 'type' => 'bar', 'itemStyle' => $series, 'data' => $data['pre']['price']];//分类1值
+                $chartdata['series'][] = ['name' => $chartdata['legend'][1], 'type' => 'bar', 'itemStyle' => $series, 'data' => $data['now']['price']];//分类1值
+                $chartdata['series'][] = ['name' => $chartdata['legend'][2], 'type' => 'line', 'itemStyle' => $series, 'data' => $data['pre']['count']];//分类2值
+                $chartdata['series'][] = ['name' => $chartdata['legend'][3], 'type' => 'line', 'itemStyle' => $series, 'data' => $data['now']['count']];//分类2值
+
+                //统计总数上期
+                $pre_total = StoreOrderModel::where('add_time', 'between time', [$datebefor, $dateafter])
+                    ->where($where)
+                    ->field("count(*) as count,sum(pay_price) as price")
+                    ->find();
+                if ($pre_total) {
+                    $chartdata['pre_cycle']['count'] = [
+                        'data' => $pre_total['count'] ?: 0
+                    ];
+                    $chartdata['pre_cycle']['price'] = [
+                        'data' => $pre_total['price'] ?: 0
+                    ];
+                }
+                //统计总数
+                $total = StoreOrderModel::where('add_time', 'between time', [$now_datebefor, $now_dateafter])
+                    ->where($where)
+                    ->field("count(*) as count,sum(pay_price) as price")
+                    ->find();
+                if ($total) {
+                    $cha_count = intval($pre_total['count']) - intval($total['count']);
+                    //$pre_total['count'] = $pre_total['count'] == 0 ? 1 : $pre_total['count'];
+                    $chartdata['cycle']['count'] = [
+                        'data' => $total['count'] ?: 0,
+                        'percent' => intval($pre_total['count']) == 0 ? 100 : round((abs($cha_count) / intval($pre_total['count']) * 100), 2),
+                        'is_plus' => $cha_count > 0 ? -1 : ($cha_count == 0 ? 0 : 1)
+                    ];
+                    $cha_price = round($pre_total['price'], 2) - round($total['price'], 2);
+                    //$pre_total['price'] = $pre_total['price'] == 0 ? 1 : $pre_total['price'];
+                    $chartdata['cycle']['price'] = [
+                        'data' => $total['price'] ?: 0,
+                        'percent' => (intval($pre_total['price']) == 0 || !$pre_total['price'] || $pre_total['price'] == 0.00) ? 100 : round(abs($cha_price) / $pre_total['price'] * 100, 2),
+                        'is_plus' => $cha_price > 0 ? -1 : ($cha_price == 0 ? 0 : 1)
+                    ];
+                }
+                return app('json')->success('ok', $chartdata);
+                break;
+            case 'year':
+                $weekarray = array('01' => ['一月'], '02' => ['二月'], '03' => ['三月'], '04' => ['四月'], '05' => ['五月'], '06' => ['六月'], '07' => ['七月'], '08' => ['八月'], '09' => ['九月'], '10' => ['十月'], '11' => ['十一月'], '12' => ['十二月']);
+                $datebefor = date('Y-01-01 00:00:00', strtotime('-1 year'));
+                $dateafter = date('Y-12-31 23:59:59', strtotime('-1 year'));
+                $order_list = StoreOrderModel::where('add_time', 'between time', [$datebefor, $dateafter])
+                    ->where($where)
+                    ->field("FROM_UNIXTIME(add_time,'%m') as day,count(*) as count,sum(pay_price) as price")
+                    ->group("FROM_UNIXTIME(add_time, '%Y%m')")
+                    ->order('add_time asc')
+                    ->select()->toArray();
+                //数据查询重新处理
+                $new_order_list = [];
+                foreach ($order_list as $k => $v) {
+                    $new_order_list[$v['day']] = $v;
+                }
+                $now_datebefor = date('Y-01-01 00:00:00');
+                $now_dateafter = date('Y-m-d 23:59:59');
+                $now_order_list = StoreOrderModel::where('add_time', 'between time', [$now_datebefor, $now_dateafter])
+                    ->where($where)
+                    ->field("FROM_UNIXTIME(add_time,'%m') as day,count(*) as count,sum(pay_price) as price")
+                    ->group("FROM_UNIXTIME(add_time, '%Y%m')")
+                    ->order('add_time asc')
+                    ->select()->toArray();
+                //数据查询重新处理 key 变为当前值
+                $new_now_order_list = [];
+                foreach ($now_order_list as $k => $v) {
+                    $new_now_order_list[$v['day']] = $v;
+                }
+                foreach ($weekarray as $dk => $dd) {
+                    if (!empty($new_order_list[$dk])) {
+                        $weekarray[$dk]['pre'] = $new_order_list[$dk];
+                    } else {
+                        $weekarray[$dk]['pre'] = ['count' => 0, 'day' => $weekarray[$dk][0], 'price' => '0'];
+                    }
+                    if (!empty($new_now_order_list[$dk])) {
+                        $weekarray[$dk]['now'] = $new_now_order_list[$dk];
+                    } else {
+                        $weekarray[$dk]['now'] = ['count' => 0, 'day' => $weekarray[$dk][0], 'price' => '0'];
+                    }
+                }
+                $chartdata = [];
+                $data = [];//临时
+                $chartdata['yAxis']['maxnum'] = 0;//最大值数量
+                $chartdata['yAxis']['maxprice'] = 0;//最大值金额
+                foreach ($weekarray as $k => $v) {
+                    $data['day'][] = $v[0];
+                    $data['pre']['count'][] = $v['pre']['count'];
+                    $data['pre']['price'][] = round($v['pre']['price'], 2);
+                    $data['now']['count'][] = $v['now']['count'];
+                    $data['now']['price'][] = round($v['now']['price'], 2);
+                    if ($chartdata['yAxis']['maxnum'] < $v['pre']['count'] || $chartdata['yAxis']['maxnum'] < $v['now']['count']) {
+                        $chartdata['yAxis']['maxnum'] = $v['pre']['count'] > $v['now']['count'] ? $v['pre']['count'] : $v['now']['count'];//日最大订单数
+                    }
+                    if ($chartdata['yAxis']['maxprice'] < $v['pre']['price'] || $chartdata['yAxis']['maxprice'] < $v['now']['price']) {
+                        $chartdata['yAxis']['maxprice'] = $v['pre']['price'] > $v['now']['price'] ? $v['pre']['price'] : $v['now']['price'];//日最大金额
+                    }
+                }
+                $chartdata['legend'] = ['去年金额', '今年金额', '去年订单数', '今年订单数'];//分类
+                $chartdata['xAxis'] = $data['day'];//X轴值
+                //,'itemStyle'=>$series
+                $series = ['normal' => ['label' => ['show' => true, 'position' => 'top']]];
+                $chartdata['series'][] = ['name' => $chartdata['legend'][0], 'type' => 'bar', 'itemStyle' => $series, 'data' => $data['pre']['price']];//分类1值
+                $chartdata['series'][] = ['name' => $chartdata['legend'][1], 'type' => 'bar', 'itemStyle' => $series, 'data' => $data['now']['price']];//分类1值
+                $chartdata['series'][] = ['name' => $chartdata['legend'][2], 'type' => 'line', 'itemStyle' => $series, 'data' => $data['pre']['count']];//分类2值
+                $chartdata['series'][] = ['name' => $chartdata['legend'][3], 'type' => 'line', 'itemStyle' => $series, 'data' => $data['now']['count']];//分类2值
+
+                //统计总数上期
+                $pre_total = StoreOrderModel::where('add_time', 'between time', [$datebefor, $dateafter])
+                    ->where($where)
+                    ->field("count(*) as count,sum(pay_price) as price")
+                    ->find();
+                if ($pre_total) {
+                    $chartdata['pre_cycle']['count'] = [
+                        'data' => $pre_total['count'] ?: 0
+                    ];
+                    $chartdata['pre_cycle']['price'] = [
+                        'data' => $pre_total['price'] ?: 0
+                    ];
+                }
+                //统计总数
+                $total = StoreOrderModel::where('add_time', 'between time', [$now_datebefor, $now_dateafter])
+                    ->where($where)
+                    ->field("count(*) as count,sum(pay_price) as price")
+                    ->find();
+                if ($total) {
+                    $cha_count = intval($pre_total['count']) - intval($total['count']);
+                    //$pre_total['count'] = $pre_total['count'] == 0 ? 1 : $pre_total['count'];
+                    $chartdata['cycle']['count'] = [
+                        'data' => $total['count'] ?: 0,
+                        'percent' => intval($pre_total['count']) == 0 ? 100 : round((abs($cha_count) / intval($pre_total['count']) * 100), 2),
+                        'is_plus' => $cha_count > 0 ? -1 : ($cha_count == 0 ? 0 : 1)
+                    ];
+                    $cha_price = round($pre_total['price'], 2) - round($total['price'], 2);
+                    //$pre_total['price'] = $pre_total['price'] == 0 ? 1 : $pre_total['price'];
+                    $chartdata['cycle']['price'] = [
+                        'data' => $total['price'] ?: 0,
+                        'percent' => (intval($pre_total['price']) == 0 || !$pre_total['price'] || $pre_total['price'] == 0.00) ? 100 : round(abs($cha_price) / $pre_total['price'] * 100, 2),
+                        'is_plus' => $cha_price > 0 ? -1 : ($cha_price == 0 ? 0 : 1)
+                    ];
+                }
+                return app('json')->success('ok', $chartdata);
+                break;
+            default:
+                break;
+        }
+
+
+    }
+
+    /**
+     * 用户图表
+     */
+    public function userchart()
+    {
+        header('Content-type:text/json');
+
+        $starday = date('Y-m-d', strtotime('-30 day'));
+        $yesterday = date('Y-m-d');
+
+        $user_list = UserModel::where('add_time', 'between time', [$starday, $yesterday])
+            ->field("FROM_UNIXTIME(add_time,'%m-%e') as day,count(*) as count")
+            ->group("FROM_UNIXTIME(add_time, '%Y%m%e')")
+            ->order('add_time asc')
+            ->select()->toArray();
+        $chartdata = [];
+        $data = [];
+        $chartdata['legend'] = ['用户数'];//分类
+        $chartdata['yAxis']['maxnum'] = 0;//最大值数量
+        $chartdata['xAxis'] = [date('m-d')];//X轴值
+        $chartdata['series'] = [0];//分类1值
+        if (!empty($user_list)) {
+            foreach ($user_list as $k => $v) {
+                $data['day'][] = $v['day'];
+                $data['count'][] = $v['count'];
+                if ($chartdata['yAxis']['maxnum'] < $v['count'])
+                    $chartdata['yAxis']['maxnum'] = $v['count'];
+            }
+            $chartdata['xAxis'] = $data['day'];//X轴值
+            $chartdata['series'] = $data['count'];//分类1值
+        }
+        return app('json')->success('ok', $chartdata);
+    }
+
+    /**
+     * 待办事统计
+     * @param int $newTime
+     * @return false|string
+     */
+    public function Jnotice($newTime = 30)
+    {
+        header('Content-type:text/json');
+        $data = [];
+        $data['ordernum'] = StoreOrderModel::statusByWhere(1)->count();//待发货
+        $replenishment_num = sys_config('store_stock') > 0 ? sys_config('store_stock') : 2;//库存预警界限
+        $data['inventory'] = ProductModel::where('stock', '<=', $replenishment_num)->where('is_show', 1)->where('is_del', 0)->count();//库存
+        $data['commentnum'] = StoreProductReplyModel::where('is_reply', 0)->count();//评论
+        $data['reflectnum'] = UserExtractModel::where('status', 0)->count();;//提现
+        $data['msgcount'] = intval($data['ordernum']) + intval($data['inventory']) + intval($data['commentnum']) + intval($data['reflectnum']);
+        //新订单提醒
+        $data['newOrderId'] = StoreOrderModel::statusByWhere(1)->where('is_remind', 0)->column('order_id', 'id');
+        if (count($data['newOrderId'])) StoreOrderModel::where('order_id', 'in', $data['newOrderId'])->update(['is_remind' => 1]);
+        return app('json')->success('ok', $data);
+    }
+}
+
+

+ 67 - 0
app/admin/controller/Login.php

@@ -0,0 +1,67 @@
+<?php
+
+namespace app\admin\controller;
+
+
+use app\admin\model\system\SystemAdmin;
+use crmeb\services\UtilService;
+use think\facade\Session;
+use think\facade\Route as Url;
+
+/**
+ * 登录验证控制器
+ * Class Login
+ * @package app\admin\controller
+ */
+class Login extends SystemBasic
+{
+    public function index()
+    {
+        return $this->fetch();
+    }
+
+    /**
+     * 登录验证 + 验证码验证
+     */
+    public function verify()
+    {
+        if (!request()->isPost()) return $this->failed('请登陆!');
+        list($account, $pwd, $verify) = UtilService::postMore([
+            'account', 'pwd', 'verify'
+        ], null, true);
+        //检验验证码
+        if (!captcha_check($verify)) return $this->failed('验证码错误,请重新输入');
+        $error = Session::get('login_error') ?: ['num' => 0, 'time' => time()];
+        $error['num'] = 0;
+        if ($error['num'] >= 5 && $error['time'] > strtotime('- 5 minutes'))
+            return $this->failed('错误次数过多,请稍候再试!');
+        //检验帐号密码
+        $res = SystemAdmin::login($account, $pwd);
+        if ($res) {
+            Session::set('login_error', null);
+            Session::save();
+            return $this->successful(['url' => Url::buildUrl('Index/index')->build()]);
+        } else {
+            $error['num'] += 1;
+            $error['time'] = time();
+            Session::set('login_error', $error);
+            Session::save();
+            return $this->failed(SystemAdmin::getErrorInfo('用户名错误,请重新输入'));
+        }
+    }
+
+    public function captcha()
+    {
+        ob_clean();
+        return captcha();
+    }
+
+    /**
+     * 退出登陆
+     */
+    public function logout()
+    {
+        SystemAdmin::clearLoginInfo();
+        $this->redirect(Url::buildUrl('index')->build());
+    }
+}

+ 118 - 0
app/admin/controller/SystemBasic.php

@@ -0,0 +1,118 @@
+<?php
+/**
+ *
+ * @author: xaboy<365615158@qq.com>
+ * @day: 2017/10/09
+ */
+
+namespace app\admin\controller;
+
+use crmeb\services\JsonService;
+use crmeb\basic\BaseController;
+
+
+class SystemBasic extends BaseController
+{
+    /**
+     * 操作失败提示框
+     * @param string $msg 提示信息
+     * @param string $backUrl 跳转地址
+     * @param string $title 标题
+     * @param int $duration 持续时间
+     * @return mixed
+     */
+    protected function failedNotice($msg = '操作失败', $backUrl = 0, $info = '', $duration = 3)
+    {
+        $type = 'error';
+        $this->assign(compact('msg', 'backUrl', 'info', 'duration', 'type'));
+        return $this->fetch('public/notice');
+    }
+
+    /**
+     * 失败提示一直持续
+     * @param $msg
+     * @param int $backUrl
+     * @param string $title
+     * @return mixed
+     */
+    protected function failedNoticeLast($msg = '操作失败', $backUrl = 0, $info = '')
+    {
+        return $this->failedNotice($msg, $backUrl, $info, 0);
+    }
+
+    /**
+     * 操作成功提示框
+     * @param string $msg 提示信息
+     * @param string $backUrl 跳转地址
+     * @param string $title 标题
+     * @param int $duration 持续时间
+     * @return mixed
+     */
+    protected function successfulNotice($msg = '操作成功', $backUrl = 0, $info = '', $duration = 3)
+    {
+        $type = 'success';
+        $this->assign(compact('msg', 'backUrl', 'info', 'duration', 'type'));
+        return $this->fetch('public/notice');
+    }
+
+    /**
+     * 成功提示一直持续
+     * @param $msg
+     * @param int $backUrl
+     * @param string $title
+     * @return mixed
+     */
+    protected function successfulNoticeLast($msg = '操作成功', $backUrl = 0, $info = '')
+    {
+        return $this->successfulNotice($msg, $backUrl, $info, 0);
+    }
+
+    /**
+     * 错误提醒页面
+     * @param string $msg
+     * @param int $url
+     */
+    protected function failed($msg = '哎呀…亲…您访问的页面出现错误', $url = 0)
+    {
+        if ($this->request->isAjax()) {
+            exit(JsonService::fail($msg, $url)->getContent());
+        } else {
+            $this->assign(compact('msg', 'url'));
+            exit($this->fetch('public/error'));
+        }
+    }
+
+    /**
+     * 成功提醒页面
+     * @param string $msg
+     * @param int $url
+     */
+    protected function successful($msg, $url = 0)
+    {
+        if ($this->request->isAjax()) {
+            exit(JsonService::successful($msg, $url)->getContent());
+        } else {
+            $this->assign(compact('msg', 'url'));
+            exit($this->fetch('public/success'));
+        }
+    }
+
+    /**异常抛出
+     * @param $name
+     */
+    protected function exception($msg = '无法打开页面')
+    {
+        $this->assign(compact('msg'));
+        exit($this->fetch('public/exception'));
+    }
+
+    /**找不到页面
+     * @param $name
+     */
+    public function _empty($name)
+    {
+        exit($this->fetch('public/404'));
+    }
+
+
+}

+ 21 - 0
app/admin/controller/Test.php

@@ -0,0 +1,21 @@
+<?php
+
+namespace app\admin\controller;
+
+
+use crmeb\utils\Redis;
+
+class Test
+{
+    public function index()
+    {
+
+        $redis = Redis::instance();
+        var_dump($redis->get(['CRMEB','TESD']));
+    }
+
+    public function test()
+    {
+
+    }
+}

+ 346 - 0
app/admin/controller/agent/AgentManage.php

@@ -0,0 +1,346 @@
+<?php
+
+namespace app\admin\controller\agent;
+
+use app\admin\controller\AuthController;
+use app\admin\model\order\StoreOrder;
+use app\admin\model\system\SystemAttachment;
+use app\admin\model\user\User;
+use app\models\user\UserBill;
+use app\admin\model\wechat\WechatUser as UserModel;
+use app\models\routine\{
+    RoutineCode, RoutineQrcode
+};
+use crmeb\services\{
+    JsonService, QrcodeService, UtilService as Util
+};
+use crmeb\services\upload\Upload;
+
+/**
+ * 分销商管理控制器
+ * Class AgentManage
+ * @package app\admin\controller\agent
+ */
+class AgentManage extends AuthController
+{
+
+    /**
+     * @return mixed
+     */
+    public function index()
+    {
+        $this->assign('year', get_month());
+        $this->assign('store_brokerage_statu', sys_config('store_brokerage_statu'));
+        return $this->fetch();
+    }
+
+    /**
+     * 分销员列表
+     */
+    public function get_spread_list()
+    {
+        $where = Util::getMore([
+            ['nickname', ''],
+            ['sex', ''],
+            ['excel', ''],
+            ['subscribe', ''],
+            ['order', ''],
+            ['page', 1],
+            ['limit', 20],
+            ['user_type', ''],
+            ['data', '']
+        ]);
+        return JsonService::successlayui(UserModel::agentSystemPage($where));
+    }
+
+    /**
+     * 分销员列表头部数据统计
+     */
+    public function get_badge()
+    {
+        $where = Util::postMore([
+            ['data', ''],
+            ['nickname', ''],
+            ['excel', ''],
+        ]);
+        return JsonService::successful(UserModel::getSpreadBadge($where));
+    }
+
+    /**
+     * 一级推荐人页面
+     * @return mixed
+     */
+    public function stair($uid = '')
+    {
+        if ($uid == '') return $this->failed('参数错误');
+        $this->assign('uid', $uid ?: 0);
+        $this->assign('year', get_month());
+        return $this->fetch();
+    }
+
+    /*
+    *  统计推广订单页面
+    * @param int $uid
+    * */
+    public function stair_order($uid = 0)
+    {
+        if ($uid == '') return $this->failed('参数错误');
+        $this->assign('uid', $uid ?: 0);
+        $this->assign('year', get_month());
+        return $this->fetch();
+    }
+
+    /**
+     * 统计推广订单列表
+     */
+    public function get_stair_order_list()
+    {
+        $where = Util::getMore([
+            ['uid', $this->request->param('uid', 0)],
+            ['data', ''],
+            ['order_id', ''],
+            ['type', ''],
+            ['page', 1],
+            ['limit', 20],
+        ]);
+        return JsonService::successlayui(UserModel::getStairOrderList($where));
+    }
+
+    /**
+     * 统计推广订单列表头部统计数据
+     */
+    public function get_stair_order_badge()
+    {
+        $where = Util::getMore([
+            ['uid', ''],
+            ['data', ''],
+            ['order_id', ''],
+            ['type', ''],
+        ]);
+        return JsonService::successful(UserModel::getStairOrderBadge($where));
+    }
+
+    public function get_stair_list()
+    {
+        $where = Util::getMore([
+            ['uid', $this->request->param('uid', 0)],
+            ['data', ''],
+            ['nickname', ''],
+            ['type', ''],
+            ['page', 1],
+            ['limit', 20],
+        ]);
+        return JsonService::successlayui(UserModel::getStairList($where));
+    }
+
+    public function get_stair_badge()
+    {
+        $where = Util::getMore([
+            ['uid', ''],
+            ['data', ''],
+            ['nickname', ''],
+            ['type', ''],
+        ]);
+        return JsonService::successful(UserModel::getSairBadge($where));
+    }
+
+    /**
+     * 二级推荐人页面
+     * @return mixed
+     */
+    public function stair_two($uid = '')
+    {
+        if ($uid == '') return $this->failed('参数错误');
+        $spread_uid = User::where('spread_uid', $uid)->column('uid', 'uid');
+        if (count($spread_uid))
+            $spread_uid_two = User::where('spread_uid', 'in', $spread_uid)->column('uid', 'uid');
+        else
+            $spread_uid_two = [0];
+        $list = User::alias('u')
+            ->where('u.uid', 'in', $spread_uid_two)
+            ->field('u.avatar,u.nickname,u.now_money,u.spread_time,u.uid')
+            ->where('u.status', 1)
+            ->order('u.add_time DESC')
+            ->select()
+            ->toArray();
+        foreach ($list as $key => $value) $list[$key]['orderCount'] = StoreOrder::getOrderCount($value['uid']) ?: 0;
+        $this->assign('list', $list);
+        return $this->fetch('stair');
+    }
+
+    /*
+     * 批量清除推广权限
+     * */
+    public function delete_promoter()
+    {
+        list($uids) = Util::postMore([
+            ['uids', []]
+        ], $this->request, true);
+        if (!count($uids)) return JsonService::fail('请选择需要解除推广权限的用户!');
+        User::beginTrans();
+        try {
+            if (User::where('uid', 'in', $uids)->update(['is_promoter' => 0])) {
+                User::commitTrans();
+                return JsonService::successful('解除成功');
+            } else {
+                User::rollbackTrans();
+                return JsonService::fail('解除失败');
+            }
+        } catch (\PDOException $e) {
+            User::rollbackTrans();
+            return JsonService::fail('数据库操作错误', ['line' => $e->getLine(), 'message' => $e->getMessage()]);
+        } catch (\Exception $e) {
+            User::rollbackTrans();
+            return JsonService::fail('系统错误', ['line' => $e->getLine(), 'message' => $e->getMessage()]);
+        }
+
+    }
+
+    /*
+     * 查看公众号推广二维码
+     * @param int $uid
+     * @return json
+     * */
+    public function look_code($uid = '', $action = '')
+    {
+        if (!$uid || !$action) return JsonService::fail('缺少参数');
+        try {
+            if (method_exists($this, $action)) {
+                $res = $this->$action($uid);
+                if ($res)
+                    return JsonService::successful($res);
+                else
+                    return JsonService::fail(isset($res['msg']) ? $res['msg'] : '获取失败,请稍后再试!');
+            } else
+                return JsonService::fail('暂无此方法');
+        } catch (\Exception $e) {
+            return JsonService::fail('获取推广二维码失败,请检查您的微信配置', ['line' => $e->getLine(), 'messag' => $e->getMessage()]);
+        }
+    }
+
+    /*
+     * 获取小程序二维码
+     * */
+    public function routine_code($uid)
+    {
+        $userInfo = User::getUserInfos($uid);
+        $name = $userInfo['uid'] . '_' . $userInfo['is_promoter'] . '_user.jpg';
+        $imageInfo = SystemAttachment::getInfo($name, 'name');
+        if (!$imageInfo) {
+            $res = RoutineCode::getShareCode($uid, 'spread', '', '');
+            if (!$res) throw new \think\Exception('二维码生成失败');
+            $upload_type = sys_config('upload_type', 1);
+            $upload = new Upload((int)$upload_type, [
+                'accessKey' => sys_config('accessKey'),
+                'secretKey' => sys_config('secretKey'),
+                'uploadUrl' => sys_config('uploadUrl'),
+                'storageName' => sys_config('storage_name'),
+                'storageRegion' => sys_config('storage_region'),
+            ]);
+            $info = $upload->to('routine/spread/code')->validate()->stream($res['res'], $name);
+            if ($info === false) {
+                return $upload->getError();
+            }
+            $imageInfo = $upload->getUploadInfo();
+            $imageInfo['image_type'] = $upload_type;
+            SystemAttachment::attachmentAdd($imageInfo['name'], $imageInfo['size'], $imageInfo['type'], $imageInfo['dir'], $imageInfo['thumb_path'], 1, $imageInfo['image_type'], $imageInfo['time'], 2);
+            RoutineQrcode::setRoutineQrcodeFind($res['id'], ['status' => 1, 'time' => time(), 'qrcode_url' => $imageInfo['dir']]);
+            $urlCode = $imageInfo['dir'];
+        } else $urlCode = $imageInfo['att_dir'];
+        return ['code_src' => $urlCode];
+    }
+
+    /*
+     * 获取公众号二维码
+     * */
+    public function wechant_code($uid)
+    {
+        $qr_code = QrcodeService::getForeverQrcode('spread', $uid);
+        if (isset($qr_code['url']))
+            return ['code_src' => $qr_code['url']];
+        else
+            throw new \think\Exception('获取失败,请稍后再试!');
+    }
+
+    /**
+     * TODO 查看小程序推广二维码
+     * @param string $uid
+     */
+    public function look_xcx_code($uid = '')
+    {
+        if (!strlen(trim($uid))) return JsonService::fail('缺少参数');
+        try {
+            $userInfo = User::getUserInfos($uid);
+            $name = $userInfo['uid'] . '_' . $userInfo['is_promoter'] . '_user.jpg';
+            $imageInfo = SystemAttachment::getInfo($name, 'name');
+            if (!$imageInfo) {
+                $res = RoutineCode::getShareCode($uid, 'spread', '', '');
+                if (!$res) return JsonService::fail('二维码生成失败');
+                $upload_type = sys_config('upload_type', 1);
+                $upload = new Upload((int)$upload_type, [
+                    'accessKey' => sys_config('accessKey'),
+                    'secretKey' => sys_config('secretKey'),
+                    'uploadUrl' => sys_config('uploadUrl'),
+                    'storageName' => sys_config('storage_name'),
+                    'storageRegion' => sys_config('storage_region'),
+                ]);
+                $info = $upload->to('routine/spread/code')->validate()->stream($res['res'], $name);
+                if ($info === false) {
+                    return $upload->getError();
+                }
+                $imageInfo = $upload->getUploadInfo();
+                $imageInfo['image_type'] = $upload_type;
+                SystemAttachment::attachmentAdd($imageInfo['name'], $imageInfo['size'], $imageInfo['type'], $imageInfo['dir'], $imageInfo['thumb_path'], 1, $imageInfo['image_type'], $imageInfo['time'], 2);
+                RoutineQrcode::setRoutineQrcodeFind($res['id'], ['status' => 1, 'time' => time(), 'qrcode_url' => $imageInfo['dir']]);
+                $urlCode = $imageInfo['dir'];
+            } else $urlCode = $imageInfo['att_dir'];
+            return JsonService::successful(['code_src' => $urlCode]);
+        } catch (\Exception $e) {
+            return JsonService::fail('查看推广二维码失败!', ['line' => $e->getLine(), 'meassge' => $e->getMessage()]);
+        }
+    }
+
+    /*
+     * 解除单个用户的推广权限
+     * @param int $uid
+     * */
+    public function delete_spread($uid = 0)
+    {
+        if (!$uid) return JsonService::fail('缺少参数');
+        if (User::where('uid', $uid)->update(['is_promoter' => 0]))
+            return JsonService::successful('解除成功');
+        else
+            return JsonService::fail('解除失败');
+    }
+
+    /*
+     * 清除推广人
+     * */
+    public function empty_spread($uid = 0)
+    {
+        if (!$uid) return JsonService::fail('缺少参数');
+        $res = User::where('uid', $uid)->update(['spread_uid' => 0]);
+        if ($res)
+            return JsonService::successful('清除成功');
+        else
+            return JsonService::fail('清除失败');
+    }
+
+    /**
+     * 个人资金详情页面
+     * @return mixed
+     */
+    public function now_money($uid = '')
+    {
+        if ($uid == '') return $this->failed('参数错误');
+        $list = UserBill::where('uid', $uid)->where('category', 'now_money')
+            ->field('mark,pm,number,add_time')
+            ->where('status', 1)->order('add_time DESC')->select()->toArray();
+        foreach ($list as &$v) {
+            $v['add_time'] = $v['add_time'] ? date('Y-m-d H:i:s', $v['add_time']) : '';
+        }
+        $this->assign('list', $list);
+        return $this->fetch();
+    }
+
+}

+ 224 - 0
app/admin/controller/article/Article.php

@@ -0,0 +1,224 @@
+<?php
+
+namespace app\admin\controller\article;
+
+use app\admin\controller\AuthController;
+use app\admin\model\system\SystemAttachment;
+use crmeb\services\{
+    UtilService as Util, JsonService as Json
+};
+use app\admin\model\article\{
+    ArticleCategory as ArticleCategoryModel, Article as ArticleModel
+};
+
+/**
+ * 图文管理
+ * Class WechatNews
+ * @package app\admin\controller\wechat
+ */
+class Article extends AuthController
+{
+    /**
+     * TODO 显示后台管理员添加的图文
+     * @return mixed
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @throws \think\exception\DbException
+     */
+    public function index()
+    {
+        $where = Util::getMore([
+            ['title', ''],
+            ['cid', $this->request->param('pid', '')],
+        ], $this->request);
+        $this->assign('where', $where);
+        $where['merchant'] = 0;//区分是管理员添加的图文显示  0 还是 商户添加的图文显示  1
+        $tree = sort_list_tier(ArticleCategoryModel::getArticleCategoryList());
+        $this->assign(compact('tree'));
+        $this->assign(ArticleModel::getAll($where));
+        return $this->fetch();
+    }
+
+    /**
+     * TODO 文件添加和修改
+     * @return mixed
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @throws \think\exception\DbException
+     */
+    public function create()
+    {
+        $id = $this->request->param('id');
+        $cid = $this->request->param('cid');
+        $news = [];
+        $all = [];
+        $news['id'] = '';
+        $news['image_input'] = '';
+        $news['title'] = '';
+        $news['author'] = '';
+        $news['is_banner'] = '';
+        $news['is_hot'] = '';
+        $news['content'] = '';
+        $news['synopsis'] = '';
+        $news['url'] = '';
+        $news['cid'] = [];
+        $select = 0;
+        if ($id) {
+            $news = ArticleModel::where('n.id', $id)->alias('n')->field('n.*,c.content')->join('ArticleContent c', 'c.nid=n.id', 'left')->find();
+            if (!$news) return $this->failed('数据不存在!');
+            $news['cid'] = explode(',', $news['cid']);
+            $news['content'] = htmlspecialchars_decode($news['content']);
+        }
+        if ($cid && in_array($cid, ArticleCategoryModel::getArticleCategoryInfo(0, 'id'))) {
+            $all = ArticleCategoryModel::getArticleCategoryInfo($cid);
+            $select = 1;
+        }
+        if (!$select) {
+            $list = ArticleCategoryModel::getTierList();
+            foreach ($list as $menu) {
+                $all[$menu['id']] = $menu['html'] . $menu['title'];
+            }
+        }
+        $this->assign('all', $all);
+        $this->assign('news', $news);
+        $this->assign('cid', $cid);
+        $this->assign('select', $select);
+        return $this->fetch();
+    }
+
+    /**
+     * 上传图文图片
+     * @return \think\response\Json
+     */
+    public function upload_image()
+    {
+        $res = Upload::instance()->setUploadPath('wechat/image/' . date('Ymd'))->image($_POST['file']);
+        if (!is_array($res)) return Json::fail($res);
+        SystemAttachment::attachmentAdd($res['name'], $res['size'], $res['type'], $res['dir'], $res['thumb_path'], 5, $res['image_type'], $res['time']);
+        return Json::successful('上传成功!', ['url' => $res['dir']]);
+    }
+
+    /**
+     * 添加和修改图文
+     */
+    public function add_new()
+    {
+        $data = Util::postMore([
+            ['id', 0],
+            ['cid', []],
+            'title',
+            'author',
+            'image_input',
+            'content',
+            'synopsis',
+            'share_title',
+            'share_synopsis',
+            ['visit', 0],
+            ['sort', 0],
+            'url',
+            ['is_banner', 0],
+            ['is_hot', 0],
+            ['status', 1],]);
+        $data['cid'] = implode(',', $data['cid']);
+        $content = $data['content'];
+        unset($data['content']);
+        if ($data['id']) {
+            $id = $data['id'];
+            unset($data['id']);
+            $res = false;
+            ArticleModel::beginTrans();
+            $res1 = ArticleModel::edit($data, $id, 'id');
+            $res2 = ArticleModel::setContent($id, $content);
+            if ($res1 && $res2) {
+                $res = true;
+            }
+            ArticleModel::checkTrans($res);
+            if ($res)
+                return Json::successful('修改图文成功!', $id);
+            else
+                return Json::fail('修改图文失败,您并没有修改什么!', $id);
+        } else {
+            $data['add_time'] = time();
+            $data['admin_id'] = $this->adminId;
+            $res = false;
+            ArticleModel::beginTrans();
+            $res1 = ArticleModel::create($data);
+            $res2 = false;
+            if ($res1)
+                $res2 = ArticleModel::setContent($res1->id, $content);
+            if ($res1 && $res2) {
+                $res = true;
+            }
+            ArticleModel::checkTrans($res);
+            if ($res)
+                return Json::successful('添加图文成功!', $res1->id);
+            else
+                return Json::successful('添加图文失败!', $res1->id);
+        }
+    }
+
+    /**
+     * 删除图文
+     * @param $id
+     * @return \think\response\Json
+     */
+    public function delete($id)
+    {
+        $res = ArticleModel::del($id);
+        if (!$res)
+            return Json::fail('删除失败,请稍候再试!');
+        else
+            return Json::successful('删除成功!');
+    }
+
+    public function merchantIndex()
+    {
+        $where = Util::getMore([
+            ['title', '']
+        ], $this->request);
+        $this->assign('where', $where);
+        $where['cid'] = input('cid');
+        $where['merchant'] = 1;//区分是管理员添加的图文显示  0 还是 商户添加的图文显示  1
+        $this->assign(ArticleModel::getAll($where));
+        return $this->fetch();
+    }
+
+    /**
+     * 关联文章 id
+     * @param int $id
+     */
+    public function relation($id = 0)
+    {
+        $this->assign('id', $id);
+        return $this->fetch();
+    }
+
+    /**
+     * 保存选择的产品
+     * @param int $id
+     */
+    public function edit_article($id = 0)
+    {
+        if (!$id) return Json::fail('缺少参数');
+        list($product_id) = Util::postMore([
+            ['product_id', 0]
+        ], $this->request, true);
+        if (ArticleModel::edit(['product_id' => $product_id], ['id' => $id]))
+            return Json::successful('保存成功');
+        else
+            return Json::fail('保存失败');
+    }
+
+    /**
+     * 取消绑定的产品id
+     * @param int $id
+     */
+    public function unrelation($id = 0)
+    {
+        if (!$id) return Json::fail('缺少参数');
+        if (ArticleModel::edit(['product_id' => 0], $id))
+            return Json::successful('取消关联成功!');
+        else
+            return Json::fail('取消失败');
+    }
+}

+ 159 - 0
app/admin/controller/article/ArticleCategory.php

@@ -0,0 +1,159 @@
+<?php
+
+namespace app\admin\controller\article;
+
+use think\facade\Route as Url;
+use app\admin\controller\AuthController;
+use app\admin\model\system\SystemAttachment;
+use app\admin\model\article\{ArticleCategory as ArticleCategoryModel,Article as ArticleModel};
+use crmeb\services\{FormBuilder as Form,UtilService as Util,JsonService as Json};
+
+
+/**
+ * 文章分类管理  控制器
+ * */
+class ArticleCategory extends AuthController
+{
+
+    /**
+     * 分类管理
+     * */
+    public function index()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['title', ''],
+        ], $this->request);
+        $this->assign('where', $where);
+        $this->assign(ArticleCategoryModel::systemPage($where));
+        return $this->fetch();
+    }
+
+    /**
+     * 添加分类管理
+     * */
+
+    public function create()
+    {
+        $f = array();
+        $f[] = Form::select('pid', '父级id')->setOptions(function () {
+            $list = ArticleCategoryModel::getTierList();
+            $menus[] = ['value' => 0, 'label' => '顶级分类'];
+            foreach ($list as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['html'] . $menu['title']];
+            }
+            return $menus;
+        })->filterable(1);
+        $f[] = Form::input('title', '分类名称');
+        $f[] = Form::input('intr', '分类简介')->type('textarea');
+        $f[] = Form::frameImageOne('image', '分类图片', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')))->icon('image')->width('100%')->height('500px');
+        $f[] = Form::number('sort', '排序', 0);
+        $f[] = Form::radio('status', '状态', 1)->options([['value' => 1, 'label' => '显示'], ['value' => 0, 'label' => '隐藏']]);
+        $form = Form::make_post_form('添加分类', $f, Url::buildUrl('save'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+
+    }
+
+    /**
+     * s上传图片
+     * */
+    public function upload()
+    {
+        $res = Upload::instance()->setUploadPath('article')->image('file');
+        if (!is_array($res)) return Json::fail($res);
+        SystemAttachment::attachmentAdd($res['name'], $res['size'], $res['type'], $res['dir'], $res['thumb_path'], 5, $res['image_type'], $res['time']);
+        return Json::successful('图片上传成功!', ['name' => $res['name'], 'url' => path_to_url($res['thumb_path'])]);
+    }
+
+    /**
+     * 保存分类管理
+     * */
+    public function save()
+    {
+        $data = Util::postMore([
+            'title',
+            'pid',
+            'intr',
+            ['new_id', []],
+            ['image', []],
+            ['sort', 0],
+            'status',]);
+        if (!$data['title']) return Json::fail('请输入分类名称');
+        if (count($data['image']) != 1) return Json::fail('请选择分类图片,并且只能上传一张');
+        if ($data['sort'] < 0) return Json::fail('排序不能是负数');
+        $data['add_time'] = time();
+        $data['image'] = $data['image'][0];
+        $new_id = $data['new_id'];
+        unset($data['new_id']);
+        $res = ArticleCategoryModel::create($data);
+        if (!ArticleModel::saveBatchCid($res['id'], implode(',', $new_id))) return Json::fail('文章列表添加失败');
+        return Json::successful('添加分类成功!');
+    }
+
+    /**
+     * 修改分类
+     * */
+
+    public function edit($id)
+    {
+        if (!$id) return $this->failed('参数错误');
+        $article = ArticleCategoryModel::get($id)->getData();
+        if (!$article) return Json::fail('数据不存在!');
+        $f = array();
+        $f[] = Form::select('pid', '父级id', (string)$article['pid'])->setOptions(function () {
+            $list = ArticleCategoryModel::getTierList();
+            $menus[] = ['value' => 0, 'label' => '顶级分类'];
+            foreach ($list as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['html'] . $menu['title']];
+            }
+            return $menus;
+        })->filterable(1);
+        $f[] = Form::input('title', '分类名称', $article['title']);
+        $f[] = Form::input('intr', '分类简介', $article['intr'])->type('textarea');
+        $f[] = Form::frameImageOne('image', '分类图片', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')), $article['image'])->icon('image')->width('100%')->height('500px');
+        $f[] = Form::number('sort', '排序', $article['sort']);
+        $f[] = Form::radio('status', '状态', $article['status'])->options([['value' => 1, 'label' => '显示'], ['value' => 0, 'label' => '隐藏']]);
+        $form = Form::make_post_form('编辑分类', $f, Url::buildUrl('update', array('id' => $id)));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+
+    }
+
+
+    public function update($id)
+    {
+        $data = Util::postMore([
+            'pid',
+            'title',
+            'intr',
+//            ['new_id',[]],
+            ['image', []],
+            ['sort', 0],
+            'status',]);
+        if (!$data['title']) return Json::fail('请输入分类名称');
+        if (count($data['image']) != 1) return Json::fail('请选择分类图片,并且只能上传一张');
+        if ($data['sort'] < 0) return Json::fail('排序不能是负数');
+        $data['image'] = $data['image'][0];
+        if (!ArticleCategoryModel::get($id)) return Json::fail('编辑的记录不存在!');
+//        if(!ArticleModel::saveBatchCid($id,implode(',',$data['new_id']))) return Json::fail('文章列表添加失败');
+//        unset($data['new_id']);
+        ArticleCategoryModel::edit($data, $id);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 删除分类
+     * */
+    public function delete($id)
+    {
+        $res = ArticleCategoryModel::delArticleCategory($id);
+        if (!$res)
+            return Json::fail(ArticleCategoryModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+
+
+}
+

+ 196 - 0
app/admin/controller/article/WechatNews.php

@@ -0,0 +1,196 @@
+<?php
+
+namespace app\admin\controller\article;
+
+use app\admin\controller\AuthController;
+use app\admin\model\system\SystemAttachment;
+use app\admin\model\wechat\WechatNews as WechatNewsModel;
+use crmeb\services\{
+    UtilService as Util, JsonService as Json
+};
+use app\admin\model\article\{
+    Article as ArticleModel, ArticleCategory as ArticleCategoryModel
+};
+use crmeb\services\upload\Upload;
+
+/**
+ * 图文管理
+ * Class WechatNews
+ * @package app\admin\controller\wechat
+ */
+class WechatNews extends AuthController
+{
+    /**
+     * 显示后台管理员添加的图文
+     * @return mixed
+     */
+    public function index($cid = 0)
+    {
+        $where = Util::getMore([
+            ['title', '']
+        ], $this->request);
+        if ($cid)
+            $where['cid'] = $cid;
+        else
+            $where['cid'] = '';
+        $this->assign('where', $where);
+        $where['merchant'] = 0;//区分是管理员添加的图文显示  0 还是 商户添加的图文显示  1
+        $this->assign('cid', $cid);
+        $this->assign(ArticleModel::getAll($where));
+        return $this->fetch();
+    }
+
+    /**
+     * 展示页面   添加和删除
+     * @return mixed
+     */
+    public function create()
+    {
+        $id = input('id');
+        $cid = input('cid');
+        $news = array();
+        $news['id'] = '';
+        $news['image_input'] = '';
+        $news['title'] = '';
+        $news['author'] = '';
+        $news['content'] = '';
+        $news['synopsis'] = '';
+        $news['url'] = '';
+        $news['cid'] = array();
+        if ($id) {
+            $news = WechatNewsModel::where('n.id', $id)->alias('n')->field('n.*,c.content')->join('wechat_news_content c', 'c.nid=n.id')->find();
+            if (!$news) return $this->failedNotice('数据不存在!');
+            $news['cid'] = explode(',', $news['cid']);
+        }
+        $all = array();
+        $select = 0;
+        if (!$cid)
+            $cid = '';
+        else {
+            if ($id) {
+                $all = ArticleCategoryModel::where('id', $cid)->where('hidden', '<>', 0)->column('title', 'id');
+                $select = 1;
+            } else {
+                $all = ArticleCategoryModel::where('id', $cid)->column('title', 'id');
+                $select = 1;
+            }
+
+        }
+        if (empty($all)) {
+            $all = ArticleCategoryModel::getField();//新闻分类
+            $select = 0;
+        }
+        $this->assign('all', $all);
+        $this->assign('news', $news);
+        $this->assign('cid', $cid);
+        $this->assign('select', $select);
+        return $this->fetch();
+    }
+
+    /**
+     * 上传图文图片
+     * @return \think\response\Json
+     */
+    public function upload_image()
+    {
+        $uploadType = (int)sys_config('upload_type', 1);
+        $upload = new Upload($uploadType, [
+            'accessKey' => sys_config('accessKey'),
+            'secretKey' => sys_config('secretKey'),
+            'uploadUrl' => sys_config('uploadUrl'),
+            'storageName' => sys_config('storage_name'),
+            'storageRegion' => sys_config('storage_region'),
+        ]);
+        $resInfo = $upload->to('wechat/image/' . date('Ymd'))->validate()->move($this->request->post('file'));
+        if ($resInfo === false) {
+            return Json::fail($upload->getError());
+        }
+        $res = $upload->getUploadInfo();
+        $res['image_type'] = $uploadType;
+        SystemAttachment::attachmentAdd($res['name'], $res['size'], $res['type'], $res['dir'], $res['thumb_path'], 5, $res['image_type'], $res['time']);
+        return Json::successful('上传成功!', ['url' => $res['thumb_path']]);
+    }
+
+    /**
+     * 添加和修改图文
+     */
+    public function add_new()
+    {
+        $data = Util::postMore([
+            ['id', 0],
+            ['cid', []],
+            'title',
+            'author',
+            'image_input',
+            'content',
+            'synopsis',
+            'share_title',
+            'share_synopsis',
+            ['visit', 0],
+            ['sort', 0],
+            'url',
+            ['status', 1],]);
+        $data['cid'] = implode(',', $data['cid']);
+        $content = $data['content'];
+        unset($data['content']);
+        if ($data['id']) {
+            $id = $data['id'];
+            unset($data['id']);
+            ArticleModel::beginTrans();
+            $res1 = ArticleModel::edit($data, $id, 'id');
+            $res2 = ArticleModel::setContent($id, $content);
+            if ($res1 && $res2)
+                $res = true;
+            else
+                $res = false;
+            ArticleModel::checkTrans($res);
+            if ($res)
+                return Json::successful('修改图文成功!', $id);
+            else
+                return Json::fail('修改图文失败!', $id);
+        } else {
+            $data['add_time'] = time();
+            $data['admin_id'] = $this->adminId;
+            ArticleModel::beginTrans();
+            $res1 = ArticleModel::create($data);
+            $res2 = false;
+            if ($res1)
+                $res2 = ArticleModel::setContent($res1->id, $content);
+            if ($res1 && $res2)
+                $res = true;
+            else
+                $res = false;
+            ArticleModel::checkTrans($res);
+            if ($res)
+                return Json::successful('添加图文成功!', $res1->id);
+            else
+                return Json::successful('添加图文失败!', $res1->id);
+        }
+    }
+
+    /**
+     * 删除图文
+     * @param $id
+     * @return \think\response\Json
+     */
+    public function delete($id)
+    {
+        $res = ArticleModel::del($id);
+        if (!$res)
+            return Json::fail('删除失败,请稍候再试!');
+        else
+            return Json::successful('删除成功!');
+    }
+
+    public function merchantIndex()
+    {
+        $where = Util::getMore([
+            ['title', '']
+        ], $this->request);
+        $this->assign('where', $where);
+        $where['cid'] = input('cid');
+        $where['merchant'] = 1;//区分是管理员添加的图文显示  0 还是 商户添加的图文显示  1
+        $this->assign(ArticleModel::getAll($where));
+        return $this->fetch();
+    }
+}

+ 524 - 0
app/admin/controller/auction/Auction.php

@@ -0,0 +1,524 @@
+<?php
+namespace app\admin\controller\auction;
+
+use app\admin\controller\AuthController;
+use app\admin\controller\Union;
+use app\admin\model\auction\AuctionGu;
+use app\admin\model\auction\AuctionProduct as model;
+use app\admin\model\store\StoreProductAttrResult;
+use app\admin\model\store\StoreProductAttrValue;
+use app\admin\model\User;
+use app\models\store\StoreProduct;
+use app\models\store\StoreProductAttr;
+use crmeb\services\{ExpressService,
+    JsonService,
+    JsonService as Json,
+    MiniProgramService,
+    upload\Upload,
+    WechatService,
+    FormBuilder as Form,
+    CacheService,
+    UtilService as Util};
+use app\admin\model\system\{
+    SystemAttachment as SystemAttachmentModel, SystemAttachmentCategory as Category
+};
+use think\facade\Route as Url;
+use think\facade\Validate;
+
+/**
+ * 竞拍管理
+ * Class StoreOrder
+ * @package app\admin\controller\store
+ */
+class Auction extends AuthController
+{
+
+
+    public function index()
+    {
+        $list = AuctionGu::select();
+
+        $this->assign('admin', $this->adminInfo);
+        $this->assign('list', $list);
+        return $this->fetch();
+    }
+
+
+    public function list()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['page', 1],
+            ['limit', 20],
+            ['auction'],
+            ['auction_id'],
+            ['uid']
+        ]);
+        if ($this->adminInfo['roles'] == 8){
+            if ($this->adminInfo['uid']){
+                $where['uid'] = $this->adminInfo['uid'];
+            }
+        }
+        $data = \app\admin\model\auction\Auction::list($where);
+
+        return Json::successlayui($data);
+    }
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return \think\Response
+     */
+    public function create($id = 0)
+    {
+        $f = [];
+        $f[] = Form::input('nickname', '场次名称')->col(12);
+        $f[] = Form::input('anticipate', '预约价格')->col(12);
+        $f[] = Form::frameImageOne('image', '场次主图片(305*305px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')))->icon('image')->width('100%')->height('500px');
+        $f[] = Form::radio('status', '状态', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        $f[] = Form::select('auction_gu_id', '绑定场馆')->setOptions(function () {
+            $model = new AuctionGu();
+            $list = $model->select();
+            $menus = [];
+            foreach ($list as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['name']];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::dateTimes('add_time', '预约开始时间');
+        $f[] = Form::dateTimes('end_time', '预约结束时间');
+        $f[] = Form::dateTimes('radd_time', '入场时间');
+        $f[] = Form::dateTimes('rend_time', '结束时间');
+        $f[] = Form::input('sort', '排序', '0');
+        $f[] = Form::input('sort', '排序', '0')->col(12);
+        $f[] = Form::input('goods_time', '放货时间(分钟)', '0')->col(12);
+        $f[] =  Form::checkbox('site', '开场日期', [1,3,5])->options([
+            ['value' => 1, 'label' => '周一'],
+            ['value' => 2, 'label' => '周二'],
+            ['value' => 3, 'label' => '周三'],
+            ['value' => 4, 'label' => '周四'],
+            ['value' => 5, 'label' => '周五'],
+            ['value' => 6, 'label' => '周六'],
+            ['value' => 7, 'label' => '周七'],
+        ]);
+
+        $form = Form::make_post_form('添加', $f, Url::buildUrl('save'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+
+//        $data = [];
+//        $model = new AuctionGu();
+//        $auction = $model->select();
+//        if ($id > 0) $data = \app\admin\model\auction\Auction::find($id)->toArray();
+//
+//        $this->assign(['id' => $id, 'dataList' => $data, 'auction' => $auction]);
+//        return $this->fetch();
+    }
+
+
+    public function save()
+    {
+        $mode  = new \app\admin\model\auction\Auction();
+        $data = Util::postMore([
+            'nickname',
+            'image',
+            'status',
+            'sort',
+            'add_time',
+            'end_time',
+            'radd_time',
+            'rend_time',
+            'info',
+            'anticipate',
+            'auction_gu_id',
+            'site',
+            'goods_time'
+        ]);
+        $validate = Validate::rule('nickname', 'require')->rule([
+            'nickname' => 'require',
+            'image' => 'require',
+            'status' => 'require',
+            'anticipate' => 'require',
+            'add_time' => 'require',
+            'end_time' => 'require',
+            'radd_time' => 'require',
+            'rend_time' => 'require',
+            'auction_gu_id' => 'require',
+            'site' => 'require',
+            'goods_time' => 'require|integer|>:0'
+        ]);
+        $validate->message([
+            'nickname.require' => '名称不能为空',
+            'image.require' => '图片不能为空',
+            'status.require' => '状态不能为空',
+            'anticipate.require' => '请填写预约价格',
+            'add_time.require' => '请选择预约开始时间价格',
+            'end_time.require' => '请选择预约结束时间价格',
+            'radd_time.require' => '请选择进场时间',
+            'rend_time.require' => '请选择结束时间',
+            'auction_gu_id.require' => '请选择绑定场馆',
+            'site.require' => '请选择开场日期',
+            'goods_time.require' => '请输入放货时间',
+            'goods_time.integer' => '放货时间为整数',
+            'goods_time.gt' => '放货时间大于0',
+
+        ]);
+
+        $data['site'] = implode($data['site'], ',');
+        if ($data['site'] == '1,3,5'  or  $data['site'] == '2,4,6') {
+            if (!$validate->check($data)) {
+                return Json::fail($validate->getError());
+            }
+            $res = $mode->save($data);
+            if ($res){
+                return Json::success('添加成功!');
+            }else{
+                return Json::fail('添加失败');
+            }
+        }else{
+            return Json::fail('请选择正确的日期,1,3,5 或者 2,4,6');
+        }
+
+
+    }
+
+    /**
+     * 删除
+     * @param $id
+     * @return void
+     * @throws \Exception
+     */
+    public function delete($id)
+    {
+        if (!$id) Json::fail('删除失败');
+        $model = new \app\admin\model\auction\Auction();
+
+        $res = $model->where('id', $id)->delete();
+        if ($res){
+            return Json::success('删除成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+
+    }
+
+
+    public function set_status($id, $status)
+    {
+
+        if (empty($id))return Json::fail('修改失败');
+
+        $res = \app\admin\model\auction\Auction::update(['status' => $status, 'id' => $id]);
+        if ($res){
+            return Json::success('修改成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+    }
+
+    public function edit($id)
+    {
+        if (!$id) Json::fail('数据不存在');
+        $data = \app\admin\model\auction\Auction::find($id);
+        $f = [];
+        $f[] = Form::input('nickname', '场次名称', $data->getData('nickname'))->col(12);
+        $f[] = Form::input('anticipate', '预约价格', $data->getData('anticipate'))->col(12);
+        $f[] = Form::frameImageOne('image', '场次主图片(305*305px)',Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')), $data->getData('image'))->icon('image')->width('100%')->height('500px');
+        $f[] = Form::radio('status', '状态',  $data->getData('status'))->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        if ($this->adminInfo['roles'] == 1){
+            $f[] = Form::select('auction_gu_id', '绑定场馆', (string)$data->getData('auction_gu_id'))->setOptions(function () {
+                $model = new AuctionGu();
+                $list = $model->select();
+                $menus = [];
+                foreach ($list as $menu) {
+                    $menus[] = ['value' => $menu['id'], 'label' => $menu['name']];
+                }
+                return $menus;
+            })->filterable(1)->col(12);
+        }else{
+            $f[] = Form::hidden('auction_gu_id', $data->getData('auction_gu_id'));
+        }
+
+
+        $f[] = Form::dateTimes('add_time', '预约开始时间', $data->getData('add_time'));
+        $f[] = Form::dateTimes('end_time', '预约结束时间', $data->getData('end_time'));
+        $f[] = Form::dateTimes('radd_time', '入场时间', $data->getData('radd_time'));
+        $f[] = Form::dateTimes('rend_time', '结束时间', $data->getData('rend_time'));
+        $f[] = Form::input('sort', '排序', $data->getData('sort'))->col(12);
+        $f[] = Form::input('goods_time', '放货时间(分钟)', $data->getData('goods_time'))->col(12);
+
+        $f[] =  Form::checkbox('site', '开场日期', explode(',', $data->getData('site')))->options([
+            ['value' => 1, 'label' => '周一'],
+            ['value' => 2, 'label' => '周二'],
+            ['value' => 3, 'label' => '周三'],
+            ['value' => 4, 'label' => '周四'],
+            ['value' => 5, 'label' => '周五'],
+            ['value' => 6, 'label' => '周六'],
+            ['value' => 7, 'label' => '周七'],
+        ]);
+        $form = Form::make_post_form('修改', $f, Url::buildUrl('update', compact('id')));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+
+    public function get_auction($id)
+    {
+        if (!$id) Json::fail('数据不存在');
+        $model = new \app\admin\model\auction\Auction();
+        $info = $model->find($id);
+
+        $data['productInfo'] = $info;
+        return JsonService::successful($data);
+    }
+
+    public function update()
+    {
+        $data = Util::postMore([
+            'id',
+            'nickname',
+            'image',
+            'status',
+            'sort',
+            'add_time',
+            'end_time',
+            'radd_time',
+            'rend_time',
+            'info',
+            'anticipate',
+            'auction_gu_id',
+            'site',
+            'goods_time'
+        ]);
+        $validate = Validate::rule('nickname', 'require')->rule([
+            'nickname' => 'require',
+            'image' => 'require',
+            'status' => 'require',
+            'anticipate' => 'require',
+            'add_time' => 'require',
+            'end_time' => 'require',
+            'radd_time' => 'require',
+            'rend_time' => 'require',
+            'auction_gu_id' => 'require',
+            'site' => 'require',
+            'goods_time' => 'require|integer|>:0'
+
+        ]);
+        $validate->message([
+            'nickname.require' => '名称不能为空',
+            'image.require' => '图片不能为空',
+            'status.require' => '状态不能为空',
+            'anticipate.require' => '请填写预约价格',
+            'add_time.require' => '请选择预约开始时间价格',
+            'end_time.require' => '请选择预约结束时间价格',
+            'radd_time.require' => '请选择进场时间',
+            'rend_time.require' => '请选择结束时间',
+            'auction_gu_id.require' => '请选择绑定场馆',
+            'site.require' => '请选择开场日期',
+            'goods_time.require' => '请输入放货时间',
+            'goods_time.integer' => '时间为整数',
+            'goods_time.gt' => '放货时间大于0',
+        ]);
+        $data['site'] = implode($data['site'], ',');
+        if ($data['site'] == '1,3,5'  or  $data['site'] == '2,4,6') {
+            if (!$validate->check($data)) {
+                return Json::fail($validate->getError());
+            }
+
+            $res = \app\admin\model\auction\Auction::update($data);
+            if ($res){
+                return Json::success('修改成功!');
+            }else{
+                return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+            }
+        }else{
+            return Json::fail('请选择正确的日期,1,3,5 或者 2,4,6');
+        }
+
+
+
+    }
+    /**
+     * 商品列表
+     * @param $id
+     * @return void
+     */
+    public function product($id)
+    {
+        $list = \app\admin\model\auction\Auction::select();
+        $this->assign([
+            'auction'=> $list,
+            'id' => $id
+
+        ]);
+        $this->assign('admin', $this->adminInfo);
+
+        return $this->fetch('');
+
+
+    }
+
+    /**
+     * 商品
+     * @param $id
+     * @return void
+     */
+    public function product_list($id)
+    {
+        $where = Util::getMore([
+            ['is_show', ''],
+            ['page', 1],
+            ['limit', 20],
+            ['store_name', ''],
+            ['auction_id'],
+            ['is_show']
+        ]);
+        $data = model::list($where, $id);
+
+        foreach ($data['data'] as $key => $val){
+            if ($data['data'][$key]['uid'] == 0) $data['data'][$key]['nickname'] = '管理';
+        }
+
+
+        return Json::successlayui($data);
+    }
+
+    /**
+     * 商品添加
+     * @param $id
+     * @return string
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function product_edit($id, $auction_id)
+    {
+        if (!$id) Json::fail('数据不存在');
+
+        $this->assign(['id' => $id, 'auction_id' => $auction_id]);
+        return $this->fetch();
+    }
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return \think\Response
+     */
+    public function product_create($id = 0)
+    {
+
+        $this->assign(['id' => $id]);
+        return $this->fetch();
+    }
+
+    public function fz($id, $auction_id)
+    {
+        if (!$id) Json::fail('数据不存在');
+
+        $this->assign(['id' => $id, 'auction_id' => $auction_id]);
+        return $this->fetch();
+    }
+
+
+
+    public function product_save($id)
+    {
+        $data = Util::postMore([
+            'name',
+            'is_show',
+            'image',
+            'price',
+            'deduct',
+            'rise',
+            'info',
+            'sort',
+            'auction_id',
+            'hanging_price',
+            'slider_image',
+            'description',
+            'fictitious_price',
+            'give'
+        ]);
+        $data['slider_image'] = json_encode($data['slider_image']);
+        $data['description'] = htmlspecialchars($data['description']);
+        $auction = \app\admin\model\auction\Auction::where('id' ,$data['auction_id'])->find();
+        $auction_gu = \app\admin\model\auction\AuctionGu::where('id' ,$auction['auction_gu_id'])->find();
+        $data['uid'] = $auction_gu['uid'];
+        $model = new model();
+        $res = $model->save($data);
+        if ($res){
+            return Json::success('添加成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+
+    }
+
+    /**
+     * 商品修改
+     * @param $id
+     * @return void
+     */
+    public function product_update($id)
+    {
+        $data = Util::postMore([
+            'id',
+            'name',
+            'image',
+            'price',
+            'deduct',
+            'rise',
+            'info',
+            'sort',
+            'auction_id',
+            'hanging_price',
+            'slider_image',
+            'description',
+            'fictitious_price',
+            'give'
+        ]);
+        $data['slider_image'] = json_encode($data['slider_image']);
+        $data['description'] = htmlspecialchars($data['description']);
+        $res = model::update($data);
+        if ($res){
+            return Json::success('修改成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+
+
+    }
+
+    public function fzsp($id)
+    {
+        $data = Util::postMore([
+            'name',
+            'image',
+            'price',
+            'deduct',
+            'rise',
+            'info',
+            'sort',
+            'auction_id',
+            'hanging_price',
+            'slider_image',
+            'description',
+            'give',
+            'fictitious_price'
+        ]);
+        $data['slider_image'] = json_encode($data['slider_image']);
+        $data['description'] = htmlspecialchars($data['description']);
+        $auction = \app\admin\model\auction\Auction::where('id' ,$data['auction_id'])->find();
+        $auction_gu = \app\admin\model\auction\AuctionGu::where('id' ,$auction['auction_gu_id'])->find();
+        $data['uid'] = $auction_gu['uid'];
+        $res = model::create($data);
+        if ($res){
+            return Json::success('修改成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+
+
+    }
+
+}

+ 84 - 0
app/admin/controller/auction/AuctionApply.php

@@ -0,0 +1,84 @@
+<?php
+namespace app\admin\controller\auction;
+
+use app\admin\controller\AuthController;
+use app\admin\controller\Union;
+use app\admin\model\auction\AuctionGu;
+use app\admin\model\User;
+use crmeb\services\{ExpressService,
+    JsonService,
+    MiniProgramService,
+    upload\Upload,
+    WechatService,
+    FormBuilder as Form,
+    CacheService,
+    UtilService as Util,
+    JsonService as Json};
+use app\admin\model\system\{
+    SystemAttachment as SystemAttachmentModel, SystemAttachmentCategory as Category
+};
+use think\facade\Route as Url;
+use think\facade\Validate;
+
+/**
+ * 竞拍管理
+ * Class StoreOrder
+ * @package app\admin\controller\store
+ */
+class AuctionApply extends AuthController
+{
+
+
+    public function index()
+    {
+
+
+        return $this->fetch();
+    }
+
+
+    public function list()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['page', 1],
+            ['limit', 20],
+            ['auction']
+        ]);
+        $data = \app\admin\model\auction\AuctionApply::list($where);
+
+        return Json::successlayui($data);
+    }
+
+
+    public function tg($id)
+    {
+        if (empty($id)) return Json::fail('失败');
+
+        $data = \app\admin\model\auction\AuctionApply::where('id', '<>',1)->find($id);
+        if (!$data){
+            return Json::fail('当前状态无法修改');
+        }
+        $res = \app\admin\model\auction\AuctionApply::update(['status' => 2, 'id' => $id]);
+        if ($res){
+            return Json::success('成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+    }
+    public function jj($id)
+    {
+
+        if (empty($id)) Json::fail('失败');
+        $data = \app\admin\model\auction\AuctionApply::where('id', '<>',1)->find($id);
+        if (!$data){
+            return Json::fail('当前状态无法修改');
+        }
+        $res = \app\admin\model\auction\AuctionApply::update(['status' => 0, 'id' => $id]);
+        if ($res){
+            return Json::success('成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+    }
+}

+ 259 - 0
app/admin/controller/auction/AuctionBooking.php

@@ -0,0 +1,259 @@
+<?php
+namespace app\admin\controller\auction;
+
+use app\admin\controller\AuthController;
+use app\admin\controller\Union;
+use app\admin\model\user\User;
+use app\admin\model\user\UserBill;
+use crmeb\services\{ExpressService,
+    JsonService,
+    MiniProgramService,
+    upload\Upload,
+    WechatService,
+    FormBuilder as Form,
+    CacheService,
+    UtilService as Util,
+    JsonService as Json};
+use app\admin\model\system\{
+    SystemAttachment as SystemAttachmentModel, SystemAttachmentCategory as Category
+};
+use app\admin\model\auction\AuctionBooking as model;
+use think\facade\Route as Url;
+
+/**
+ * 竞拍管理
+ * Class StoreOrder
+ * @package app\admin\controller\store
+ */
+class AuctionBooking extends AuthController
+{
+
+    public function index()
+    {
+
+        $list = \app\admin\model\auction\Auction::select();
+
+        $this->assign([
+            'year' => get_month(),
+            'auction'=> $list
+
+        ]);
+        return $this->fetch();
+    }
+
+
+    /**
+     * 获取列表
+     * @return void
+     */
+    public function list()
+    {
+        $where = Util::getMore([
+            ['is_show', ''],
+            ['page', 1],
+            ['limit', 20],
+            ['auction_id', ''],
+            ['store_name', ''],
+            ['data', '']
+        ]);
+        $data = model::list($where);
+        foreach ($data['data'] as $key => $val){
+            if ($data['data'][$key]['uid'] == 0) $data['data'][$key]['nickname'] = '管理';
+        }
+
+
+        return Json::successlayui($data);
+    }
+
+    public function auction_list()
+    {
+        $list = model::select()->toArray();
+
+        Json::successful($list);
+    }
+
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return \think\Response
+     */
+    public function create($id = 0)
+    {
+        $data = \app\admin\model\auction\Auction::select()->toArray();
+
+        $this->assign(['id' => $id, 'list' => $data]);
+        return $this->fetch();
+    }
+
+
+    /**
+     * 添加
+     * @param $id
+     * @return void
+     */
+    public function save($id)
+    {
+        $data = Util::postMore([
+            'name',
+            'is_show',
+            'image',
+            'price',
+            'deduct',
+            'rise',
+            'info',
+            'sort',
+            'auction_id'
+        ]);
+        $model = new model();
+        $res = $model->save($data);
+        if ($res){
+            return Json::success('添加成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+
+    }
+
+    /**
+     * 删除
+     * @param $id
+     * @return void
+     * @throws \Exception
+     */
+    public function delete($id)
+    {
+        if (!$id) Json::fail('删除失败');
+
+        $res = model::where('id', $id)->delete();
+        if ($res){
+            return Json::success('删除成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+
+    }
+
+
+    /**
+     * 修改状态
+     * @param $id
+     * @param $status
+     * @return void
+     */
+    public function set_status($id, $status)
+    {
+
+        if (empty($id)) Json::fail('修改失败');
+
+        $res = model::update(['is_show' => $status, 'id' => $id]);
+        if ($res){
+            return Json::success('修改成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+    }
+
+    /**
+     * 编辑页面
+     * @param $id
+     * @return string
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function edit($id)
+    {
+        if (!$id) Json::fail('数据不存在');
+        $data = \app\admin\model\auction\Auction::select()->toArray();
+
+        $this->assign(['id' => $id, 'list' => $data]);
+        return $this->fetch();
+    }
+
+
+    public function get_list($id)
+    {
+        if (!$id) Json::fail('数据不存在');
+        $model = new model();
+        $info = $model->find($id);
+
+        return JsonService::successful($info);
+    }
+
+    /**
+     * 修改
+     * @param $id
+     * @return void
+     */
+    public function update($id)
+    {
+        $data = Util::postMore([
+            'id',
+            'name',
+            'is_show',
+            'image',
+            'price',
+            'deduct',
+            'rise',
+            'info',
+            'sort',
+            'auction_id'
+        ]);
+        $res = model::update($data);
+        if ($res){
+            return Json::success('修改成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+
+
+    }
+
+
+    /**
+     * 退回预约卷
+     * @param $id
+     * @return void
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function th($id)
+    {
+        if (!$id) Json::fail('没有数据');
+        $data = model::find($id);
+        if ($data['status'] < 1) Json::fail('已退回请勿重复提交');
+
+        $userModel = new User();
+        $user = $userModel->where('uid', $data['uid'])->find();
+        if (!$user) Json::fail('没有数据');
+
+        $user['anticipate'] = $user['anticipate']+ $data['anticipate'];
+        $bill = UserBill::create([
+            'uid' => $user['uid'],
+            'pm' => 1,
+            'title' => '预约卷退回',
+            'category' => 'anticipate',
+            'type' => 'add_anticipate',
+            'number' => $data['anticipate'],
+            'balance' => $user['anticipate'],
+            'mark' => '后台操作退回',
+            'add_time' => time(),
+        ]);
+
+        if ($bill){
+            $res = $user->save();
+            model::where('id', $id)->update(['status' => 0]);
+            if ($res){
+                Json::successful('退回成功');
+            }else{
+                Json::fail('退回失败');
+            }
+
+        }else{
+            Json::fail('错误');
+        }
+    }
+
+}

+ 282 - 0
app/admin/controller/auction/AuctionGu.php

@@ -0,0 +1,282 @@
+<?php
+namespace app\admin\controller\auction;
+
+use app\admin\controller\AuthController;
+use app\admin\controller\Union;
+use app\admin\model\User;
+use crmeb\services\{ExpressService,
+    FormBuilder,
+    JsonService,
+    MiniProgramService,
+    upload\Upload,
+    WechatService,
+    FormBuilder as Form,
+    CacheService,
+    UtilService as Util,
+    JsonService as Json};
+use app\admin\model\system\{SystemAdmin,
+    SystemAttachment as SystemAttachmentModel,
+    SystemAttachmentCategory as Category};
+use think\Db;
+use think\facade\Route as Url;
+use think\facade\Validate;
+
+/**
+ * 竞拍管理
+ * Class StoreOrder
+ * @package app\admin\controller\store
+ */
+class AuctionGu extends AuthController
+{
+
+
+    public function index()
+    {
+
+        $this->assign('admin', $this->adminInfo);
+        return $this->fetch();
+    }
+
+
+    public function list()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['page', 1],
+            ['limit', 20],
+            ['auction'],
+            ['uid'],
+            ['null']
+        ]);
+        if ($this->adminInfo['roles'] == 8){
+            if ($this->adminInfo['uid']){
+                $where['uid'] = $this->adminInfo['uid'];
+            }
+        }
+
+        $data = \app\admin\model\auction\AuctionGu::list($where);
+        return Json::successlayui($data);
+    }
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return \think\Response
+     */
+    public function create($id = 0)
+    {
+        $f = [];
+        $f[] = Form::input('name', '场馆名称')->col(12);
+        $f[] = Form::input('max_hanging', '最大挂售额度')->col(12);
+        $f[] = Form::frameImageOne('image', '主图片(305*305px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')))->icon('image')->width('100%')->height('500px');
+        $f[] = Form::frameImages('slider_image', '轮播图(640*640px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'slider_image')))->maxLength(3)->icon('images')->width('100%')->height('500px');
+        $f[] = Form::radio('status', '状态', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]]);
+        $f[] = Form::select('uid', '绑定用户')->setOptions(function () {
+            $model = new \app\models\user\User();
+            $list = $model->select();
+            $menus = [];
+            foreach ($list as $menu) {
+                $menus[] = ['value' => $menu['uid'], 'label' => $menu['nickname']];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::input('sort', '排序', '0')->col(12);
+        $f[] = Form::textarea('info', '介绍');
+
+        $form = Form::make_post_form('添加', $f, Url::buildUrl('save'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+
+    public function save()
+    {
+        $mode  = new \app\admin\model\auction\AuctionGu();
+        $data = Util::postMore([
+            'name',
+            'image',
+            'sort',
+            'info',
+            'uid',
+            'slider_image',
+            'max_hanging'
+        ]);
+        $validate = Validate::rule('name', 'require')->rule([
+            'name' => 'require',
+            'image' => 'require',
+            'uid' => 'require',
+            'slider_image' => 'require',
+            'max_hanging' => 'require'
+        ]);
+        $validate->message([
+            'name.require' => '名称不能为空',
+            'image.require' => '图片不能为空',
+            'uid.require' => '请绑定用户',
+            'slider_image.require' => '轮播图不能为空',
+            'max_hanging.require' => '挂售额度不能为空',
+        ]);
+        $data['slider_image'] = json_encode($data['slider_image']);
+        if (!$validate->check($data)) {
+            return Json::fail($validate->getError());
+        }
+        $user = \app\models\user\User::where('uid', $data['uid'])->find();
+        if ($user['spread_uid']){
+            $user['spread_uid'] = 0; // 更新用户上级
+            $user->save();
+        }
+        $res = $mode->save($data);
+        if ($res){
+            return Json::success('添加成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+
+    }
+
+    /**
+     * 删除
+     * @param $id
+     * @return void
+     * @throws \Exception
+     */
+    public function delete($id)
+    {
+        if (!$id) Json::fail('删除失败');
+        $model = new \app\admin\model\auction\AuctionGu();
+
+        $res = $model->where('id', $id)->delete();
+        if ($res){
+            return Json::success('删除成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+
+    }
+
+
+    public function set_status($id, $status)
+    {
+
+        if (empty($id))return Json::fail('修改失败');
+
+        $res = \app\admin\model\auction\AuctionGu::update(['status' => $status, 'id' => $id]);
+        if ($res){
+            return Json::success('修改成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+    }
+
+    public function edit($id)
+    {
+        if (!$id) Json::fail('数据不存在');
+        $data = \app\admin\model\auction\AuctionGu::find($id);
+        $f = [];
+        $f[] = Form::input('name', '场馆名称',$data->getData('name'))->col(12);
+        if ($this->adminInfo['roles'] == 8){
+            $f[] = Form::hidden('max_hanging', $data->getData('max_hanging'))->col(12);
+        }else{
+            $f[] = Form::input('max_hanging', '最大挂售额度',$data->getData('max_hanging'))->col(12);
+        }
+
+        $f[] = Form::frameImageOne('image', '场次主图片(305*305px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')), $data->getData('image'))->icon('image')->width('100%')->height('500px');
+        $f[] = Form::frameImages('slider_image', '商品轮播图(640*640px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'slider_image')), json_decode($data->getData('slider_image'), 1))->maxLength(5)->icon('images')->width('100%')->height('500px');
+        $f[] = Form::radio('status', '状态', $data->getData('status'))->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]]);
+        $f[] = Form::select('uid', '绑定用户',(string)$data->getData('uid'))->setOptions(function () {
+            $model = new \app\models\user\User();
+            $list = $model->select();
+            $menus = [];
+            foreach ($list as $menu) {
+                $menus[] = ['value' => $menu['uid'], 'label' => $menu['nickname']];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::input('sort', '排序' ,$data->getData('sort'))->col(12);
+        $f[] = Form::textarea('info', '介绍',$data->getData('info'));
+
+        $form = Form::make_post_form('修改', $f, Url::buildUrl('update', compact('id')));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+
+    public function get_auction($id)
+    {
+        if (!$id) Json::fail('数据不存在');
+        $info = \app\admin\model\auction\AuctionGu::find($id)->toArray();
+
+        $data['productInfo'] = $info;
+        return JsonService::successful($data);
+    }
+
+    public function update()
+    {
+        $data = Util::postMore([
+            'id',
+            'name',
+            'image',
+            'sort',
+            'info',
+            'uid',
+            'status',
+            'slider_image',
+            'max_hanging'
+        ]);
+
+        $validate = Validate::rule('name', 'require')->rule([
+            'name' => 'require',
+            'image' => 'require',
+            'uid' => 'require',
+            'slider_image' => 'require',
+            'max_hanging' => 'require'
+        ]);
+        $validate->message([
+            'name.require' => '名称不能为空',
+            'image.require' => '图片不能为空',
+            'uid.require' => '请绑定用户',
+            'slider_image.require' => '轮播图不能为空',
+            'max_hanging.require' => '挂售额度不能为空',
+
+        ]);
+        if (!$validate->check($data)) {
+            return Json::fail($validate->getError());
+        }
+        $data['slider_image'] = json_encode($data['slider_image']);
+        $user = \app\models\user\User::where('uid', $data['uid'])->find();
+        if ($user['spread_uid']){
+            $user['spread_uid'] = 0; // 更新用户上级
+            $user->save();
+        }
+
+        $res = \app\admin\model\auction\AuctionGu::update($data);
+        if ($res){
+            return Json::success('修改成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+
+
+    }
+
+
+//    public function edit($id)
+//    {
+//        if (!$id) Json::fail('数据不存在');
+//
+//
+//        $list = \app\admin\model\auction\Auction::get($id);
+//        if (!$list) Json::fail('数据不存在');
+//
+//        $f = array();
+//        $f[] = Form::input('id', 'ID', $list->getData('id'))->disabled(1);
+//        $f[] = Form::input('nickname', '名称', $list->getData('nickname'));
+//        $f[] = Form::uploadImageOne('image', '图片','/index.php/admin/widget.images/upload',$list->getData('image'));
+//        $f[] = Form::radio('is_promoter', '推广员',$list->getData('status'))->options([['value' => 1, 'label' => '启用'], ['value' => 0, 'label' => '禁用']]);
+//        $f[] = Form::dateTime('time', '推广员',$list->getData('add_time'));
+//
+//        $form = Form::make_post_form('添加用户通知', $f, Url::buildUrl('update', array('uid' => $id)), 5);
+//        $this->assign(compact('form'));
+//        return $this->fetch('public/form-builder');
+//    }
+
+}

+ 291 - 0
app/admin/controller/auction/AuctionOrder.php

@@ -0,0 +1,291 @@
+<?php
+namespace app\admin\controller\auction;
+
+use app\admin\controller\AuthController;
+use app\admin\controller\Union;
+use app\admin\model\user\User;
+use app\admin\model\user\UserBill;
+use crmeb\services\{ExpressService,
+    JsonService,
+    MiniProgramService,
+    upload\Upload,
+    WechatService,
+    FormBuilder as Form,
+    CacheService,
+    UtilService as Util,
+    JsonService as Json};
+use app\admin\model\system\{
+    SystemAttachment as SystemAttachmentModel, SystemAttachmentCategory as Category
+};
+use app\admin\model\auction\AuctionOrder as model;
+use think\facade\Route as Url;
+
+/**
+ * 竞拍管理
+ * Class StoreOrder
+ * @package app\admin\controller\store
+ */
+class AuctionOrder extends AuthController
+{
+
+    public function index()
+    {
+
+        $list = \app\admin\model\auction\Auction::select();
+        $gu = \app\admin\model\auction\AuctionGu::select();
+        $this->assign([
+            'year' => get_month(),
+            'auction'=> $list,
+            'gu' => $gu
+
+        ]);
+        return $this->fetch();
+    }
+
+
+    /**
+     * 获取列表
+     * @return void
+     */
+    public function list()
+    {
+        $where = Util::getMore([
+            ['is_show', ''],
+            ['page', 1],
+            ['limit', 20],
+            ['auction_id', ''],
+            ['store_name', ''],
+            ['data', ''],
+            ['status', ''],
+            ['gu_id', ''],
+            ['product_name'],
+            ['excel', 0],
+            ['is_gs', ''],
+            ['uid']
+        ]);
+        if ($this->adminInfo['roles'] == 8){
+            if ($this->adminInfo['uid']){
+                $where['uid'] = $this->adminInfo['uid'];
+            }
+        }
+        $data = model::list($where);
+        foreach ($data['data'] as $key => $val){
+            if ($data['data'][$key]['uid'] == 0) $data['data'][$key]['nickname'] = '管理';
+        }
+
+
+        return Json::successlayui($data);
+    }
+
+    public function auction_list()
+    {
+        $list = model::select()->toArray();
+
+        Json::successful($list);
+    }
+
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return \think\Response
+     */
+    public function create($id = 0)
+    {
+        $data = \app\admin\model\auction\Auction::select()->toArray();
+
+        $this->assign(['id' => $id, 'list' => $data]);
+        return $this->fetch();
+    }
+
+
+    /**
+     * 添加
+     * @param $id
+     * @return void
+     */
+    public function save($id)
+    {
+        $data = Util::postMore([
+            'name',
+            'is_show',
+            'image',
+            'price',
+            'deduct',
+            'rise',
+            'info',
+            'sort',
+            'auction_id'
+        ]);
+        $model = new model();
+        $res = $model->save($data);
+        if ($res){
+            return Json::success('添加成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+
+    }
+
+    /**
+     * 删除
+     * @param $id
+     * @return void
+     * @throws \Exception
+     */
+    public function delete($id)
+    {
+        if (!$id) Json::fail('删除失败');
+
+        $res = model::where('id', $id)->delete();
+        if ($res){
+            return Json::success('删除成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+
+    }
+
+
+    /**
+     * 修改状态
+     * @param $id
+     * @param $status
+     * @return void
+     */
+    public function set_status($id, $status)
+    {
+
+        if (empty($id)) Json::fail('修改失败');
+
+        $res = model::update(['is_show' => $status, 'id' => $id]);
+        if ($res){
+            return Json::success('修改成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+    }
+
+    /**
+     * 编辑页面
+     * @param $id
+     * @return string
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function edit($id)
+    {
+        if (!$id) Json::fail('数据不存在');
+        $data = \app\admin\model\auction\Auction::select()->toArray();
+
+        $this->assign(['id' => $id, 'list' => $data]);
+        return $this->fetch();
+    }
+
+
+    public function get_list($id)
+    {
+        if (!$id) Json::fail('数据不存在');
+        $model = new model();
+        $info = $model->find($id);
+
+        return JsonService::successful($info);
+    }
+
+    /**
+     * 修改
+     * @param $id
+     * @return void
+     */
+    public function update($id)
+    {
+        $data = Util::postMore([
+            'id',
+            'name',
+            'is_show',
+            'image',
+            'price',
+            'deduct',
+            'rise',
+            'info',
+            'sort',
+            'auction_id'
+        ]);
+        $res = model::update($data);
+        if ($res){
+            return Json::success('修改成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+
+
+    }
+
+
+    /**
+     * 通过
+     * @param $id
+     * @return void
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function qd($id)
+    {
+        if (!$id) return Json::fail('没有数据');
+        $data = model::find($id);// 订单数据
+
+        if($data['status'] < 3 and $data['status'] > 0){
+
+            \app\admin\model\auction\AuctionProduct::beginTrans();
+
+            $product = \app\admin\model\auction\AuctionProduct::find($data['product_id']);
+            if (!$product)return Json::fail('数据不存在');
+            $uid = $product['uid']; // 所属人id
+
+            $product['uid'] = $data['uid'];// 商品拥有人更新
+            $product['add_time'] = time();
+            $product['order'] = $data['order_id'];
+            $res = $product->save();
+            if ($res){
+                if ($uid > 0){
+                    \app\models\auction\AuctionOrder::earn($uid,$data['price'] ,$product); // 卖家
+                }
+                \app\models\auction\AuctionOrder::return($id); // 买家
+                $data['status'] = 3;
+                $data->save();
+                \app\admin\model\auction\AuctionProduct::commitTrans();
+				// 计算总消费金额
+				$prices=model::where('uid',$data['uid'])->where('status',3)->sum('price');//历史完成订单
+                $sum=floatval($prices+$data['price']);
+                //如果总金额大于等于三万
+                if($sum>=30000){
+                    $user=User::where('uid',$data['uid'])->find();//获取用户信息
+                    if($user['f_integral']==3000){//如果积分依旧冻结
+                        //释放冻结积分
+                        $integral=floatval($user['integral']+3000);
+                        $res=User::where('uid',$data['uid'])->update(['f_integral' =>0,'integral'=>$integral]);
+                        //积分释放流水
+                        $res3=UserBill::income('冻结积分释放',$data['uid'], 'integral', 'release',3000, $id,$integral, '释放3000积分');
+						if(!$res3){
+							return self::setErrorInfo('操作失败');
+				}
+
+                    }
+                }
+
+                return Json::successful('审核通过!');
+            }else{
+
+
+                \app\admin\model\auction\AuctionProduct::rollbackTrans();
+                return Json::successful('审核失败!');
+            }
+
+        }
+        return Json::fail('该订单不能通过');
+
+    }
+
+}

+ 281 - 0
app/admin/controller/auction/AuctionProduct.php

@@ -0,0 +1,281 @@
+<?php
+namespace app\admin\controller\auction;
+
+use app\admin\controller\AuthController;
+use app\admin\controller\Union;
+use app\models\auction\AuctionTime;
+use app\models\user\User;
+use crmeb\services\{ExpressService,
+    JsonService,
+    MiniProgramService,
+    upload\Upload,
+    WechatService,
+    FormBuilder as Form,
+    CacheService,
+    UtilService as Util,
+    JsonService as Json};
+use app\admin\model\system\{
+    SystemAttachment as SystemAttachmentModel, SystemAttachmentCategory as Category
+};
+use app\admin\model\auction\AuctionProduct as model;
+use think\facade\Route as Url;
+
+/**
+ * 竞拍管理
+ * Class StoreOrder
+ * @package app\admin\controller\store
+ */
+class AuctionProduct extends AuthController
+{
+
+    public function index()
+    {
+
+        $list = \app\admin\model\auction\Auction::select();
+
+        $this->assign('auction', $list);
+        return $this->fetch();
+    }
+
+
+    public function list()
+    {
+        $where = Util::getMore([
+            ['is_show', ''],
+            ['page', 1],
+            ['limit', 20],
+            ['auction_id', ''],
+            ['store_name', '']
+        ]);
+        $data = model::list($where);
+        foreach ($data['data'] as $key => $val){
+            if ($data['data'][$key]['uid'] == 0) $data['data'][$key]['nickname'] = '管理';
+        }
+
+
+        return Json::successlayui($data);
+    }
+
+    public function auction_list()
+    {
+        $list = model::select()->toArray();
+
+        Json::successful($list);
+    }
+
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return \think\Response
+     */
+    public function create($id = 0)
+    {
+        $data = \app\admin\model\auction\Auction::select()->toArray();
+
+        $this->assign(['id' => $id, 'list' => $data]);
+        return $this->fetch();
+    }
+
+
+    public function save($id)
+    {
+        $data = Util::postMore([
+            'name',
+            'is_show',
+            'image',
+            'price',
+            'deduct',
+            'rise',
+            'info',
+            'sort',
+            'auction_id',
+            'hanging_price',
+            'slider_image',
+            'description',
+            'give',
+            'fictitious_price'
+        ]);
+        $data['slider_image'] = json_encode($data['slider_image']);
+        $data['description'] = htmlspecialchars($data['description']);
+        $auction = \app\admin\model\auction\Auction::where('id' ,$data['auction_id'])->find();
+        $auction_gu = \app\admin\model\auction\AuctionGu::where('id' ,$auction['auction_gu_id'])->find();
+        $data['uid'] = $auction_gu['uid'];
+        $model = new model();
+        $res = $model->save($data);
+        if ($res){
+            return Json::success('添加成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+
+    }
+
+    /**
+     * 删除
+     * @param $id
+     * @return void
+     * @throws \Exception
+     */
+    public function delete($id)
+    {
+        if (!$id)return Json::fail('删除失败');
+
+        $res = model::where('id', $id)->delete();
+        if ($res){
+            return Json::success('删除成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+
+    }
+
+
+    public function set_status($id, $status)
+    {
+
+        if (empty($id))return Json::fail('修改失败');
+
+        $res = model::update(['is_show' => $status, 'id' => $id]);
+        if ($res){
+            return Json::success('修改成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+    }
+
+    public function edit($id)
+    {
+        if (!$id) Json::fail('数据不存在');
+        $data = \app\admin\model\auction\Auction::select()->toArray();
+
+        $this->assign(['id' => $id, 'list' => $data]);
+        return $this->fetch();
+    }
+
+
+    public function get_list($id)
+    {
+        if (!$id) Json::fail('数据不存在');
+        $model = new model();
+        $info = $model->find($id);
+        $info['slider_image'] = is_string($info['slider_image']) ? json_decode($info['slider_image'], true) : [];
+        $info['description'] = htmlspecialchars_decode($info['description']);
+        $data['productInfo'] = $info;
+        return JsonService::successful($data);
+    }
+
+    public function update($id)
+    {
+        $data = Util::postMore([
+            'id',
+            'name',
+            'image',
+            'price',
+            'deduct',
+            'rise',
+            'info',
+            'sort',
+            'auction_id',
+            'hanging_price',
+            'slider_image',
+            'description',
+            'give',
+            'fictitious_price'
+        ]);
+        $data['slider_image'] = json_encode($data['slider_image']);
+        $data['description'] = htmlspecialchars($data['description']);
+        $res = model::update($data);
+        if ($res){
+            return Json::success('修改成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+
+
+    }
+
+    /**
+     * 修改商品所属人页面
+     * @param $id
+     * @return string
+     * @throws \Exception
+     */
+    public function belonging($id)
+    {
+        $f = [];
+        $f[] = Form::input('account', '输入用户账号或者ID' );
+        $f[] = Form::hidden('id', $id );
+        $form = Form::make_post_form('修改', $f, Url::buildUrl('belonging_save'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+
+    }
+
+    /**
+     * 修改商品所属人
+     * @param $account
+     * @param $id
+     * @return void
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function belonging_save($account, $id)
+    {
+        if (!$account) return  Json::fail('不能为空');
+        $user = User::where('account|uid', '=', $account)->find();
+        if (!$user) return  Json::fail('用户不存在');
+        $product = \app\admin\model\auction\AuctionProduct::find($id);
+        if ($product['is_admin'] != 1 and $product['is_show'] == 1){
+            AuctionTime::where('product_id', $product['id'])->delete();// 删除上架信息
+        }
+        $product['is_show'] = 0;
+        $product['uid'] = $user['uid'];
+        $res = $product->save();
+        if ($res) return  Json::success('修改成功');
+        return  Json::fail('修改失败');
+    }
+
+
+    public function fz($id)
+    {
+        if (!$id) Json::fail('数据不存在');
+        $data = \app\admin\model\auction\Auction::select()->toArray();
+
+        $this->assign(['id' => $id, 'list' => $data]);
+        return $this->fetch();
+    }
+
+    public function fzsp($id)
+    {
+        $data = Util::postMore([
+            'name',
+            'image',
+            'price',
+            'deduct',
+            'rise',
+            'info',
+            'sort',
+            'auction_id',
+            'hanging_price',
+            'slider_image',
+            'description',
+            'give',
+            'uid',
+            'fictitious_price'
+        ]);
+        $data['slider_image'] = json_encode($data['slider_image']);
+        $data['description'] = htmlspecialchars($data['description']);
+        $res = model::create($data);
+        if ($res){
+            return Json::success('修改成功!');
+        }else{
+            return Json::fail(\app\admin\model\auction\Auction::getErrorInfo());
+        }
+
+
+    }
+
+
+}

+ 47 - 0
app/admin/controller/auction/AuctionSite.php

@@ -0,0 +1,47 @@
+<?php
+namespace app\admin\controller\auction;
+
+use app\admin\controller\AuthController;
+use app\admin\controller\Union;
+use crmeb\services\{ExpressService,
+    JsonService,
+    MiniProgramService,
+    upload\Upload,
+    WechatService,
+    FormBuilder as Form,
+    CacheService,
+    UtilService as Util,
+    JsonService as Json};
+use app\admin\model\system\{
+    SystemAttachment as SystemAttachmentModel, SystemAttachmentCategory as Category
+};
+use think\facade\Route as Url;
+
+/**
+ * 竞拍管理
+ * Class StoreOrder
+ * @package app\admin\controller\store
+ */
+class AuctionSite extends AuthController
+{
+
+
+    public function index()
+    {
+
+        $data = \app\admin\model\auction\AuctionSite::select();
+
+        $form = ['getTitle' => '竞拍配置'];
+
+        $this->assign([
+            'form' => $form,
+            'getTitle' => '竞拍配置',
+            'config_tab' => [
+                'id'  => 1,
+                'type' => 1
+            ]
+        ]);
+        return $this->fetch();
+    }
+
+}

+ 130 - 0
app/admin/controller/finance/Finance.php

@@ -0,0 +1,130 @@
+<?php
+/**
+ * Created by PhpStorm.
+ * User: xurongyao <763569752@qq.com>
+ * Date: 2018/6/14 下午5:25
+ */
+
+namespace app\admin\controller\finance;
+
+use app\admin\controller\AuthController;
+use app\admin\model\user\{User,UserBill};
+use app\admin\model\finance\FinanceModel;
+use crmeb\services\{UtilService as Util,JsonService as Json};
+
+/**
+ * 微信充值记录
+ * Class UserRecharge
+ * @package app\admin\controller\user
+ */
+class Finance extends AuthController
+{
+    /**
+     * 显示资金记录
+     */
+    public function bill()
+    {
+        $list = UserBill::where('type', 'not in', ['gain', 'system_sub', 'deduction', 'sign'])
+            ->where('category', 'not in', 'integral')
+            ->field(['title', 'type'])
+            ->group('type')
+            ->distinct(true)
+            ->select()
+            ->toArray();
+        $this->assign('selectList', $list);
+        return $this->fetch();
+    }
+
+    /**
+     * 显示资金记录ajax列表
+     */
+    public function billlist()
+    {
+        $where = Util::getMore([
+            ['start_time', ''],
+            ['end_time', ''],
+            ['nickname', ''],
+            ['limit', 20],
+            ['page', 1],
+            ['type', ''],
+        ]);
+        return Json::successlayui(FinanceModel::getBillList($where));
+    }
+
+    /**
+     *保存资金监控的excel表格
+     */
+    public function save_bell_export()
+    {
+        $where = Util::getMore([
+            ['start_time', ''],
+            ['end_time', ''],
+            ['nickname', ''],
+            ['type', ''],
+        ]);
+        FinanceModel::SaveExport($where);
+    }
+
+    /**
+     * 显示佣金记录
+     */
+    public function commission_list()
+    {
+        $this->assign('is_layui', true);
+        return $this->fetch();
+    }
+
+    /**
+     * 佣金记录异步获取
+     */
+    public function get_commission_list()
+    {
+        $get = Util::getMore([
+            ['page', 1],
+            ['limit', 20],
+            ['nickname', ''],
+            ['price_max', ''],
+            ['price_min', ''],
+            ['order', ''],
+            ['excel', ''],
+        ]);
+        return Json::successlayui(User::getCommissionList($get));
+    }
+
+    /**
+     * 显示操作记录
+     */
+    public function index3()
+    {
+
+    }
+
+    /**
+     * 佣金详情
+     */
+    public function content_info($uid = '')
+    {
+        if ($uid == '') return $this->failed('缺少参数');
+        $this->assign('userinfo', User::getUserinfo($uid));
+        $this->assign('uid', $uid);
+        return $this->fetch();
+    }
+
+    /**
+     * 佣金提现记录个人列表
+     */
+    public function get_extract_list($uid = '')
+    {
+        if ($uid == '') return Json::fail('缺少参数');
+        $where = Util::getMore([
+            ['page', 1],
+            ['limit', 20],
+            ['start_time', ''],
+            ['end_time', ''],
+            ['nickname', '']
+        ]);
+        return Json::successlayui(UserBill::getExtrctOneList($where, $uid));
+    }
+
+}
+

+ 154 - 0
app/admin/controller/finance/UserExtract.php

@@ -0,0 +1,154 @@
+<?php
+/**
+ * Created by PhpStorm.
+ * User: lianghuan
+ * Date: 2018-03-03
+ * Time: 16:37
+ */
+
+namespace app\admin\controller\finance;
+
+use app\admin\controller\AuthController;
+use think\facade\Route as Url;
+use crmeb\services\JsonService;
+use app\admin\model\user\UserExtract as UserExtractModel;
+use crmeb\services\{UtilService as Util, FormBuilder as Form};
+
+/**
+ * 用户提现管理
+ * Class UserExtract
+ * @package app\admin\controller\finance
+ */
+class UserExtract extends AuthController
+{
+    public function index()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['nickname', ''],
+            ['extract_type', ''],
+            ['nireid', ''],
+            ['date', ''],
+        ], $this->request);
+        $limitTimeList = [
+            'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
+            'week' => implode(' - ', [
+                date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
+                date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
+            ]),
+            'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
+            'quarter' => implode(' - ', [
+                date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
+                date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
+            ]),
+            'year' => implode(' - ', [
+                date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
+            ])
+        ];
+        $this->assign('where', $where);
+        $this->assign('limitTimeList', $limitTimeList);
+        $this->assign(UserExtractModel::extractStatistics());
+        $this->assign(UserExtractModel::systemPage($where));
+        return $this->fetch();
+    }
+
+    public function edit($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $UserExtract = UserExtractModel::get($id);
+        if (!$UserExtract) return JsonService::fail('数据不存在!');
+        $f = array();
+        $f[] = Form::input('real_name', '姓名', $UserExtract['real_name']);
+        $f[] = Form::number('extract_price', '提现金额', $UserExtract['extract_price'])->precision(2);
+        if ($UserExtract['extract_type'] == 'alipay') {
+            $f[] = Form::input('alipay_code', '支付宝账号', $UserExtract['alipay_code']);
+        } else if ($UserExtract['extract_type'] == 'weixin') {
+            $f[] = Form::input('wechat', '微信号', $UserExtract['wechat']);
+        } else {
+            $f[] = Form::input('bank_code', '银行卡号', $UserExtract['bank_code']);
+            $f[] = Form::input('bank_address', '开户行', $UserExtract['bank_address']);
+        }
+        $f[] = Form::input('mark', '备注', $UserExtract['mark'])->type('textarea');
+        $form = Form::make_post_form('编辑', $f, Url::buildUrl('update', array('id' => $id)));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    public function update($id)
+    {
+        $UserExtract = UserExtractModel::get($id);
+        if (!$UserExtract) return JsonService::fail('数据不存在!');
+        if ($UserExtract['extract_type'] == 'alipay') {
+            $data = Util::postMore([
+                'real_name',
+                'mark',
+                'extract_price',
+                'alipay_code',
+            ]);
+            if (!$data['real_name']) return JsonService::fail('请输入姓名');
+            if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
+            if (!$data['alipay_code']) return JsonService::fail('请输入支付宝账号');
+        } else if ($UserExtract['extract_type'] == 'weixin') {
+            $data = Util::postMore([
+                'real_name',
+                'mark',
+                'extract_price',
+                'wechat',
+            ]);
+//            if(!$data['real_name']) return JsonService::fail('请输入姓名');
+            if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
+            if (!$data['wechat']) return JsonService::fail('请输入微信账号');
+        } else {
+            $data = Util::postMore([
+                'real_name',
+                'extract_price',
+                'mark',
+                'bank_code',
+                'bank_address',
+            ]);
+            if (!$data['real_name']) return JsonService::fail('请输入姓名');
+            if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
+            if (!$data['bank_code']) return JsonService::fail('请输入银行卡号');
+            if (!$data['bank_address']) return JsonService::fail('请输入开户行');
+        }
+        if (!UserExtractModel::edit($data, $id))
+            return JsonService::fail(UserExtractModel::getErrorInfo('修改失败'));
+        else
+            return JsonService::successful('修改成功!');
+    }
+
+    public function fail($id)
+    {
+        if (!UserExtractModel::be(['id' => $id, 'status' => 0])) return JsonService::fail('操作记录不存在或状态错误!');
+        $fail_msg = request()->post();
+        $extract = UserExtractModel::get($id);
+        if (!$extract) return JsonService::fail('操作记录不存在!');
+        if ($extract->status == 1) return JsonService::fail('已经提现,错误操作');
+        if ($extract->status == -1) return JsonService::fail('您的提现申请已被拒绝,请勿重复操作!');
+        $res = UserExtractModel::changeFail($id, $fail_msg['message']);
+        if ($res) {
+            return JsonService::successful('操作成功!');
+        } else {
+            return JsonService::fail('操作失败!');
+        }
+    }
+
+    public function succ($id)
+    {
+        if (!UserExtractModel::be(['id' => $id, 'status' => 0]))
+            return JsonService::fail('操作记录不存在或状态错误!');
+        UserExtractModel::beginTrans();
+        $extract = UserExtractModel::get($id);
+        if (!$extract) return JsonService::fail('操作记录不存!');
+        if ($extract->status == 1) return JsonService::fail('您已提现,请勿重复提现!');
+        if ($extract->status == -1) return JsonService::fail('您的提现申请已被拒绝!');
+        $res = UserExtractModel::changeSuccess($id);
+        if ($res) {
+            UserExtractModel::commitTrans();
+            return JsonService::successful('操作成功!');
+        } else {
+            UserExtractModel::rollbackTrans();
+            return JsonService::fail('操作失败!');
+        }
+    }
+}

+ 141 - 0
app/admin/controller/finance/UserRecharge.php

@@ -0,0 +1,141 @@
+<?php
+
+namespace app\admin\controller\finance;
+
+use app\admin\controller\AuthController;
+use app\admin\model\user\{User, UserRecharge as UserRechargeModel};
+use app\models\routine\RoutineTemplate;
+use app\models\user\{UserBill, WechatUser as WechatUserWap};
+use crmeb\services\{JsonService,
+    MiniProgramService,
+    WechatService,
+    UtilService as Util,
+    FormBuilder as Form,
+    WechatTemplateService};
+use think\facade\Route as Url;
+
+/**
+ * 微信充值记录
+ * Class UserRecharge
+ * @package app\admin\controller\user
+ */
+class UserRecharge extends AuthController
+{
+    /**
+     * 显示操作记录
+     */
+    public function index()
+    {
+        $this->assign('year', get_month());
+        return $this->fetch();
+    }
+
+    public function get_user_recharge_list()
+    {
+        $where = Util::getMore([
+            ['data', ''],
+            ['paid', ''],
+            ['page', 1],
+            ['limit', 20],
+            ['nickname', ''],
+            ['excel', ''],
+        ]);
+        return JsonService::successlayui(UserRechargeModel::getUserRechargeList($where));
+    }
+
+    public function delect($id = 0)
+    {
+        if (!$id) return JsonService::fail('缺少参数');
+        $rechargInfo = UserRechargeModel::get($id);
+        if ($rechargInfo->paid) return JsonService::fail('已支付的订单记录无法删除');
+        if (UserRechargeModel::del($id))
+            return JsonService::successful('删除成功');
+        else
+            return JsonService::fail('删除失败');
+    }
+
+    public function get_badge()
+    {
+        $where = Util::getMore([
+            ['data', ''],
+            ['paid', ''],
+            ['nickname', ''],
+        ]);
+        return JsonService::successful(UserRechargeModel::getDataList($where));
+    }
+
+    /**退款
+     * @param $id
+     * @return mixed|void
+     */
+    public function edit($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $UserRecharge = UserRechargeModel::get($id);
+        if (!$UserRecharge) return JsonService::fail('数据不存在!');
+        if ($UserRecharge['paid'] == 1) {
+            $f = array();
+            $f[] = Form::input('order_id', '退款单号', $UserRecharge->getData('order_id'))->disabled(1);
+            $f[] = Form::number('refund_price', '退款金额', $UserRecharge->getData('price'))->precision(2)->min(0)->max($UserRecharge->getData('price'));
+            $jsContent = <<<SCRIPT
+parent.SuccessFun();
+parent.layer.close(parent.layer.getFrameIndex(window.name));
+SCRIPT;
+            $form = Form::make_post_form('编辑', $f, Url::buildUrl('updateRefundY', array('id' => $id)), $jsContent);
+            $this->assign(compact('form'));
+            return $this->fetch('public/form-builder');
+        } else return JsonService::fail('数据不存在!');
+    }
+
+    /**
+     * 退款更新
+     * @param $id
+     */
+    public function updateRefundY($id)
+    {
+        $data = Util::postMore([
+            'refund_price',
+        ]);
+        if (!$id) return $this->failed('数据不存在');
+        $UserRecharge = UserRechargeModel::get($id);
+        if (!$UserRecharge) return JsonService::fail('数据不存在!');
+        if ($UserRecharge['price'] == $UserRecharge['refund_price']) return JsonService::fail('已退完支付金额!不能再退款了');
+        if (!$data['refund_price']) return JsonService::fail('请输入退款金额');
+        $refund_price = $data['refund_price'];
+        $data['refund_price'] = bcadd($data['refund_price'], $UserRecharge['refund_price'], 2);
+        $bj = bccomp((float)$UserRecharge['price'], (float)$data['refund_price'], 2);
+        if ($bj < 0) return JsonService::fail('退款金额大于支付金额,请修改退款金额');
+        $refund_data['pay_price'] = $UserRecharge['price'];
+        $refund_data['refund_price'] = $refund_price;
+//        $refund_data['refund_account']='REFUND_SOURCE_RECHARGE_FUNDS';
+        try {
+            $recharge_type = UserRechargeModel::where('order_id', $UserRecharge['order_id'])->value('recharge_type');
+            if ($recharge_type == 'weixin') {
+                WechatService::payOrderRefund($UserRecharge['order_id'], $refund_data);
+            } else {
+                MiniProgramService::payOrderRefund($UserRecharge['order_id'], $refund_data);
+            }
+        } catch (\Exception $e) {
+            return JsonService::fail($e->getMessage());
+        }
+        UserRechargeModel::edit($data, $id);
+        User::bcDec($UserRecharge['uid'], 'now_money', $refund_price, 'uid');
+        switch (strtolower($UserRecharge['recharge_type'])) {
+            case 'weixin':
+                WechatTemplateService::sendTemplate(WechatUserWap::where('uid', $UserRecharge['uid'])->value('openid'), WechatTemplateService::ORDER_REFUND_STATUS, [
+                    'first' => '亲,您充值的金额已退款,本次退款' .
+                        $data['refund_price'] . '金额',
+                    'keyword1' => $UserRecharge['order_id'],
+                    'keyword2' => $UserRecharge['price'],
+                    'keyword3' => date('Y-m-d H:i:s', $UserRecharge['add_time']),
+                    'remark' => '点击查看订单详情'
+                ], Url::buildUrl('/user/bill/2')->suffix(false)->build());
+                break;
+            case 'routine':
+                RoutineTemplate::sendRechargeSuccess($UserRecharge, $data['refund_price']);
+                break;
+        }
+        UserBill::expend('系统退款', $UserRecharge['uid'], 'now_money', 'user_recharge_refund', $refund_price, $id, $UserRecharge['price'], '退款给用户' . $refund_price . '元');
+        return JsonService::successful('退款成功!');
+    }
+}

+ 955 - 0
app/admin/controller/order/StoreOrder.php

@@ -0,0 +1,955 @@
+<?php
+/**
+ *
+ * @author: xaboy<365615158@qq.com>
+ * @day: 2017/11/11
+ */
+
+namespace app\admin\controller\order;
+
+use app\admin\controller\AuthController;
+use app\admin\model\order\StoreOrderCartInfo;
+use app\admin\model\system\Express;
+use crmeb\repositories\OrderRepository;
+use crmeb\repositories\ShortLetterRepositories;
+use crmeb\services\{
+    ExpressService,
+    JsonService,
+    MiniProgramService,
+    WechatService,
+    FormBuilder as Form,
+    CacheService,
+    UtilService as Util,
+    JsonService as Json
+};
+use app\admin\model\order\StoreOrderStatus;
+use app\admin\model\ump\StorePink;
+use app\admin\model\user\{
+    User, UserBill
+};
+use crmeb\basic\BaseModel;
+use think\facade\Route as Url;
+use app\admin\model\order\StoreOrder as StoreOrderModel;
+use crmeb\services\YLYService;
+use think\facade\Log;
+use app\models\store\StoreOrder as StoreOrderModels;
+
+/**
+ * 订单管理控制器 同一个订单表放在一个控制器
+ * Class StoreOrder
+ * @package app\admin\controller\store
+ */
+class StoreOrder extends AuthController
+{
+    /**
+     * @return mixed
+     */
+    public function index()
+    {
+        $this->assign([
+            'year' => get_month(),
+            'real_name' => $this->request->get('real_name', ''),
+            'status' => $this->request->param('status', ''),
+            'orderCount' => StoreOrderModel::orderCount(),
+            'payTypeCount' => StoreOrderModel::payTypeCount(),
+        ]);
+        return $this->fetch();
+    }
+
+    /**
+     * 获取头部订单金额等信息
+     * return json
+     */
+    public function getBadge()
+    {
+        $where = Util::postMore([
+            ['status', ''],
+            ['real_name', ''],
+            ['is_del', 0],
+            ['data', ''],
+            ['type', ''],
+            ['pay_type', ''],
+            ['order', '']
+        ]);
+        return Json::successful(StoreOrderModel::getBadge($where));
+    }
+
+    /**
+     * 获取订单列表
+     * return json
+     */
+    public function order_list()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['real_name', $this->request->param('real_name', '')],
+            ['is_del', 0],
+            ['data', ''],
+            ['type', ''],
+            ['pay_type', ''],
+            ['order', ''],
+            ['page', 1],
+            ['limit', 20],
+            ['excel', 0]
+        ]);
+        return Json::successlayui(StoreOrderModel::OrderList($where));
+    }
+
+    public function order_print($id = '')
+    {
+        if (!$id) {
+            return JsonService::fail('缺少参数');
+        }
+        $order = StoreOrderModel::get($id);
+        if (!$order) {
+            return JsonService::fail('订单没有查到,无法打印!');
+        }
+        try {
+            $order['cart_id'] = is_string($order['cart_id']) ? json_decode($order['cart_id'], true) : $order['cart_id'];
+            $cartInfo = StoreOrderCartInfo::whereIn('cart_id', $order['cart_id'])->field('cart_info')->select();
+            $cartInfo = count($cartInfo) ? $cartInfo->toArray() : [];
+            $product = [];
+            foreach ($cartInfo as $item) {
+                $value = is_string($item['cart_info']) ? json_decode($item['cart_info'], true) : $item['cart_info'];
+                $value['productInfo']['store_name'] = $value['productInfo']['store_name'] ?? "";
+                $value['productInfo']['store_name'] = StoreOrderCartInfo::getSubstrUTf8($value['productInfo']['store_name'], 10, 'UTF-8', '');
+                $product[] = $value;
+            }
+            if (!$product) {
+                return JsonService::fail('订单商品获取失败,无法打印!');
+            }
+            $res = YLYService::instance()->setContent(sys_config('site_name'), is_object($order) ? $order->toArray() : $order, $product)->orderPrinting();
+            if ($res) {
+                return JsonService::successful('打印成功');
+            } else {
+                return JsonService::fail('打印失败');
+            }
+        } catch (\Exception $e) {
+            Log::error('小票打印出现错误,错误原因:' . $e->getMessage());
+            return JsonService::fail($e->getMessage());
+        }
+    }
+
+    /**
+     * 核销码核销
+     * @param string $verify_code
+     * @return html
+     */
+    public function write_order($verify_code = '', $is_confirm = 0)
+    {
+        if ($this->request->isAjax()) {
+            if (!$verify_code) return Json::fail('缺少核销码!');
+            StoreOrderModel::beginTrans();
+            $orderInfo = StoreOrderModel::where('verify_code', $verify_code)->where('paid', 1)->where('refund_status', 0)->find();
+            if (!$orderInfo) return Json::fail('核销订单不存在!');
+            if ($orderInfo->status > 0) return Json::fail('订单已核销!');
+            if ($orderInfo->combination_id && $orderInfo->pink_id) {
+                $res = StorePink::where('id', $orderInfo->pink_id)->where('status', '<>', 2)->count();
+                if ($res) return Json::fail('拼团订单暂未成功无法核销!');
+            }
+            if ($is_confirm == 0) {
+                $orderInfo['nickname'] = User::where(['uid' => $orderInfo['uid']])->value('nickname');
+                return Json::successful($orderInfo);
+            }
+            $orderInfo->status = 2;
+            if ($orderInfo->save()) {
+                OrderRepository::storeProductOrderTakeDeliveryAdmin($orderInfo);
+                StoreOrderStatus::setStatus($orderInfo->id, 'take_delivery', '已核销');
+                //发送短信
+                event('ShortMssageSend', [$orderInfo['order_id'], 'Receiving']);
+                StoreOrderModel::commitTrans();
+                return Json::successful('核销成功!');
+            } else {
+                StoreOrderModel::rollbackTrans();
+                return Json::fail('核销失败');
+            }
+        } else
+            $this->assign('is_layui', 1);
+        return $this->fetch();
+    }
+
+    public function orderchart()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['real_name', ''],
+            ['is_del', 0],
+            ['data', ''],
+            ['combination_id', ''],
+            ['export', 0],
+            ['order', 'id desc']
+        ], $this->request);
+        $limitTimeList = [
+            'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
+            'week' => implode(' - ', [
+                date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
+                date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
+            ]),
+            'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
+            'quarter' => implode(' - ', [
+                date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
+                date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
+            ]),
+            'year' => implode(' - ', [
+                date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
+            ])
+        ];
+        if ($where['data'] == '') $where['data'] = $limitTimeList['today'];
+        $orderCount = [
+            urlencode('未支付') => StoreOrderModel::getOrderWhere($where, StoreOrderModel::statusByWhere(0))->count(),
+            urlencode('未发货') => StoreOrderModel::getOrderWhere($where, StoreOrderModel::statusByWhere(1))->count(),
+            urlencode('待收货') => StoreOrderModel::getOrderWhere($where, StoreOrderModel::statusByWhere(2))->count(),
+            urlencode('待评价') => StoreOrderModel::getOrderWhere($where, StoreOrderModel::statusByWhere(3))->count(),
+            urlencode('交易完成') => StoreOrderModel::getOrderWhere($where, StoreOrderModel::statusByWhere(4))->count(),
+            urlencode('退款中') => StoreOrderModel::getOrderWhere($where, StoreOrderModel::statusByWhere(-1))->count(),
+            urlencode('已退款') => StoreOrderModel::getOrderWhere($where, StoreOrderModel::statusByWhere(-2))->count()
+        ];
+        $model = StoreOrderModel::getOrderWhere($where, new StoreOrderModel())->field('sum(total_num) total_num,count(*) count,sum(total_price) total_price,sum(refund_price) refund_price,from_unixtime(add_time,\'%Y-%m-%d\') add_time')
+            ->group('from_unixtime(add_time,\'%Y-%m-%d\')');
+        $orderPrice = $model->select()->toArray();
+        $orderDays = [];
+        $orderCategory = [
+            ['name' => '商品数', 'type' => 'line', 'data' => []],
+            ['name' => '订单数', 'type' => 'line', 'data' => []],
+            ['name' => '订单金额', 'type' => 'line', 'data' => []],
+            ['name' => '退款金额', 'type' => 'line', 'data' => []]
+        ];
+        foreach ($orderPrice as $price) {
+            $orderDays[] = $price['add_time'];
+            $orderCategory[0]['data'][] = $price['total_num'];
+            $orderCategory[1]['data'][] = $price['count'];
+            $orderCategory[2]['data'][] = $price['total_price'];
+            $orderCategory[3]['data'][] = $price['refund_price'];
+        }
+        $this->assign(StoreOrderModel::systemPage($where, $this->adminId));
+        $this->assign('price', StoreOrderModel::getOrderPrice($where));
+        $this->assign(compact('limitTimeList', 'where', 'orderCount', 'orderPrice', 'orderDays', 'orderCategory'));
+        return $this->fetch();
+    }
+
+    /**
+     * 修改支付金额等
+     * @param $id
+     * @return mixed|\think\response\Json|void
+     */
+    public function edit($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $f = [];
+        $f[] = Form::input('order_id', '订单编号', $product->getData('order_id'))->disabled(1);
+        $f[] = Form::number('total_price', '商品总价', $product->getData('total_price'))->min(0);
+        $f[] = Form::number('total_postage', '原始邮费', $product->getData('total_postage'))->min(0);
+        $f[] = Form::number('pay_price', '实际支付金额', $product->getData('pay_price'))->min(0);
+        $f[] = Form::number('pay_postage', '实际支付邮费', $product->getData('pay_postage'));
+        $f[] = Form::number('gain_integral', '赠送积分', $product->getData('gain_integral'));
+//        $f[] = Form::radio('status','状态',$product->getData('status'))->options([['label'=>'开启','value'=>1],['label'=>'关闭','value'=>0]]);
+        $form = Form::make_post_form('修改订单', $f, Url::buildUrl('update', array('id' => $id)));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 修改订单提交更新
+     * @param $id
+     */
+    public function update($id)
+    {
+        $data = Util::postMore([
+            'order_id',
+            'total_price',
+            'total_postage',
+            'pay_price',
+            'pay_postage',
+            'gain_integral',
+        ]);
+        if ($data['total_price'] <= 0) return Json::fail('请输入商品总价');
+        if ($data['pay_price'] <= 0) return Json::fail('请输入实际支付金额');
+        $orderInfo = StoreOrderModel::get($id);
+        if (!$orderInfo) {
+            return Json::fail('订单不存在');
+        }
+        $orderInfo->order_id = StoreOrderModel::changeOrderId($data['order_id']);
+        $pay_price = $orderInfo->pay_price;
+        $orderInfo->pay_price = $data['pay_price'];
+        $orderInfo->total_price = $data['total_price'];
+        $orderInfo->total_postage = $data['total_postage'];
+        $orderInfo->pay_postage = $data['pay_postage'];
+        $orderInfo->gain_integral = $data['gain_integral'];
+        if ($orderInfo->save()) {
+            //改价短信提醒
+            if ($data['pay_price'] != $pay_price) {
+                $switch = sys_config('price_revision_switch') ? true : false;
+                ShortLetterRepositories::send($switch, $orderInfo->user_phone, ['order_id' => $orderInfo->order_id, 'pay_price' => $orderInfo->pay_price], 'PRICE_REVISION_CODE');
+            }
+            event('StoreProductOrderEditAfter', [$data, $id]);
+            StoreOrderStatus::setStatus($id, 'order_edit', '修改商品总价为:' . $data['total_price'] . ' 实际支付金额' . $data['pay_price']);
+            return Json::successful('修改成功!');
+        } else {
+            return Json::fail('订单修改失败');
+        }
+    }
+
+    /*
+     * 发送货
+     * @param int $id
+     * @return html
+     * */
+    public function order_goods($id = 0)
+    {
+        $list = Express::where('is_show', 1)->order('sort desc')->column('name', 'id');
+        $this->assign([
+            'list' => $list,
+            'id' => $id
+        ]);
+        return $this->fetch();
+    }
+
+    /*
+     * 删除订单
+     * */
+    public function del_order()
+    {
+        $ids = Util::postMore(['ids'])['ids'];
+        if (!count($ids)) return Json::fail('请选择需要删除的订单');
+        if (StoreOrderModel::where('is_del', 0)->where('id', 'in', $ids)->count())
+            return Json::fail('您选择的的订单存在用户未删除的订单,无法删除用户未删除的订单');
+        $res = StoreOrderModel::where('id', 'in', $ids)->update(['is_system_del' => 1]);
+        if ($res)
+            return Json::successful('删除成功');
+        else
+            return Json::fail('删除失败');
+    }
+
+    /**
+     * TODO 送货信息提交
+     * @param Request $request
+     * @param $id
+     */
+    public function update_delivery($id = 0)
+    {
+        $data = Util::postMore([
+            ['type', 1],
+            ['delivery_name', ''],
+            ['delivery_id', ''],
+            ['sh_delivery_name', ''],
+            ['sh_delivery_id', ''],
+        ], $this->request);
+        switch ((int)$data['type']) {
+            case 1:
+                //发货
+                $data['delivery_type'] = 'express';
+                if (!$data['delivery_name']) return Json::fail('请选择快递公司');
+                if (!$data['delivery_id']) return Json::fail('请输入快递单号');
+                $data['status'] = 1;
+                StoreOrderModel::edit($data, $id);
+                event('StoreProductOrderDeliveryGoodsAfter', [$data, $id]);
+                StoreOrderStatus::setStatus($id, 'delivery_goods', '已发货 快递公司:' . $data['delivery_name'] . ' 快递单号:' . $data['delivery_id']);
+                break;
+            case 2:
+                //送货
+                $data['delivery_type'] = 'send';
+                $data['delivery_name'] = $data['sh_delivery_name'];
+                $data['delivery_id'] = $data['sh_delivery_id'];
+                unset($data['sh_delivery_name'], $data['sh_delivery_id']);
+                if (!$data['delivery_name']) return Json::fail('请输入送货人姓名');
+                if (!(int)$data['delivery_id']) return Json::fail('请输入送货人电话号码');
+                else if (!preg_match("/^1[3456789]{1}\d{9}$/", $data['delivery_id'])) return Json::fail('请输入正确的送货人电话号码');
+                $data['status'] = 1;
+                StoreOrderModel::edit($data, $id);
+                event('StoreProductOrderDeliveryAfter', [$data, $id]);
+                StoreOrderStatus::setStatus($id, 'delivery', '已配送 发货人:' . $data['delivery_name'] . ' 发货人电话:' . $data['delivery_id']);
+                break;
+            case 3:
+                //虚拟发货
+                $data['delivery_type'] = 'fictitious';
+                $data['status'] = 1;
+                StoreOrderModel::edit($data, $id);
+                event('StoreProductOrderDeliveryAfter', [$data, $id]);
+                StoreOrderStatus::setStatus($id, 'delivery_fictitious', '已虚拟发货');
+                break;
+            default:
+                return Json::fail('暂时不支持其他发货类型');
+                break;
+        }
+        //短信发送
+        event('ShortMssageSend', [StoreOrderModel::where('id', $id)->value('order_id'), 'Deliver']);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * TODO 填写送货信息
+     * @param $id
+     * @return mixed|void
+     * @throws \think\exception\DbException
+     */
+    public function delivery($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['paid'] == 1 && $product['status'] == 0) {
+            $f = [];
+            $f[] = Form::input('delivery_name', '送货人姓名')->required('送货人姓名不能为空', 'required:true;');
+            $f[] = Form::input('delivery_id', '送货人电话')->required('请输入正确电话号码', 'telephone');
+            $form = Form::make_post_form('修改订单', $f, Url::buildUrl('updateDelivery', array('id' => $id)), 7);
+            $this->assign(compact('form'));
+            return $this->fetch('public/form-builder');
+        } else $this->failedNotice('订单状态错误');
+    }
+
+    /**
+     * TODO 送货信息提交
+     * @param $id
+     */
+    public function updateDelivery($id)
+    {
+        $data = Util::postMore([
+            'delivery_name',
+            'delivery_id',
+        ]);
+        $data['delivery_type'] = 'send';
+        if (!$data['delivery_name']) return Json::fail('请输入送货人姓名');
+        if (!(int)$data['delivery_id']) return Json::fail('请输入送货人电话号码');
+        else if (!preg_match("/^1[3456789]{1}\d{9}$/", $data['delivery_id'])) return Json::fail('请输入正确的送货人电话号码');
+        $data['status'] = 1;
+        StoreOrderModel::edit($data, $id);
+        event('StoreProductOrderDeliveryAfter', [$data, $id]);
+        StoreOrderStatus::setStatus($id, 'delivery', '已配送 发货人:' . $data['delivery_name'] . ' 发货人电话:' . $data['delivery_id']);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * TODO 填写发货信息
+     * @param $id
+     * @return mixed|void
+     * @throws \think\exception\DbException
+     */
+    public function deliver_goods($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['paid'] == 1 && $product['status'] == 0) {
+            $f = [];
+            $f[] = Form::select('delivery_name', '快递公司')->setOptions(function () {
+                $list = Express::where('is_show', 1)->order('sort DESC')->column('name', 'id');
+                $menus = [];
+                foreach ($list as $k => $v) {
+                    $menus[] = ['value' => $v, 'label' => $v];
+                }
+                return $menus;
+            })->filterable(1);
+            $f[] = Form::input('delivery_id', '快递单号');
+            $form = Form::make_post_form('修改订单', $f, Url::buildUrl('updateDeliveryGoods', array('id' => $id)), 7);
+            $this->assign(compact('form'));
+            return $this->fetch('public/form-builder');
+        } else return $this->failedNotice('订单状态错误');
+    }
+
+    /**
+     * TODO 发货信息提交
+     * @param $id
+     */
+    public function updateDeliveryGoods($id)
+    {
+        $data = Util::postMore([
+            'delivery_name',
+            'delivery_id',
+        ]);
+        $data['delivery_type'] = 'express';
+        if (!$data['delivery_name']) return Json::fail('请选择快递公司');
+        if (!$data['delivery_id']) return Json::fail('请输入快递单号');
+        $data['status'] = 1;
+        StoreOrderModel::edit($data, $id);
+        event('StoreProductOrderDeliveryGoodsAfter', [$data, $id]);
+        StoreOrderStatus::setStatus($id, 'delivery_goods', '已发货 快递公司:' . $data['delivery_name'] . ' 快递单号:' . $data['delivery_id']);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 修改状态为已收货
+     * @param $id
+     * @return \think\response\Json|void
+     */
+    public function take_delivery($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $order = StoreOrderModel::get($id);
+        if (!$order) return Json::fail('数据不存在!');
+        if ($order['status'] == 2) return Json::fail('不能重复收货!');
+        if ($order['paid'] == 1 && $order['status'] == 1) $data['status'] = 2;
+        else if ($order['pay_type'] == 'offline') $data['status'] = 2;
+
+        else return Json::fail('请先发货或者送货!');
+        StoreOrderModel::beginTrans();
+        try {
+            if (!StoreOrderModel::edit($data, $id)) {
+                StoreOrderModel::rollbackTrans();
+                return Json::fail(StoreOrderModel::getErrorInfo('收货失败,请稍候再试!'));
+            } else {
+                OrderRepository::storeProductOrderTakeDeliveryAdmin($order, $id);
+                StoreOrderStatus::setStatus($id, 'take_delivery', '已收货');
+                StoreOrderModel::commitTrans();
+                //发送短信
+                event('ShortMssageSend', [$order['order_id'], 'Receiving']);
+// 				// 释放冻结积分
+// 				//获取当前订单的用户信息
+//                 $user=User::where('uid',$order['uid'])->find();
+// //                计算当前用户的消费金额总和
+//                 $listsum=StoreOrderModel::where('id', $id)->where('status',2)->sum('total_price');
+// //                判断当前用户金额加上当前订单金额是否大于三万
+//                 if($user['f_integral']==3000){
+//                     $integral=floatval($user['integral']+3000);
+//                     $res=User::where('uid',$order['uid'])->update(['f_integral' =>0,'integral'=>$integral]);
+//                 }
+
+
+
+
+// 				$order = self::getUserOrderDetail($uid, $uni);
+// 				//计算历史金额加上当前金额
+// 				$listsum=floatval($order['total_price']+$list);
+// 				if (!$order) return self::setErrorInfo('订单不存在!');
+// 				$order = self::tidyOrder($order);
+// 				// 如果总金额大于等于30000 释放冻结积分
+// 				if($listsum>=30000){
+// 					// 释放积分
+// 					$res=User::where('uid',$uid)->find();
+// 					if($res['f_integral']==3000){
+
+
+// 						$res3=UserBill::income('冻结积分释放',$uid, 'integral', 'release',3000, $order['id'],$listsum, '释放3000积分');
+// 						if(!$res2){
+// 							return self::setErrorInfo('操作失败');
+// 						}
+// 					}
+// 				}
+
+
+
+
+
+
+                return Json::successful('收货成功!');
+            }
+        } catch (\Exception $e) {
+            StoreOrderModel::rollbackTrans();
+            return Json::fail($e->getMessage());
+        }
+    }
+
+    /**
+     * 修改退款状态
+     * @param $id
+     * @return \think\response\Json|void
+     */
+    public function refund_y($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['paid'] == 1) {
+            $f = [];
+            $f[] = Form::input('order_id', '退款单号', $product->getData('order_id'))->disabled(1);
+            $f[] = Form::number('refund_price', '退款金额', $product->getData('pay_price'))->precision(2)->min(0.01);
+            $f[] = Form::radio('type', '状态', 1)->options([['label' => '直接退款', 'value' => 1], ['label' => '退款后,返回原状态', 'value' => 2]]);
+            $form = Form::make_post_form('退款处理', $f, Url::buildUrl('updateRefundY', array('id' => $id)), 7);
+            $this->assign(compact('form'));
+            return $this->fetch('public/form-builder');
+        } else return Json::fail('数据不存在!');
+    }
+
+    /**
+     * 退款处理
+     * @param $id
+     */
+    public function updateRefundY($id)
+    {
+        $data = Util::postMore([
+            'refund_price',
+            ['type', 1],
+        ]);
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['pay_price'] == $product['refund_price']) return Json::fail('已退完支付金额!不能再退款了');
+        if (!$data['refund_price']) return Json::fail('请输入退款金额');
+        $refund_price = $data['refund_price'];
+        $data['refund_price'] = bcadd($data['refund_price'], $product['refund_price'], 2);
+        $bj = bccomp((float)$product['pay_price'], (float)$data['refund_price'], 2);
+        if ($bj < 0) return Json::fail('退款金额大于支付金额,请修改退款金额');
+        if ($data['type'] == 1) {
+            $data['refund_status'] = 2;
+        } else if ($data['type'] == 2) {
+            $data['refund_status'] = 0;
+        }
+        $type = $data['type'];
+        unset($data['type']);
+        $refund_data['pay_price'] = $product['pay_price'];
+        $refund_data['refund_price'] = $refund_price;
+        if ($product['pay_type'] == 'weixin') {
+            if ($product['is_channel'] == 1) {//小程序
+                try {
+                    MiniProgramService::payOrderRefund($product['order_id'], $refund_data);//2.5.36
+                } catch (\Exception $e) {
+                    return Json::fail($e->getMessage());
+                }
+            } else {//TODO 公众号
+                try {
+                    WechatService::payOrderRefund($product['order_id'], $refund_data);
+                } catch (\Exception $e) {
+                    return Json::fail($e->getMessage());
+                }
+            }
+        } else if ($product['pay_type'] == 'yue') {
+            BaseModel::beginTrans();
+            $usermoney = User::where('uid', $product['uid'])->value('now_money');
+            $res1 = User::bcInc($product['uid'], 'now_money', $refund_price, 'uid');
+            $res2 = $res2 = UserBill::income('商品退款', $product['uid'], 'now_money', 'pay_product_refund', $refund_price, $product['id'], bcadd($usermoney, $refund_price, 2), '订单退款到余额' . floatval($refund_price) . '元');
+            try {
+                OrderRepository::storeOrderYueRefund($product, $refund_data);
+            } catch (\Exception $e) {
+                BaseModel::rollbackTrans();
+                return Json::fail($e->getMessage());
+            }
+            $res = $res1 && $res2;
+            BaseModel::checkTrans($res);
+            if (!$res) return Json::fail('余额退款失败!');
+        }
+        $resEdit = StoreOrderModel::edit($data, $id);
+        $res = true;
+        if ($resEdit) {
+            $data['type'] = $type;
+            if ($data['type'] == 1) $res = StorePink::setRefundPink($id);
+            if (!$res) return Json::fail('修改失败');
+            try {
+                OrderRepository::storeProductOrderRefundY($data, $id);
+            } catch (\Exception $e) {
+                BaseModel::rollbackTrans();
+                return Json::fail($e->getMessage());
+            }
+            StoreOrderStatus::setStatus($id, 'refund_price', '退款给用户' . $refund_price . '元');
+
+            //退佣金
+            $brokerage_list = UserBill::where('category', 'now_money')
+                ->where('type', 'brokerage')
+                ->where('link_id', $id)
+                ->where('pm', 1)
+                ->select();
+
+            if ($brokerage_list) {
+                $brokerage_list = $brokerage_list->toArray();
+                foreach ($brokerage_list as $item) {
+                    $usermoney = User::where('uid', $item['uid'])->value('brokerage_price');
+                    if ($item['number'] > $usermoney)
+                        $item['number'] = $usermoney;
+                    User::bcDec($item['uid'], 'brokerage_price', $item['number'], 'uid');
+                    UserBill::expend('退款退佣金', $item['uid'], 'now_money', 'brokerage', $item['number'], $id, bcsub($usermoney, $item['number'], 2), '订单退款扣除佣金' . floatval($item['number']) . '元');
+                }
+            }
+
+            //退款扣除用户积分
+            //购买赠送的积分
+            $bill_integral = UserBill::where('category', 'integral')
+                ->where('type', 'gain')
+                ->where('link_id', $id)
+                ->where('pm', 1)
+                ->find();
+            if ($bill_integral) {
+                $bill_integral = $bill_integral->toArray();
+                //用户积分
+                $user_integral = User::where('uid', $bill_integral['uid'])->value('integral');
+                if ($bill_integral['number'] > $user_integral)
+                    $bill_integral['number'] = $user_integral;
+                User::bcDec($bill_integral['uid'], 'integral', $bill_integral['number'], 'uid');
+                UserBill::expend('退款扣除趣豆', $bill_integral['uid'], 'integral', 'gain', $bill_integral['number'], $id, bcsub($user_integral, $bill_integral['number'], 2), '订单退款扣除积分' . floatval($bill_integral['number']) . '趣豆');
+            }
+            //回退库存
+            StoreOrderModels::RegressionStock($product);
+            BaseModel::commitTrans();
+            return Json::successful('修改成功!');
+        } else {
+            StoreOrderStatus::setStatus($id, 'refund_price', '退款给用户' . $refund_price . '元失败');
+            return Json::fail('修改失败!');
+        }
+    }
+
+    public function order_info($oid = '')
+    {
+        if (!$oid || !($orderInfo = StoreOrderModel::get($oid)))
+            return $this->failed('订单不存在!');
+        $userInfo = User::getUserInfos($orderInfo['uid']);
+        if ($userInfo['spread_uid']) {
+            $spread = User::where('uid', $userInfo['spread_uid'])->value('nickname');
+        } else {
+            $spread = '';
+        }
+        $this->assign(compact('orderInfo', 'userInfo', 'spread'));
+        return $this->fetch();
+    }
+
+    public function express($oid = '')
+    {
+        if (!$oid || !($order = StoreOrderModel::get($oid)))
+            return $this->failed('订单不存在!');
+        if ($order['delivery_type'] != 'express' || !$order['delivery_id']) return $this->failed('该订单不存在快递单号!');
+        $cacheName = $order['order_id'] . $order['delivery_id'];
+        $result = CacheService::get($cacheName, null);
+        if ($result === null) {
+            try {
+                $result = ExpressService::query($order['delivery_id'], $order['delivery_name']);
+            } catch (\Throwable $e) {
+                $result = [];
+            }
+            if (is_array($result) && (isset($result['result']) || isset($result['content']))) {
+                $cacheTime = 1200;
+                if(isset($result['content'])){
+                    $result['result'] = $result['content'];
+                    unset($result['content']);
+                }
+            }else
+                $cacheTime = 1800;
+            CacheService::set($cacheName, $result, $cacheTime);
+        }
+        $this->assign([
+            'order' => $order,
+            'express' => $result
+        ]);
+        return $this->fetch();
+    }
+
+    /**
+     * 修改配送信息
+     * @param $id
+     * @return mixed|\think\response\Json|void
+     */
+    public function distribution($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $f = [];
+        $f[] = Form::input('order_id', '订单号', $product->getData('order_id'))->disabled(1);
+        if ($product['delivery_type'] == 'send') {
+            $f[] = Form::input('delivery_name', '送货人姓名', $product->getData('delivery_name'));
+            $f[] = Form::input('delivery_id', '送货人电话', $product->getData('delivery_id'));
+        } else if ($product['delivery_type'] == 'express') {
+            $f[] = Form::select('delivery_name', '快递公司', $product->getData('delivery_name'))->setOptions(function () {
+                $list = Express::where('is_show', 1)->column('name', 'id');
+                $menus = [];
+                foreach ($list as $k => $v) {
+                    $menus[] = ['value' => $v, 'label' => $v];
+                }
+                return $menus;
+            });
+            $f[] = Form::input('delivery_id', '快递单号', $product->getData('delivery_id'));
+        }
+        $form = Form::make_post_form('配送信息', $f, Url::buildUrl('updateDistribution', array('id' => $id)), 7);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 修改配送信息
+     * @param $id
+     */
+    public function updateDistribution($id)
+    {
+        $data = Util::postMore([
+            'delivery_name',
+            'delivery_id',
+        ]);
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['delivery_type'] == 'send') {
+            if (!$data['delivery_name']) return Json::fail('请输入送货人姓名');
+            if (!(int)$data['delivery_id']) return Json::fail('请输入送货人电话号码');
+            else if (!preg_match("/^1[3456789]{1}\d{9}$/", $data['delivery_id'])) return Json::fail('请输入正确的送货人电话号码');
+        } else if ($product['delivery_type'] == 'express') {
+            if (!$data['delivery_name']) return Json::fail('请选择快递公司');
+            if (!$data['delivery_id']) return Json::fail('请输入快递单号');
+        }
+        StoreOrderModel::edit($data, $id);
+        event('StoreProductOrderDistributionAfter', [$data, $id]);
+        StoreOrderStatus::setStatus($id, 'distribution', '修改发货信息为' . $data['delivery_name'] . '号' . $data['delivery_id']);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 修改退款状态
+     * @param $id
+     * @return mixed|\think\response\Json|void
+     */
+    public function refund_n($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $f[] = Form::input('order_id', '订单号', $product->getData('order_id'))->disabled(1);
+        $f[] = Form::input('refund_reason', '退款原因')->type('textarea');
+        $form = Form::make_post_form('退款', $f, Url::buildUrl('updateRefundN', array('id' => $id)));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 不退款原因
+     * @param $id
+     */
+    public function updateRefundN($id)
+    {
+        $data = Util::postMore([
+            'refund_reason',
+        ]);
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if (!$data['refund_reason']) return Json::fail('请输入退款原因');
+        $data['refund_status'] = 0;
+        StoreOrderModel::edit($data, $id);
+        event('StoreProductOrderRefundNAfter', [$data['refund_reason'], $id]);
+        StoreOrderStatus::setStatus($id, 'refund_n', '不退款原因:' . $data['refund_reason']);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 立即支付
+     * @param $id
+     */
+    public function offline($id)
+    {
+        $res = StoreOrderModel::updateOffline($id);
+        if ($res) {
+            event('StoreProductOrderOffline', [$id]);
+            StoreOrderStatus::setStatus($id, 'offline', '线下付款');
+            return Json::successful('修改成功!');
+        } else {
+            return Json::fail(StoreOrderModel::getErrorInfo('修改失败!'));
+        }
+    }
+
+    /**
+     * 修改积分和金额
+     * @param $id
+     * @return mixed|\think\response\Json|void
+     */
+    public function integral_back($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['paid'] == 1) {
+            $f[] = Form::input('order_id', '退款单号', $product->getData('order_id'))->disabled(1);
+            $f[] = Form::number('use_integral', '使用的积分', $product->getData('use_integral'))->min(0)->disabled(1);
+            $f[] = Form::number('use_integrals', '已退积分', $product->getData('back_integral'))->min(0)->disabled(1);
+            $f[] = Form::number('back_integral', '可退积分', bcsub($product->getData('use_integral'), $product->getData('use_integral')))->min(0);
+            $form = Form::make_post_form('退积分', $f, Url::buildUrl('updateIntegralBack', array('id' => $id)), 7);
+            $this->assign(compact('form'));
+            return $this->fetch('public/form-builder');
+        } else {
+            return Json::fail('参数错误!');
+        }
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 退积分保存
+     * @param $id
+     */
+    public function updateIntegralBack($id)
+    {
+        $data = Util::postMore([
+            'back_integral',
+        ]);
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($data['back_integral'] <= 0) return Json::fail('请输入积分');
+        if ($product['use_integral'] == $product['back_integral']) return Json::fail('已退完积分!不能再积分了');
+        $back_integral = $data['back_integral'];
+        $data['back_integral'] = bcadd($data['back_integral'], $product['back_integral'], 2);
+        $bj = bccomp((float)$product['use_integral'], (float)$data['back_integral'], 2);
+        if ($bj < 0) return Json::fail('退积分大于支付积分,请修改退积分');
+        BaseModel::beginTrans();
+        $integral = User::where('uid', $product['uid'])->value('integral');
+        $res1 = User::bcInc($product['uid'], 'integral', $back_integral, 'uid');
+        $res2 = UserBill::income('商品退积分', $product['uid'], 'integral', 'pay_product_integral_back', $back_integral, $product['id'], bcadd($integral, $back_integral, 2), '订单退积分' . floatval($back_integral) . '积分到用户积分');
+        event('StoreOrderIntegralBack', [$product, $back_integral]);
+        try {
+            OrderRepository::storeOrderIntegralBack($product, $back_integral);
+        } catch (\Exception $e) {
+            BaseModel::rollbackTrans();
+            return Json::fail($e->getMessage());
+        }
+        $res = $res1 && $res2;
+        BaseModel::checkTrans($res);
+        if (!$res) return Json::fail('退积分失败!');
+        if ($product['pay_price'] == 0 && $bj == 0) {
+            $data['refund_status'] = 2;
+        }
+        StoreOrderModel::edit($data, $id);
+        StoreOrderStatus::setStatus($id, 'integral_back', '商品退积分:' . $data['back_integral']);
+        return Json::successful('退积分成功!');
+    }
+
+    public function remark()
+    {
+        $data = Util::postMore(['id', 'remark']);
+        if (!$data['id']) return Json::fail('参数错误!');
+        if ($data['remark'] == '') return Json::fail('请输入要备注的内容!');
+        $id = $data['id'];
+        unset($data['id']);
+        StoreOrderModel::edit($data, $id);
+        return Json::successful('备注成功!');
+    }
+
+    public function order_status($oid)
+    {
+        if (!$oid) return $this->failed('数据不存在');
+        $this->assign(StoreOrderStatus::systemPage($oid));
+        return $this->fetch();
+    }
+
+    /*
+     * 订单列表推荐人详细
+     */
+    public function order_spread_user($uid)
+    {
+        $spread = User::where('uid', $uid)->find();
+        $this->assign('spread', $spread);
+        return $this->fetch();
+    }
+
+    /**
+     * 立即核销
+     * @param $id
+     */
+    public function verify($id)
+    {
+        StoreOrderModel::beginTrans();
+        $orderInfo = StoreOrderModel::where('id', $id)->find();
+        if (!$orderInfo) return Json::fail('核销订单不存在!');
+        if ($orderInfo->status > 0) return Json::fail('订单已核销!');
+        if ($orderInfo->combination_id && $orderInfo->pink_id) {
+            $res = StorePink::where('id', $orderInfo->pink_id)->where('status', '<>', 2)->count();
+            if ($res) return Json::fail('拼团订单暂未成功无法核销!');
+        }
+
+        $orderInfo->status = 2;
+        if ($orderInfo->save()) {
+            OrderRepository::storeProductOrderTakeDeliveryAdmin($orderInfo);
+            StoreOrderStatus::setStatus($orderInfo->id, 'take_delivery', '已核销');
+            //发送短信
+            event('ShortMssageSend', [$orderInfo['order_id'], 'Receiving']);
+            StoreOrderModel::commitTrans();
+            return Json::successful('核销成功!');
+        } else {
+            StoreOrderModel::rollbackTrans();
+            return Json::fail('核销失败');
+        }
+    }
+
+}

+ 645 - 0
app/admin/controller/order/combinationOrder.php

@@ -0,0 +1,645 @@
+<?php
+
+namespace app\admin\controller\order;
+
+use app\admin\model\system\Express;
+use crmeb\repositories\OrderRepository;
+use crmeb\services\{ExpressService,
+    MiniProgramService,
+    WechatService,
+    CacheService,
+    UtilService as Util,
+    JsonService as Json,
+    FormBuilder as Form
+};
+use crmeb\basic\BaseModel;
+use think\facade\Route as Url;
+use app\admin\controller\AuthController;
+use app\admin\model\order\{StoreOrderStatus, StoreOrder as StoreOrderModel};
+use app\admin\model\ump\StorePink;
+use app\admin\model\user\{User, UserBill};
+
+/**
+ * 订单管理控制器
+ * Class StoreOrder
+ * @package app\admin\controller\store
+ */
+class CombinationOrder extends AuthController
+{
+    /**
+     * @return mixed
+     */
+    public function index()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['real_name', ''],
+            ['is_del', 0],
+            ['data', ''],
+            ['combination_id', ''],
+            ['export', 0],
+            ['order', 'id desc']
+        ], $this->request);
+        $limitTimeList = [
+            'yesterday' => implode(' - ', [date('Y/m/d', strtotime('-1 day')), date('Y/m/d')]),
+            'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
+            'week' => implode(' - ', [
+                date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
+                date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
+            ]),
+            'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
+            'quarter' => implode(' - ', [
+                date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
+                date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
+            ]),
+            'year' => implode(' - ', [
+                date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
+            ])
+        ];
+        $this->assign(StoreOrderModel::systemPage($where, $this->adminId));
+        $this->assign('price', StoreOrderModel::getOrderPrice($where));
+        $this->assign(compact('where', 'limitTimeList'));
+        return $this->fetch();
+    }
+
+    public function orderchart()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['real_name', ''],
+            ['is_del', 0],
+            ['data', ''],
+            ['combination_id', ''],
+            ['export', 0],
+            ['order', 'id desc']
+        ], $this->request);
+        $limitTimeList = [
+            'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
+            'week' => implode(' - ', [
+                date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
+                date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
+            ]),
+            'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
+            'quarter' => implode(' - ', [
+                date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
+                date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
+            ]),
+            'year' => implode(' - ', [
+                date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
+            ])
+        ];
+        if ($where['data'] == '') $where['data'] = $limitTimeList['today'];
+        $orderCount = [
+            urlencode('未支付') => StoreOrderModel::getOrderWhere($where, StoreOrderModel::statusByWhere(0))->count(),
+            urlencode('未发货') => StoreOrderModel::getOrderWhere($where, StoreOrderModel::statusByWhere(1))->count(),
+            urlencode('待收货') => StoreOrderModel::getOrderWhere($where, StoreOrderModel::statusByWhere(2))->count(),
+            urlencode('待评价') => StoreOrderModel::getOrderWhere($where, StoreOrderModel::statusByWhere(3))->count(),
+            urlencode('交易完成') => StoreOrderModel::getOrderWhere($where, StoreOrderModel::statusByWhere(4))->count(),
+            urlencode('退款中') => StoreOrderModel::getOrderWhere($where, StoreOrderModel::statusByWhere(-1))->count(),
+            urlencode('已退款') => StoreOrderModel::getOrderWhere($where, StoreOrderModel::statusByWhere(-2))->count()
+        ];
+        $model = StoreOrderModel::getOrderWhere($where, new StoreOrderModel())->field('sum(total_num) total_num,count(*) count,sum(total_price) total_price,sum(refund_price) refund_price,from_unixtime(add_time,\'%Y-%m-%d\') add_time')
+            ->group('from_unixtime(add_time,\'%Y-%m-%d\')');
+        $orderPrice = $model->select()->toArray();
+        $orderDays = [];
+        $orderCategory = [
+            ['name' => '商品数', 'type' => 'line', 'data' => []],
+            ['name' => '订单数', 'type' => 'line', 'data' => []],
+            ['name' => '订单金额', 'type' => 'line', 'data' => []],
+            ['name' => '退款金额', 'type' => 'line', 'data' => []]
+        ];
+        foreach ($orderPrice as $price) {
+            $orderDays[] = $price['add_time'];
+            $orderCategory[0]['data'][] = $price['total_num'];
+            $orderCategory[1]['data'][] = $price['count'];
+            $orderCategory[2]['data'][] = $price['total_price'];
+            $orderCategory[3]['data'][] = $price['refund_price'];
+        }
+        $this->assign(StoreOrderModel::systemPage($where, $this->adminId));
+        $this->assign('price', StoreOrderModel::getOrderPrice($where));
+        $this->assign(compact('limitTimeList', 'where', 'orderCount', 'orderPrice', 'orderDays', 'orderCategory'));
+        return $this->fetch();
+    }
+
+    /**
+     * 修改支付金额等
+     * @param $id
+     * @return mixed|\think\response\Json|void
+     */
+    public function edit($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $this->assign([
+            'title' => '修改订单', 'rules' => $this->read($id)->getContent(),
+            'action' => Url::buildUrl('update', array('id' => $id))
+        ]);
+        return $this->fetch('public/common_form');
+    }
+
+    public function read($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        Form::text('order_id', '订单编号', $product->getData('order_id'))->readonly();
+        Form::number('total_price', '商品总价', $product->getData('total_price'))->min(0);
+        Form::number('total_postage', '原始邮费', $product->getData('total_postage'))->min(0);
+        Form::number('pay_price', '实际支付金额', $product->getData('pay_price'))->min(0);
+        Form::number('pay_postage', '实际支付邮费', $product->getData('pay_postage'))->min(0);
+        Form::number('gain_integral', '赠送积分', $product->getData('gain_integral'))->min(0);
+        return Form::builder();
+    }
+
+    public function update($id)
+    {
+        $data = Util::postMore([
+            'order_id',
+            'total_price',
+            'total_postage',
+            'pay_price',
+            'pay_postage',
+            'gain_integral',
+        ]);
+        if ($data['total_price'] <= 0) return Json::fail('请输入商品总价');
+        if ($data['pay_price'] <= 0) return Json::fail('请输入实际支付金额');
+        $data['order_id'] = StoreOrderModel::changeOrderId($data['order_id']);
+        StoreOrderModel::edit($data, $id);
+        event('StoreProductOrderEditAfter', [$data, $id]);
+        StoreOrderStatus::setStatus($id, 'order_edit', '修改商品总价为:' . $data['total_price'] . ' 实际支付金额' . $data['pay_price']);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 送货
+     * @param $id
+     *  send
+     */
+    public function delivery($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['paid'] == 1 && $product['status'] == 0) {
+            $this->assign([
+                'title' => '送货信息', 'rules' => $this->readDelivery($id)->getContent(),
+                'action' => Url::buildUrl('updateDelivery', array('id' => $id))
+            ]);
+            return $this->fetch('public/common_form');
+        } else return Json::fail('数据不存在!');
+    }
+
+    public function readDelivery($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        Form::text('delivery_name', '送货人姓名');
+        Form::text('delivery_id', '送货人电话')->number();
+        return Form::builder();
+    }
+
+    public function updateDelivery($id)
+    {
+        $data = Util::postMore([
+            'delivery_name',
+            'delivery_id',
+        ]);
+        $data['delivery_type'] = 'send';
+        if (!$data['delivery_name']) return Json::fail('请输入送货人姓名');
+        if (!(int)$data['delivery_id']) return Json::fail('请输入送货人电话号码');
+        else if (!preg_match("/^1[3456789]{1}\d{9}$/", $data['delivery_id'])) return Json::fail('请输入正确的送货人电话号码');
+        $data['status'] = 1;
+        StoreOrderModel::edit($data, $id);
+        event('storeProductOrderDeliveryAfter', [$data, $id]);
+        StoreOrderStatus::setStatus($id, 'delivery', '已配送 发货人:' . $data['delivery_name'] . ' 发货人电话:' . $data['delivery_id']);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 发货
+     * @param $id
+     *  express
+     */
+    public function deliver_goods($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['paid'] == 1 && $product['status'] == 0) {
+            $this->assign([
+                'title' => '发货信息', 'rules' => $this->readDeliveryGoods($id)->getContent(),
+                'action' => Url::buildUrl('updateDeliveryGoods', array('id' => $id))
+            ]);
+            return $this->fetch('public/common_form');
+        } else return Json::fail('数据不存在!');
+    }
+
+    public function readDeliveryGoods($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        Form::select('delivery_name', '快递公司', function () {
+            $list = Express::where('is_show', 1)->order('sort DESC')->column('name', 'id');
+            $menus = [];
+            foreach ($list as $k => $v) {
+                $menus[] = ['value' => $v, 'label' => $v];
+            }
+            return $menus;
+        })->filterable();
+        Form::text('delivery_id', '快递单号');
+        return Form::builder();
+    }
+
+    public function updateDeliveryGoods($id)
+    {
+        $data = Util::postMore([
+            'delivery_name',
+            'delivery_id',
+        ]);
+        $data['delivery_type'] = 'express';
+        if (!$data['delivery_name']) return Json::fail('请选择快递公司');
+        if (!$data['delivery_id']) return Json::fail('请输入快递单号');
+        $data['status'] = 1;
+        StoreOrderModel::edit($data, $id);
+        event('StoreProductOrderDeliveryGoodsAfter', [$data, $id]);
+        StoreOrderStatus::setStatus($id, 'delivery_goods', '已发货 快递公司:' . $data['delivery_name'] . ' 快递单号:' . $data['delivery_id']);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 修改状态为已收货
+     * @param $id
+     * @return \think\response\Json|void
+     */
+    public function take_delivery($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['status'] == 2) return Json::fail('不能重复收货!');
+        if ($product['paid'] == 1 && $product['status'] == 1) $data['status'] = 2;
+        else if ($product['pay_type'] == 'offline') $data['status'] = 2;
+        else return Json::fail('请先发货或者送货!');
+        if (!StoreOrderModel::edit($data, $id))
+            return Json::fail(StoreOrderModel::getErrorInfo('收货失败,请稍候再试!'));
+        else {
+            try {
+                OrderRepository::storeProductOrderTakeDeliveryAdmin($data, $id);
+            } catch (\Exception $e) {
+                return Json::fail($e->getMessage());
+            }
+            StoreOrderStatus::setStatus($id, 'take_delivery', '已收货');
+            return Json::successful('收货成功!');
+        }
+    }
+
+    /**
+     * 修改退款状态
+     * @param $id
+     * @return \think\response\Json|void
+     */
+    public function refund_y($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['paid'] == 1) {
+            $this->assign([
+                'title' => '退款', 'rules' => $this->readRefundY($id)->getContent(),
+                'action' => Url::buildUrl('updateRefundY', array('id' => $id))
+            ]);
+            return $this->fetch('public/common_form');
+        } else return Json::fail('数据不存在!');
+    }
+
+    public function readRefundY($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        Form::text('order_id', '退款单号', $product->getData('order_id'))->readonly();
+        Form::number('refund_price', '退款金额', $product->getData('pay_price'))->min(0);
+        Form::radio('type', '状态', [['label' => '直接退款', 'value' => 1], ['label' => '退款后,返回原状态', 'value' => 2]], 1);
+        return Form::builder();
+    }
+
+    public function updateRefundY($id)
+    {
+        $data = Util::postMore([
+            'refund_price',
+            ['type', 1],
+        ]);
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['pay_price'] == $product['refund_price']) return Json::fail('已退完支付金额!不能再退款了');
+        if (!$data['refund_price']) return Json::fail('请输入退款金额');
+        $refund_price = $data['refund_price'];
+        $data['refund_price'] = bcadd($data['refund_price'], $product['refund_price'], 2);
+        $bj = bccomp((float)$product['pay_price'], (float)$data['refund_price'], 2);
+        if ($bj < 0) return Json::fail('退款金额大于支付金额,请修改退款金额');
+        if ($data['type'] == 1) {
+            $data['refund_status'] = 2;
+        } else if ($data['type'] == 2) {
+            $data['refund_status'] = 0;
+        }
+        $type = $data['type'];
+        unset($data['type']);
+        $refund_data['pay_price'] = $product['pay_price'];
+        $refund_data['refund_price'] = $refund_price;
+        if ($product['pay_type'] == 'weixin') {
+            if ($product['is_channel'] == 1) {//TODO 小程序
+                try {
+                    MiniProgramService::payOrderRefund($product['order_id'], $refund_data);//2.5.36
+                } catch (\Exception $e) {
+                    return Json::fail($e->getMessage());
+                }
+            } else { //TODO 公众号
+                try {
+                    WechatService::payOrderRefund($product['order_id'], $refund_data);
+                } catch (\Exception $e) {
+                    return Json::fail($e->getMessage());
+                }
+            }
+
+        } else if ($product['pay_type'] == 'yue') {
+            BaseModel::beginTrans();
+            $usermoney = User::where('uid', $product['uid'])->value('now_money');
+            $res1 = User::bcInc($product['uid'], 'now_money', $refund_price, 'uid');
+            $res2 = $res2 = UserBill::income('商品退款', $product['uid'], 'now_money', 'pay_product_refund', $refund_price, $product['id'], bcadd($usermoney, $refund_price, 2), '订单退款到余额' . floatval($refund_price) . '元');
+            try {
+                OrderRepository::storeOrderYueRefund($product, $refund_data);
+            } catch (\Exception $e) {
+                BaseModel::rollbackTrans();
+                return Json::fail($e->getMessage());
+            }
+            $res = $res1 && $res2;
+            BaseModel::checkTrans($res);
+            if (!$res) return Json::fail('余额退款失败!');
+        }
+        $resEdit = StoreOrderModel::edit($data, $id);
+        if ($resEdit) {
+            $data['type'] = $type;
+            if ($data['type'] == 1) StorePink::setRefundPink($id);
+            try {
+                OrderRepository::storeProductOrderRefundY($data, $id);
+            } catch (\Exception $e) {
+                return Json::fail($e->getMessage());
+            }
+            StoreOrderStatus::setStatus($id, 'refund_price', '退款给用户' . $refund_price . '元');
+            return Json::successful('修改成功!');
+        } else {
+            StoreOrderStatus::setStatus($id, 'refund_price', '退款给用户' . $refund_price . '元失败');
+            return Json::fail('修改失败!');
+        }
+    }
+
+    public function order_info($oid = '')
+    {
+        if (!$oid || !($orderInfo = StoreOrderModel::get($oid)))
+            return $this->failed('订单不存在!');
+        $userInfo = User::getUserInfo($orderInfo['uid']);
+        if ($userInfo['spread_uid']) {
+            $spread = User::where('uid', $userInfo['spread_uid'])->value('nickname');
+        } else {
+            $spread = '';
+        }
+        $this->assign(compact('orderInfo', 'userInfo', 'spread'));
+        return $this->fetch();
+    }
+
+    public function express($oid = '')
+    {
+        if (!$oid || !($order = StoreOrderModel::get($oid)))
+            return $this->failed('订单不存在!');
+        if ($order['delivery_type'] != 'express' || !$order['delivery_id']) return $this->failed('该订单不存在快递单号!');
+        $cacheName = $order['order_id'] . $order['delivery_id'];
+        $result = CacheService::get($cacheName, null);
+        if ($result === null) {
+            try {
+                $result = ExpressService::query($order['delivery_id'], $order['delivery_name']);
+            } catch (\Throwable $e) {
+                $result = [];
+            }
+            if (is_array($result) && (isset($result['result']) || isset($result['content']))) {
+                $cacheTime = 1200;
+                if(isset($result['content'])){
+                    $result['result'] = $result['content'];
+                    unset($result['content']);
+                }
+            }else
+                $cacheTime = 1800;
+            CacheService::set($cacheName, $result, $cacheTime);
+        }
+        $this->assign([
+            'order' => $order,
+            'express' => $result
+        ]);
+        return $this->fetch();
+    }
+
+    /**
+     * 修改配送信息
+     * @param $id
+     * @return mixed|\think\response\Json|void
+     */
+    public function distribution($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $this->assign([
+            'title' => '配送信息', 'rules' => $this->readDistribution($id)->getContent(),
+            'action' => Url::buildUrl('updateDistribution', array('id' => $id))
+        ]);
+        return $this->fetch('public/common_form');
+    }
+
+    public function readDistribution($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['delivery_type'] == 'send') {
+            Form::text('delivery_name', '送货人姓名', $product->getData('delivery_name'));
+            Form::text('delivery_id', '送货人电话', $product->getData('delivery_id'))->number();
+        } else if ($product['delivery_type'] == 'express') {
+            Form::select('delivery_name', '快递公司', function () {
+                $list = Express::where('is_show', 1)->column('name', 'id');
+                $menus = [];
+                foreach ($list as $k => $v) {
+                    $menus[] = ['value' => $v, 'label' => $v];
+                }
+                return $menus;
+            }, $product->getData('delivery_name'))->filterable();
+            Form::text('delivery_id', '快递单号', $product->getData('delivery_id'));
+        }
+        return Form::builder();
+    }
+
+    public function updateDistribution($id)
+    {
+        $data = Util::postMore([
+            'delivery_name',
+            'delivery_id',
+        ]);
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['delivery_type'] == 'send') {
+            if (!$data['delivery_name']) return Json::fail('请输入送货人姓名');
+            if (!(int)$data['delivery_id']) return Json::fail('请输入送货人电话号码');
+            else if (!preg_match("/^1[3456789]{1}\d{9}$/", $data['delivery_id'])) return Json::fail('请输入正确的送货人电话号码');
+        } else if ($product['delivery_type'] == 'express') {
+            if (!$data['delivery_name']) return Json::fail('请选择快递公司');
+            if (!$data['delivery_id']) return Json::fail('请输入快递单号');
+        }
+        StoreOrderModel::edit($data, $id);
+        event('StoreProductOrderDistributionAfter', [$data, $id]);
+        StoreOrderStatus::setStatus($id, 'distribution', '修改发货信息为' . $data['delivery_name'] . '号' . $data['delivery_id']);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 修改退款状态
+     * @param $id
+     * @return mixed|\think\response\Json|void
+     */
+    public function refund_n($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $this->assign([
+            'title' => '退款', 'rules' => $this->readRefundN($id)->getContent(),
+            'action' => Url::buildUrl('updateRefundN', array('id' => $id))
+        ]);
+        return $this->fetch('public/common_form');
+    }
+
+    public function readRefundN($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        Form::text('order_id', '退款单号', $product->getData('order_id'))->readonly();
+        Form::textarea('refund_reason', '退款原因');
+        return Form::builder();
+    }
+
+    public function updateRefundN($id)
+    {
+        $data = Util::postMore([
+            'refund_reason',
+        ]);
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if (!$data['refund_reason']) return Json::fail('请输入退款原因');
+        $data['refund_status'] = 0;
+        StoreOrderModel::edit($data, $id);
+        event('StoreProductOrderRefundNAfter', [$data['refund_reason'], $id]);
+        StoreOrderStatus::setStatus($id, 'refund_n', '不退款原因:' . $data['refund_reason']);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 立即支付
+     * @param $id
+     */
+    public function offline($id)
+    {
+        $res = StoreOrderModel::updateOffline($id);
+        if ($res) {
+            event('StoreProductOrderOffline', [$id]);
+            StoreOrderStatus::setStatus($id, 'offline', '线下付款');
+            return Json::successful('修改成功!');
+        } else {
+            return Json::fail(StoreOrderModel::getErrorInfo('修改失败!'));
+        }
+    }
+
+    /**
+     * 修改积分和金额
+     * @param $id
+     * @return mixed|\think\response\Json|void
+     */
+    public function integral_back($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['paid'] == 1) {
+            $this->assign([
+                'title' => '退积分', 'rules' => $this->readIntegralBack($id)->getContent(),
+                'action' => Url::buildUrl('updateIntegralBack', array('id' => $id))
+            ]);
+        } else {
+            return Json::fail('参数错误!');
+        }
+        return $this->fetch('public/common_form');
+    }
+
+    public function readIntegralBack($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        Form::text('order_id', '退积分单号', $product->getData('order_id'))->readonly();
+        Form::number('back_integral', '退积分')->min(0);
+        return Form::builder();
+    }
+
+    public function updateIntegralBack($id)
+    {
+        $data = Util::postMore([
+            'back_integral',
+        ]);
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreOrderModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($data['back_integral'] <= 0) return Json::fail('请输入积分');
+        if ($product['use_integral'] == $product['back_integral']) return Json::fail('已退完积分!不能再积分了');
+        $back_integral = $data['back_integral'];
+        $data['back_integral'] = bcadd($data['back_integral'], $product['back_integral'], 2);
+        $bj = bccomp((float)$product['use_integral'], (float)$data['back_integral'], 2);
+        if ($bj < 0) return Json::fail('退积分大于支付积分,请修改退积分');
+        BaseModel::beginTrans();
+        $integral = User::where('uid', product['uid'])->value('integral');
+        $res1 = User::bcInc($product['uid'], 'integral', $back_integral, 'uid');
+        $res2 = UserBill::income('商品退积分', $product['uid'], 'integral', 'pay_product_integral_back', $back_integral, $product['id'], bcadd($integral, $back_integral, 2), '订单退积分' . floatval($back_integral) . '积分到用户积分');
+        try {
+            OrderRepository::storeOrderIntegralBack($product, $back_integral);
+        } catch (\Exception $e) {
+            BaseModel::rollbackTrans();
+            return Json::fail($e->getMessage());
+        }
+        $res = $res1 && $res2;
+        BaseModel::checkTrans($res);
+        if (!$res) return Json::fail('退积分失败!');
+        StoreOrderModel::edit($data, $id);
+        StoreOrderStatus::setStatus($id, 'integral_back', '商品退积分:' . $data['back_integral']);
+        return Json::successful('退积分成功!');
+    }
+
+    public function remark()
+    {
+        $data = Util::postMore(['id', 'remark']);
+        if (!$data['id']) return Json::fail('参数错误!');
+        if ($data['remark'] == '') return Json::fail('请输入要备注的内容!');
+        $id = $data['id'];
+        unset($data['id']);
+        StoreOrderModel::edit($data, $id);
+        return Json::successful('备注成功!');
+    }
+
+    public function order_status($oid)
+    {
+        if (!$oid) return $this->failed('数据不存在');
+        $this->assign(StoreOrderStatus::systemPage($oid));
+        return $this->fetch();
+    }
+}

+ 733 - 0
app/admin/controller/record/Record.php

@@ -0,0 +1,733 @@
+<?php
+/**
+ * Created by PhpStorm.
+ * User: xurongyao <763569752@qq.com>
+ * Date: 2018/6/14 下午5:25
+ */
+
+namespace app\admin\controller\record;
+
+use app\admin\controller\AuthController;
+use app\admin\model\store\{StoreProduct, StoreCouponUser};
+use app\admin\model\order\StoreOrder;
+use app\admin\model\ump\{StoreBargain, StoreSeckill, StoreCombination};
+use crmeb\services\{JsonService, UtilService as Util};
+use app\admin\model\user\{User, UserBill, UserExtract};
+
+/**
+ * 微信充值记录
+ * Class UserRecharge
+ * @package app\admin\controller\user
+ */
+class Record extends AuthController
+{
+    /**
+     * 显示操作记录
+     */
+    public function index()
+    {
+
+
+    }
+
+    /**
+     * 显示订单记录
+     */
+    public function chart_order()
+    {
+        $this->assign([
+            'is_layui' => true,
+            'year' => get_month()
+        ]);
+        return $this->fetch();
+    }
+
+    public function get_echarts_order()
+    {
+        $where = Util::getMore([
+            ['type', ''],
+            ['status', ''],
+            ['data', ''],
+        ]);
+        return JsonService::successful(StoreOrder::getEchartsOrder($where));
+    }
+
+    /**
+     * 显示产品记录
+     */
+    public function chart_product()
+    {
+        $this->assign([
+            'is_layui' => true,
+            'year' => get_month()
+        ]);
+        return $this->fetch();
+    }
+
+    /**
+     * 获取产品曲线图数据
+     */
+    public function get_echarts_product($type = '', $data = '')
+    {
+        return JsonService::successful(StoreProduct::getChatrdata($type, $data));
+
+    }
+
+    /**
+     * 获取销量
+     */
+    public function get_echarts_maxlist($data = '')
+    {
+        return JsonService::successful(StoreProduct::getMaxList(compact('data')));
+    }
+
+    /**
+     * 获取利润
+     */
+    public function get_echarts_profity($data = '')
+    {
+        return JsonService::successful(StoreProduct::ProfityTop10(compact('data')));
+    }
+
+    /**
+     * 获取缺货列表
+     */
+    public function getLackList()
+    {
+        $where = Util::getMore([
+            ['page', 1],
+            ['limit', 20],
+        ]);
+        return JsonService::successlayui(StoreProduct::getLackList($where));
+    }
+
+    /**
+     * 表单快速修改
+     */
+    public function editField($id = '')
+    {
+        $post = $this->request->post();
+        StoreProduct::beginTrans();
+        try {
+            StoreProduct::edit($post, $id);
+            StoreProduct::commitTrans();
+            return JsonService::successful('修改成功');
+        } catch (\Exception $e) {
+            StoreProduct::rollbackTrans();
+            return JsonService::fail($e->getMessage());
+        }
+    }
+
+    //获取差评
+    public function getnegativelist()
+    {
+        $where = Util::getMore([
+            ['page', 1],
+            ['limit', 10],
+        ]);
+        return JsonService::successful(StoreProduct::getnegativelist($where));
+    }
+
+    /**
+     * 获取退货
+     */
+    public function getTuiPriesList()
+    {
+        return JsonService::successful(StoreProduct::TuiProductList());
+    }
+    //营销统计
+
+    /**
+     * 显示积分统计
+     */
+    public function chart_score()
+    {
+        $this->assign([
+            'is_layui' => true,
+            'year' => get_month()
+        ]);
+        return $this->fetch();
+    }
+
+    /**
+     * 获取积分头部信息
+     */
+    public function getScoreBadgeList($data = '')
+    {
+        return JsonService::successful(UserBill::getScoreBadgeList(compact('data')));
+    }
+
+    /**
+     * 获取积分曲线图和柱状图
+     */
+    public function getScoreCurve($data = '', $limit = 20)
+    {
+        return JsonService::successful(UserBill::getScoreCurve(compact('data', 'limit')));
+    }
+
+    /**
+     * 显示优惠券统计
+     */
+    public function chart_coupon()
+    {
+        $this->assign([
+            'is_layui' => true,
+            'year' => get_month()
+        ]);
+        return $this->fetch();
+    }
+
+    /**
+     * 获取优惠劵头部信息
+     */
+    public function getCouponBadgeList($data = '')
+    {
+        return JsonService::successful(StoreCouponUser::getCouponBadgeList(compact('data')));
+    }
+
+    /**
+     * 获取优惠劵数据图表
+     */
+    public function getConponCurve($data = '')
+    {
+        return JsonService::successful(StoreCouponUser::getConponCurve(compact('data')));
+    }
+
+    /**
+     * 显示拼团统计
+     */
+    public function chart_combination()
+    {
+        $this->assign([
+            'is_layui' => true,
+            'year' => get_month()
+        ]);
+        return $this->fetch();
+    }
+
+    /**
+     * 显示砍价统计
+     */
+    public function chart_bargain()
+    {
+        $this->assign([
+            'is_layui' => true,
+            'year' => get_month()
+        ]);
+        return $this->fetch();
+    }
+
+    /**
+     * 显示秒杀统计
+     */
+    public function chart_seckill()
+    {
+        $this->assign([
+            'is_layui' => true,
+            'year' => get_month()
+        ]);
+        return $this->fetch();
+    }
+    //财务统计
+
+    /**
+     * 显示反佣统计
+     */
+    public function chart_rebate()
+    {
+        $this->assign([
+            'is_layui' => true,
+            'year' => get_month()
+        ]);
+        return $this->fetch();
+    }
+
+    //获取用户返佣柱状图
+    public function getUserBillBrokerage($data = '')
+    {
+        return JsonService::successful(UserBill::getUserBillChart(compact('data')));
+    }
+
+    //获取用户返佣头部信息
+    public function getRebateBadge($data = '')
+    {
+        return JsonService::successful(UserBill::getRebateBadge(compact('data')));
+    }
+
+    //获得 返佣列表,带分页
+    public function getFanList($page = 1, $limit = 20)
+    {
+        return JsonService::successful(UserBill::getFanList(compact('page', 'limit')));
+    }
+
+    //获得 返佣总次数
+    public function getFanCount()
+    {
+        return JsonService::successful(UserBill::getFanCount());
+    }
+
+    /**
+     * 显示充值统计
+     */
+    public function chart_recharge()
+    {
+        $this->assign([
+            'is_layui' => true,
+            'year' => get_month()
+        ]);
+        return $this->fetch();
+    }
+
+    /**
+     * 获取用户充值柱状图和曲线图
+     */
+    public function getEchartsRecharge($data = '')
+    {
+        return JsonService::successful(UserBill::getEchartsRecharge(compact('data')));
+    }
+
+    /**
+     * 显示提现统计
+     */
+    public function chart_cash()
+    {
+        $this->assign([
+            'is_layui' => true,
+            'year' => get_month()
+        ]);
+        return $this->fetch();
+    }
+
+    //获取提现头部信息
+    public function getExtractHead($data = '')
+    {
+        return JsonService::successful(UserExtract::getExtractHead(compact('data')));
+    }
+    //会员统计
+
+    /**
+     * 显示用户统计
+     */
+    public function user_chart()
+    {
+        $this->assign([
+            'is_layui' => true,
+            'year' => get_month()
+        ]);
+        return $this->fetch();
+    }
+
+    /**
+     * 获取头部信息
+     *
+     * 人数 增长 分销人数 分销增长
+     */
+    public function getBadgeList($data = '', $is_promoter = '', $status = '')
+    {
+        return JsonService::successful(User::getBadgeList(compact('data', 'is_promoter', 'status')));
+    }
+
+    /*
+     * 获取用户增长曲线图
+     *
+     */
+    public function getUserChartList($data = '', $is_promoter = '', $status = '')
+    {
+        return JsonService::successful(User::getUserChartList(compact('data', 'is_promoter', 'status')));
+    }
+
+    /*
+     * 获取提现分布图和提现人数金额曲线图
+     *
+     */
+    public function getExtractData($data = '')
+    {
+        return JsonService::successful(UserExtract::getExtractList(compact('data')));
+    }
+
+    /*
+     * 分销会员统计
+     *
+     */
+    public function user_distribution_chart()
+    {
+        $limit = 10;
+        $top10list = User::getUserDistributionTop10List($limit);
+        $this->assign([
+            'is_layui' => true,
+            'limit' => $limit,
+            'year' => get_month(),
+            'commissionList' => $top10list['commission'],
+            'extractList' => $top10list['extract'],
+        ]);
+        return $this->fetch();
+    }
+
+    /*
+     * 获取分销会员统计会员头部详情
+     *
+     */
+    public function getDistributionBadgeList($data = '')
+    {
+        return JsonService::successful(User::getDistributionBadgeList(compact('data')));
+    }
+
+    /*
+     * 获取分销会员统计图表数据
+     *
+     * $data 时间范围
+     *
+     */
+    public function getUserDistributionChart($data = '')
+    {
+        return JsonService::successful(User::getUserDistributionChart(compact('data')));
+    }
+
+    /**
+     * 会员业务
+     */
+    public function user_business_chart()
+    {
+        $limit = 10;
+        $top10list = User::getUserTop10List($limit);
+        $this->assign([
+            'is_layui' => true,
+            'limit' => $limit,
+            'year' => get_month(),
+            'integralList' => $top10list['integral'],
+            'moneyList' => $top10list['now_money'],
+            'shopcountList' => $top10list['shopcount'],
+            'orderList' => $top10list['order'],
+            'lastorderList' => $top10list['lastorder']
+        ]);
+        return $this->fetch();
+    }
+
+    /*
+     * 获取 会员业务的
+     * 购物会员统计
+     * 分销商业务人数和提现人数统计
+     * 分销商业务佣金和提现金额统计
+     * 曲线图
+     * $data 时间
+     */
+    public function getUserBusinessChart($data = '')
+    {
+        return JsonService::successful(User::getUserBusinessChart(compact('data')));
+    }
+
+    /*
+    * 获取 会员业务
+    * 会员总余额 分销商总佣金 分销商总佣金余额 分销商总提现佣金 本月分销商业务佣金 本月分销商佣金提现金额
+    * 上月分销商业务佣金 上月分销商佣金提现金额
+    * $where 查询条件
+    *
+    * return array
+    */
+    public function getUserBusinesHeade($data)
+    {
+        return JsonService::successful(User::getUserBusinesHeade(compact('data')));
+    }
+
+    /**
+     * 显示用户属性统计
+     */
+    public function user_attr()
+    {
+        $this->assign([
+            'is_layui' => true,
+            'year' => get_month()
+        ]);
+        return $this->fetch();
+    }
+
+    /**
+     * 获取用户属性统计
+     */
+    public function getEchartsData($data = '')
+    {
+        return JsonService::successful(User::getEchartsData(compact('data')));
+    }
+    //排行榜
+
+    /**
+     * 显示产品排行榜
+     */
+    public function ranking_saleslists()
+    {
+        $this->assign([
+            'is_layui' => true,
+        ]);
+        return $this->fetch();
+    }
+
+    /*
+     *获取产品排行 带分页
+     */
+    public function getSaleslists($start_time = '', $end_time = '', $title = '', $page = 1, $limit = 20)
+    {
+        return JsonService::successlayui(StoreProduct::getSaleslists(compact('start_time', 'end_time', 'title', 'page', 'limit')));
+    }
+
+    /*
+     *生成表格,并下载
+     */
+    public function save_product_export($start_time = '', $end_time = '', $title = '')
+    {
+        return JsonService::successlayui(StoreProduct::SaveProductExport(compact('start_time', 'end_time', 'title')));
+    }
+
+    /*
+     *获取单个商品的详情
+     */
+    public function product_info($id = '')
+    {
+        if ($id == '') $this->failed('缺少商品id');
+        if (!StoreProduct::be(['id' => $id])) return $this->failed('商品不存在!');
+        $this->assign([
+            'is_layui' => true,
+            'year' => get_month(),
+            'id' => $id,
+        ]);
+        return $this->fetch();
+    }
+
+    /*
+     *获取单个商品的详情头部信息
+     */
+    public function getProductBadgeList($id = '', $data = '')
+    {
+        return JsonService::successful(StoreProduct::getProductBadgeList($id, $data));
+    }
+
+    /*
+     *获取单个商品的销售曲线图
+     */
+    public function getProductCurve($id = '', $data = '', $limit = 20)
+    {
+        return JsonService::successful(StoreProduct::getProductCurve(compact('id', 'data', 'limit')));
+    }
+
+    /*
+     *获取单个商品的销售总条数
+     */
+    public function getProductCount($id, $data = '')
+    {
+        return JsonService::successful(StoreProduct::setWhere(compact('data'))
+            ->where('a.product_id', $id)
+            ->join('user c', 'c.uid=a.uid')
+            ->where('a.is_pay', 1)
+            ->count());
+    }
+
+    /*
+     *获取单个商品的销售列表
+     */
+    public function getSalelList($data = '', $id = 0, $page = 1, $limit = 20)
+    {
+        return JsonService::successful(StoreProduct::getSalelList(compact('data', 'id', 'page', 'limit')));
+    }
+
+    /**
+     * 显示反佣排行榜
+     */
+    public function ranking_commission()
+    {
+        $this->assign([
+            'is_layui' => true,
+            'year' => get_month()
+        ]);
+        return $this->fetch();
+    }
+
+    public function getcommissionlist($page = 1, $limit = 20)
+    {
+        return JsonService::successful(UserExtract::where('status', 1)
+            ->field(['real_name', 'extract_price', 'balance'])
+            ->order('extract_price desc')
+            ->page($page, $limit)
+            ->select());
+    }
+
+    public function getmonthcommissionlist($page = 1, $limit = 20)
+    {
+        return JsonService::successful(UserExtract::where('status', 1)
+            ->whereTime('add_time', 'month')
+            ->field(['real_name', 'extract_price', 'balance'])
+            ->order('extract_price desc')
+            ->page($page, $limit)
+            ->select());
+    }
+
+    //获取佣金返现总条数
+    public function getCommissonCount()
+    {
+        return JsonService::successful(UserExtract::where('status', 1)->count());
+    }
+
+    //获取本月佣金返现条数
+    public function getMonthCommissonCount()
+    {
+        return JsonService::successful(UserExtract::where('status', 1)->whereTime('add_time', 'month')->count());
+    }
+
+    /**
+     * 显示积分排行榜
+     */
+    public function ranking_point()
+    {
+        $this->assign([
+            'is_layui' => true,
+            'year' => get_month()
+        ]);
+        return $this->fetch();
+    }
+
+    //获取所有积分排行总人数
+    public function getPountCount()
+    {
+        return JsonService::successful(User::where('status', 1)->where('integral', '<>', 0)->count());
+    }
+
+    //获取积分排行列表
+    public function getpointList($page = 1, $limit = 20)
+    {
+        return JsonService::successful(($list = User::where('status', 1)
+            ->where('integral', '<>', 0)
+            ->field('nickname,integral')
+            ->order('integral desc')
+            ->page($page, $limit)
+            ->select()) && count($list) ? $list->toArray() : []);
+    }
+
+    //获取本月积分排行别表
+    public function getMonthpountList($page = 1, $limit = 20)
+    {
+        return JsonService::successful(($list = User::where('status', 1)
+            ->where('integral', '<>', 0)
+            ->whereTime('add_time', 'month')
+            ->order('integral desc')
+            ->field('nickname,integral')
+            ->page($page, $limit)
+            ->select()) && count($list) ? $list->toArray() : []);
+    }
+
+    public function getMonthPountCount()
+    {
+        return JsonService::successful(User::where('status', 1)->where('integral', '<>', 0)->whereTime('add_time', 'month')->count());
+    }
+
+    /**
+     *
+     * 显示下级会员排行榜
+     */
+    public function ranking_lower()
+    {
+        echo " 复购率 复购增长率 活跃度 活跃率 分销总金额 增长率 消费会员 非消费会员 消费排行榜 积分排行榜 余额排行榜 分销总金额排行榜 分销人数排行榜 分销余额排行榜 购物金额排行榜 购物次数排行榜 提现排行榜 ";
+    }
+
+    /**
+     * 获取砍价产品曲线图数据
+     */
+    public function get_mark_echarts_product($type = '', $data = '', $model = 0)
+    {
+        if (!$model) return JsonService::successful(StoreBargain::getChatrdata($type, $data));
+        if ($model) return JsonService::successful(StoreSeckill::getChatrdata($type, $data));
+    }
+
+    /**
+     * 获取拼团产品曲线图数据
+     */
+    public function get_combination_echarts_product($type = '', $data = '')
+    {
+        return JsonService::successful(StoreCombination::getChatrdata($type, $data));
+    }
+
+    /*
+     * 获取拼团销量
+    */
+    public function get_combination_maxlist($data = '')
+    {
+        return JsonService::successful(StoreCombination::getMaxList(compact('data')));
+    }
+
+    /*
+     *  拼团盈利
+     */
+    public function get_combination_profity($data = '')
+    {
+        return JsonService::successful(StoreCombination::ProfityTop10(compact('data')));
+    }
+
+    /*
+     *  拼团退货
+     */
+    public function get_combination_refund_list()
+    {
+        $where = Util::getMore([
+            ['page', 1],
+            ['limit', 20],
+        ]);
+        return JsonService::successlayui(StoreCombination::getBargainRefundList($where));
+    }
+
+    /**
+     * 获取销量
+     */
+    public function get_mark_echarts_maxlist($data = '', $model = 0)
+    {
+        if (!$model) return JsonService::successful(StoreBargain::getMaxList(compact('data')));
+        if ($model) return JsonService::successful(StoreSeckill::getMaxList(compact('data')));
+    }
+
+    /**
+     * 获取利润
+     */
+    public function get_mark_echarts_profity($data = '', $model = 0)
+    {
+        if (!$model) return JsonService::successful(StoreBargain::ProfityTop10(compact('data')));
+        if ($model) return JsonService::successful(StoreSeckill::ProfityTop10(compact('data')));
+    }
+
+    /**
+     * 获取补货的砍价产品
+     */
+    public function get_mark_lack_list($model = 0)
+    {
+        $where = Util::getMore([
+            ['page', 1],
+            ['limit', 20],
+        ]);
+        if (!$model) return JsonService::successlayui(StoreBargain::getLackList($where));
+        if ($model) return JsonService::successlayui(StoreSeckill::getLackList($where));
+    }
+
+    /**
+     * 获取砍价产品的评论
+     */
+    public function get_mark_negative_list($model = 0)
+    {
+        $where = Util::getMore([
+            ['page', 1],
+            ['limit', 20],
+        ]);
+        if (!$model) return JsonService::successlayui(StoreBargain::getNegativeList($where));
+        if ($model) return JsonService::successlayui(StoreSeckill::getNegativeList($where));
+    }
+
+    /**
+     * 获取砍价产品的退货
+     */
+    public function get_mark_bargain_refund_list($model = 0)
+    {
+        $where = Util::getMore([
+            ['page', 1],
+            ['limit', 20],
+        ]);
+        if (!$model) return JsonService::successlayui(StoreBargain::getBargainRefundList($where));
+        if ($model) return JsonService::successlayui(StoreSeckill::getBargainRefundList($where));
+    }
+
+
+}
+

+ 87 - 0
app/admin/controller/record/StoreStatistics.php

@@ -0,0 +1,87 @@
+<?php
+/**
+ * Created by PhpStorm.
+ * User: Administrator
+ * Date: 2018/4/16 0016
+ * Time: 10:39
+ */
+
+namespace app\admin\controller\record;
+
+use app\admin\controller\AuthController;
+use crmeb\services\UtilService as Util;
+use app\admin\model\record\StoreStatistics as StatisticsModel;
+
+/**
+ * Class StoreStatistics
+ * @package app\admin\controller\record
+ */
+class StoreStatistics extends AuthController
+{
+    /**
+     * 显示列表
+     */
+    public function index()
+    {
+        $where = Util::getMore([
+            ['date', ''],
+            ['export', ''],
+            ['data', '']
+        ], $this->request);
+        $where['date'] = $this->request->param('date');
+        $where['data'] = $this->request->param('data');
+        $where['export'] = $this->request->param('export');
+        $trans = StatisticsModel::trans();//最近交易
+        $seckill = StatisticsModel::getSeckill($where);//秒杀商品
+        $ordinary = StatisticsModel::getOrdinary($where);//普通商品
+        $pink = StatisticsModel::getPink($where);//拼团商品
+        $recharge = StatisticsModel::getRecharge($where);//充值
+        $extension = StatisticsModel::getExtension($where);//推广金
+        $orderCount = [
+            urlencode('微信支付') => StatisticsModel::getTimeWhere($where, StatisticsModel::statusByWhere('weixin'))->count(),
+            urlencode('余额支付') => StatisticsModel::getTimeWhere($where, StatisticsModel::statusByWhere('yue'))->count(),
+            urlencode('线下支付') => StatisticsModel::getTimeWhere($where, StatisticsModel::statusByWhere('offline'))->count(),
+        ];
+        $Statistic = [
+            ['name' => '营业额', 'type' => 'line', 'data' => []],
+            ['name' => '支出', 'type' => 'line', 'data' => []],
+            ['name' => '盈利', 'type' => 'line', 'data' => []],
+        ];
+        $orderinfos = StatisticsModel::getOrderInfo($where);
+        $orderinfo = $orderinfos['orderinfo'];
+        $orderDays = [];
+        if (empty($orderinfo)) {
+            $orderDays[] = date('Y-m-d', time());
+            $Statistic[0]['data'][] = 0;
+            $Statistic[1]['data'][] = 0;
+            $Statistic[2]['data'][] = 0;
+        }
+        foreach ($orderinfo as $info) {
+            $orderDays[] = $info['pay_time'];
+            $Statistic[0]['data'][] = $info['total_price'] + $info['pay_postage'];
+            $Statistic[1]['data'][] = $info['coupon_price'] + $info['deduction_price'] + $info['cost'];
+            $Statistic[2]['data'][] = ($info['total_price'] + $info['pay_postage']) - ($info['coupon_price'] + $info['deduction_price'] + $info['cost']);
+        }
+        $price = $orderinfos['price'] + $orderinfos['postage'];
+        $cost = $orderinfos['deduction'] + $orderinfos['coupon'] + $orderinfos['cost'];
+        $Consumption = StatisticsModel::getConsumption($where)['number'];
+        $header = [
+            ['name' => '总营业额', 'class' => 'fa-line-chart', 'value' => '¥' . $price, 'color' => 'red'],
+            ['name' => '总支出', 'class' => 'fa-area-chart', 'value' => '¥' . ($cost + $extension), 'color' => 'lazur'],
+            ['name' => '总盈利', 'class' => 'fa-bar-chart', 'value' => '¥' . bcsub($price, $cost, 0), 'color' => 'navy'],
+            ['name' => '新增消费', 'class' => 'fa-pie-chart', 'value' => '¥' . ($Consumption == 0 ? 0 : $Consumption), 'color' => 'yellow']
+        ];
+        $data = [
+            ['value' => $orderinfos['cost'], 'name' => '商品成本'],
+            ['value' => $orderinfos['coupon'], 'name' => '优惠券抵扣'],
+            ['value' => $orderinfos['deduction'], 'name' => '积分抵扣'],
+            ['value' => $extension, 'name' => '推广人佣金']
+        ];
+
+        $this->assign(StatisticsModel::systemTable($where));
+        $this->assign(compact('where', 'trans', 'orderCount', 'orderDays', 'header', 'Statistic', 'ordinary', 'pink', 'recharge', 'data', 'seckill'));
+        $this->assign('price', StatisticsModel::getOrderPrice($where));
+
+        return $this->fetch();
+    }
+}

+ 175 - 0
app/admin/controller/routine/RoutineTemplate.php

@@ -0,0 +1,175 @@
+<?php
+
+namespace app\admin\controller\routine;
+
+use app\admin\controller\AuthController;
+use crmeb\services\CacheService;
+use crmeb\services\FormBuilder as Form;
+use crmeb\services\UtilService as Util;
+use crmeb\services\JsonService as Json;
+use think\facade\Route as Url;
+use app\admin\model\routine\RoutineTemplate as RoutineTemplateModel;
+use crmeb\services\MiniProgramService;
+
+/**
+ * 小程序模板消息控制器
+ * Class RoutineTemplate
+ * @package app\admin\controller\routine
+ */
+class RoutineTemplate extends AuthController
+{
+    public function index()
+    {
+        $where = Util::getMore([
+            ['name', ''],
+            ['status', '']
+        ], $this->request);
+        $this->assign('where', $where);
+        $this->assign(RoutineTemplateModel::SystemPage($where));
+        return $this->fetch();
+    }
+
+    /**
+     * 添加模板消息
+     * @return mixed
+     */
+    public function create()
+    {
+        $f = array();
+        $f[] = Form::input('tempkey', '模板编号');
+        $f[] = Form::input('tempid', '模板ID');
+        $f[] = Form::input('name', '模板名');
+        $f[] = Form::input('content', '回复内容')->type('textarea');
+        $f[] = Form::radio('status', '状态', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]]);
+        $form = Form::make_post_form('添加模板消息', $f, Url::buildUrl('save'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    public function save()
+    {
+        $data = Util::postMore([
+            'tempkey',
+            'tempid',
+            'name',
+            'content',
+            ['status', 0]
+        ]);
+        if ($data['tempkey'] == '') return Json::fail('请输入模板编号');
+        if ($data['tempkey'] != '' && RoutineTemplateModel::be($data['tempkey'], 'tempkey'))
+            return Json::fail('请输入模板编号已存在,请重新输入');
+        if ($data['tempid'] == '') return Json::fail('请输入模板ID');
+        if ($data['name'] == '') return Json::fail('请输入模板名');
+        if ($data['content'] == '') return Json::fail('请输入回复内容');
+        $data['add_time'] = time();
+        $data['type'] = 0;
+        RoutineTemplateModel::create($data);
+        CacheService::clear();
+        return Json::successful('添加模板消息成功!');
+    }
+
+    /**
+     * 编辑模板消息
+     * @param $id
+     * @return mixed|\think\response\Json|void
+     */
+    public function edit($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = RoutineTemplateModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $f = array();
+        $f[] = Form::input('tempkey', '模板编号', $product->getData('tempkey'))->disabled(1);
+        $f[] = Form::input('name', '模板名', $product->getData('name'))->disabled(1);
+        $f[] = Form::input('tempid', '模板ID', $product->getData('tempid'));
+        $f[] = Form::radio('status', '状态', $product->getData('status'))->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]]);
+        $form = Form::make_post_form('编辑模板消息', $f, Url::buildUrl('update', compact('id')));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    public function update($id)
+    {
+        $data = Util::postMore([
+            'tempid',
+            ['status', 0]
+        ]);
+        if ($data['tempid'] == '') return Json::fail('请输入模板ID');
+        if (!$id) return $this->failed('数据不存在');
+        $product = RoutineTemplateModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        RoutineTemplateModel::edit($data, $id);
+        CacheService::clear();
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 删除模板消息
+     * @param $id
+     * @return \think\response\Json
+     */
+    public function delete($id)
+    {
+        if (!$id) return Json::fail('数据不存在!');
+        if (!RoutineTemplateModel::del($id))
+            return Json::fail(RoutineTemplateModel::getErrorInfo('删除失败,请稍候再试!'));
+        else {
+            CacheService::clear();
+            return Json::successful('删除成功!');
+        }
+    }
+
+    /**
+     * 同步订阅消息
+     * @return mixed
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function syncSubscribe()
+    {
+        $all = RoutineTemplateModel::where(['status' => 1, 'type' => 0])->select();
+        $errData = [];
+        if ($all) {
+            $time = time();
+            foreach ($all as $template) {
+                if ($template['tempkey']) {
+                    if (!isset($template['kid'])) {
+                        return Json::fail('数据库模版表(template_message)缺少字段:kid');
+                    }
+                    $works = [];
+                    try {
+                        $works = MiniProgramService::getSubscribeTemplateKeyWords($template['tempkey']);
+                    } catch (\Throwable $e) {
+                        $errData[] = $template['name'] . '获取关键词列表失败';
+                    }
+                    $kid = [];
+                    if ($works) {
+                        $works = array_combine(array_column($works, 'name'), $works);
+                        $content = is_array($template['content']) ? $template['content'] : explode("\n", $template['content']);
+                        foreach ($content as $c) {
+                            $name = explode('{{', $c)[0] ?? '';
+                            if ($name && isset($works[$name])) {
+                                $kid[] = $works[$name]['kid'];
+                            }
+                        }
+                    }
+                    if ($kid && isset($template['kid']) && !$template['kid']) {
+                        $tempid = '';
+                        try {
+                            $tempid = MiniProgramService::addSubscribeTemplate($template['tempkey'], $kid, $template['name']);
+                        } catch (\Throwable $e) {
+                            $errData[] = $template['name'] . '添加订阅消息模版失败';
+                        }
+                        if ($tempid != $template['tempid']) {
+                            RoutineTemplateModel::update(['tempid' => $tempid, 'kid' => json_encode($kid), 'add_time' => $time], ['id' => $template['id']]);
+                        }
+                    }
+                }
+
+            }
+        }
+        $msg = $errData ? implode('\n', $errData) : '同步成功';
+        return Json::success($msg);
+    }
+}

+ 184 - 0
app/admin/controller/setting/ShippingTemplates.php

@@ -0,0 +1,184 @@
+<?php
+
+namespace app\admin\controller\setting;
+
+use app\admin\controller\AuthController;
+use app\admin\model\system\ShippingTemplatesFree;
+use app\admin\model\system\ShippingTemplatesRegion;
+use crmeb\services\UtilService;
+use crmeb\services\JsonService;
+use app\admin\model\system\SystemCity;
+use app\admin\model\system\ShippingTemplates as STModel;
+
+class ShippingTemplates extends AuthController
+{
+    /**
+     * 列表页面
+     * @return string
+     * @throws \Exception
+     */
+    public function index()
+    {
+        return $this->fetch();
+    }
+
+    /**
+     * 添加页面
+     * @return string
+     * @throws \Exception
+     */
+    public function add($id = 0)
+    {
+        $this->assign(compact('id'));
+        return $this->fetch();
+    }
+
+    /**
+     * 修改
+     * @return string
+     * @throws \Exception
+     */
+    public function edit($id = 0)
+    {
+        $templates = STModel::get($id);
+        if (!$templates) {
+            return JsonService::fail('修改的模板不存在');
+        }
+        $data['appointList'] = ShippingTemplatesFree::getFreeList($id);
+        $data['templateList'] = ShippingTemplatesRegion::getRegionList($id);
+        if (!isset($data['templateList'][0]['region'])) {
+            $data['templateList'][0]['region'] = ['city_id' => 0, 'name' => '默认全国'];
+        }
+        $data['formData'] = [
+            'name' => $templates->name,
+            'type' => $templates->getData('type'),
+            'appoint_check' => $templates->getData('appoint'),
+            'sort' => $templates->getData('sort'),
+        ];
+        return JsonService::successful($data);
+    }
+
+    /**
+     * 选择城市页面
+     * @return string
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function city()
+    {
+        $data = UtilService::getMore([
+            ['type', 0],
+            ['isedit', 0]
+        ]);
+        $this->assign('is_layui', true);
+        $this->assign($data);
+        return $this->fetch();
+    }
+
+    public function city_list()
+    {
+        $list = SystemCity::with('children')->where('parent_id', 0)->order('id asc')->select();
+        return app('json')->success($list->toArray());
+    }
+
+    /**
+     * 列表数据
+     */
+    public function temp_list()
+    {
+        $where = UtilService::postMore([
+            ['page', 1],
+            ['limit', 20],
+            ['name', '']
+        ]);
+        return JsonService::successlayui(STModel::getList($where));
+    }
+
+    /**
+     * 保存或者修改
+     * @param int $id
+     */
+    public function save($id = 0)
+    {
+        $data = UtilService::postMore([
+            ['region_info', []],
+            ['appoint_info', []],
+            ['sort', 0],
+            ['type', 0],
+            ['name', ''],
+            ['appoint', 0],
+        ]);
+        $temp['name'] = $data['name'];
+        $temp['type'] = $data['type'];
+        $temp['appoint'] = $data['appoint'];
+        $temp['sort'] = $data['sort'];
+        $temp['add_time'] = time();
+        STModel::beginTrans();
+        $res = true;
+        try {
+            if ($id) {
+                $res = STModel::where('id', $id)->update($temp);
+            } else {
+                $id = STModel::insertGetId($temp);
+            }
+            //设置区域配送
+            $res = $res && ShippingTemplatesRegion::saveRegion($data['region_info'], $data['type'], $id);
+            if (!$res) {
+                STModel::rollbackTrans();
+                return JsonService::fail(ShippingTemplatesRegion::getErrorInfo());
+            }
+            //设置指定包邮
+            if ($data['appoint']) {
+                $res = $res && ShippingTemplatesFree::saveFree($data['appoint_info'], $data['type'], $id);
+            } else {
+                if ($id) {
+                    if (ShippingTemplatesFree::where('temp_id', $id)->count()) {
+                        $res = $res && ShippingTemplatesFree::where('temp_id', $id)->delete();
+                    }
+                }
+            }
+            if ($res) {
+                STModel::commitTrans();
+                return JsonService::successful('保存成功');
+            } else {
+                STModel::rollbackTrans();
+                return JsonService::fail(ShippingTemplatesFree::getErrorInfo('保存失败'));
+            }
+        } catch (\Throwable $e) {
+            STModel::rollbackTrans();
+            return JsonService::fail($e->getMessage());
+        }
+    }
+
+    /**
+     * 删除运费模板
+     */
+    public function delete()
+    {
+        $data = UtilService::getMore([
+            ['id', ''],
+        ]);
+        if ($data['id'] == 1) {
+            return JsonService::fail('默认模板不能删除');
+        } else {
+            STModel::del($data['id']);
+            ShippingTemplatesRegion::where('temp_id', $data['id'])->delete();
+            ShippingTemplatesFree::where('temp_id', $data['id'])->delete();
+            return JsonService::successful('删除成功');
+        }
+    }
+
+    /**
+     * 获取所有运费模板
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function get_template_list()
+    {
+        return JsonService::successful(STModel::order('sort desc,id desc')->field(['id', 'name'])->select()->toArray());
+    }
+
+
+}

+ 222 - 0
app/admin/controller/setting/SystemAdmin.php

@@ -0,0 +1,222 @@
+<?php
+
+namespace app\admin\controller\setting;
+
+use app\admin\controller\AuthController;
+use app\models\user\User;
+use crmeb\services\{FormBuilder as Form, JsonService as Json, UtilService as Util};
+use app\admin\model\system\{SystemRole, SystemAdmin as AdminModel};
+use think\facade\Route as Url;
+
+/**
+ * 管理员列表控制器
+ * Class SystemAdmin
+ * @package app\admin\controller\system
+ */
+class SystemAdmin extends AuthController
+{
+    /**
+     * 显示资源列表
+     *
+     * @return \think\Response
+     */
+    public function index()
+    {
+        $admin = $this->adminInfo;
+        $where = Util::getMore([
+            ['name', ''],
+            ['roles', ''],
+            ['level', bcadd($admin->level, 1, 0)]
+        ]);
+        $this->assign('where', $where);
+        $this->assign('role', SystemRole::getRole(bcadd($admin->level, 1, 0)));
+        $this->assign(AdminModel::systemPage($where));
+        return $this->fetch();
+    }
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return \think\Response
+     */
+    public function create()
+    {
+        $admin = $this->adminInfo;
+        $f = array();
+        $f[] = Form::input('account', '管理员账号');
+        $f[] = Form::input('pwd', '管理员密码')->type('password');
+        $f[] = Form::input('conf_pwd', '确认密码')->type('password');
+        $f[] = Form::input('real_name', '管理员姓名');
+        $f[] = Form::select('roles', '管理员身份')->setOptions(function () use ($admin) {
+            $list = SystemRole::getRole(bcadd($admin->level, 1, 0));
+            $options = [];
+            foreach ($list as $id => $roleName) {
+                $options[] = ['label' => $roleName, 'value' => $id];
+            }
+            return $options;
+        })->multiple(1);
+        $f[] = Form::select('uid', '绑定会员', $admin->uid)
+            ->options(User::field('uid as value,nickname as label')->select()->toArray())->filterable(1);
+        $f[] = Form::radio('status', '状态', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]]);
+        $form = Form::make_post_form('添加管理员', $f, Url::buildUrl('save'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存新建的资源
+     *
+     * @param \think\Request $request
+     * @return \think\Response
+     */
+    public function save()
+    {
+        $data = Util::postMore([
+            'account',
+            'conf_pwd',
+            'pwd',
+            'real_name',
+            ['roles', []],
+            ['status', 0],
+            ['uid']
+        ]);
+        if (!$data['account']) return Json::fail('请输入管理员账号');
+        if (!$data['roles']) return Json::fail('请选择至少一个管理员身份');
+        if (!$data['pwd']) return Json::fail('请输入管理员登陆密码');
+        if ($data['pwd'] != $data['conf_pwd']) return Json::fail('两次输入密码不想同');
+        if (AdminModel::be($data['account'], 'account')) return Json::fail('管理员账号已存在');
+        $data['pwd'] = md5($data['pwd']);
+        $data['add_time'] = time();
+        unset($data['conf_pwd']);
+        $data['level'] = $this->adminInfo['level'] + 1;
+        $data['add_time'] = time();
+        if (!AdminModel::create($data)) return Json::fail('添加管理员失败');
+        return Json::successful('添加管理员成功!');
+    }
+
+    /**
+     * 显示编辑资源表单页.
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function edit($id)
+    {
+        if (!$id) return $this->failed('参数错误');
+        $admin = AdminModel::get($id);
+        if (!$admin) return Json::fail('数据不存在!');
+        $f = array();
+        $f[] = Form::input('account', '管理员账号', $admin->account);
+        $f[] = Form::input('pwd', '管理员密码')->type('password');
+        $f[] = Form::input('conf_pwd', '确认密码')->type('password');
+        $f[] = Form::input('real_name', '管理员姓名', $admin->real_name);
+        $f[] = Form::select('roles', '管理员身份', explode(',', $admin->roles))->setOptions(function () use ($admin) {
+            $list = SystemRole::getRole($admin->level);
+            $options = [];
+            foreach ($list as $id => $roleName) {
+                $options[] = ['label' => $roleName, 'value' => $id];
+            }
+            return $options;
+        })->multiple(1);
+
+        $f[] = Form::selectOne('uid', '绑定会员', $admin->uid)
+            ->options(User::field('uid as value,nickname as label')->select()->toArray())->filterable(1);
+
+        $f[] = Form::radio('status', '状态', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]]);
+        $form = Form::make_post_form('编辑管理员', $f, Url::buildUrl('update', compact('id')));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存更新的资源
+     *
+     * @param \think\Request $request
+     * @param int $id
+     * @return \think\Response
+     */
+    public function update($id)
+    {
+        $data = Util::postMore([
+            'account',
+            'conf_pwd',
+            'pwd',
+            'real_name',
+            ['roles', []],
+            ['status', 0],
+            ['uid']
+        ]);
+        if (!$data['account']) return Json::fail('请输入管理员账号');
+        if (!$data['roles']) return Json::fail('请选择至少一个管理员身份');
+        if (!$data['pwd'])
+            unset($data['pwd']);
+        else {
+            if (isset($data['pwd']) && $data['pwd'] != $data['conf_pwd']) return Json::fail('两次输入密码不想同');
+            $data['pwd'] = md5($data['pwd']);
+        }
+        if (AdminModel::where('account', $data['account'])->where('id', '<>', $id)->count()) return Json::fail('管理员账号已存在');
+        unset($data['conf_pwd']);
+        if (!AdminModel::edit($data, $id)) return Json::fail('修改失败');
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function delete($id)
+    {
+        if (!$id)
+            return Json::fail('删除失败!');
+        if (AdminModel::edit(['is_del' => 1, 'status' => 0], $id, 'id'))
+            return Json::successful('删除成功!');
+        else
+            return Json::fail('删除失败!');
+    }
+
+    /**
+     * 个人资料 展示
+     * @return string
+     */
+    public function admin_info()
+    {
+        $adminInfo = $this->adminInfo;//获取当前登录的管理员
+        $this->assign('adminInfo', $adminInfo);
+        return $this->fetch();
+    }
+
+    /**
+     * 保存信息
+     */
+    public function setAdminInfo()
+    {
+        $adminInfo = $this->adminInfo;//获取当前登录的管理员
+        if ($this->request->isPost()) {
+            $data = Util::postMore([
+                ['new_pwd', ''],
+                ['new_pwd_ok', ''],
+                ['pwd', ''],
+                'real_name',
+            ]);
+            if ($data['pwd'] != '') {
+                $pwd = md5($data['pwd']);
+                if ($adminInfo['pwd'] != $pwd) return Json::fail('原始密码错误');
+            }
+            if ($data['new_pwd'] != '') {
+                if (!$data['new_pwd_ok']) return Json::fail('请输入确认新密码');
+                if ($data['new_pwd'] != $data['new_pwd_ok']) return Json::fail('俩次密码不一样');
+            }
+            if ($data['pwd'] != '' && $data['new_pwd'] != '') {
+                $data['pwd'] = md5($data['new_pwd']);
+            } else {
+                unset($data['pwd']);
+            }
+            unset($data['new_pwd']);
+            unset($data['new_pwd_ok']);
+            if (!AdminModel::edit($data, $adminInfo['id'])) return Json::fail('修改失败');
+            return Json::successful('修改成功!,请重新登录');
+        }
+    }
+}

+ 151 - 0
app/admin/controller/setting/SystemCity.php

@@ -0,0 +1,151 @@
+<?php
+
+namespace app\admin\controller\setting;
+
+use app\admin\controller\AuthController;
+use app\admin\model\system\SystemCity as CityModel;
+use crmeb\services\CacheService;
+use crmeb\services\FormBuilder as Form;
+use crmeb\services\JsonService as Json;
+use crmeb\services\UtilService as Util;
+use think\facade\Route as Url;
+
+class SystemCity extends AuthController
+{
+    /**
+     * 城市列表
+     * @return string
+     * @throws \Exception
+     */
+    public function index()
+    {
+        $params = Util::getMore([
+            ['parent_id', 0]
+        ], $this->request);
+        $this->assign('pid',$params['parent_id']);
+        $this->assign('list', CityModel::getList($params));
+        $addurl = Url::buildUrl('add?parent_id=' . $params['parent_id']);
+        $this->assign(compact('params', 'addurl'));
+        return $this->fetch();
+    }
+
+    /**
+     * 添加城市
+     * @return string
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function add()
+    {
+        $data = Util::getMore([
+            ['parent_id', 0]
+        ]);
+        if ($data['parent_id'] != 0) {
+            $info = CityModel::where('city_id', $data['parent_id'])->find()->toArray();
+        } else {
+            $info = [
+                "level" => 0,
+                "city_id" => 0,
+                "name" => '中国'
+            ];
+        }
+        $field[] = Form::hidden('level', $info['level']);
+        $field[] = Form::hidden('parent_id', $info['city_id']);
+        $field[] = Form::input('parent_name', '上级名称', $info['name'])->readonly(true);
+        $field[] = Form::input('name', '名称');
+        $field[] = Form::input('merger_name', '合并名称')->placeholder('格式:陕西,西安,雁塔');
+        $field[] = Form::input('area_code', '区号');
+        $field[] = Form::input('lng', '经度');
+        $field[] = Form::input('lat', '纬度');
+        $form = Form::make_post_form('添加地区', $field, Url::buildUrl('save'), 3);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存
+     */
+    public function save()
+    {
+        $data = Util::postMore([
+            ['id', 0],
+            ['name', 0],
+            ['merger_name', 0],
+            ['area_code', 0],
+            ['lng', 0],
+            ['lat', 0],
+            ['level', 0],
+            ['parent_id', 0],
+        ]);
+        if (!$data['name']) return Json::fail('请输入城市名称');
+        if (!$data['merger_name']) return Json::fail('请输入城市合并名称');
+        if ($data['id'] == 0) {
+            unset($data['id']);
+            $data['level'] = $data['level'] + 1;
+            $data['city_id'] = intval(CityModel::max('city_id') + 1);
+            CityModel::create($data);
+            return Json::successful('添加城市成功!');
+        } else {
+            unset($data['level']);
+            unset($data['parent_id']);
+            CityModel::where('id', $data['id'])->update($data);
+            return Json::successful('修改城市成功!');
+        }
+    }
+
+    /**
+     * 修改城市
+     * @return string
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function edit()
+    {
+        $data = Util::getMore([
+            ['id', 0]
+        ]);
+        $info = CityModel::get($data['id'])->toArray();
+        $info['parent_name'] = CityModel::where('city_id', $info['parent_id'])->value('name') ? : '中国';
+        $field[] = Form::hidden('id', $info['id']);
+        $field[] = Form::hidden('level', $info['level']);
+        $field[] = Form::hidden('parent_id', $info['parent_id']);
+        $field[] = Form::input('parent_name', '上级名称', $info['parent_name'])->readonly(true);
+        $field[] = Form::input('name', '名称', $info['name']);
+        $field[] = Form::input('merger_name', '合并名称', $info['merger_name'])->placeholder('格式:陕西,西安,雁塔');
+        $field[] = Form::input('area_code', '区号', $info['area_code']);
+        $field[] = Form::input('lng', '经度', $info['lng']);
+        $field[] = Form::input('lat', '纬度', $info['lat']);
+        $form = Form::make_post_form('添加地区', $field, Url::buildUrl('save'), 3);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 删除城市
+     * @throws \Exception
+     */
+    public function delete()
+    {
+        $data = Util::getMore([
+            ['city_id', 0]
+        ]);
+        CityModel::where('city_id', $data['city_id'])->whereOr('parent_id', $data['city_id'])->delete();
+        return Json::successful('删除成功!');
+    }
+
+    /**
+     * 清除城市缓存
+     * @throws \Psr\SimpleCache\InvalidArgumentException
+     */
+    public function clean_cache()
+    {
+        $res = CacheService::delete('CITY_LIST');
+        if ($res) {
+            return Json::successful('清除成功!');
+        } else {
+            return Json::fail('清除失败!');
+        }
+    }
+}

+ 376 - 0
app/admin/controller/setting/SystemConfig.php

@@ -0,0 +1,376 @@
+<?php
+
+namespace app\admin\controller\setting;
+
+use think\facade\Route as Url;
+use app\admin\controller\AuthController;
+use app\admin\model\system\{
+    SystemConfig as ConfigModel, SystemConfigTab as ConfigTabModel
+};
+use crmeb\services\{
+    CacheService,
+    FormBuilder as Form,
+    UtilService as Util,
+    JsonService as Json
+};
+use crmeb\services\upload\Upload;
+
+
+/**
+ *  配置列表控制器
+ * Class SystemConfig
+ * @package app\admin\controller\system
+ */
+class SystemConfig extends AuthController
+{
+    /**
+     * 基础配置
+     * */
+    public function index()
+    {
+        [$type, $tab_id, $children_tab_id] = Util::getMore([
+            ['type', 0],//配置类型
+            ['tab_id', 1],//当前分类ID
+            ['children_tab_id', null],//当前子集分类ID
+        ], null, true);
+
+        $config_tab = null;//顶级分类
+        $children_config_tab = null;//二级分类
+
+        if ($type == 3) {//其它分类
+            $config_tab = null;
+        } else {
+            $config_tab = ConfigModel::getConfigTabAll($type);//获取一级tab
+        }
+        $children_config_tab = ConfigModel::getConfigChildrenTabAll($tab_id);//获取二级tab
+
+        if (!$children_tab_id && $children_config_tab) {
+            $children_tab_id = $children_config_tab[0]['id'];
+        }
+
+        if ($children_tab_id) {
+            $tid = $children_tab_id;
+        } else {
+            $tid = $tab_id;
+        }
+
+        //获取分类配置参数
+        $list = ConfigModel::getAll($tid);
+        $formbuider = ConfigModel::builder_config_from_data($list);//生产表单json
+        $form = Form::make_post_form('编辑配置', $formbuider, Url::buildUrl('save_basics'));
+
+        $this->assign('tab_id', $tab_id);
+        $this->assign('children_tab_id', $children_tab_id);
+        $this->assign('config_tab', $config_tab);
+        $this->assign('children_config_tab', $children_config_tab);
+
+        $this->assign(compact('form'));
+        $this->assign('list', $list);
+        return $this->fetch();
+    }
+
+
+
+    /**
+     * 基础配置  单个
+     * @return mixed|void
+     */
+    public function index_alone()
+    {
+        $tab_id = input('tab_id');
+        if (!$tab_id) return $this->failed('参数错误,请重新打开');
+        $this->assign('tab_id', $tab_id);
+        $list = ConfigModel::getAll($tab_id);
+        foreach ($list as $k => $v) {
+            if (!is_null(json_decode($v['value'])))
+                $list[$k]['value'] = json_decode($v['value'], true);
+            if ($v['type'] == 'upload' && !empty($v['value'])) {
+                if ($v['upload_type'] == 1 || $v['upload_type'] == 3) $list[$k]['value'] = explode(',', $v['value']);
+            }
+        }
+        $this->assign('list', $list);
+        return $this->fetch();
+    }
+
+    /**
+     * 添加字段
+     * @return string
+     * @throws \FormBuilder\exception\FormBuilderException
+     */
+    public function create()
+    {
+        $data = Util::getMore(['type',]);//接收参数
+        $tab_id = !empty(request()->param('tab_id')) ? request()->param('tab_id') : 1;
+        //前面通用字段
+        $formbuiderheader = array();
+        $formbuiderheader[] = Form::select('config_tab_id', '分类', 0)->setOptions(function () {
+            $menuList = ConfigTabModel::field(['id', 'pid', 'title'])->select()->toArray();
+            $list = sort_list_tier($menuList, '顶级', 'pid', 'id');
+            $options = [['value' => 0, 'label' => '顶级按钮']];
+            foreach ($list as $option) {
+                $options[] = ['value' => $option['id'], 'label' => $option['html'] . $option['title']];
+            }
+            return $options;
+        })->filterable(1);
+        $formbuiderheader[] = Form::select('input_type', '类型')->setOptions(ConfigModel::texttype());
+        $formbuiderheader[] = Form::input('info', '配置名称')->autofocus(1);
+        $formbuiderheader[] = Form::input('menu_name', '字段变量')->placeholder('例如:site_url');
+        $formbuiderheader[] = Form::input('desc', '配置简介');
+        //不同类型不同字段
+        $formbuider = array();
+        switch ($data['type']) {
+            case 0://文本框
+                $formbuider = ConfigModel::createInputRule($tab_id);
+                break;
+            case 1://多行文本框
+                $formbuider = ConfigModel::createTextAreaRule($tab_id);
+                break;
+            case 2://单选框
+                $formbuider = ConfigModel::createRadioRule($tab_id);
+                break;
+            case 3://文件上传
+                $formbuider = ConfigModel::createUploadRule($tab_id);
+                break;
+            case 4://多选框
+                $formbuider = ConfigModel::createCheckboxRule($tab_id);
+                break;
+            case 5://下拉框
+                $formbuider = ConfigModel::createSelectRule($tab_id);
+                break;
+        }
+        //后面通用字段
+        $formbuiderfoot = array();
+        $formbuiderfoot[] = Form::number('sort', '排序');
+        $formbuiderfoot[] = Form::radio('status', '状态', 1)->options(ConfigModel::formstatus());
+        $formbuiders = array_merge($formbuiderheader, $formbuider, $formbuiderfoot);
+        $form = Form::make_post_form('添加字段', $formbuiders, Url::buildUrl('save'));
+        $this->assign(compact('form'));
+        $this->assign('get', request()->param());
+        return $this->fetch();
+    }
+
+    /**
+     * 保存字段
+     * */
+    public function save()
+    {
+        $data = Util::postMore([
+            'menu_name',
+            'type',
+            'input_type',
+            'config_tab_id',
+            'parameter',
+            'upload_type',
+            'required',
+            'width',
+            'high',
+            'value',
+            'info',
+            'desc',
+            'sort',
+            'status',]);
+        if (!$data['info']) return Json::fail('请输入配置名称');
+        if (!$data['menu_name']) return Json::fail('请输入字段名称');
+        if ($data['menu_name']) {
+            $oneConfig = ConfigModel::getOneConfig('menu_name', $data['menu_name']);
+            if (!empty($oneConfig)) return Json::fail('请重新输入字段名称,之前的已经使用过了');
+        }
+        if (!$data['desc']) return Json::fail('请输入配置简介');
+        if ($data['sort'] < 0) {
+            $data['sort'] = 0;
+        }
+        if ($data['type'] == 'text') {
+            if (!ConfigModel::valiDateTextRole($data)) return Json::fail(ConfigModel::getErrorInfo());
+        }
+        if ($data['type'] == 'textarea') {
+            if (!ConfigModel::valiDateTextareaRole($data)) return Json::fail(ConfigModel::getErrorInfo());
+        }
+        $data['parameter'] = htmlspecialchars_decode($data['parameter']);
+        if ($data['type'] == 'radio' || $data['type'] == 'checkbox') {
+            if (!$data['parameter']) return Json::fail('请输入配置参数');
+            if (!ConfigModel::valiDateRadioAndCheckbox($data)) return Json::fail(ConfigModel::getErrorInfo());
+            $data['value'] = json_encode($data['value']);
+        }
+        ConfigModel::create($data);
+        CacheService::clear();
+        return Json::successful('添加菜单成功!');
+    }
+
+    /**
+     * @param $id
+     */
+    public function update_config($id)
+    {
+        $type = request()->post('type');
+        if ($type == 'text' || $type == 'textarea' || $type == 'radio' || ($type == 'upload' && (request()->post('upload_type') == 1 || request()->post('upload_type') == 3))) {
+            $value = request()->post('value');
+        } else {
+            $value = request()->post('value/a');
+        }
+        $data = Util::postMore(['status', 'info', 'desc', 'sort', 'config_tab_id', 'required', 'parameter', ['value', $value], 'upload_type', 'input_type']);
+        $data['value'] = htmlspecialchars_decode(json_encode($data['value']));
+        $data['parameter'] = htmlspecialchars_decode($data['parameter']);
+        if (!ConfigModel::get($id)) return Json::fail('编辑的记录不存在!');
+        ConfigModel::edit($data, $id);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 修改是否显示子子段
+     * @param $id
+     * @return mixed
+     */
+    public function edit_config($id)
+    {
+        $menu = ConfigModel::get($id)->getData();
+        if (!$menu) return Json::fail('数据不存在!');
+        $formbuider = array();
+        $formbuider[] = Form::input('menu_name', '字段变量', $menu['menu_name'])->disabled(1);
+        $formbuider[] = Form::hidden('type', $menu['type']);
+//        $formbuider[] = Form::select('config_tab_id', '分类', (string)$menu['config_tab_id'])->setOptions(ConfigModel::getConfigTabAll(-1));
+        $formbuider[] = Form::select('config_tab_id', '分类', (string)$menu['config_tab_id'])->setOptions(function () {
+            $menuList = ConfigTabModel::field(['id', 'pid', 'title'])->select()->toArray();
+            $list = sort_list_tier($menuList, '顶级', 'pid', 'id');
+            $options = [['value' => 0, 'label' => '顶级按钮']];
+            foreach ($list as $option) {
+                $options[] = ['value' => $option['id'], 'label' => $option['html'] . $option['title']];
+            }
+            return $options;
+        })->filterable(1);
+        $formbuider[] = Form::input('info', '配置名称', $menu['info'])->autofocus(1);
+        $formbuider[] = Form::input('desc', '配置简介', $menu['desc']);
+        switch ($menu['type']) {
+            case 'text':
+                $menu['value'] = json_decode($menu['value'], true);
+                $formbuider[] = Form::select('input_type', '类型', $menu['input_type'])->setOptions(ConfigModel::texttype());
+                //输入框验证规则
+                $formbuider[] = Form::input('value', '默认值', $menu['value']);
+                if (!empty($menu['required'])) {
+                    $formbuider[] = Form::number('width', '文本框宽(%)', $menu['width']);
+                    $formbuider[] = Form::input('required', '验证规则', $menu['required'])->placeholder('多个请用,隔开例如:required:true,url:true');
+                }
+                break;
+            case 'textarea':
+                $menu['value'] = json_decode($menu['value'], true);
+                //多行文本
+                if (!empty($menu['high'])) {
+                    $formbuider[] = Form::textarea('value', '默认值', $menu['value'])->rows(5);
+                    $formbuider[] = Form::number('width', '文本框宽(%)', $menu['width']);
+                    $formbuider[] = Form::number('high', '多行文本框高(%)', $menu['high']);
+                } else {
+                    $formbuider[] = Form::input('value', '默认值', $menu['value']);
+                }
+                break;
+            case 'radio':
+                $menu['value'] = json_decode($menu['value'], true);
+                $parameter = explode("\n", htmlspecialchars_decode($menu['parameter']));
+                $options = [];
+                if ($parameter) {
+                    foreach ($parameter as $v) {
+                        $data = explode("=>", $v);
+                        $options[] = ['label' => $data[1], 'value' => $data[0]];
+                    }
+                    $formbuider[] = Form::radio('value', '默认值', $menu['value'])->options($options);
+                }
+                //单选和多选参数配置
+                if (!empty($menu['parameter'])) {
+                    $formbuider[] = Form::textarea('parameter', '配置参数', $menu['parameter'])->placeholder("参数方式例如:\n1=白色\n2=红色\n3=黑色");
+                }
+                break;
+            case 'checkbox':
+                $menu['value'] = json_decode($menu['value'], true) ?: [];
+                $parameter = explode("\n", htmlspecialchars_decode($menu['parameter']));
+                $options = [];
+                if ($parameter) {
+                    foreach ($parameter as $v) {
+                        $data = explode("=>", $v);
+                        $options[] = ['label' => $data[1], 'value' => $data[0]];
+                    }
+                    $formbuider[] = Form::checkbox('value', '默认值', $menu['value'])->options($options);
+                }
+                //单选和多选参数配置
+                if (!empty($menu['parameter'])) {
+                    $formbuider[] = Form::textarea('parameter', '配置参数', $menu['parameter'])->placeholder("参数方式例如:\n1=白色\n2=红色\n3=黑色");
+                }
+                break;
+            case 'upload':
+                if ($menu['upload_type'] == 1) {
+                    $menu['value'] = json_decode($menu['value'], true);
+                    $formbuider[] = Form::frameImageOne('value', '图片', Url::buildUrl('admin/widget.images/index', array('fodder' => 'value')), (string)$menu['value'])->icon('image')->width('100%')->height('550px');
+                } elseif ($menu['upload_type'] == 2) {
+                    $menu['value'] = json_decode($menu['value'], true) ?: [];
+                    $formbuider[] = Form::frameImages('value', '多图片', Url::buildUrl('admin/widget.images/index', array('fodder' => 'value')), $menu['value'])->maxLength(5)->icon('images')->width('100%')->height('550px')->spin(0);
+                } else {
+                    $menu['value'] = json_decode($menu['value'], true);
+                    $formbuider[] = Form::uploadFileOne('value', '文件', Url::buildUrl('file_upload'), $menu['value'])->name('file');
+                }
+                //上传类型选择
+                if (!empty($menu['upload_type'])) {
+                    $formbuider[] = Form::radio('upload_type', '上传类型', $menu['upload_type'])->options([['value' => 1, 'label' => '单图'], ['value' => 2, 'label' => '多图'], ['value' => 3, 'label' => '文件']]);
+                }
+                break;
+
+        }
+        $formbuider[] = Form::number('sort', '排序', $menu['sort']);
+        $formbuider[] = Form::radio('status', '状态', $menu['status'])->options([['value' => 1, 'label' => '显示'], ['value' => 2, 'label' => '隐藏']]);
+
+        $form = Form::make_post_form('编辑字段', $formbuider, Url::buildUrl('update_config', array('id' => $id)));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 删除子字段
+     * @return \think\response\Json
+     */
+    public function delete_config()
+    {
+        $id = input('id');
+        if (!ConfigModel::del($id)) {
+            return Json::fail(ConfigModel::getErrorInfo('删除失败,请稍候再试!'));
+        } else {
+            CacheService::clear();
+            return Json::successful('删除成功!');
+        }
+    }
+
+    /**
+     * 保存数据    true
+     * */
+    public function save_basics()
+    {
+        $request = app('request');
+        if ($request->isPost()) {
+            $post = $request->post();
+            foreach ($post as $k => $v) {
+                if (is_array($v)) {
+                    $res = ConfigModel::where('menu_name', $k)->column('upload_type', 'type');
+                    foreach ($res as $kk => $vv) {
+                        if ($kk == 'upload') {
+                            if ($vv == 1 || $vv == 3) {
+                                $post[$k] = $v[0];
+                            }
+                        }
+                    }
+                }
+            }
+            foreach ($post as $k => $v) {
+                ConfigModel::edit(['value' => json_encode($v)], $k, 'menu_name');
+            }
+            CacheService::clear();
+            return $this->successful('修改成功');
+        }
+    }
+
+    /**
+     * 文件上传
+     * */
+    public function file_upload()
+    {
+        $upload = new Upload('local');
+        $res = $upload->to('config/file')->validate()->move($this->request->param('file', 'file'));
+        if ($res === false) return Json::fail($upload->getError());
+        return Json::successful('上传成功!', ['filePath' => $res->filePath]);
+    }
+
+}

+ 179 - 0
app/admin/controller/setting/SystemConfigTab.php

@@ -0,0 +1,179 @@
+<?php
+
+namespace app\admin\controller\setting;
+
+use think\facade\Route as Url;
+use app\admin\controller\AuthController;
+use crmeb\services\{
+    FormBuilder as Form, UtilService as Util, JsonService as Json
+};
+use app\admin\model\system\{
+    SystemConfig as ConfigModel, SystemConfigTab as ConfigTabModel
+};
+
+/**
+ * 配置分类控制器
+ * Class SystemConfigTab
+ * @package app\admin\controller\system
+ */
+class SystemConfigTab extends AuthController
+{
+    /** 定义配置分类,需要添加分类可以手动添加
+     * @return array
+     */
+    public function getConfigType()
+    {
+        return [
+            ['value' => 0, 'label' => '系统']
+            , ['value' => 1, 'label' => '应用']
+            , ['value' => 2, 'label' => '支付']
+            , ['value' => 3, 'label' => '其它']
+        ];
+    }
+
+    /**
+     * 子子段
+     * @return mixed|\think\response\Json
+     */
+    public function sonconfigtab()
+    {
+        $tab_id = input('tab_id');
+        if (!$tab_id) return Json::fail('参数错误');
+        $this->assign('tab_id', $tab_id);
+        $list = ConfigModel::getAll($tab_id, 2);
+        foreach ($list as $k => $v) {
+            $list[$k]['value'] = json_decode($v['value'], true) ?: '';
+            if ($v['type'] == 'radio' || $v['type'] == 'checkbox') {
+                $list[$k]['value'] = ConfigTabModel::getRadioOrCheckboxValueInfo($v['menu_name'], $v['value']);
+            }
+            if ($v['type'] == 'upload' && !empty($v['value'])) {
+                if ($v['upload_type'] == 1 || $v['upload_type'] == 3) $list[$k]['value'] = explode(',', $v['value']);
+            }
+        }
+        $this->assign('list', $list);
+        return $this->fetch();
+    }
+
+    /**
+     * 基础配置
+     * @return mixed
+     */
+    public function index()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['title', ''],
+            ['pid', 0],
+        ], $this->request);
+        $this->assign('where', $where);
+        $this->assign(ConfigTabModel::getSystemConfigTabPage($where));
+        return $this->fetch();
+    }
+
+
+    /**
+     * 添加配置分类
+     * @return mixed
+     */
+    public function create()
+    {
+        $field = [];
+        $field[] = Form::select('pid', '父级分类', 0)->setOptions(function () {
+            $menuList = ConfigTabModel::field(['id', 'pid', 'title'])->select()->toArray();//var_dump($menuList);
+            $list = sort_list_tier($menuList, '顶级', 'pid', 'id');//var_dump($list);
+            $menus = [['value' => 0, 'label' => '顶级按钮']];
+            foreach ($list as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['html'] . $menu['title']];
+            }
+            return $menus;
+        })->filterable(1);
+        $field[] = Form::input('title', '分类名称');
+        $field[] = Form::input('eng_title', '分类字段英文');
+        $field[] = Form::frameInputOne('icon', '图标', Url::buildUrl('admin/widget.widgets/icon', array('fodder' => 'icon')))->icon('ionic')->height('500px');
+        $field[] = Form::radio('type', '类型', 0)->options(self::getConfigType());
+        $field[] = Form::radio('status', '状态', 1)->options([['value' => 1, 'label' => '显示'], ['value' => 2, 'label' => '隐藏']]);
+        $field[] = Form::radio('type', '类型', 0)->options(self::getConfigType());
+        $field[] = Form::number('sort', '排序', 0);
+        $form = Form::make_post_form('添加分类配置', $field, Url::buildUrl('save'), 3);
+        $form->setMethod('post')->setTitle('添加分类配置');
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存分类名称
+     */
+    public function save()
+    {
+        $data = Util::postMore([
+            'eng_title',
+            'status',
+            'title',
+            'pid',
+            'icon',
+            'type',
+            ['sort', 0]
+        ]);
+        if (!$data['title']) return Json::fail('请输入按钮名称');
+        ConfigTabModel::create($data);
+        return Json::successful('添加菜单成功!');
+    }
+
+    /**
+     * 修改分类
+     * @param $id
+     * @return string|void
+     * @throws \FormBuilder\exception\FormBuilderException
+     */
+    public function edit($id)
+    {
+        $menu = ConfigTabModel::get($id)->getData();
+        if (!$menu) return Json::fail('数据不存在!');
+        $form = Form::create(Url::buildUrl('update', array('id' => $id)), [
+            Form::select('pid', '父级分类', (string)$menu['pid'])->setOptions(function () {
+                $menuList = ConfigTabModel::field(['id', 'pid', 'title'])->select()->toArray();
+                $list = sort_list_tier($menuList, '顶级', 'pid', 'id');
+                $options = [['value' => 0, 'label' => '顶级按钮']];
+                foreach ($list as $option) {
+                    $options[] = ['value' => $option['id'], 'label' => $option['html'] . $option['title']];
+                }
+                return $options;
+            })->filterable(1),
+            Form::input('title', '分类名称', $menu['title']),
+            Form::input('eng_title', '分类字段英文', $menu['eng_title']),
+            Form::frameInputOne('icon', '图标', Url::buildUrl('admin/widget.widgets/icon', array('fodder' => 'icon')), $menu['icon'])->icon('ionic')->height('500px'),
+            Form::radio('type', '类型', $menu['type'])->options(self::getConfigType()),
+            Form::radio('status', '状态', $menu['status'])->options([['value' => 1, 'label' => '显示'], ['value' => 2, 'label' => '隐藏']]),
+            Form::number('sort', '排序', $menu['sort'] ?? 0),
+        ]);
+        $form->setMethod('post')->setTitle('添加分类配置');
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * @param $id
+     */
+    public function update($id)
+    {
+        $data = Util::postMore(['title', 'pid', 'status', 'eng_title', 'icon', 'type','sort']);
+        if (!$data['title']) return Json::fail('请输入分类昵称');
+        if (!$data['eng_title']) return Json::fail('请输入分类字段');
+        if (!ConfigTabModel::get($id)) return Json::fail('编辑的记录不存在!');
+        ConfigTabModel::edit($data, $id);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * @param $id
+     */
+    public function delete($id)
+    {
+        if (!$id) return Json::fail('参数有误!');
+        if (ConfigTabModel::be(['pid' => $id])) return Json::fail('有子分类,不能直接删除');
+        if (!ConfigTabModel::del($id))
+            return Json::fail(ConfigTabModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+}

+ 127 - 0
app/admin/controller/setting/SystemGroup.php

@@ -0,0 +1,127 @@
+<?php
+
+namespace app\admin\controller\setting;
+
+use crmeb\services\UtilService as Util;
+use crmeb\services\JsonService as Json;
+use think\facade\Route as Url;
+use app\admin\model\system\SystemGroup as GroupModel;
+use app\admin\model\system\SystemGroupData as GroupDataModel;
+use app\admin\controller\AuthController;
+
+/**
+ * 组合数据控制器
+ * Class SystemGroup
+ * @package app\admin\controller\system
+ */
+class SystemGroup extends AuthController
+{
+    /**
+     * 显示资源列表
+     *
+     * @return \think\Response
+     */
+    public function index()
+    {
+        $this->assign(GroupModel::page());
+        return $this->fetch();
+    }
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return \think\Response
+     */
+    public function create()
+    {
+        $this->assign(['title'=>'添加数据组','save'=>Url::buildUrl('save')]);
+        return $this->fetch();
+    }
+
+    /**
+     * 保存新建的资源
+     *
+     * @param  \think\Request  $request
+     * @return \think\Response
+     */
+    public function save()
+    {
+        $params = Util::postMore([
+            ['id',''],
+            ['name',''],
+            ['config_name',''],
+            ['info',''],
+            ['typelist',[]],
+        ],$this->request);
+
+        //数据组名称判断
+        if(!$params['name'])return Json::fail('请输入数据组名称!');
+        if(!$params['config_name'])return Json::fail('请输入配置名称!');
+        //判断ID是否存在,存在就是编辑,不存在就是添加
+        if(!$params['id']){
+            if(GroupModel::be($params['config_name'],'config_name')) return Json::fail('数据关键字已存在!');
+        }
+        $data["name"] = $params['name'];
+        $data["config_name"] = $params['config_name'];
+        $data["info"] = $params['info'];
+        //字段信息判断
+        if(!count($params['typelist']))
+            return Json::fail('字段至少存在一个!');
+        else{
+            $validate = ["name","type","title","description"];
+            foreach ($params["typelist"] as $key => $value) {
+                foreach ($value as $name => $field) {
+                    if(empty($field["value"]) && in_array($name,$validate))
+                        return Json::fail("字段".($key + 1).":".$field["placeholder"]."不能为空!");
+                    else
+                        $data["fields"][$key][$name] = $field["value"];
+                }
+            }
+        }
+        $data["fields"] = htmlspecialchars_decode(json_encode($data["fields"]));
+        //判断ID是否存在,存在就是编辑,不存在就是添加
+        if(!$params['id']) {
+            GroupModel::create($data);
+            return Json::successful('添加数据组成功!');
+        }else{
+            GroupModel::edit($data,$params['id']);
+            return Json::successful('编辑数据组成功!');
+        }
+    }
+
+    /**编辑数组
+     * @param $id
+     */
+    public function edit($id)
+    {
+        $Groupinfo = GroupModel::get($id);
+        $fields = json_decode($Groupinfo['fields'],true);
+        $typelist = [];
+        foreach ($fields as $key => $v){
+            $typelist[$key]['name']['value'] = $v['name'];
+            $typelist[$key]['title']['value'] = $v['title'];
+            $typelist[$key]['type']['value'] = $v['type'];
+            $typelist[$key]['param']['value'] = $v['param'];
+        }
+        $Groupinfo['fields'] = json_encode($typelist);
+        $this->assign(compact('Groupinfo'));
+        $this->assign(['title'=>'添加数据组','save'=>Url::buildUrl('save')]);
+        return $this->fetch();
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param  int  $id
+     * @return \think\Response
+     */
+    public function delete($id)
+    {
+        if(!GroupModel::del($id))
+            return Json::fail(GroupModel::getErrorInfo('删除失败,请稍候再试!'));
+        else{
+            GroupDataModel::del(["gid"=>$id]);
+            return Json::successful('删除成功!');
+        }
+    }
+}

+ 291 - 0
app/admin/controller/setting/SystemGroupData.php

@@ -0,0 +1,291 @@
+<?php
+
+namespace app\admin\controller\setting;
+
+use app\admin\controller\AuthController;
+use app\admin\model\ump\StoreSeckill;
+use crmeb\services\{
+    CacheService,
+    FormBuilder as Form,
+    JsonService as Json,
+    UtilService as Util
+};
+use EasyWeChat\Js\Js;
+use think\facade\Route as Url;
+use app\admin\model\system\{
+    SystemAttachment, SystemGroup as GroupModel, SystemGroupData as GroupDataModel
+};
+
+/**
+ * 数据列表控制器  在组合数据中
+ * Class SystemGroupData
+ * @package app\admin\controller\system
+ */
+class SystemGroupData extends AuthController
+{
+
+    /**
+     * 显示资源列表
+     * @return \think\Response
+     */
+    public function index($gid = 0)
+    {
+        $where = Util::getMore([
+            ['gid', 0],
+            ['status', ''],
+        ], $this->request);
+        if ($gid) $where['gid'] = $gid;
+        $this->assign('where', $where);
+        $this->assign(compact("gid"));
+        $this->assign(GroupModel::getField($gid));
+        $this->assign(GroupDataModel::getList($where));
+        return $this->fetch();
+    }
+
+    /**
+     * 显示创建资源表单页.
+     * @return \think\Response
+     */
+    public function create($gid)
+    {
+        $Fields = GroupModel::getField($gid);
+        $f = array();
+        foreach ($Fields["fields"] as $key => $value) {
+            $info = [];
+            if (isset($value["param"])) {
+                $value["param"] = str_replace("\r\n", "\n", $value["param"]);//防止不兼容
+                $params = explode("\n", $value["param"]);
+                if (is_array($params) && !empty($params)) {
+                    foreach ($params as $index => $v) {
+                        $vl = explode('=>', $v);
+                        if (isset($vl[0]) && isset($vl[1])) {
+                            $info[$index]["value"] = $vl[0];
+                            $info[$index]["label"] = $vl[1];
+                        }
+                    }
+                }
+            }
+
+            switch ($value["type"]) {
+                case 'input':
+                    $f[] = Form::input($value["title"], $value["name"]);
+                    break;
+                case 'textarea':
+                    $f[] = Form::input($value["title"], $value["name"])->type('textarea')->placeholder($value['param']);
+                    break;
+                case 'radio':
+                    $f[] = Form::radio($value["title"], $value["name"], $info[0]["value"] ?? '')->options($info);
+                    break;
+                case 'checkbox':
+                    $f[] = Form::checkbox($value["title"], $value["name"], $info[0] ?? '')->options($info);
+                    break;
+                case 'select':
+                    $f[] = Form::select($value["title"], $value["name"], $info[0] ?? '')->options($info)->multiple(false);
+                    break;
+                case 'upload':
+                    $f[] = Form::frameImageOne($value["title"], $value["name"], Url::buildUrl('admin/widget.images/index', array('fodder' => $value["title"], 'big' => 1)))->icon('image')->width('100%')->height('500px');
+                    break;
+                case 'uploads':
+                    $f[] = Form::frameImages($value["title"], $value["name"], Url::buildUrl('admin/widget.images/index', array('fodder' => $value["title"], 'big' => 1)))->maxLength(5)->icon('images')->width('100%')->height('500px')->spin(0);
+                    break;
+                case 'number':
+                    $f[] = Form::number($value["title"], $value["name"])->precision('int');
+                    break;
+                default:
+                    $f[] = Form::input($value["title"], $value["name"]);
+                    break;
+
+            }
+        }
+        $f[] = Form::number('sort', '排序', 1);
+        $f[] = Form::radio('status', '状态', 1)->options([['value' => 1, 'label' => '显示'], ['value' => 2, 'label' => '隐藏']]);
+        $form = Form::make_post_form('添加数据', $f, Url::buildUrl('save', compact('gid')), 2);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存新建的资源
+     *
+     * @param \think\Request $request
+     * @return \think\Response
+     */
+    public function save($gid)
+    {
+        $Fields = GroupModel::getField($gid);
+        $params = request()->post();
+        foreach ($params as $key => $param) {
+            foreach ($Fields['fields'] as $index => $field) {
+                if ($key == $field["title"]) {
+//                    if($param == "" || count($param) == 0)
+                    if ($param == "")
+                        return Json::fail($field["name"] . "不能为空!");
+                    else {
+                        $value[$key]["type"] = $field["type"];
+                        $value[$key]["value"] = $param;
+                    }
+                }
+            }
+        }
+
+        $data = array("gid" => $gid, "add_time" => time(), "value" => htmlspecialchars_decode(json_encode($value)), "sort" => $params["sort"], "status" => $params["status"]);
+        GroupDataModel::create($data);
+        CacheService::clear();
+        return Json::successful('添加数据成功!');
+    }
+
+    /**
+     * 显示指定的资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function read($id)
+    {
+        //
+    }
+
+    /**
+     * 显示编辑资源表单页.
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function edit($gid, $id)
+    {
+        $GroupData = GroupDataModel::get($id);
+        $GroupDataValue = json_decode($GroupData["value"], true);
+        $Fields = GroupModel::getField($gid);
+        $f = array();
+        if (!isset($Fields['fields'])) return $this->failed('数据解析失败!');
+        foreach ($Fields['fields'] as $key => $value) {
+            $info = [];
+            if (isset($value["param"])) {
+                $value["param"] = str_replace("\r\n", "\n", $value["param"]);//防止不兼容
+                $params = explode("\n", $value["param"]);
+                if (is_array($params) && !empty($params)) {
+                    foreach ($params as $index => $v) {
+                        $vl = explode('=>', $v);
+                        if (isset($vl[0]) && isset($vl[1])) {
+                            $info[$index]["value"] = $vl[0];
+                            $info[$index]["label"] = $vl[1];
+                        }
+                    }
+                }
+            }
+            $fvalue = isset($GroupDataValue[$value['title']]['value']) ? $GroupDataValue[$value['title']]['value'] : '';
+            switch ($value['type']) {
+                case 'input':
+                    $f[] = Form::input($value['title'], $value['name'], $fvalue);
+                    break;
+                case 'textarea':
+                    $f[] = Form::input($value['title'], $value['name'], $fvalue)->type('textarea');
+                    break;
+                case 'radio':
+
+                    $f[] = Form::radio($value['title'], $value['name'], $fvalue)->options($info);
+                    break;
+                case 'checkbox':
+                    $f[] = Form::checkbox($value['title'], $value['name'], $fvalue)->options($info);
+                    break;
+                case 'upload':
+                    if (!empty($fvalue)) {
+                        $image = is_string($fvalue) ? $fvalue : $fvalue[0];
+                    } else {
+                        $image = '';
+                    }
+                    $f[] = Form::frameImageOne($value['title'], $value['name'], Url::buildUrl('admin/widget.images/index', array('fodder' => $value['title'], 'big' => 1)), $image)->icon('image')->width('100%')->height('500px');
+                    break;
+                case 'uploads':
+                    $images = !empty($fvalue) ? $fvalue : [];
+                    $f[] = Form::frameImages($value['title'], $value['name'], Url::buildUrl('admin/widget.images/index', array('fodder' => $value['title'], 'big' => 1)), $images)->maxLength(5)->icon('images')->width('100%')->height('500px')->spin(0);
+                    break;
+                case 'select':
+                    $f[] = Form::select($value['title'], $value['name'], $fvalue)->setOptions($info);
+                    break;
+                case 'number':
+                    $f[] = Form::number($value["title"], $value["name"])->precision('int');
+                    break;
+                default:
+                    $f[] = Form::input($value['title'], $value['name'], $fvalue);
+                    break;
+
+            }
+        }
+        $f[] = Form::number('sort', '排序', $GroupData["sort"]);
+        $f[] = Form::radio('status', '状态', $GroupData["status"])->options([['value' => 1, 'label' => '显示'], ['value' => 2, 'label' => '隐藏']]);
+        $form = Form::make_post_form('添加用户通知', $f, Url::buildUrl('update', compact('id')), 2);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存更新的资源
+     *
+     * @param $id
+     */
+    public function update($id)
+    {
+        $GroupData = GroupDataModel::get($id);
+        $group = GroupModel::where('id', $GroupData['gid'])->find();
+        if(!$GroupData || !$group){
+            return Json::fail('请检查配置');
+        }
+        $params = request()->post();
+        //秒杀
+        if($group['config_name'] == 'routine_seckill_time'){
+            if((int)($params['time'] + $params['continued']) > 24){
+                return Json::fail('请重新填写持续时间或者开始时间(时间跨度超过了一天)');
+            }
+        }
+        $Fields = json_decode( $group['fields'],true) ?? [];
+
+        foreach ($params as $key => $param) {
+            foreach ($Fields as $index => $field) {
+                if ($key == $field["title"]) {
+                    if (trim($param) == '')
+                        return Json::fail($field["name"] . "不能为空!");
+                    else {
+                        $value[$key]["type"] = $field["type"];
+                        $value[$key]["value"] = $param;
+                    }
+                }
+            }
+        }
+        $data = array("value" => htmlspecialchars_decode(json_encode($value)), "sort" => $params["sort"], "status" => $params["status"]);
+        GroupDataModel::edit($data, $id);
+        CacheService::clear();
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function delete($id)
+    {
+        $gid = GroupDataModel::where('id', $id)->value('gid');
+        $config_name = GroupModel::where('id', $gid)->value('config_name');
+        if ($config_name == 'routine_seckill_time') {
+            if (!StoreSeckill::where('is_del', 0)->find()) {
+                if (!GroupDataModel::del($id))
+                    return Json::fail(GroupDataModel::getErrorInfo('删除失败,请稍候再试!'));
+                else {
+                    CacheService::clear();
+                    return Json::successful('删除成功!');
+                }
+            } else {
+                return Json::fail('有秒杀活动,不能删除秒杀时段,请先删除活动');
+            }
+        } else {
+            if (!GroupDataModel::del($id))
+                return Json::fail(GroupDataModel::getErrorInfo('删除失败,请稍候再试!'));
+            else {
+                CacheService::clear();
+                return Json::successful('删除成功!');
+            }
+        }
+    }
+}

+ 208 - 0
app/admin/controller/setting/SystemMenus.php

@@ -0,0 +1,208 @@
+<?php
+
+namespace app\admin\controller\setting;
+
+use app\admin\controller\AuthController;
+use crmeb\traits\CurdControllerTrait;
+use think\facade\Route as Url;
+use app\admin\model\system\SystemMenus as MenusModel;
+use crmeb\services\{FormBuilder as Form, UtilService as Util, JsonService as Json};
+
+/**
+ * 菜单管理控制器
+ * Class SystemMenus
+ * @package app\admin\controller\system
+ */
+class SystemMenus extends AuthController
+{
+    use CurdControllerTrait;
+
+    public $bindModel = MenusModel::class;
+
+    /**
+     * 显示资源列表
+     *
+     * @return \think\Response
+     */
+    public function index()
+    {
+        $pid = $this->request->param('pid') ? $this->request->param('pid') : 0;
+        $params = Util::getMore([
+            ['is_show', ''],
+//            ['access',''],
+            ['keyword', ''],
+            ['pid', $pid]
+        ], $this->request);
+        $this->assign(MenusModel::getAdminPage($params));
+        $addurl = Url::buildUrl('create', ['cid' => input('pid')]);
+        $this->assign(compact('params', 'addurl'));
+        return $this->fetch();
+    }
+
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return \think\Response
+     */
+    public function create($cid = 0)
+    {
+        $field = [];
+        $field[] = Form::input('menu_name', '按钮名称')->required('按钮名称必填');
+        $field[] = Form::select('pid', '父级id', $cid)->setOptions(function () {
+            $menuList = MenusModel::field(['id', 'pid', 'menu_name'])->order('sort DESC,id ASC')->select()->toArray();
+            $list = sort_list_tier($menuList, '顶级', 'pid', 'menu_name');
+            $menus = [['value' => 0, 'label' => '顶级按钮']];
+            foreach ($list as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['html'] . $menu['menu_name']];
+            }
+            return $menus;
+        })->filterable(1);
+        $field[] = Form::select('module', '模块名')->options([['label' => '总后台', 'value' => 'admin']]);
+        if ($cid) $controller = MenusModel::where('id', $cid)->value('controller') ?: '';
+        else $controller = '';
+        $field[] = Form::input('controller', '控制器名', $controller);
+        if (!empty($controller)) {
+            $controller = preg_replace_callback('/([.]+([a-z]{1}))/i', function ($matches) {
+                return '\\' . strtoupper($matches[2]);
+            }, $controller);
+            if (class_exists('\app\admin\controller\\' . $controller)) {
+                $list = get_this_class_methods('\app\admin\controller\\' . $controller);
+
+                $field[] = Form::select('action', '方法名')->setOptions(function () use ($list) {
+                    $menus = [['value' => 0, 'label' => '默认函数']];
+                    foreach ($list as $menu) {
+                        $menus[] = ['value' => $menu, 'label' => $menu];
+                    }
+                    return $menus;
+                })->filterable(1);
+            } else {
+                $field[] = Form::input('action', '方法名');
+            }
+        } else {
+            $field[] = Form::input('action', '方法名');
+        }
+        $field[] = Form::input('params', '参数')->placeholder('举例:a/123/b/234');
+        $field[] = Form::frameInputOne('icon', '图标', Url::buildUrl('admin/widget.widgets/icon', array('fodder' => 'icon')))->icon('ionic')->height('500px');
+        $field[] = Form::number('sort', '排序', 0);
+        $field[] = Form::radio('is_show', '是否菜单', 0)->options([['value' => 0, 'label' => '隐藏'], ['value' => 1, 'label' => '显示(菜单只显示三级)']]);
+        $form = Form::make_post_form('添加权限', $field, Url::buildUrl('save'), 3);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存新建的资源
+     */
+    public function save()
+    {
+        $data = Util::postMore([
+            'menu_name',
+            'controller',
+            ['module', 'admin'],
+            'action',
+            'icon',
+            'params',
+            ['pid', 0],
+            ['sort', 0],
+            ['is_show', 0],
+            ['access', 1]]);
+        if (!$data['menu_name']) return Json::fail('请输入按钮名称');
+        MenusModel::create($data);
+        return Json::successful('添加菜单成功!');
+    }
+
+    /**
+     * 显示编辑资源表单页.
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function edit($id)
+    {
+        $menu = MenusModel::get($id);
+        if (!$menu) return Json::fail('数据不存在!');
+        $field = [];
+        $field[] = Form::input('menu_name', '按钮名称', $menu['menu_name']);
+        $field[] = Form::select('pid', '父级id', (string)$menu->getData('pid'))->setOptions(function () use ($id) {
+            $menuList = MenusModel::field(['id', 'pid', 'menu_name'])->order('sort DESC,id ASC')->select()->toArray();
+            $list = sort_list_tier($menuList, '顶级', 'pid', 'menu_name');
+            $menus = [['value' => 0, 'label' => '顶级按钮']];
+            foreach ($list as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['html'] . $menu['menu_name']];
+            }
+            return $menus;
+        })->filterable(1);
+        $field[] = Form::select('module', '模块名', $menu['module'])->options([['label' => '总后台', 'value' => 'admin']]);
+        $field[] = Form::input('controller', '控制器名', $menu['controller']);
+        if (!empty($menu['controller'])) {
+            $controller = preg_replace_callback('/([.]+([a-z]{1}))/i', function ($matches) {
+                return '\\' . strtoupper($matches[2]);
+            }, $menu['controller']);
+            if (class_exists('\app\admin\controller\\' . $controller)) {
+                $list = get_this_class_methods('\app\admin\controller\\' . $controller);
+
+                $field[] = Form::select('action', '方法名', (string)$menu->getData('action'))->setOptions(function () use ($list) {
+                    $menus = [['value' => 0, 'label' => '默认函数']];
+                    foreach ($list as $menu) {
+                        $menus[] = ['value' => $menu, 'label' => $menu];
+                    }
+                    return $menus;
+                })->filterable(1);
+            } else {
+                $field[] = Form::input('action', '方法名', $menu['action']);
+            }
+        } else {
+            $field[] = Form::input('action', '方法名');
+        }
+        $field[] = Form::input('params', '参数', MenusModel::paramStr($menu['params']))->placeholder('举例:a/123/b/234');
+        $field[] = Form::frameInputOne('icon', '图标', Url::buildUrl('admin/widget.widgets/icon', array('fodder' => 'icon')), $menu['icon'])->icon('ionic')->height('500px');
+        $field[] = Form::number('sort', '排序', $menu['sort']);
+        $field[] = Form::radio('is_show', '是否菜单', $menu['is_show'])->options([['value' => 0, 'label' => '隐藏'], ['value' => 1, 'label' => '显示(菜单只显示三级)']]);
+        $form = Form::make_post_form('添加权限', $field, Url::buildUrl('update', array('id' => $id)), 3);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存更新的资源
+     *
+     * @param $id
+     */
+    public function update($id)
+    {
+//        $this->request->filter('htmlspecialchars');
+        $data = Util::postMore([
+            'menu_name',
+            ['controller', '', 'htmlspecialchars'],
+            ['module', 'admin'],
+            'action',
+            'params',
+            'icon',
+            ['sort', 0],
+            ['pid', 0],
+            ['is_show', 0],
+            ['access', 1]]);
+        if (!$data['menu_name']) return Json::fail('请输入按钮名称');
+        if (!MenusModel::get($id)) return Json::fail('编辑的记录不存在!');
+        MenusModel::edit($data, $id);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function delete($id)
+    {
+        if (!$id) return $this->failed('参数错误,请重新打开');
+        $res = MenusModel::delMenu($id);
+        if (!$res)
+            return Json::fail(MenusModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+
+}

+ 130 - 0
app/admin/controller/setting/SystemNotice.php

@@ -0,0 +1,130 @@
+<?php
+
+namespace app\admin\controller\setting;
+
+use app\admin\controller\AuthController;
+use app\admin\model\system\{SystemAdmin, SystemNotice as NoticeModel};
+use crmeb\services\{JsonService, UtilService, FormBuilder as Form};
+use think\facade\Route as Url;
+
+/**
+ * 管理员消息通知 控制器
+ * Class SystemNotice
+ * @package app\admin\controller\system
+ */
+class SystemNotice extends AuthController
+{
+    public function index()
+    {
+        $this->assign(NoticeModel::page(function ($notice) {
+            $notice->push_admin_name = !empty($notice->push_admin) ? implode(',', SystemAdmin::where('id', 'IN', $notice->push_admin)->column('real_name', 'real_name')) : '';
+        }));
+        return $this->fetch();
+    }
+
+    public function create()
+    {
+        $f = array();
+        $f[] = Form::input('title', '通知标题');
+        $f[] = Form::input('type', '通知类型');
+        $f[] = Form::frameInputOne('icon', '图标', Url::buildUrl('admin/widget.widgets/icon', array('fodder' => 'icon')))->icon('ionic')->height('500px');
+        $f[] = Form::input('template', '通知模板');
+        $f[] = Form::input('table_title', '通知数据')->type('textarea')->placeholder('数据1-key1,数据2-key2');
+        $f[] = Form::select('push_admin', '通知管理员')->setOptions(function () {
+            $list = SystemAdmin::getOrdAdmin('real_name,id') ?: [];
+            $options = [];
+            foreach ($list as $admin) {
+                $options[] = ['label' => $admin['real_name'], 'value' => $admin['id']];
+            }
+            return $options;
+        })->multiple(1);
+        $f[] = Form::radio('status', '状态', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]]);
+        $form = Form::make_post_form('添加通知模板', $f, Url::buildUrl('save'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    public function save()
+    {
+        $data = UtilService::postMore([
+            'title', 'type', 'icon', 'template', 'table_title',
+            ['push_admin', []], ['status', 0]
+        ]);
+        $data['push_admin'] = array_unique(array_filter($data['push_admin']));
+        if (!$data['template']) return $this->failed('请填写通知模板');
+        if (!$data['title']) return $this->failed('请输入模板标题');
+        if (!$data['type']) return $this->failed('请输入模板类型');
+        if (NoticeModel::create($data))
+            return $this->successful('添加通知成功');
+        else
+            return $this->failed('添加失败!');
+    }
+
+    /**编辑通知模板
+     * @param $id
+     * @return mixed|void
+     */
+    public function edit($id)
+    {
+        $data = NoticeModel::get($id);
+        if (!$data) return JsonService::fail('数据不存在!');
+        $data->tableTitle = implode(',', array_map(function ($value) {
+            return $value['title'] . '-' . $value['key'];
+        }, $data->table_title));
+        $data->tableTitleStr = implode(',', array_map(function ($value) {
+            return $value['title'] . '-' . $value['key'];
+        }, $data->table_title));
+        $f = array();
+        $f[] = Form::input('title', '通知标题', $data->title);
+        $f[] = Form::input('type', '通知类型', $data->type);
+        $f[] = Form::frameInputOne('icon', '图标', Url::buildUrl('admin/widget.widgets/icon', array('fodder' => 'icon')), $data->icon)->icon('ionic')->height('500px');
+        $f[] = Form::input('template', '通知模板', $data->template);
+        $f[] = Form::input('table_title', '通知数据', $data->tableTitleStr)->type('textarea')->placeholder('数据1-key1,数据2-key2');
+        $f[] = Form::select('push_admin', '通知管理员', $data->push_admin)->setOptions(function () {
+            $list = SystemAdmin::getOrdAdmin('real_name,id') ?: [];
+            $options = [];
+            foreach ($list as $admin) {
+                $options[] = ['label' => $admin['real_name'], 'value' => $admin['id']];
+            }
+            return $options;
+        })->multiple(1);
+        $f[] = Form::radio('status', '状态', $data->status)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]]);
+        $form = Form::make_post_form('编辑通知模板', $f, Url::buildUrl('update', array('id' => $id)));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    public function update($id)
+    {
+        $data = UtilService::postMore([
+            'title', 'type', 'icon', 'template', 'table_title',
+            ['push_admin', []], ['status', 0]
+        ]);
+        $data['push_admin'] = array_unique(array_filter($data['push_admin']));
+        if (!$data['template']) return $this->failed('请填写通知模板');
+        if (!$data['title']) return $this->failed('请输入模板标题');
+        if (!$data['type']) return $this->failed('请输入模板类型');
+        NoticeModel::edit($data, $id);
+        return $this->successful('修改成功!');
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function delete($id)
+    {
+        $res = NoticeModel::del($id);
+        if (!$res)
+            return $this->failed(('删除失败,请稍候再试!'));
+        else
+            return $this->successful('删除成功!');
+    }
+
+    public function message($type = 'all')
+    {
+        return $this->fetch();
+    }
+}

+ 579 - 0
app/admin/controller/setting/SystemPlat.php

@@ -0,0 +1,579 @@
+<?php
+
+namespace app\admin\controller\setting;
+
+use app\admin\controller\AuthController;
+use app\admin\model\system\SystemConfig as ConfigModel;
+use app\models\system\Cache as CacheModel;
+use crmeb\services\{CacheService, ExpressService, FormBuilder, JsonService as Json, product\Product, UtilService};
+use EasyWeChat\Js\Js;
+use think\facade\Route as Url;
+use crmeb\services\CrmebPlatService;
+use crmeb\services\sms\Sms;
+use crmeb\services\express\Express;
+
+/**
+ * crmeb 平台
+ * Class SystemPlat
+ * @package app\admin\controller\setting
+ */
+class SystemPlat extends AuthController
+{
+    protected $account = NULL;
+
+    protected $secret = NULL;
+    /**
+     * @var $crmebPlatHandle
+     */
+    protected $crmebPlatHandle;
+    /**
+     * @var $smsHandle
+     */
+    protected $smsHandle;
+    /**
+     * @var $expressHandle
+     */
+    protected $expressHandle;
+    /**
+     * @var $productHandle
+     */
+    protected $productHandle;
+
+    protected $allowAction = ['index', 'verify', 'login', 'go_login', 'register', 'go_register', 'modify', 'go_modify', 'forget', 'go_forget', 'loginOut', 'meal', 'sms_temp'];
+
+    /**
+     * @var string
+     */
+    protected $cacheTokenPrefix = "_crmeb_plat";
+
+    protected $cacheKey;
+
+    protected function initialize()
+    {
+        parent::initialize();
+        $this->account = sys_config('sms_account');
+        $this->secret = sys_config('sms_token');
+        $config = ['account' => $this->account, 'secret' => $this->secret];
+        $this->crmebPlatHandle = new CrmebPlatService();
+        $this->smsHandle = new Sms('sms', $config);
+        $this->expressHandle = new Express('express', $config);
+        $this->productHandle = new Product('copy', $config);
+        $this->cacheKey = md5($this->account . '_' . $this->secret . $this->cacheTokenPrefix);
+    }
+
+    /**
+     * 显示资源列表
+     *
+     * @return \think\Response
+     */
+    public function index()
+    {
+        if (!CacheModel::getDbCache($this->cacheKey, '')) {
+            return redirect(Url('login')->build() . '?url=index');
+        }
+        [$out, $type] = UtilService::postMore([
+            ['out', 0],
+            ['type', 'sms']
+        ], null, true);
+        try {
+            $info = $this->crmebPlatHandle->info();
+        } catch (\Throwable $e) {
+            $info = [];
+        }
+        $this->assign('info', $info);
+        $this->assign('type', $type);
+        if ($out == 0 && $info) {
+            return $this->fetch();
+        } else {
+            $this->assign('account', $this->account);
+            $this->assign('password', $this->secret);
+            return $this->fetch('login');
+        }
+
+    }
+
+    /**
+     * 获取短信验证码
+     */
+    public function verify()
+    {
+        [$phone] = UtilService::postMore([
+            ['phone', '']
+        ], null, true);
+        if (!$phone) {
+            return Json::fail('请输入手机号');
+        }
+        if (!check_phone($phone)) {
+            return Json::fail('请输入正确的手机号');
+        }
+        $this->crmebPlatHandle->code($phone);
+        return Json::success('获取成功');
+    }
+
+    /**
+     * 登录页面
+     * @return string
+     * @throws \Exception
+     */
+    public function login()
+    {
+        $this->assign('account', $this->account);
+        $this->assign('password', $this->secret);
+        return $this->fetch();
+    }
+
+    /**
+     * 退出登录
+     * @return string
+     * @throws \Exception
+     */
+    public function loginOut()
+    {
+        CacheModel::delectDbCache($this->cacheKey);
+        return Json::success('退出成功', $this->crmebPlatHandle->loginOut());
+    }
+
+
+    /**
+     * 登录逻辑
+     */
+    public function go_login()
+    {
+        $data = UtilService::postMore([
+            ['account', ''],
+            ['password', '']
+        ]);
+        if (!$data['account']) {
+            return Json::fail('请输入账号');
+        }
+        if (!$data['password']) {
+            return Json::fail('请输入秘钥');
+        }
+        $this->save_basics(['sms_account' => $data['account'], 'sms_token' => $data['password']]);
+        $token = $this->crmebPlatHandle->login($data['account'], $data['password']);
+        CacheModel::setDbCache($this->cacheKey, $token, 0);
+        return Json::success('登录成功', $token);
+    }
+
+    /**
+     * 注册页面
+     * @return string
+     * @throws \Exception
+     */
+    public function register()
+    {
+        return $this->fetch();
+    }
+
+    /**
+     * 注册逻辑
+     */
+    public function go_register()
+    {
+        $data = UtilService::postMore([
+            ['account', ''],
+            ['phone', ''],
+            ['password', ''],
+            ['verify_code', ''],
+        ]);
+        if (!$data['account']) {
+            return Json::fail('请输入账号');
+        }
+        if (!$data['phone']) {
+            return Json::fail('请输入手机号');
+        }
+        if (!check_phone($data['phone'])) {
+            return Json::fail('请输入正确的手机号');
+        }
+        if (!$data['password']) {
+            return Json::fail('请设置秘钥');
+        }
+        if (strlen($data['password']) < 6 || strlen($data['password']) > 32) {
+            return Json::fail('密码长度6~32位');
+        }
+        if (!$data['verify_code']) {
+            return Json::fail('请先获取短信验证码');
+        }
+        $result = $this->crmebPlatHandle->register($data['account'], $data['phone'], $data['password'], $data['verify_code']);
+        $this->save_basics(['sms_account' => $data['account'], 'sms_token' => $data['password']]);
+        return Json::success('注册成功', $result);
+    }
+
+    /**
+     * 修改秘钥页面
+     * @return string
+     * @throws \Exception
+     */
+    public function modify()
+    {
+        $this->assign('account', $this->account);
+        return $this->fetch();
+    }
+
+    /**
+     * 修改秘钥逻辑
+     */
+    public function go_modify()
+    {
+        $data = UtilService::postMore([
+            ['account', ''],
+            ['phone', ''],
+            ['password', ''],
+            ['verify_code', ''],
+        ]);
+        if (!$data['account']) {
+            return Json::fail('请输入账号');
+        }
+        if (!$data['phone']) {
+            return Json::fail('请输入手机号');
+        }
+        if (!check_phone($data['phone'])) {
+            return Json::fail('请输入正确的手机号');
+        }
+        if (!$data['password']) {
+            return Json::fail('请设置秘钥');
+        }
+        if (strlen($data['password']) < 6 || strlen($data['password']) > 32) {
+            return Json::fail('密码长度6~32位');
+        }
+        if (!$data['verify_code']) {
+            return Json::fail('请先获取短信验证码');
+        }
+        $result = $this->crmebPlatHandle->modify($data['account'], $data['phone'], $data['password'], $data['verify_code']);
+        $this->save_basics(['sms_account' => $data['account'], 'sms_token' => $data['password']]);
+        return Json::success('修改成功', $result);
+    }
+
+    /**
+     * 找回账号
+     * @return string
+     * @throws \Exception
+     */
+    public function forget()
+    {
+        return $this->fetch();
+    }
+
+    /**
+     * 找回账号逻辑
+     */
+    public function go_fotget()
+    {
+        $data = $where = UtilService::postMore([
+            ['phone', ''],
+            ['verify_code', ''],
+        ]);
+        if (!isset($data['phone']) || $data['phone']) {
+            return Json::fail('请输入手机号');
+        }
+        if (!check_phone($data['phone'])) {
+            return Json::fail('请输入正确的手机号');
+        }
+        if (!isset($data['verify_code']) || $data['verify_code']) {
+            return Json::fail('请先获取短信验证码');
+        }
+        $result = $this->crmebPlatHandle->fotget($data['phone'], $data['verify_code']);
+        return Json::success('修改成功', $result);
+    }
+
+    /**
+     * 获取消费记录
+     */
+    public function record()
+    {
+        [$type, $page, $limit] = UtilService::getMore([
+            ['type', 'sms'],
+            ['page', 1],
+            ['limit', 20]
+        ], null, true);
+        $result = $this->crmebPlatHandle->record($type, $page, $limit);
+        if ($type == 'expr_query') {
+            $express = ExpressService::expressList();
+            $express = array_combine(array_column($express, 'code'), $express);
+            foreach ($result['data'] as $key => $value) {
+                $result['data'][$key]['name'] = $express[$value['code']]['name'] ?? '';
+                $result['data'][$key]['num'] = $value['content']['num'] ?? '';
+            }
+        }
+        return Json::successlayui($result);
+    }
+
+    /**
+     * @return string
+     * @throws \Exception
+     */
+    public function meal()
+    {
+        if (!CacheModel::getDbCache($this->cacheKey, '')) {
+            return redirect(Url('login')->build() . '?url=meal');
+        }
+        return $this->fetch();
+    }
+
+    /**
+     * 获取套餐列表
+     */
+    public function get_meal()
+    {
+        [$type] = UtilService::getMore([
+            ['type', 'sms']
+        ], null, true);
+        return Json::success($this->crmebPlatHandle->meal($type));
+    }
+
+    /**
+     * 获取支付二维码
+     * @return string
+     * @throws \Exception
+     */
+    public function pay()
+    {
+        [$meal_id, $price, $num, $type, $pay_type] = UtilService::postMore([
+            ['meal_id', 0],
+            ['price', ''],
+            ['num', 0],
+            ['type', ''],
+            ['pay_type', 'weixin']
+        ], null, true);
+        if (!$meal_id) {
+            return Json::fail('请选择套餐');
+        }
+        return Json::success($this->crmebPlatHandle->pay($type, $meal_id, $price, $num, $pay_type));
+    }
+
+
+    /**
+     * 保存一号通配置
+     */
+    public function save_basics($data)
+    {
+        if ($data) {
+            CacheService::clear();
+            foreach ($data as $k => $v) {
+                ConfigModel::edit(['value' => json_encode($v)], $k, 'menu_name');
+            }
+        }
+        return true;
+    }
+
+    /**
+     * 开通短信服务页面
+     * @return string
+     * @throws \Exception
+     */
+    public function sms_open()
+    {
+        try {
+            $info = $this->crmebPlatHandle->info();
+        } catch (\Throwable $e) {
+            $info = [];
+        }
+        $this->assign('info', $info);
+        return $this->fetch();
+    }
+
+    /**
+     * 处理开通短信服务
+     */
+    public function go_sms_open()
+    {
+        [$sign] = UtilService::postMore([
+            ['sign', '']
+        ], null, true);
+        if (!$sign) {
+            return Json::fail('请输入短信签名');
+        }
+        return Json::success('开通成功', $this->smsHandle->setSign($sign)->open());
+    }
+
+    /**
+     * 短信账户信息
+     */
+    public function sms_info()
+    {
+        return Json::success($this->smsHandle->info());
+    }
+
+    /**
+     * 修改签名页面
+     * @return string
+     * @throws \Exception
+     */
+    public function sms_modify()
+    {
+        return $this->fetch();
+    }
+
+    /**
+     * 处理修改签名
+     */
+    public function go_sms_modify()
+    {
+        [$sign] = UtilService::postMore([
+            ['sign', '']
+        ], null, true);
+        if (!$sign) {
+            return Json::fail('请输入短信签名');
+        }
+        return Json::success($this->smsHandle->modify($sign));
+    }
+
+    /**
+     * 短信模版页面
+     */
+    public function sms_temp()
+    {
+        if (!CacheModel::getDbCache($this->cacheKey, '')) {
+            return redirect(Url('login')->build() . '?url=sms_temp');
+        }
+        [$type] = UtilService::getMore([
+            ['type', 'temps'],
+        ], null, true);
+        $this->assign('type', $type);
+        return $this->fetch();
+    }
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return string
+     * @throws \FormBuilder\exception\FormBuilderException
+     */
+    public function create()
+    {
+        $field = [
+            FormBuilder::input('title', '模板名称'),
+            FormBuilder::textarea('text', '模板内容示例', '您的验证码是:{$code},有效期为{$time}分钟。如非本人操作,可不用理会。(模板中的{$code}和{$time}需要替换成对应的变量,请开发者知晓。修改此项无效!)')->readonly(true),
+            FormBuilder::input('content', '模板内容')->type('textarea'),
+            FormBuilder::radio('type', '模板类型', 1)->options([['label' => '验证码', 'value' => 1], ['label' => '通知', 'value' => 2], ['label' => '推广', 'value' => 3]])
+        ];
+        $form = FormBuilder::make_post_form('申请短信模板', $field, Url::buildUrl('go_sms_temps_apply'), 2);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 短信模版
+     */
+    public function get_sms_temps()
+    {
+        [$page, $limit, $temp_type] = UtilService::getMore([
+            ['page', 1],
+            ['limit', 20],
+            ['temp_type', ''],
+        ], null, true);
+        return Json::successlayui($this->smsHandle->temps($page, $limit, $temp_type));
+    }
+
+    /**
+     * 短信模版申请记录
+     */
+    public function get_sms_appls()
+    {
+        [$temp_type, $page, $limit] = UtilService::getMore([
+            ['temp_type', ''],
+            ['page', 1],
+            ['limit', 20]
+        ], null, true);
+        return Json::successlayui($this->smsHandle->applys($temp_type, $page, $limit));
+    }
+
+    /**
+     * 短信发送记录
+     */
+    public function sms_record()
+    {
+        [$record_id] = UtilService::getMore([
+            ['record_id', 0],
+        ], null, true);
+        return Json::success($this->smsHandle->record($record_id));
+    }
+
+    /**
+     * 模版申请页面
+     * @return string
+     * @throws \Exception
+     */
+    public function sms_temps_apply()
+    {
+        return $this->fetch();
+    }
+
+    /**
+     * 处理申请模版
+     */
+    public function go_sms_temps_apply()
+    {
+        [$type, $title, $content] = UtilService::getMore([
+            ['type', 1],
+            ['title', ''],
+            ['content', '']
+        ], null, true);
+        if (!$type) {
+            return Json::fail('请选择模版类型');
+        }
+        if (!$title) {
+            return Json::fail('请输入模版标题');
+        }
+        if (!$content) {
+            return Json::fail('请输入模版内容');
+        }
+        $this->smsHandle->apply($title, $content, $type);
+        return Json::success('申请成功');
+    }
+
+    /**
+     * 开通物流服务页面
+     * @return string
+     * @throws \Exception
+     */
+    public function express_open()
+    {
+        return $this->fetch();
+    }
+
+    /**
+     * 处理开通物流服务
+     */
+    public function go_express_open()
+    {
+        return Json::success('开通成功', $this->expressHandle->open());
+    }
+
+    /**
+     * 获取快递公司列表
+     */
+    public function express_list()
+    {
+        [$type, $page, $limit] = UtilService::postMore([
+            ['sign', 1],
+            ['page', 1],
+            ['limit', 10]
+        ], null, true);
+        return Json::success($this->expressHandle->express($type, $page, $limit));
+    }
+
+    /**
+     * 获取电子面单模版
+     */
+    public function express_temp()
+    {
+        [$com, $page, $limit] = UtilService::postMore([
+            ['com', 0],
+            ['page', 1],
+            ['limit', 10]
+        ], null, true);
+        if (!$com) {
+            return Json::fail('请选择快递');
+        }
+        return Json::success($this->expressHandle->temp($com, $page, $limit));
+    }
+
+    /**
+     * 开通复制商品
+     */
+    public function go_copy_open()
+    {
+        return Json::success($this->productHandle->open());
+    }
+}

+ 142 - 0
app/admin/controller/setting/SystemRole.php

@@ -0,0 +1,142 @@
+<?php
+
+namespace app\admin\controller\setting;
+
+use app\admin\controller\AuthController;
+use app\admin\model\system\{SystemMenus, SystemRole as RoleModel};
+use crmeb\services\{UtilService as Util, JsonService as Json};
+use think\facade\Route as Url;
+
+/**
+ * 身份管理  控制器
+ * Class SystemRole
+ * @package app\admin\controller\setting
+ */
+class SystemRole extends AuthController
+{
+    /**
+     * 显示资源列表
+     *
+     * @return \think\Response
+     */
+    public function index()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['role_name', ''],
+        ], $this->request);
+        $where['level'] = $this->adminInfo['level'];
+        $this->assign('where', $where);
+        $this->assign(RoleModel::systemPage($where));
+        return $this->fetch();
+    }
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return \think\Response
+     */
+    public function create()
+    {
+
+//        if(0 == 0){
+//        }else{
+//            dump($this->adminInfo['level']);
+//        }
+        $menus = $this->adminInfo['level'] == 0 ? SystemMenus::ruleList() : SystemMenus::rolesByRuleList($this->adminInfo['roles']);
+        $this->assign(['menus' => json($menus)->getContent(), 'saveUrl' => Url::buildUrl('save')]);
+        return $this->fetch();
+    }
+
+    /**
+     * 保存新建的资源
+     *
+     * @param \think\Request $request
+     * @return \think\Response
+     */
+    public function save()
+    {
+        $data = Util::postMore([
+            'role_name',
+            ['status', 0],
+            ['checked_menus', [], '', 'rules']
+        ]);
+        if (!$data['role_name']) return Json::fail('请输入身份名称');
+        if (!is_array($data['rules']) || !count($data['rules']))
+            return Json::fail('请选择最少一个权限');
+        foreach ($data['rules'] as $v) {
+            $pid = SystemMenus::where('id', $v)->value('pid');
+            if (!in_array($pid, $data['rules'])) $data['rules'][] = $pid;
+        }
+        $data['rules'] = implode(',', $data['rules']);
+        $data['level'] = $this->adminInfo['level'] + 1;
+        if (!RoleModel::create($data)) return Json::fail('添加身份失败!');
+        return Json::successful('添加身份成功!');
+    }
+
+    /**
+     * 显示指定的资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function read($id)
+    {
+        //
+    }
+
+    /**
+     * 显示编辑资源表单页.
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function edit($id)
+    {
+        //
+        $role = RoleModel::get($id);
+        $menus = $this->adminInfo['level'] == 0 ? SystemMenus::ruleList() : SystemMenus::rolesByRuleList($this->adminInfo['roles']);
+        $this->assign(['role' => $role->toJson(), 'menus' => json($menus)->getContent(), 'updateUrl' => Url::buildUrl('update', array('id' => $id))]);
+        return $this->fetch();
+    }
+
+    /**
+     * 保存更新的资源
+     *
+     * @param \think\Request $request
+     * @param int $id
+     * @return \think\Response
+     */
+    public function update($id)
+    {
+        $data = Util::postMore([
+            'role_name',
+            ['status', 0],
+            ['checked_menus', [], '', 'rules']
+        ]);
+        if (!$data['role_name']) return Json::fail('请输入身份名称');
+        if (!is_array($data['rules']) || !count($data['rules']))
+            return Json::fail('请选择最少一个权限');
+        foreach ($data['rules'] as $v) {
+            $pid = SystemMenus::where('id', $v)->value('pid');
+            if (!in_array($pid, $data['rules'])) $data['rules'][] = $pid;
+        }
+        $data['rules'] = implode(',', $data['rules']);
+        if (!RoleModel::edit($data, $id)) return Json::fail('修改失败!');
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function delete($id)
+    {
+        if (!RoleModel::del($id))
+            return Json::fail(RoleModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+}

+ 65 - 0
app/admin/controller/sms/SmsAdmin.php

@@ -0,0 +1,65 @@
+<?php
+
+namespace app\admin\controller\sms;
+
+use app\admin\controller\AuthController;
+use app\admin\model\system\SystemConfig;
+use crmeb\services\{
+    CacheService, HttpService, JsonService, sms\Sms, UtilService
+};
+
+/**
+ * 短信账号
+ * Class SmsAdmin
+ * @package app\admin\controller\sms
+ */
+class SmsAdmin extends AuthController
+{
+    /**
+     * @return string
+     */
+    public function index()
+    {
+        return $this->fetch();
+    }
+
+    public function captcha()
+    {
+        if (!request()->isPost()) return JsonService::fail('发送失败');
+        $phone = request()->param('phone');
+        if (!trim($phone)) return JsonService::fail('请填写手机号');
+        $sms = new Sms('yunxin');
+        $res = json_decode(HttpService::getRequest($sms->getSmsUrl(), compact('phone')), true);
+        if (!isset($res['status']) && $res['status'] !== 200)
+            return JsonService::fail(isset($res['data']['message']) ? $res['data']['message'] : $res['msg']);
+        return JsonService::success(isset($res['data']['message']) ? $res['data']['message'] : '发送成功');
+    }
+
+    /**
+     * 修改/注册短信平台账号
+     */
+    public function save()
+    {
+        list($account, $password, $phone, $code, $url, $sign) = UtilService::postMore([
+            ['account', ''],
+            ['password', ''],
+            ['phone', ''],
+            ['code', ''],
+            ['url', ''],
+            ['sign', ''],
+        ], null, true);
+        $signLen = mb_strlen(trim($sign));
+        if (!strlen(trim($account))) return JsonService::fail('请填写账号');
+        if (!strlen(trim($password))) return JsonService::fail('请填写密码');
+        if (!$signLen) return JsonService::fail('请填写短信签名');
+        if ($signLen > 8) return JsonService::fail('短信签名最长为8位');
+        if (!strlen(trim($code))) return JsonService::fail('请填写验证码');
+        if (!strlen(trim($url))) return JsonService::fail('请填写域名');
+        $sms = new Sms('yunxin');
+        $status = $sms->register($account, md5(trim($password)), $url, $phone, $code, $sign);
+        if ($status['status'] == 400) return JsonService::fail('短信平台:' . $status['msg']);
+        CacheService::clear();
+        SystemConfig::setConfigSmsInfo($account, $password);
+        return JsonService::success('短信平台:' . $status['msg']);
+    }
+}

+ 140 - 0
app/admin/controller/sms/SmsConfig.php

@@ -0,0 +1,140 @@
+<?php
+
+namespace app\admin\controller\sms;
+
+use app\admin\controller\AuthController;
+use think\facade\Route;
+use app\admin\model\system\SystemConfig as ConfigModel;
+use crmeb\services\{FormBuilder, sms\Sms, SystemConfigService, UtilService, CacheService};
+
+/**
+ * 短信配置
+ * Class SmsConfig
+ * @package app\admin\controller\sms
+ */
+class SmsConfig extends AuthController
+{
+    /**
+     * @var Sms
+     */
+    protected $smsHandle;
+
+    protected function initialize()
+    {
+        parent::initialize(); // TODO: Change the autogenerated stub
+
+    }
+
+    /**
+     * 展示配置
+     * @return string
+     * @throws \FormBuilder\exception\FormBuilderException
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @throws \think\exception\DbException
+     */
+    public function index()
+    {
+        [$type, $tab_id] = UtilService::getMore([
+            ['type', 0],
+            ['tab_id', 0]
+        ], null, true);
+
+        if (!$tab_id) $tab_id = 1;
+        $this->assign('tab_id', $tab_id);
+        $list = ConfigModel::getAll($tab_id);
+        if ($type == 3) {//其它分类
+            $config_tab = null;
+        } else {
+            $config_tab = ConfigModel::getConfigTabAll($type);
+            foreach ($config_tab as $kk => $vv) {
+                $arr = ConfigModel::getAll($vv['value'])->toArray();
+                if (empty($arr)) {
+                    unset($config_tab[$kk]);
+                }
+            }
+        }
+        $formBuilder = ConfigModel::builder_config_from_data($list);
+        $form = FormBuilder::make_post_form('编辑配置', $formBuilder, Route::buildUrl('save_basics'));
+        $this->assign(compact('form'));
+        $this->assign('config_tab', $config_tab);
+        $this->assign('list', $list);
+        return $this->fetch();
+    }
+
+    /**
+     * 保存配置
+     */
+    public function save_basics()
+    {
+        $request = app('request');
+        if ($request->isPost()) {
+            CacheService::clear();
+            $post = $request->post();
+            foreach ($post as $k => $v) {
+                if (is_array($v)) {
+                    $res = ConfigModel::where('menu_name', $k)->column('upload_type', 'type');
+                    foreach ($res as $kk => $vv) {
+                        if ($kk == 'upload') {
+                            if ($vv == 1 || $vv == 3) {
+                                $post[$k] = $v[0];
+                            }
+                        }
+                    }
+                }
+            }
+            foreach ($post as $k => $v) {
+                ConfigModel::edit(['value' => json_encode($v)], $k, 'menu_name');
+            }
+
+            //添加公共短信模板
+            $this->smsHandle = new Sms('yunxin', [
+                'sms_account' => SystemConfigService::get('sms_account','',true),
+                'sms_token' => SystemConfigService::get('sms_token','',true),
+                'site_url' => sys_config('site_url')
+            ]);
+            $templateList = $this->smsHandle->publictemp([]);
+            if ($templateList['status'] != 400){
+                if ($templateList['data']['data'])
+                    foreach ($templateList['data']['data'] as $v) {
+                        if ($v['is_have'] == 0)
+                            $this->smsHandle->use($v['id'], $v['templateid']);
+                    }
+
+                return $this->successful('修改成功');
+            }else{
+                return $this->failed('账号或密码错误');
+            }
+        }
+    }
+
+    /**
+     * 退出
+     * @return mixed
+     * @throws \Psr\SimpleCache\InvalidArgumentException
+     */
+    public function logout()
+    {
+        $post = [
+            'sms_account' => '',
+            'sms_token' => ''
+        ];
+        foreach ($post as $k => $v) {
+            if (is_array($v)) {
+                $res = ConfigModel::where('menu_name', $k)->column('upload_type', 'type');
+                foreach ($res as $kk => $vv) {
+                    if ($kk == 'upload') {
+                        if ($vv == 1 || $vv == 3) {
+                            $post[$k] = $v[0];
+                        }
+                    }
+                }
+            }
+        }
+        foreach ($post as $k => $v) {
+            ConfigModel::edit(['value' => json_encode($v)], $k, 'menu_name');
+        }
+        CacheService::clear();
+        return redirect(url('sms.smsConfig/index') . '?type=4&tab_id=18');
+    }
+}

+ 82 - 0
app/admin/controller/sms/SmsPay.php

@@ -0,0 +1,82 @@
+<?php
+
+namespace app\admin\controller\sms;
+
+use think\facade\Route;
+use app\admin\controller\AuthController;
+use crmeb\services\{
+    sms\Sms, FormBuilder, JsonService, UtilService
+};
+
+/**
+ * 短信购买
+ * Class SmsPay
+ * @package app\admin\controller\sms
+ */
+class SmsPay extends AuthController
+{
+    /**
+     * @var Sms
+     */
+    protected $smsHandle;
+
+    protected function initialize()
+    {
+        parent::initialize(); // TODO: Change the autogenerated stub
+        $this->smsHandle = new Sms('yunxin', [
+            'sms_account' => sys_config('sms_account'),
+            'sms_token' => sys_config('sms_token'),
+            'site_url' => sys_config('site_url')
+        ]);
+    }
+
+    /**
+     * 显示资源列表
+     * @return string
+     */
+    public function index()
+    {
+        if (!$this->smsHandle->isLogin()) return redirect(url('sms.smsConfig/index').'?type=4&tab_id=18');
+        return $this->fetch();
+    }
+
+    /**
+     *  获取账号信息
+     */
+    public function number()
+    {
+        $countInfo = $this->smsHandle->count();
+        if ($countInfo['status'] == 400) return JsonService::fail($countInfo['msg']);
+        return JsonService::success($countInfo['data']);
+    }
+
+    /**
+     *  获取支付套餐
+     */
+    public function price()
+    {
+        list($page, $limit) = UtilService::getMore([
+            ['page', 1],
+            ['limit', 20],
+        ], null, true);
+        $mealInfo = $this->smsHandle->meal($page, $limit);
+        if ($mealInfo['status'] == 400) return JsonService::fail($mealInfo['msg']);
+        return JsonService::success($mealInfo['data']['data']);
+    }
+
+    /**
+     * 获取支付码
+     */
+    public function pay()
+    {
+        list($payType, $mealId, $price) = UtilService::postMore([
+            ['payType', 'weixin'],
+            ['mealId', 0],
+            ['price', 0],
+        ], null, true);
+        $payInfo = $this->smsHandle->pay($payType, $mealId, $price, $this->adminId);
+        if ($payInfo['status'] == 400) return JsonService::fail($payInfo['msg']);
+        return JsonService::success($payInfo['data']);
+    }
+
+}

+ 70 - 0
app/admin/controller/sms/SmsPublicTemp.php

@@ -0,0 +1,70 @@
+<?php
+
+namespace app\admin\controller\sms;
+
+use app\admin\controller\AuthController;
+use crmeb\services\{
+    JsonService, sms\Sms, UtilService
+};
+
+/**
+ * 公共短信模板
+ * Class SmsPublicTemp
+ * @package app\admin\controller\sms
+ */
+class SmsPublicTemp extends AuthController
+{
+    /**
+     * @var Sms
+     */
+    protected $smsHandle;
+
+    protected function initialize()
+    {
+        parent::initialize(); // TODO: Change the autogenerated stub
+        $this->smsHandle = new Sms('yunxin', [
+            'sms_account' => sys_config('sms_account'),
+            'sms_token' => sys_config('sms_token'),
+            'site_url' => sys_config('site_url')
+        ]);
+    }
+
+    public function index()
+    {
+        if (!$this->smsHandle->isLogin()) return $this->failed('请先填写短信配置');
+        return $this->fetch();
+    }
+
+    /**
+     * 异步获取公共模板列表
+     */
+    public function lst()
+    {
+        $where = UtilService::getMore([
+            ['is_have', ''],
+            ['page', 1],
+            ['limit', 20],
+        ]);
+        $templateList = $this->smsHandle->publictemp($where);
+        if ($templateList['status'] == 400) return JsonService::fail($templateList['msg']);
+        return JsonService::successlayui($templateList['data']);
+    }
+
+    /**
+     * 添加公共短信模板
+     */
+    public function status()
+    {
+        list($id, $tempId) = UtilService::postMore([
+            ['id', 0],
+            ['tempId', 0]
+        ], null, true);
+        if (!(int)$id) return JsonService::fail('参数错误');
+        if (!strlen(trim($tempId))) return JsonService::fail('参数错误');
+        $useStatus = $this->smsHandle->use($id, $tempId);
+        if ($useStatus['status'] == 400) return JsonService::fail($useStatus['msg']);
+        return JsonService::success($useStatus['msg']);
+    }
+
+
+}

+ 57 - 0
app/admin/controller/sms/SmsRecord.php

@@ -0,0 +1,57 @@
+<?php
+
+namespace app\admin\controller\sms;
+
+use app\admin\controller\AuthController;
+use crmeb\services\JsonService;
+use app\admin\model\sms\SmsRecord as SmsRecordModel;
+use crmeb\services\sms\Sms;
+use crmeb\services\UtilService;
+
+/**
+ * 短息发送日志
+ * Class SmsLog
+ * @package app\admin\controller\sms
+ */
+class SmsRecord extends AuthController
+{
+    /**
+     * @var Sms
+     */
+    protected $smsHandle;
+
+    protected function initialize()
+    {
+        parent::initialize(); // TODO: Change the autogenerated stub
+        $this->smsHandle = new Sms('yunxin', [
+            'sms_account' => sys_config('sms_account'),
+            'sms_token' => sys_config('sms_token'),
+            'site_url' => sys_config('site_url')
+        ]);
+    }
+
+    /**
+     * 短信记录页面
+     * @return string
+     */
+    public function index()
+    {
+        if (!$this->smsHandle->isLogin()) return redirect(url('sms.smsConfig/index').'?type=4&tab_id=18');
+        return $this->fetch();
+    }
+
+    /**
+     * 获取短信记录列表
+     */
+    public function recordList()
+    {
+        $where = UtilService::getMore([
+            ['page', 1],
+            ['limit', 20],
+            ['type', ''],
+            ['uid', ''],
+            ['phone', ''],
+        ]);
+        return JsonService::successlayui(SmsRecordModel::getRecordList($where));
+    }
+}

+ 97 - 0
app/admin/controller/sms/SmsTemplateApply.php

@@ -0,0 +1,97 @@
+<?php
+
+namespace app\admin\controller\sms;
+
+use app\admin\controller\AuthController;
+use crmeb\services\{
+    FormBuilder, JsonService, sms\Sms, UtilService
+};
+use think\facade\Route;
+
+/**
+ * 短信模板申请
+ * Class SmsTemplateApply
+ * @package app\admin\controller\sms
+ */
+class SmsTemplateApply extends AuthController
+{
+    /**
+     * @var Sms
+     */
+    protected $smsHandle;
+
+    protected function initialize()
+    {
+        parent::initialize(); // TODO: Change the autogenerated stub
+        $this->smsHandle = new Sms('yunxin', [
+            'sms_account' => sys_config('sms_account'),
+            'sms_token' => sys_config('sms_token'),
+            'site_url' => sys_config('site_url')
+        ]);
+    }
+
+    /**
+     * 显示资源列表
+     *
+     * @return string
+     */
+    public function index()
+    {
+        if (!$this->smsHandle->isLogin()) return redirect(url('sms.smsConfig/index').'?type=4&tab_id=18');
+        $sms_account = sys_config('sms_account');
+        $this->assign('sms_account',$sms_account);
+        return $this->fetch();
+    }
+
+    /**
+     * 异步获取模板列表
+     */
+    public function lst()
+    {
+        $where = UtilService::getMore([
+            ['status', ''],
+            ['title', ''],
+            ['page', 1],
+            ['limit', 20],
+        ]);
+        $templateList = $this->smsHandle->template($where);
+        if ($templateList['status'] == 400) return JsonService::fail($templateList['msg']);
+        return JsonService::successlayui($templateList['data']);
+    }
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return string
+     * @throws \FormBuilder\exception\FormBuilderException
+     */
+    public function create()
+    {
+        $field = [
+            FormBuilder::input('title', '模板名称'),
+            FormBuilder::textarea('text', '模板内容示例', '【您的短信签名】您的验证码是:{$code},有效期为{$time}分钟。如非本人操作,可不用理会。模板中的{$code}和{$time}需要替换成对应的变量,请开发者知晓。修改此项无效!'),
+            FormBuilder::input('content', '模板内容')->type('textarea'),
+            FormBuilder::radio('type', '模板类型', 1)->options([['label' => '验证码', 'value' => 1], ['label' => '通知', 'value' => 2], ['label' => '推广', 'value' => 3]])
+        ];
+        $form = FormBuilder::make_post_form('申请短信模板', $field, Route::buildUrl('save'), 2);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存新建的资源
+     */
+    public function save()
+    {
+        $data = UtilService::postMore([
+            ['title', ''],
+            ['content', ''],
+            ['type', 0]
+        ]);
+        if (!strlen(trim($data['title']))) return JsonService::fail('请输入模板名称');
+        if (!strlen(trim($data['content']))) return JsonService::fail('请输入模板内容');
+        $applyStatus = $this->smsHandle->apply($data['title'], $data['content'], $data['type']);
+        if ($applyStatus['status'] == 400) return JsonService::fail($applyStatus['msg']);
+        return JsonService::success('申请成功');
+    }
+}

+ 1008 - 0
app/admin/controller/store/CopyTaobao.php

@@ -0,0 +1,1008 @@
+<?php
+/**
+ * Project: 快速复制 淘宝、天猫、1688、京东 商品到CRMEB系统
+ * Author: 有一片天 <810806442@qq.com>  微信:szktor
+ * Date: 2019-04-25
+ */
+
+namespace app\admin\controller\store;
+
+use app\admin\controller\AuthController;
+use think\exception\PDOException;
+use crmeb\traits\CurdControllerTrait;
+use crmeb\services\{CacheService, HttpService, JsonService, UtilService};
+use app\admin\model\system\{
+    SystemAttachment, SystemAttachmentCategory
+};
+use app\admin\model\store\{
+    StoreCategory as CategoryModel, StoreDescription, StoreProduct as ProductModel, StoreProductAttr, StoreProductCate
+};
+use crmeb\services\upload\Upload;
+use crmeb\services\product\Product;
+
+/**
+ * 产品管理
+ * Class StoreProduct
+ * @package app\admin\controller\store
+ */
+class CopyTaobao extends AuthController
+{
+
+    use CurdControllerTrait;
+
+    protected $bindModel = ProductModel::class;
+    //错误信息
+    protected $errorInfo = true;
+    //产品默认字段
+    protected $productInfo = [
+        'cate_id' => '',
+        'store_name' => '',
+        'store_info' => '',
+        'unit_name' => '件',
+        'price' => 0,
+        'keyword' => '',
+        'ficti' => 0,
+        'ot_price' => 0,
+        'give_integral' => 0,
+        'postage' => 0,
+        'cost' => 0,
+        'image' => '',
+        'slider_image' => '',
+        'add_time' => 0,
+        'stock' => 0,
+        'description' => '',
+        'soure_link' => '',
+        'temp_id' => 0
+    ];
+    //抓取网站主域名
+    protected $grabName = [
+        'taobao',
+        '1688',
+        'tmall',
+        'jd'
+    ];
+    //远程下载附件图片分类名称
+    protected $AttachmentCategoryName = '远程下载';
+
+    //cookie 采集前请配置自己的 cookie,获取方式浏览器登录平台,F12或查看元素 network->headers 查看Request Headers 复制cookie 到下面变量中
+    protected $webcookie = [
+        //淘宝
+        'taobao' => 'cookie: miid=8289590761042824660; thw=cn; cna=bpdDExs9KGgCAXuLszWnEXxS; hng=CN%7Czh-CN%7CCNY%7C156; tracknick=taobaorongyao; _cc_=WqG3DMC9EA%3D%3D; tg=0; enc=WQPStocTopRI3wEBOPpj8VUDkqSw4Ph81ASG9053SgG8xBMzaOuq6yMe8KD4xPBlNfQST7%2Ffsk9M9GDtGmn6iQ%3D%3D; t=4bab065740d964a05ad111f5057078d4; cookie2=1965ea371faf24b163093f31af4120c2; _tb_token_=5d3380e119d6e; v=0; mt=ci%3D-1_1; _m_h5_tk=61bf01c61d46a64c98209a7e50e9e1df_1572349453522; _m_h5_tk_enc=9d9adfcbd7af7e2274c9b331dc9bae9b; l=dBgc_jG4vxuski7DBOCgCuI8aj7TIIRAguPRwN0viOCKUxT9CgCDAJt5v8PWVNKO7t1nNetzvui3udLHRntW6KTK6MK9zd9snxf..; isg=BJWVXJ3FZGyiWUENfGCuywlwpJePOkncAk8hmRc6WoxbbrVg3-Jadf0uODL97mFc',
+        //阿里巴巴 1688
+        'alibaba' => '',
+        //天猫 可以和淘宝一样
+        'tmall' => 'cookie: miid=8289590761042824660; thw=cn; cna=bpdDExs9KGgCAXuLszWnEXxS; hng=CN%7Czh-CN%7CCNY%7C156; tracknick=taobaorongyao; _cc_=WqG3DMC9EA%3D%3D; tg=0; enc=WQPStocTopRI3wEBOPpj8VUDkqSw4Ph81ASG9053SgG8xBMzaOuq6yMe8KD4xPBlNfQST7%2Ffsk9M9GDtGmn6iQ%3D%3D; t=4bab065740d964a05ad111f5057078d4; cookie2=1965ea371faf24b163093f31af4120c2; _tb_token_=5d3380e119d6e; v=0; mt=ci%3D-1_1; _m_h5_tk=61bf01c61d46a64c98209a7e50e9e1df_1572349453522; _m_h5_tk_enc=9d9adfcbd7af7e2274c9b331dc9bae9b; l=dBgc_jG4vxuski7DBOCgCuI8aj7TIIRAguPRwN0viOCKUxT9CgCDAJt5v8PWVNKO7t1nNetzvui3udLHRntW6KTK6MK9zd9snxf..; isg=BJWVXJ3FZGyiWUENfGCuywlwpJePOkncAk8hmRc6WoxbbrVg3-Jadf0uODL97mFc',
+        //京东 可不用配置
+        'jd' => ''
+    ];
+
+    //请求平台名称 taobao alibaba tmall jd
+    protected $webnname = 'taobao';
+
+    /**
+     * 显示资源
+     * @return html
+     */
+    public function index()
+    {
+        $list = CategoryModel::getTierList(null, 1);
+        $menus = [];
+        foreach ($list as $menu) {
+            $menus[] = ['value' => $menu['id'], 'label' => $menu['html'] . $menu['cate_name'], 'disabled' => $menu['pid'] == 0];//,'disabled'=>$menu['pid']== 0];
+        }
+        $this->assign('menus', $menus);
+        $this->assign('is_layui', 1);
+        return $this->fetch();
+    }
+
+    /**
+     * 付费采集页面
+     * @return html
+     */
+    public function product()
+    {
+        $list = CategoryModel::getTierList(null, 1);
+        $menus = [];
+        foreach ($list as $menu) {
+            $menus[] = ['value' => $menu['id'], 'label' => $menu['html'] . $menu['cate_name'], 'disabled' => $menu['pid'] == 0];//,'disabled'=>$menu['pid']== 0];
+        }
+        $this->assign('menus', $menus);
+        $this->assign('is_layui', 1);
+        return $this->fetch();
+    }
+
+    /**
+     * 付费采集请求
+     */
+    public function get_product_info()
+    {
+        list($link, $type) = UtilService::postMore([
+            ['link', ''],
+            ['type', '']
+        ], $this->request, true);
+        $cache = app()->make(CacheService::class);
+        $product = new Product('copy', ['account' => sys_config('sms_account'), 'secret' => sys_config('sms_token')]);
+        $key = md5($link);
+        $info = $cache->get($key);
+        if(!$info){
+            $info = $product->goods($link);
+            $cache->set($key,$info,7200);
+        }
+        $info = array_merge($this->productInfo,$info);
+        return JsonService::successful($info);
+    }
+
+    /*
+     * 设置错误信息
+     * @param string $msg 错误信息
+     * */
+    public function setErrorInfo($msg = '')
+    {
+        $this->errorInfo = $msg;
+        return false;
+    }
+
+    /*
+     * 设置字符串字符集
+     * @param string $str 需要设置字符集的字符串
+     * @return string
+     * */
+    public function Utf8String($str)
+    {
+        $encode = mb_detect_encoding($str, array("ASCII", 'UTF-8', "GB2312", "GBK", 'BIG5'));
+        if (strtoupper($encode) == 'UTF-8') {
+
+        } else if (strtolower($encode) == 'cp936') {
+//            $str = iconv('latin1//IGNORE', 'utf-8', $str);
+            $str = mb_convert_encoding($str, 'utf-8', 'GBK');
+        } else {
+            $str = mb_convert_encoding($str, 'utf-8', $encode);
+        }
+        return $str;
+    }
+
+    /**
+     * 获取资源,并解析出对应的商品参数
+     * @return json
+     */
+    public function get_request_contents()
+    {
+        list($link) = UtilService::postMore([
+            ['link', '']
+        ], $this->request, true);
+        $url = $this->checkurl($link);
+        if ($url === false) return JsonService::fail($this->errorInfo);
+        $this->errorInfo = true;
+        $html = $this->curl_Get($url, 60);
+        if (!$html) return JsonService::fail('商品HTML信息获取失败');
+        $html = $this->Utf8String($html);
+        preg_match('/<title>([^<>]*)<\/title>/', $html, $title);
+        //商品标题
+        $this->productInfo['store_name'] = isset($title['1']) ? str_replace(['-淘宝网', '-tmall.com天猫', ' - 阿里巴巴', ' ', '-', '【图片价格品牌报价】京东', '京东', '【行情报价价格评测】'], '', trim($title['1'])) : '';
+        $this->productInfo['store_info'] = $this->productInfo['store_name'];
+        try {
+            //获取url信息
+            $pathinfo = pathinfo($url);
+            if (!isset($pathinfo['dirname'])) return JsonService::fail('解析URL失败');
+            //提取域名
+            $parse_url = parse_url($pathinfo['dirname']);
+            if (!isset($parse_url['host'])) return JsonService::fail('获取域名失败');
+            //获取第一次.出现的位置
+            $strLeng = strpos($parse_url['host'], '.') + 1;
+            //截取域名中的真实域名不带.com后的
+            $funsuffix = substr($parse_url['host'], $strLeng, strrpos($parse_url['host'], '.') - $strLeng);
+            if (!in_array($funsuffix, $this->grabName)) return JsonService::fail('您输入的地址不在复制范围内!');
+            //设拼接设置产品函数
+            $funName = "setProductInfo" . ucfirst($funsuffix);
+            //执行方法
+            if (method_exists($this, $funName))
+                $this->$funName($html);
+            else
+                return JsonService::fail('设置产品函数不存在');
+            if (!$this->productInfo['slider_image']) return JsonService::fail('未能获取到商品信息,请确保商品信息有效!');
+            return JsonService::successful($this->productInfo);
+        } catch (\Exception $e) {
+            return JsonService::fail('系统错误', ['line' => $e->getLine(), 'meass' => $e->getMessage()]);
+        }
+    }
+
+    /**
+     * 淘宝设置产品
+     * @param $html
+     */
+    public function setProductInfoTaobao($html)
+    {
+        $this->webnname = 'taobao';
+        //获取轮播图
+        $images = $this->getTaobaoImg($html);
+        $images = array_merge(is_array($images) ? $images : []);
+        $this->productInfo['slider_image'] = isset($images['gaoqing']) ? $images['gaoqing'] : (array)$images;
+        $this->productInfo['slider_image'] = array_slice($this->productInfo['slider_image'], 0, 5);
+        //获取产品详情请求链接
+        $link = $this->getTaobaoDesc($html);
+        //获取请求内容
+        $desc_json = HttpService::getRequest($link);
+        //转换字符集
+        $desc_json = $this->Utf8String($desc_json);
+        //截取掉多余字符
+        $this->productInfo['test'] = $desc_json;
+        $desc_json = str_replace('var desc=\'', '', $desc_json);
+        $desc_json = str_replace(["\n", "\t", "\r"], '', $desc_json);
+        $content = substr($desc_json, 0, -2);
+        $this->productInfo['description'] = $content;
+        //获取详情图
+        $description_images = $this->decodedesc($this->productInfo['description']);
+        $this->productInfo['description_images'] = is_array($description_images) ? $description_images : [];
+        $this->productInfo['image'] = is_array($this->productInfo['slider_image']) && isset($this->productInfo['slider_image'][0]) ? $this->productInfo['slider_image'][0] : '';
+    }
+
+    /**
+     * 天猫设置产品
+     * @param $html
+     */
+    public function setProductInfoTmall($html)
+    {
+        $this->webnname = 'tmall';
+        //获取轮播图
+        $images = $this->getTianMaoImg($html);
+        $images = array_merge(is_array($images) ? $images : []);
+        $this->productInfo['slider_image'] = $images;
+        $this->productInfo['slider_image'] = array_slice($this->productInfo['slider_image'], 0, 5);
+        $this->productInfo['image'] = is_array($this->productInfo['slider_image']) && isset($this->productInfo['slider_image'][0]) ? $this->productInfo['slider_image'][0] : '';
+        //获取产品详情请求链接
+        $link = $this->getTianMaoDesc($html);
+        //获取请求内容
+        $desc_json = HttpService::getRequest($link);
+        //转换字符集
+        $desc_json = $this->Utf8String($desc_json);
+        //截取掉多余字符
+        $desc_json = str_replace('var desc=\'', '', $desc_json);
+        $desc_json = str_replace(["\n", "\t", "\r"], '', $desc_json);
+        $content = substr($desc_json, 0, -2);
+        $this->productInfo['description'] = $content;
+        //获取详情图
+        $description_images = $this->decodedesc($this->productInfo['description']);
+        $this->productInfo['description_images'] = is_array($description_images) ? $description_images : [];
+    }
+
+    /**
+     * 1688设置产品
+     * @param $html
+     */
+    public function setProductInfo1688($html)
+    {
+        $this->webnname = 'alibaba';
+        //获取轮播图
+        $images = $this->get1688Img($html);
+        if (isset($images['gaoqing'])) {
+            $images['gaoqing'] = array_merge($images['gaoqing']);
+            $this->productInfo['slider_image'] = $images['gaoqing'];
+        } else
+            $this->productInfo['slider_image'] = $images;
+        if (!is_array($this->productInfo['slider_image'])) {
+            $this->productInfo['slider_image'] = [];
+        }
+        $this->productInfo['slider_image'] = array_slice($this->productInfo['slider_image'], 0, 5);
+        $this->productInfo['image'] = is_array($this->productInfo['slider_image']) && isset($this->productInfo['slider_image'][0]) ? $this->productInfo['slider_image'][0] : '';
+        //获取产品详情请求链接
+        $link = $this->get1688Desc($html);
+        //获取请求内容
+        $desc_json = HttpService::getRequest($link);
+        //转换字符集
+        $desc_json = $this->Utf8String($desc_json);
+        $this->productInfo['test'] = $desc_json;
+        //截取掉多余字符
+        $desc_json = str_replace('var offer_details=', '', $desc_json);
+        $desc_json = str_replace(["\n", "\t", "\r"], '', $desc_json);
+        $desc_json = substr($desc_json, 0, -1);
+        $descArray = json_decode($desc_json, true);
+        if (!isset($descArray['content'])) $descArray['content'] = '';
+        $this->productInfo['description'] = $descArray['content'];
+        //获取详情图
+        $description_images = $this->decodedesc($this->productInfo['description']);
+        $this->productInfo['description_images'] = is_array($description_images) ? $description_images : [];
+    }
+
+    /**
+     * JD设置产品
+     * @param string $html 网页内容
+     * */
+    public function setProductInfoJd($html)
+    {
+        $this->webnname = 'jd';
+        //获取产品详情请求链接
+        $desc_url = $this->getJdDesc($html);
+        //获取请求内容
+        $desc_json = HttpService::getRequest($desc_url);
+        //转换字符集
+        $desc_json = $this->Utf8String($desc_json);
+        //截取掉多余字符
+        if (substr($desc_json, 0, 8) == 'showdesc') $desc_json = str_replace('showdesc', '', $desc_json);
+        $desc_json = str_replace('data-lazyload=', 'src=', $desc_json);
+        $descArray = json_decode($desc_json, true);
+        if (!$descArray) $descArray = ['content' => ''];
+        //获取轮播图
+        $images = $this->getJdImg($html);
+        $images = array_merge(is_array($images) ? $images : []);
+        $this->productInfo['slider_image'] = $images;
+        $this->productInfo['image'] = is_array($this->productInfo['slider_image']) ? ($this->productInfo['slider_image'][0] ?? '') : '';
+        $this->productInfo['description'] = $descArray['content'];
+        //获取详情图
+        $description_images = $this->decodedesc($descArray['content']);
+        $this->productInfo['description_images'] = is_array($description_images) ? $description_images : [];
+    }
+
+    /**
+     * 检查淘宝,天猫,1688的商品链接
+     * @param $link
+     * @return bool|string
+     */
+    public function checkurl($link)
+    {
+        $link = strtolower(htmlspecialchars_decode($link));
+        if (!$link) return $this->setErrorInfo('请输入链接地址');
+        if (substr($link, 0, 4) != 'http') return $this->setErrorInfo('链接地址必须以http开头');
+        $arrLine = explode('?', $link);
+        if (!count($arrLine)) return $this->setErrorInfo('链接地址有误(ERR:1001)');
+        if (!isset($arrLine[1])) {
+            if (strpos($link, '1688') !== false && strpos($link, 'offer') !== false) return trim($arrLine[0]);
+            else if (strpos($link, 'item.jd') !== false) return trim($arrLine[0]);
+            else return $this->setErrorInfo('链接地址有误(ERR:1002)');
+        }
+        if (strpos($link, '1688') !== false && strpos($link, 'offer') !== false) return trim($arrLine[0]);
+        if (strpos($link, 'item.jd') !== false) return trim($arrLine[0]);
+        $arrLineValue = explode('&', $arrLine[1]);
+        if (!is_array($arrLineValue)) return $this->setErrorInfo('链接地址有误(ERR:1003)');
+        if (!strpos(trim($arrLine[0]), 'item.htm')) $this->setErrorInfo('链接地址有误(ERR:1004)');
+        //链接参数
+        $lastStr = '';
+        foreach ($arrLineValue as $k => $v) {
+            if (substr(strtolower($v), 0, 3) == 'id=') {
+                $lastStr = trim($v);
+                break;
+            }
+        }
+        if (!$lastStr) return $this->setErrorInfo('链接地址有误(ERR:1005)');
+        return trim($arrLine[0]) . '?' . $lastStr;
+    }
+
+    /*
+     * 保存图片保存产品信息
+     * */
+    public function save_product()
+    {
+        $data = UtilService::postMore([
+            ['cate_id', ''],
+            ['store_name', ''],
+            ['store_info', ''],
+            ['keyword', ''],
+            ['unit_name', ''],
+            ['image', ''],
+            ['slider_image', []],
+            ['price', ''],
+            ['ot_price', ''],
+            ['give_integral', ''],
+            ['postage', ''],
+            ['sales', ''],
+            ['ficti', ''],
+            ['stock', ''],
+            ['cost', ''],
+            ['description_images', []],
+            ['description', ''],
+            ['is_show', 0],
+            ['soure_link', ''],
+            ['temp_id', 0],
+        ]);
+
+        if (!$data['cate_id']) return JsonService::fail('请选择分类!');
+        if (!$data['store_name']) return JsonService::fail('请填写产品名称');
+        if (!$data['unit_name']) return JsonService::fail('请填写产品单位');
+        if (!$data['image']) return JsonService::fail('商品主图暂无,无法保存商品,您可选择其他链接进行复制产品');
+        if ($data['price'] == '' || $data['price'] < 0) return JsonService::fail('请输入产品售价');
+        if ($data['ot_price'] == '' || $data['ot_price'] < 0) return JsonService::fail('请输入产品市场价');
+        if ($data['stock'] == '' || $data['stock'] < 0) return JsonService::fail('请输入库存');
+        if (!$data['temp_id']) return JsonService::fail('请选择运费模板');
+        //查询附件分类
+        $AttachmentCategory = SystemAttachmentCategory::where('name', $this->AttachmentCategoryName)->find();
+        //不存在则创建
+        if (!$AttachmentCategory) $AttachmentCategory = SystemAttachmentCategory::create(['pid' => '0', 'name' => $this->AttachmentCategoryName, 'enname' => '']);
+        //生成附件目录
+        try {
+            if (make_path('attach', 3, true) === '')
+                return JsonService::fail('无法创建文件夹,请检查您的上传目录权限:' . app()->getRootPath() . 'public' . DS . 'uploads' . DS . 'attach' . DS);
+
+        } catch (\Exception $e) {
+            return JsonService::fail($e->getMessage() . '或无法创建文件夹,请检查您的上传目录权限:' . app()->getRootPath() . 'public' . DS . 'uploads' . DS . 'attach' . DS);
+        }
+        ini_set("max_execution_time", 600);
+        //开始图片下载处理
+        ProductModel::beginTrans();
+        try {
+            //放入主图
+            $images = [
+                ['w' => 305, 'h' => 305, 'line' => $data['image'], 'valuename' => 'image']
+            ];
+            //放入轮播图
+            foreach ($data['slider_image'] as $item) {
+                $value = ['w' => 640, 'h' => 640, 'line' => $item, 'valuename' => 'slider_image', 'isTwoArray' => true];
+                array_push($images, $value);
+            }
+            //执行下载
+            $res = $this->uploadImage($images, false, 0, $AttachmentCategory['id']);
+            if (!is_array($res)) return JsonService::fail($this->errorInfo ? $this->errorInfo : '保存图片失败');
+            if (isset($res['image'])) $data['image'] = $res['image'];
+            if (isset($res['slider_image'])) $data['slider_image'] = $res['slider_image'];
+            $data['slider_image'] = count($data['slider_image']) ? json_encode($data['slider_image']) : '';
+            //替换并下载详情里面的图片默认下载全部图片
+            $data['description'] = preg_replace('#<style>.*?</style>#is', '', $data['description']);
+            $data['description'] = $this->uploadImage($data['description_images'], $data['description'], 1, $AttachmentCategory['id']);
+            unset($data['description_images']);
+            $description = $data['description'];
+            unset($data['description']);
+            $data['add_time'] = time();
+            $cate_id = explode(',', $data['cate_id']);
+            //产品存在
+            if ($productInfo = ProductModel::where('soure_link', $data['soure_link'])->find()) {
+                $productInfo->slider_image = $data['slider_image'];
+                $productInfo->image = $data['image'];
+                $productInfo->store_name = $data['store_name'];
+                StoreDescription::saveDescription($description, $productInfo->id);
+                $productInfo->save();
+                ProductModel::commitTrans();
+                return JsonService::successful('商品存在,信息已被更新成功');
+            } else {
+                //不存在时新增
+                if ($productId = ProductModel::insertGetId($data)) {
+                    $cateList = [];
+                    foreach ($cate_id as $cid) {
+                        $cateList [] = ['product_id' => $productId, 'cate_id' => $cid, 'add_time' => time()];
+                    }
+                    StoreProductCate::insertAll($cateList);
+                    $attr = [
+                        [
+                            'value' => '规格',
+                            'detailValue' => '',
+                            'attrHidden' => '',
+                            'detail' => ['默认']
+                        ]
+                    ];
+                    $detail[0]['value1'] = '规格';
+                    $detail[0]['detail'] = ['规格' => '默认'];
+                    $detail[0]['price'] = $data['price'];
+                    $detail[0]['stock'] = $data['stock'];
+                    $detail[0]['cost'] = $data['cost'];
+                    $detail[0]['pic'] = $data['image'];
+                    $detail[0]['ot_price'] = $data['price'];
+                    $attr_res = StoreProductAttr::createProductAttr($attr, $detail, $productId);
+                    if ($attr_res) {
+                        StoreDescription::saveDescription($description, $productId);
+                        ProductModel::commitTrans();
+                        return JsonService::successful('生成产品成功');
+                    } else {
+                        ProductModel::rollbackTrans();
+                        return JsonService::fail(StoreProductAttr::getErrorInfo('生成产品失败'));
+                    }
+                } else {
+                    ProductModel::rollbackTrans();
+                    return JsonService::fail('生成产品失败');
+                }
+            }
+        } catch (PDOException $e) {
+            ProductModel::rollbackTrans();
+            return JsonService::fail('插入数据库错误', ['line' => $e->getLine(), 'messag' => $e->getMessage()]);
+        } catch (\Exception $e) {
+            ProductModel::rollbackTrans();
+            return JsonService::fail('系统错误', ['line' => $e->getLine(), 'messag' => $e->getMessage(), 'file' => $e->getFile()]);
+        }
+    }
+
+    /*
+     * 上传图片处理
+     * @param array $image 图片路径
+     * @param int $uploadType 上传方式 0=远程下载
+     * */
+    public function uploadImage(array $images = [], $html = '', $uploadType = 0, $AttachmentCategoryId = 0)
+    {
+        $uploadImage = [];
+        $siteUrl = sys_config('site_url');
+        switch ($uploadType) {
+            case 0:
+                foreach ($images as $item) {
+                    //下载图片文件
+                    if ($item['w'] && $item['h'])
+                        $uploadValue = $this->downloadImage($item['line'], '', 0, 30, $item['w'], $item['h']);
+                    else
+                        $uploadValue = $this->downloadImage($item['line']);
+                    //下载成功更新数据库
+                    if (is_array($uploadValue)) {
+                        //TODO 拼接图片地址
+                        if ($uploadValue['image_type'] == 1) $imagePath = $siteUrl . $uploadValue['path'];
+                        else $imagePath = $uploadValue['path'];
+                        //写入数据库
+                        if (!$uploadValue['is_exists'] && $AttachmentCategoryId) SystemAttachment::attachmentAdd($uploadValue['name'], $uploadValue['size'], $uploadValue['mime'], $imagePath, $imagePath, $AttachmentCategoryId, $uploadValue['image_type'], time(), 1);
+                        //组装数组
+                        if (isset($item['isTwoArray']) && $item['isTwoArray'])
+                            $uploadImage[$item['valuename']][] = $imagePath;
+                        else
+                            $uploadImage[$item['valuename']] = $imagePath;
+                    }
+                }
+                break;
+            case 1:
+                preg_match_all('#<img.*?src="([^"]*)"[^>]*>#i', $html, $match);
+                if (isset($match[1])) {
+                    foreach ($match[1] as $item) {
+                        if (is_int(strpos($item, 'http')))
+                            $arcurl = $item;
+                        else
+                            $arcurl = 'http://' . ltrim($item, '\//');
+                        $uploadValue = $this->downloadImage($arcurl);
+                        //下载成功更新数据库
+                        if (is_array($uploadValue)) {
+                            //TODO 拼接图片地址
+                            if ($uploadValue['image_type'] == 1) $imagePath = $siteUrl . $uploadValue['path'];
+                            else $imagePath = $uploadValue['path'];
+                            //写入数据库
+                            if (!$uploadValue['is_exists'] && $AttachmentCategoryId) SystemAttachment::attachmentAdd($uploadValue['name'], $uploadValue['size'], $uploadValue['mime'], $imagePath, $imagePath, $AttachmentCategoryId, $uploadValue['image_type'], time(), 1);
+                            //替换图片
+                            $html = str_replace($item, $imagePath, $html);
+                        } else {
+                            //替换掉没有下载下来的图片
+                            $html = preg_replace('#<img.*?src="' . $item . '"*>#i', '', $html);
+                        }
+                    }
+                }
+                return $html;
+                break;
+            default:
+                return $this->setErrorInfo('上传方式错误');
+                break;
+        }
+        return $uploadImage;
+    }
+
+    //提取商品描述中的所有图片
+    public function decodedesc($desc = '')
+    {
+        $desc = trim($desc);
+        if (!$desc) return '';
+        preg_match_all('/<img[^>]*?src="([^"]*?)"[^>]*?>/i', $desc, $match);
+        if (!isset($match[1]) || count($match[1]) <= 0) {
+            preg_match_all('/:url(([^"]*?));/i', $desc, $match);
+            if (!isset($match[1]) || count($match[1]) <= 0) return $desc;
+        } else {
+            preg_match_all('/:url(([^"]*?));/i', $desc, $newmatch);
+            if (isset($newmatch[1]) && count($newmatch[1]) > 0) $match[1] = array_merge($match[1], $newmatch[1]);
+        }
+        $match[1] = array_unique($match[1]); //去掉重复
+        foreach ($match[1] as $k => &$v) {
+            $_tmp_img = str_replace([')', '(', ';'], '', $v);
+            $_tmp_img = strpos($_tmp_img, 'http') ? $_tmp_img : 'http:' . $_tmp_img;
+            if (strpos($v, '?')) {
+                $_tarr = explode('?', $v);
+                $_tmp_img = trim($_tarr[0]);
+            }
+            $_urls = str_replace(['\'', '"'], '', $_tmp_img);
+            if ($this->_img_exists($_urls)) $v = $_urls;
+        }
+        return $match[1];
+    }
+
+    //获取京东商品组图
+    public function getJdImg($html = '')
+    {
+        //获取图片服务器网址
+        preg_match('/<img(.*?)id="spec-img"(.*?)data-origin=\"(.*?)\"[^>]*>/', $html, $img);
+        if (!isset($img[3])) return '';
+        $info = parse_url(trim($img[3]));
+        if (!$info['host']) return '';
+        if (!$info['path']) return '';
+        $_tmparr = explode('/', trim($info['path']));
+        $url = 'http://' . $info['host'] . '/' . $_tmparr[1] . '/' . str_replace(['jfs', ' '], '', trim($_tmparr[2]));
+        preg_match('/imageList:(.*?)"],/is', $html, $img);
+        if (!isset($img[1])) {
+            return '';
+        }
+        $_arr = explode(',', $img[1]);
+        foreach ($_arr as $k => &$v) {
+            $_str = $url . str_replace(['"', '[', ']', ' '], '', trim($v));
+            if (strpos($_str, '?')) {
+                $_tarr = explode('?', $_str);
+                $_str = trim($_tarr[0]);
+            }
+            if ($this->_img_exists($_str)) {
+                $v = $_str;
+            } else {
+                unset($_arr[$k]);
+            }
+        }
+        return array_unique($_arr);
+    }
+
+    //获取京东商品描述
+    public function getJdDesc($html = '')
+    {
+        preg_match('/,(.*?)desc:([^<>]*)\',/i', $html, $descarr);
+        if (!isset($descarr[1]) && !isset($descarr[2])) return '';
+        $tmpArr = explode(',', $descarr[2]);
+        if (count($tmpArr) > 0) {
+            $descarr[2] = trim($tmpArr[0]);
+        }
+        $replace_arr = ['\'', '\',', ' ', ',', '/*', '*/'];
+        if (isset($descarr[2])) {
+            $d_url = str_replace($replace_arr, '', $descarr[2]);
+            return $this->formatDescUrl(strpos($d_url, 'http') ? $d_url : 'http:' . $d_url);
+        }
+        $d_url = str_replace($replace_arr, '', $descarr[1]);
+        $d_url = $this->formatDescUrl($d_url);
+        $d_url = rtrim(rtrim($d_url, "?"), "&");
+        return substr($d_url, 0, 4) == 'http' ? $d_url : 'http:' . $d_url;
+    }
+
+    //处理下京东商品描述网址
+    public function formatDescUrl($url = '')
+    {
+        if (!$url) return '';
+        $url = substr($url, 0, 4) == 'http' ? $url : 'http:' . $url;
+        if (!strpos($url, '&')) {
+            $_arr = explode('?', $url);
+            if (!is_array($_arr) || count($_arr) <= 0) return $url;
+            return trim($_arr[0]);
+        } else {
+            $_arr = explode('&', $url);
+        }
+        if (!is_array($_arr) || count($_arr) <= 0) return $url;
+        unset($_arr[count($_arr) - 1]);
+        $new_url = '';
+        foreach ($_arr as $k => $v) {
+            $new_url .= $v . '&';
+        }
+        return !$new_url ? $url : $new_url;
+    }
+
+    //获取1688商品组图
+    public function get1688Img($html = '')
+    {
+        preg_match('/<ul class=\"nav nav-tabs fd-clr\">(.*?)<\/ul>/is', $html, $img);
+        if (!isset($img[0])) {
+            return '';
+        }
+        preg_match_all('/preview":"(.*?)\"\}\'>/is', $img[0], $arrb);
+        if (!isset($arrb[1]) || count($arrb[1]) <= 0) {
+            return '';
+        }
+        $thumb = [];
+        $gaoqing = [];
+        $res = ['thumb' => '', 'gaoqing' => ''];  //缩略图片和高清图片
+        foreach ($arrb[1] as $k => $v) {
+            $_str = str_replace(['","original":"'], '*', $v);
+            $_arr = explode('*', $_str);
+            if (is_array($_arr) && isset($_arr[0]) && isset($_arr[1])) {
+                if (strpos($_arr[0], '?')) {
+                    $_tarr = explode('?', $_arr[0]);
+                    $_arr[0] = trim($_tarr[0]);
+                }
+                if (strpos($_arr[1], '?')) {
+                    $_tarr = explode('?', $_arr[1]);
+                    $_arr[1] = trim($_tarr[0]);
+                }
+                if ($this->_img_exists($_arr[0])) $thumb[] = trim($_arr[0]);
+                if ($this->_img_exists($_arr[1])) $gaoqing[] = trim($_arr[1]);
+            }
+        }
+        $res = ['thumb' => array_unique($thumb), 'gaoqing' => array_unique($gaoqing)];  //缩略图片和高清图片
+        return $res;
+    }
+
+    //获取1688商品描述
+    public function get1688Desc($html = '')
+    {
+        preg_match('/data-tfs-url="([^<>]*)data-enable="true"/', $html, $descarr);
+        if (!isset($descarr[1])) return '';
+        return str_replace(['"', ' '], '', $descarr[1]);
+    }
+
+    //获取天猫商品组图
+    public function getTianMaoImg($html = '')
+    {
+        $pic_size = '430';
+        preg_match('/<img[^>]*id="J_ImgBooth"[^r]*rc=\"([^"]*)\"[^>]*>/', $html, $img);
+        if (isset($img[1])) {
+            $_arr = explode('x', $img[1]);
+            $filename = $_arr[count($_arr) - 1];
+            $pic_size = intval(substr($filename, 0, 3));
+        }
+        preg_match('|<ul id="J_UlThumb" class="tb-thumb tm-clear">(.*)</ul>|isU', $html, $match);
+        preg_match_all('/<img src="(.*?)" \//', $match[1], $images);
+        if (!isset($images[1])) return '';
+        foreach ($images[1] as $k => &$v) {
+            $tmp_v = trim($v);
+            $_arr = explode('x', $tmp_v);
+            $_fname = $_arr[count($_arr) - 1];
+            $_size = intval(substr($_fname, 0, 3));
+            if (strpos($tmp_v, '://')) {
+                $_arr = explode(':', $tmp_v);
+                $r_url = trim($_arr[1]);
+            } else {
+                $r_url = $tmp_v;
+            }
+            $str = str_replace($_size, $pic_size, $r_url);
+            if (strpos($str, '?')) {
+                $_tarr = explode('?', $str);
+                $str = trim($_tarr[0]);
+            }
+            $_i_url = strpos($str, 'http') ? $str : 'http:' . $str;
+            if ($this->_img_exists($_i_url)) {
+                $v = $_i_url;
+            } else {
+                unset($images[1][$k]);
+            }
+        }
+        return array_unique($images[1]);
+    }
+
+    //获取天猫商品描述
+    public function getTianMaoDesc($html = '')
+    {
+        preg_match('/descUrl":"([^<>]*)","httpsDescUrl":"/', $html, $descarr);
+        if (!isset($descarr[1])) {
+            preg_match('/httpsDescUrl":"([^<>]*)","fetchDcUrl/', $html, $descarr);
+            if (!isset($descarr[1])) return '';
+        }
+        return strpos($descarr[1], 'http') ? $descarr[1] : 'http:' . $descarr[1];
+    }
+
+    //获取淘宝商品组图
+    public function getTaobaoImg($html = '')
+    {
+        preg_match('/auctionImages([^<>]*)"]/', $html, $imgarr);
+        if (!isset($imgarr[1])) return '';
+        $arr = explode(',', $imgarr[1]);
+        foreach ($arr as $k => &$v) {
+            $str = trim($v);
+            $str = str_replace(['"', ' ', '', ':['], '', $str);
+            if (strpos($str, '?')) {
+                $_tarr = explode('?', $str);
+                $str = trim($_tarr[0]);
+            }
+            $_i_url = strpos($str, 'http') ? $str : 'http:' . $str;
+            if ($this->_img_exists($_i_url)) {
+                $v = $_i_url;
+            } else {
+                unset($arr[$k]);
+            }
+        }
+        return array_unique($arr);
+    }
+
+    //获取淘宝商品描述
+    public function getTaobaoDesc($html = '')
+    {
+        preg_match('/descUrl([^<>]*)counterApi/', $html, $descarr);
+        if (!isset($descarr[1])) return '';
+        $arr = explode(':', $descarr[1]);
+        $url = [];
+        foreach ($arr as $k => $v) {
+            if (strpos($v, '//')) {
+                $str = str_replace(['\'', ',', ' ', '?', ':'], '', $v);
+                $url[] = trim($str);
+            }
+        }
+        if ($url) {
+            return strpos($url[0], 'http') ? $url[0] : 'http:' . $url[0];
+        } else {
+            return '';
+        }
+    }
+
+    /**
+     * GET 请求
+     * @param string $url
+     */
+    public function curl_Get($url = '', $time_out = 25)
+    {
+        if (!$url) return '';
+        $ch = curl_init();
+        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); // 跳过证书检查  
+        if (stripos($url, "https://") !== FALSE) {
+            curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2);  // 从证书中检查SSL加密算法是否存在
+        }
+        $headers = ['user-agent:Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.100 Safari/537.36'];
+        if ($this->webnname) {
+            $headers[] = $this->webcookie["$this->webnname"];
+        }
+
+        curl_setopt($ch, CURLOPT_URL, $url);
+        curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
+        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
+        curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
+        curl_setopt($ch, CURLOPT_TIMEOUT, $time_out);
+        $response = curl_exec($ch);
+        if ($error = curl_error($ch)) {
+            return false;
+        }
+        curl_close($ch);
+//        return mb_convert_encoding($response, 'utf-8', 'auto');
+        return $response;
+    }
+
+    //检测远程文件是否存在
+    public function _img_exists($url = '')
+    {
+        ini_set("max_execution_time", 0);
+        $str = @file_get_contents($url, 0, null, 0, 1);
+        if (strlen($str) <= 0) return false;
+        if ($str)
+            return true;
+        else
+            return false;
+    }
+
+    //TODO 下载图片
+    public function downloadImage($url = '', $name = '', $type = 0, $timeout = 30, $w = 0, $h = 0)
+    {
+        if (!strlen(trim($url))) return '';
+        if (!strlen(trim($name))) {
+            //TODO 获取要下载的文件名称
+            $downloadImageInfo = $this->getImageExtname($url);
+            if (!$this->checkExtname($url, $downloadImageInfo['ext_name'])) {
+                return JsonService::fail('文件后缀不合法');
+            }
+            $name = $downloadImageInfo['file_name'];
+            if (!strlen(trim($name))) return '';
+        }
+        //TODO 获取远程文件所采用的方法
+        if ($type) {
+            $ch = curl_init();
+            curl_setopt($ch, CURLOPT_URL, $url);
+            curl_setopt($ch, CURLOPT_RETURNTRANSFER, false);
+            curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, $timeout);
+            curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); //TODO 跳过证书检查
+            if (stripos($url, "https://") !== FALSE) curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2);  //TODO 从证书中检查SSL加密算法是否存在
+            curl_setopt($ch, CURLOPT_HTTPHEADER, array('user-agent:' . $_SERVER['HTTP_USER_AGENT']));
+            if (ini_get('open_basedir') == '' && ini_get('safe_mode' == 'Off')) curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);//TODO 是否采集301、302之后的页面
+            $content = curl_exec($ch);
+            curl_close($ch);
+        } else {
+            try {
+                ob_start();
+                readfile($url);
+                $content = ob_get_contents();
+                ob_end_clean();
+            } catch (\Exception $e) {
+                return $e->getMessage();
+            }
+        }
+        $size = strlen(trim($content));
+        if (!$content || $size <= 2) return '图片流获取失败';
+        $date_dir = date('Y') . DS . date('m') . DS . date('d');
+        $upload_type = sys_config('upload_type', 1);
+        $upload = new Upload((int)$upload_type, [
+            'accessKey' => sys_config('accessKey'),
+            'secretKey' => sys_config('secretKey'),
+            'uploadUrl' => sys_config('uploadUrl'),
+            'storageName' => sys_config('storage_name'),
+            'storageRegion' => sys_config('storage_region'),
+        ]);
+        $info = $upload->to('attach/' . $date_dir)->validate()->stream($content, $name);
+        if ($info === false) {
+            return $upload->getError();
+        }
+        $imageInfo = $upload->getUploadInfo();
+        $date['path'] = str_replace('\\', '/', $imageInfo['dir']);
+        $date['name'] = $imageInfo['name'];
+        $date['size'] = $imageInfo['size'];
+        $date['mime'] = $imageInfo['type'];
+        $date['image_type'] = $upload_type;
+        $date['is_exists'] = false;
+        return $date;
+    }
+
+    //获取即将要下载的图片扩展名
+    public function getImageExtname($url = '', $ex = 'jpg')
+    {
+        $_empty = ['file_name' => '', 'ext_name' => $ex];
+        if (!$url) return $_empty;
+        if (strpos($url, '?')) {
+            $_tarr = explode('?', $url);
+            $url = trim($_tarr[0]);
+        }
+        $arr = explode('.', $url);
+        if (!is_array($arr) || count($arr) <= 1) return $_empty;
+        $ext_name = trim($arr[count($arr) - 1]);
+        $ext_name = !$ext_name ? $ex : $ext_name;
+        return ['file_name' => md5($url) . '.' . $ext_name, 'ext_name' => $ext_name];
+    }
+
+    /**
+     * 验证下载图片文件后缀
+     * @param string $url
+     * @param string $ex
+     * @return bool
+     */
+    public function checkExtname($url = '', $ex = 'jpg')
+    {
+        if (in_array($ex, ['jpg', 'jpeg', 'gif', 'png', 'swf', 'bmp', 'pcx', 'tif', 'tga', 'exif'])) {
+            return true;
+        }
+        return false;
+    }
+
+    /*
+      $filepath = 绝对路径,末尾有斜杠 /
+      $name = 图片文件名
+      $maxwidth 定义生成图片的最大宽度(单位:像素)
+      $maxheight 生成图片的最大高度(单位:像素)
+      $filetype 最终生成的图片类型(.jpg/.png/.gif)
+    */
+    public function resizeImage($filepath = '', $name = '', $maxwidth = 0, $maxheight = 0)
+    {
+        $pic_file = $filepath . $name; //图片文件
+        $img_info = getimagesize($pic_file); //索引 2 是图像类型的标记:1 = GIF,2 = JPG,3 = PNG,4 = SWF,5 = PSD,
+        if ($img_info[2] == 1) {
+            $im = imagecreatefromgif($pic_file); //打开图片
+            $filetype = '.gif';
+        } elseif ($img_info[2] == 2) {
+            $im = imagecreatefromjpeg($pic_file); //打开图片
+            $filetype = '.jpg';
+        } elseif ($img_info[2] == 3) {
+            $im = imagecreatefrompng($pic_file); //打开图片
+            $filetype = '.png';
+        } else {
+            return ['path' => $filepath, 'file' => $name, 'mime' => ''];
+        }
+        $file_name = md5('_tmp_' . microtime() . '_' . rand(0, 10)) . $filetype;
+        $pic_width = imagesx($im);
+        $pic_height = imagesy($im);
+        $resizewidth_tag = false;
+        $resizeheight_tag = false;
+        if (($maxwidth && $pic_width > $maxwidth) || ($maxheight && $pic_height > $maxheight)) {
+            if ($maxwidth && $pic_width > $maxwidth) {
+                $widthratio = $maxwidth / $pic_width;
+                $resizewidth_tag = true;
+            }
+            if ($maxheight && $pic_height > $maxheight) {
+                $heightratio = $maxheight / $pic_height;
+                $resizeheight_tag = true;
+            }
+            if ($resizewidth_tag && $resizeheight_tag) {
+                if ($widthratio < $heightratio)
+                    $ratio = $widthratio;
+                else
+                    $ratio = $heightratio;
+            }
+            if ($resizewidth_tag && !$resizeheight_tag)
+                $ratio = $widthratio;
+            if ($resizeheight_tag && !$resizewidth_tag)
+                $ratio = $heightratio;
+            $newwidth = $pic_width * $ratio;
+            $newheight = $pic_height * $ratio;
+            if (function_exists("imagecopyresampled")) {
+                $newim = imagecreatetruecolor($newwidth, $newheight);
+                imagecopyresampled($newim, $im, 0, 0, 0, 0, $newwidth, $newheight, $pic_width, $pic_height);
+            } else {
+                $newim = imagecreate($newwidth, $newheight);
+                imagecopyresized($newim, $im, 0, 0, 0, 0, $newwidth, $newheight, $pic_width, $pic_height);
+            }
+            if ($filetype == '.png') {
+                imagepng($newim, $filepath . $file_name);
+            } else if ($filetype == '.gif') {
+                imagegif($newim, $filepath . $file_name);
+            } else {
+                imagejpeg($newim, $filepath . $file_name);
+            }
+            imagedestroy($newim);
+        } else {
+            if ($filetype == '.png') {
+                imagepng($im, $filepath . $file_name);
+            } else if ($filetype == '.gif') {
+                imagegif($im, $filepath . $file_name);
+            } else {
+                imagejpeg($im, $filepath . $file_name);
+            }
+            imagedestroy($im);
+        }
+        @unlink($pic_file);
+        return ['path' => $filepath, 'file' => $file_name, 'mime' => $img_info['mime']];
+    }
+}

+ 198 - 0
app/admin/controller/store/StoreCategory.php

@@ -0,0 +1,198 @@
+<?php
+
+namespace app\admin\controller\store;
+
+use app\admin\controller\AuthController;
+use think\Request;
+use think\facade\Route as Url;
+use app\admin\model\system\SystemAttachment;
+use app\admin\model\store\StoreCategory as CategoryModel;
+use crmeb\services\{FormBuilder as Form, JsonService as Json, UtilService as Util};
+
+/**
+ * 产品分类控制器
+ * Class StoreCategory
+ * @package app\admin\controller\system
+ */
+class StoreCategory extends AuthController
+{
+    /**
+     * 显示资源列表
+     *
+     * @return \think\Response
+     */
+    public function index()
+    {
+        $this->assign('pid', $this->request->get('pid', 0));
+        $this->assign('cate', CategoryModel::getTierList(null, 0));
+        return $this->fetch();
+    }
+
+    /*
+     *  异步获取分类列表
+     *  @return json
+     */
+    public function category_list()
+    {
+        $where = Util::getMore([
+            ['is_show', ''],
+            ['pid', $this->request->param('pid', '')],
+            ['cate_name', ''],
+            ['page', 1],
+            ['limit', 20],
+            ['order', '']
+        ]);
+        return Json::successlayui(CategoryModel::CategoryList($where));
+    }
+
+    /**
+     * 设置产品分类上架|下架
+     * @param string $is_show
+     * @param string $id
+     */
+    public function set_show($is_show = '', $id = '')
+    {
+        ($is_show == '' || $id == '') && Json::fail('缺少参数');
+        if (CategoryModel::setCategoryShow($id, (int)$is_show)) {
+            return Json::successful($is_show == 1 ? '显示成功' : '隐藏成功');
+        } else {
+            return Json::fail(CategoryModel::getErrorInfo($is_show == 1 ? '显示失败' : '隐藏失败'));
+        }
+    }
+
+    /**
+     * 快速编辑
+     * @param string $field
+     * @param string $id
+     * @param string $value
+     */
+    public function set_category($field = '', $id = '', $value = '')
+    {
+        $field == '' || $id == '' || $value == '' && Json::fail('缺少参数');
+        if (CategoryModel::where('id', $id)->update([$field => $value]))
+            return Json::successful('保存成功');
+        else
+            return Json::fail('保存失败');
+    }
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return \think\Response
+     */
+    public function create()
+    {
+        $field = [
+            Form::select('pid', '父级')->setOptions(function () {
+                $list = CategoryModel::getTierList(null, 0);
+                $menus = [['value' => 0, 'label' => '顶级菜单']];
+                foreach ($list as $menu) {
+                    $menus[] = ['value' => $menu['id'], 'label' => $menu['html'] . $menu['cate_name']];
+                }
+                return $menus;
+            })->filterable(1),
+            Form::input('cate_name', '分类名称'),
+            Form::frameImageOne('pic', '分类图标(180*180)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'pic')))->icon('image')->width('100%')->height('500px'),
+            Form::number('sort', '排序'),
+            Form::radio('is_show', '状态', 1)->options([['label' => '显示', 'value' => 1], ['label' => '隐藏', 'value' => 0]])
+        ];
+        $form = Form::make_post_form('添加分类', $field, Url::buildUrl('save'), 2);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存新建的资源
+     *
+     * @param \think\Request $request
+     * @return \think\Response
+     */
+    public function save(Request $request)
+    {
+        $data = Util::postMore([
+            'pid',
+            'cate_name',
+            ['pic', []],
+            'sort',
+            ['is_show', 0]
+        ], $request);
+        if ($data['pid'] == '') return Json::fail('请选择父类');
+        if (!$data['cate_name']) return Json::fail('请输入分类名称');
+        if (count($data['pic']) < 1) return Json::fail('请上传分类图标');
+        if ($data['sort'] < 0) $data['sort'] = 0;
+        $data['pic'] = $data['pic'][0];
+        $data['add_time'] = time();
+        CategoryModel::create($data);
+        return Json::successful('添加分类成功!');
+    }
+
+    /**
+     * 显示编辑资源表单页.
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function edit($id)
+    {
+        $c = CategoryModel::get($id);
+        if (!$c) return Json::fail('数据不存在!');
+        $field = [
+            Form::select('pid', '父级', (string)$c->getData('pid'))->setOptions(function () use ($id) {
+                $list = CategoryModel::getTierList(CategoryModel::where('id', '<>', $id), 0);
+//                $list = (sort_list_tier((CategoryModel::where('id','<>',$id)->select()->toArray(),'顶级','pid','cate_name'));
+                $menus = [['value' => 0, 'label' => '顶级菜单']];
+                foreach ($list as $menu) {
+                    $menus[] = ['value' => $menu['id'], 'label' => $menu['html'] . $menu['cate_name']];
+                }
+                return $menus;
+            })->filterable(1),
+            Form::input('cate_name', '分类名称', $c->getData('cate_name')),
+            Form::frameImageOne('pic', '分类图标', Url::buildUrl('admin/widget.images/index', array('fodder' => 'pic')), $c->getData('pic'))->icon('image')->width('100%')->height('500px'),
+            Form::number('sort', '排序', $c->getData('sort')),
+            Form::radio('is_show', '状态', $c->getData('is_show'))->options([['label' => '显示', 'value' => 1], ['label' => '隐藏', 'value' => 0]])
+        ];
+        $form = Form::make_post_form('编辑分类', $field, Url::buildUrl('update', array('id' => $id)), 2);
+
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存更新的资源
+     *
+     * @param \think\Request $request
+     * @param int $id
+     * @return \think\Response
+     */
+    public function update(Request $request, $id)
+    {
+        $data = Util::postMore([
+            'pid',
+            'cate_name',
+            ['pic', []],
+            'sort',
+            ['is_show', 0]
+        ], $request);
+        if ($data['pid'] == '') return Json::fail('请选择父类');
+        if (!$data['cate_name']) return Json::fail('请输入分类名称');
+        if (count($data['pic']) < 1) return Json::fail('请上传分类图标');
+        if ($data['sort'] < 0) $data['sort'] = 0;
+        $data['pic'] = $data['pic'][0];
+        CategoryModel::edit($data, $id);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function delete($id)
+    {
+        if (!CategoryModel::delCategory($id))
+            return Json::fail(CategoryModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+}

+ 154 - 0
app/admin/controller/store/StoreInfoMana.php

@@ -0,0 +1,154 @@
+<?php
+
+namespace app\admin\controller\store;
+
+use app\admin\controller\AuthController;
+use app\admin\model\system\SystemAttachment;
+use think\facade\Route as Url;
+use app\admin\model\wechat\WechatNews as WechatNewsModel;
+use app\admin\model\article\ArticleCategory as ArticleCategoryModel;
+use crmeb\services\{FormBuilder, UtilService as Util, JsonService as Json};
+
+/**
+ * 资讯管理  控制器
+ * Class StoreInfoMana
+ * @package app\admin\controller\store
+ */
+class StoreInfoMana extends AuthController
+{
+    /**
+     * 新闻管理
+     * */
+    public function index($is_list = 0)
+    {
+        if (!$is_list) return $this->failed('数据不存在');
+        echo $is_list;
+        exit();
+        $where = Util::getMore([
+            ['status', ''],
+            ['title', ''],
+        ], $this->request);
+        $this->assign('where', $where);
+        $this->assign(ArticleCategoryModel::systemPage($where));
+        return $this->fetch();
+    }
+
+    /**
+     * 添加分类管理
+     * */
+
+    public function create()
+    {
+        FormBuilder::text('title', '分类昵称');
+        FormBuilder::textarea('intr', '分类简介');
+        FormBuilder::select('new_id', '图文列表', function () {
+            $list    = \app\admin\model\wechat\WechatNews::getNews();
+            $options = [];
+            foreach ($list as $id => $roleName) {
+                $options[] = ['label' => $roleName, 'value' => $id];
+            }
+            return $options;
+        })->multiple()->filterable();
+        FormBuilder::frameImageOne('image', '分类图片', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')))->icon('image')->width('100%')->height('500px');
+        FormBuilder::number('sort', '排序', 0);
+        FormBuilder::radio('status', '状态', [['value' => 1, 'label' => '显示'], ['value' => 0, 'label' => '隐藏']], 1);
+        $rules = FormBuilder::builder()->getContent();
+        $this->assign(['title' => '编辑菜单', 'rules' => $rules, 'save' => Url::buildUrl('save')]);
+        return $this->fetch();
+    }
+
+    /**
+     * 保存分类管理
+     * */
+
+    public function save()
+    {
+        $data = Util::postMore([
+            'title',
+            'intr',
+            ['new_id', []],
+            ['image', []],
+            ['sort', 0],
+            'status',]);
+        if (!$data['title']) return Json::fail('请输入分类名称');
+        if (count($data['image']) != 1) return Json::fail('请选择分类图片,并且只能上传一张');
+        if ($data['sort'] < 0) return Json::fail('排序不能是负数');
+        $data['add_time'] = time();
+        $data['image']    = $data['image'][0];
+        $new_id           = $data['new_id'];
+        unset($data['new_id']);
+        $res = ArticleCategoryModel::create($data);
+        if (!WechatNewsModel::saveBatchCid($res['id'], implode(',', $new_id))) return Json::fail('文章列表添加失败');
+        return Json::successful('添加分类成功!');
+    }
+
+    /**
+     * 修改分类
+     * */
+
+    public function edit($id)
+    {
+        $this->assign(['title' => '编辑菜单', 'read' => Url::buildUrl('read', array('id' => $id)), 'update' => Url::buildUrl('update', array('id' => $id))]);
+        return $this->fetch();
+    }
+
+    public function read($id)
+    {
+        $article = ArticleCategoryModel::get($id)->getData();
+        if (!$article) return Json::fail('数据不存在!');
+        FormBuilder::text('title', '分类昵称', $article['title']);
+        FormBuilder::textarea('intr', '分类简介', $article['intr']);
+        $arr    = ArticleCategoryModel::getArticle($id, 'id,title,cid');//子文章
+        $new_id = array();
+        foreach ($arr as $k => $v) {
+            $new_id[$k] = $k;
+        }
+        FormBuilder::select('new_id', '文章列表', function () {
+            $list    = \app\admin\model\wechat\WechatNews::getNews();
+            $options = [];
+            foreach ($list as $id => $roleName) {
+                $options[] = ['label' => $roleName, 'value' => $id];
+            }
+            return $options;
+        }, $new_id)->multiple();
+        FormBuilder::upload('image', '分类图片')->defaultFileList($article['image']);
+        FormBuilder::number('sort', '排序', $article['sort']);
+        FormBuilder::radio('status', '状态', [['value' => 1, 'label' => '显示'], ['value' => 0, 'label' => '隐藏']], $article['status']);
+        return FormBuilder::builder();
+    }
+
+    public function update($id)
+    {
+        $data = Util::postMore([
+            'title',
+            'intr',
+            ['new_id', []],
+            ['image', []],
+            ['sort', 0],
+            'status',]);
+        if (!$data['title']) return Json::fail('请输入分类名称');
+        if (count($data['image']) != 1) return Json::fail('请选择分类图片,并且只能上传一张');
+        if ($data['sort'] < 0) return Json::fail('排序不能是负数');
+        $data['image'] = $data['image'][0];
+//        dump($data);
+//        exit;
+        if (!ArticleCategoryModel::get($id)) return Json::fail('编辑的记录不存在!');
+        if (!WechatNewsModel::saveBatchCid($id, implode(',', $data['new_id']))) return Json::fail('文章列表添加失败');
+        unset($data['new_id']);
+        ArticleCategoryModel::edit($data, $id);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 删除分类
+     * */
+    public function delete($id)
+    {
+        $res = ArticleCategoryModel::delArticleCategory($id);
+        if (!$res)
+            return Json::fail(ArticleCategoryModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+}
+

+ 724 - 0
app/admin/controller/store/StoreProduct.php

@@ -0,0 +1,724 @@
+<?php
+
+namespace app\admin\controller\store;
+
+use app\admin\controller\AuthController;
+use app\admin\model\store\{
+    StoreDescription,
+    StoreProductAttrValue,
+    StoreProductAttr,
+    StoreProductAttrResult,
+    StoreProductCate,
+    StoreProductRelation,
+    StoreCategory as CategoryModel,
+    StoreProduct as ProductModel
+};
+use app\admin\model\ump\StoreBargain;
+use app\admin\model\ump\StoreCombination;
+use app\admin\model\ump\StoreSeckill;
+use crmeb\services\{
+    JsonService, UtilService as Util, JsonService as Json, FormBuilder as Form
+};
+use crmeb\traits\CurdControllerTrait;
+use think\facade\Route as Url;
+use app\admin\model\system\{
+    SystemAttachment, ShippingTemplates
+};
+
+
+/**
+ * 产品管理
+ * Class StoreProduct
+ * @package app\admin\controller\store
+ */
+class StoreProduct extends AuthController
+{
+
+    use CurdControllerTrait;
+
+    protected $bindModel = ProductModel::class;
+
+    /**
+     * 显示资源列表
+     *
+     * @return \think\Response
+     */
+    public function index()
+    {
+        $type = $this->request->param('type', 1);
+        //获取分类
+        $this->assign('cate', CategoryModel::getTierList(null, 1));
+        //出售中产品
+        $onsale = ProductModel::where('is_del', 0)->where('is_show', 1)->count();
+        //待上架产品
+        $forsale = ProductModel::where('is_del', 0)->where('is_show', 0)->count();
+        //仓库中产品
+        $warehouse = ProductModel::where('is_del', 0)->count();
+        //已经售馨产品
+        $outofstock = ProductModel::getModelObject(['type' => 4])->count();
+        //警戒库存
+        $policeforce = ProductModel::getModelObject(['type' => 5])->count();
+        //回收站
+        $recycle = ProductModel::where('is_del', 1)->count();
+        $this->assign(compact('type', 'onsale', 'forsale', 'warehouse', 'outofstock', 'policeforce', 'recycle'));
+        return $this->fetch();
+    }
+
+    /**
+     * 异步查找产品
+     *
+     * @return json
+     */
+    public function product_ist()
+    {
+        $where = Util::getMore([
+            ['page', 1],
+            ['limit', 20],
+            ['store_name', ''],
+            ['cate_id', ''],
+            ['excel', 0],
+            ['order', ''],
+            ['type', $this->request->param('type')]
+        ]);
+        return Json::successlayui(ProductModel::ProductList($where));
+    }
+
+    /**
+     * 设置单个产品上架|下架
+     *
+     * @return json
+     */
+    public function set_show($is_show = '', $id = '')
+    {
+        ($is_show == '' || $id == '') && Json::fail('缺少参数');
+        $res = ProductModel::where(['id' => $id])->update(['is_show' => (int)$is_show]);
+        if ($res) {
+            return Json::successful($is_show == 1 ? '上架成功' : '下架成功');
+        } else {
+            return Json::fail($is_show == 1 ? '上架失败' : '下架失败');
+        }
+    }
+
+    /**
+     * 快速编辑
+     *
+     * @return json
+     */
+    public function set_product($field = '', $id = '', $value = '')
+    {
+        $field == '' || $id == '' || $value == '' && Json::fail('缺少参数');
+        if (ProductModel::where(['id' => $id])->update([$field => $value]))
+            return Json::successful('保存成功');
+        else
+            return Json::fail('保存失败');
+    }
+
+    /**
+     * 设置批量产品上架
+     *
+     * @return json
+     */
+    public function product_show()
+    {
+        $post = Util::postMore([
+            ['ids', []]
+        ]);
+        if (empty($post['ids'])) {
+            return Json::fail('请选择需要上架的产品');
+        } else {
+            $res = ProductModel::where('id', 'in', $post['ids'])->update(['is_show' => 1]);
+            if ($res)
+                return Json::successful('上架成功');
+            else
+                return Json::fail('上架失败');
+        }
+    }
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return \think\Response
+     */
+    public function create($id = 0)
+    {
+        $this->assign('id', (int)$id);
+        return $this->fetch();
+    }
+
+    /**
+     * 获取规则属性模板
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function get_rule()
+    {
+        return Json::successful(\app\models\store\StoreProductRule::field(['rule_name', 'rule_value'])->select()->each(function ($item) {
+            $item['rule_value'] = json_decode($item['rule_value'], true);
+        })->toArray());
+    }
+
+    /**
+     * 获取产品详细信息
+     * @param int $id
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function get_product_info($id = 0)
+    {
+        $list = CategoryModel::getTierList(null, 1);
+        $menus = [];
+        foreach ($list as $menu) {
+            $menus[] = ['value' => $menu['id'], 'label' => $menu['html'] . $menu['cate_name'], 'disabled' => $menu['pid'] == 0 ? 0 : 1];//,'disabled'=>$menu['pid']== 0];
+        }
+        $data['tempList'] = ShippingTemplates::order('sort', 'desc')->field(['id', 'name'])->select()->toArray();
+        $data['cateList'] = $menus;
+        $data['productInfo'] = [];
+        if ($id) {
+            $productInfo = ProductModel::get($id);
+            if (!$productInfo) {
+                return Json::fail('修改的产品不存在');
+            }
+            $productInfo['cate_id'] = explode(',', $productInfo['cate_id']);
+            $productInfo['description'] = htmlspecialchars_decode(StoreDescription::getDescription($id));
+            $productInfo['slider_image'] = is_string($productInfo['slider_image']) ? json_decode($productInfo['slider_image'], true) : [];
+            if ($productInfo['spec_type'] == 1) {
+                $result = StoreProductAttrResult::getResult($id);
+                foreach ($result['value'] as $k => $v) {
+                    $num = 1;
+                    foreach ($v['detail'] as $dv) {
+                        $result['value'][$k]['value' . $num] = $dv;
+                        $num++;
+                    }
+                }
+                $productInfo['items'] = $result['attr'] ?? [];
+                $productInfo['attrs'] = $result['value'] ?? [];
+                $productInfo['attr'] = ['pic' => '', 'price' => 0, 'integral' => 0, 'cost' => 0, 'ot_price' => 0, 'stock' => 0, 'bar_code' => '', 'weight' => 0, 'volume' => 0, 'brokerage' => 0, 'brokerage_two' => 0];
+            } else {
+                $result = StoreProductAttrResult::getResult($id);
+                $single = isset($result['value'][0]) ? $result['value'][0] : [];
+                $productInfo['items'] = [];
+                $productInfo['attrs'] = [];
+                $productInfo['attr'] = [
+                    'pic' => $single['pic'] ?? '',
+                    'price' => $single['price'] ?? 0,
+                    'integral' => $single['integral'] ?? 0,
+                    'cost' => $single['cost'] ?? 0,
+                    'ot_price' => $single['ot_price'] ?? 0,
+                    'stock' => $single['stock'] ?? 0,
+                    'bar_code' => $single['bar_code'] ?? '',
+                    'weight' => $single['weight'] ?? 0,
+                    'volume' => $single['volume'] ?? 0,
+                    'brokerage' => $single['brokerage'] ?? 0,
+                    'brokerage_two' => $single['brokerage_two'] ?? 0,
+                ];
+            }
+            if ($productInfo['activity']) {
+                $activity = explode(',', $productInfo['activity']);
+                foreach ($activity as $k => $v) {
+                    if ($v == 1) {
+                        $activity[$k] = '秒杀';
+                    } elseif ($v == 2) {
+                        $activity[$k] = '砍价';
+                    } elseif ($v == 3) {
+                        $activity[$k] = '拼团';
+                    }
+                }
+                $productInfo['activity'] = $activity;
+            } else {
+                $productInfo['activity'] = ['秒杀', '砍价', '拼团'];
+            }
+            $data['productInfo'] = $productInfo;
+        }
+        return JsonService::successful($data);
+    }
+
+    /**
+     * 保存新建的资源
+     *
+     *
+     */
+    public function save($id)
+    {
+        $data = Util::postMore([
+            ['cate_id', []],
+            'store_name',
+            'store_info',
+            'keyword',
+            ['unit_name', '件'],
+            ['image', []],
+            ['slider_image', []],
+            ['postage', 0],
+            ['is_sub', 0],
+            ['sort', 0],
+            ['sales', 0],
+            ['ficti', 100],
+            ['give_integral', 0],
+            ['is_show', 0],
+            ['temp_id', 0],
+            ['is_hot', 0],
+            ['is_benefit', 0],
+            ['is_best', 0],
+            ['is_new', 0],
+            ['mer_use', 0],
+            ['is_postage', 0],
+            ['is_good', 0],
+            ['description', ''],
+            ['spec_type', 0],
+            ['video_link', ''],
+            ['items', []],
+            ['attrs', []],
+            ['activity', []]
+        ]);
+        foreach ($data['activity'] as $k => $v) {
+            if ($v == '秒杀') {
+                $data['activity'][$k] = 1;
+            } elseif ($v == '砍价') {
+                $data['activity'][$k] = 2;
+            } else {
+                $data['activity'][$k] = 3;
+            }
+        }
+        $data['activity'] = implode(',', $data['activity']);
+        $detail = $data['attrs'];
+        $data['price'] = min(array_column($detail, 'price'));
+        $data['integral'] = min(array_column($detail, 'integral'));
+        $data['ot_price'] = min(array_column($detail, 'ot_price'));
+        $data['cost'] = min(array_column($detail, 'cost'));
+        $attr = $data['items'];
+        unset($data['items'], $data['video'], $data['attrs']);
+        if (count($data['cate_id']) < 1) return Json::fail('请选择产品分类');
+        $cate_id = $data['cate_id'];
+        $data['cate_id'] = implode(',', $data['cate_id']);
+        if (!$data['store_name']) return Json::fail('请输入产品名称');
+        if (count($data['image']) < 1) return Json::fail('请上传产品图片');
+        if (count($data['slider_image']) < 1) return Json::fail('请上传产品轮播图');
+        $data['image'] = $data['image'][0];
+        $data['slider_image'] = json_encode($data['slider_image']);
+        $data['stock'] = array_sum(array_column($detail, 'stock'));
+        ProductModel::beginTrans();
+        foreach ($detail as &$item) {
+            if (($item['brokerage'] + $item['brokerage_two']) > $item['price']) {
+                return Json::fail('一二级返佣相加不能大于商品售价');
+            }
+        }
+        if ($id) {
+            unset($data['sales']);
+            ProductModel::edit($data, $id);
+            $description = $data['description'];
+            unset($data['description']);
+            StoreDescription::saveDescription($description, $id);
+            StoreProductCate::where('product_id', $id)->delete();
+            $cateData = [];
+            foreach ($cate_id as $cid) {
+                $cateData[] = ['product_id' => $id, 'cate_id' => $cid, 'add_time' => time()];
+            }
+            StoreProductCate::insertAll($cateData);
+            if ($data['spec_type'] == 0) {
+                $attr = [
+                    [
+                        'value' => '规格',
+                        'detailValue' => '',
+                        'attrHidden' => '',
+                        'detail' => ['默认']
+                    ]
+                ];
+                $detail[0]['value1'] = '规格';
+                $detail[0]['detail'] = ['规格' => '默认'];
+            }
+
+            $attr_res = StoreProductAttr::createProductAttr($attr, $detail, $id);
+            if ($attr_res) {
+                ProductModel::commitTrans();
+                return Json::success('修改成功!');
+            } else {
+                ProductModel::rollbackTrans();
+                return Json::fail(StoreProductAttr::getErrorInfo());
+            }
+        } else {
+            $data['add_time'] = time();
+            $data['code_path'] = '';
+            $res = ProductModel::create($data);
+            $description = $data['description'];
+            StoreDescription::saveDescription($description, $res['id']);
+            $cateData = [];
+            foreach ($cate_id as $cid) {
+                $cateData[] = ['product_id' => $res['id'], 'cate_id' => $cid, 'add_time' => time()];
+            }
+            StoreProductCate::insertAll($cateData);
+            if ($data['spec_type'] == 0) {
+                $attr = [
+                    [
+                        'value' => '规格',
+                        'detailValue' => '',
+                        'attrHidden' => '',
+                        'detail' => ['默认']
+                    ]
+                ];
+                $detail[0]['value1'] = '规格';
+                $detail[0]['detail'] = ['规格' => '默认'];
+            }
+            $attr_res = StoreProductAttr::createProductAttr($attr, $detail, $res['id']);
+            if ($attr_res) {
+                ProductModel::commitTrans();
+                return Json::success('添加产品成功!');
+            } else {
+                ProductModel::rollbackTrans();
+                return Json::fail(StoreProductAttr::getErrorInfo());
+            }
+        }
+    }
+
+
+    public function edit_content($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = ProductModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $this->assign([
+            'content' => $product->description,
+            'field' => 'description',
+            'action' => Url::buildUrl('change_field', ['id' => $id, 'field' => 'description'])
+        ]);
+        return $this->fetch('public/edit_content');
+    }
+
+    /**
+     * 显示编辑资源表单页.
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function edit($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = ProductModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $field = [
+            Form::select('cate_id', '产品分类', explode(',', $product->getData('cate_id')))->setOptions(function () {
+                $list = CategoryModel::getTierList(null, 1);
+                $menus = [];
+                foreach ($list as $menu) {
+                    $menus[] = ['value' => $menu['id'], 'label' => $menu['html'] . $menu['cate_name'], 'disabled' => $menu['pid'] == 0];//,'disabled'=>$menu['pid']== 0];
+                }
+                return $menus;
+            })->filterable(1)->multiple(1),
+            Form::input('store_name', '产品名称', $product->getData('store_name')),
+            Form::input('store_info', '产品简介', $product->getData('store_info'))->type('textarea'),
+            Form::input('keyword', '产品关键字', $product->getData('keyword'))->placeholder('多个用英文状态下的逗号隔开'),
+            Form::input('unit_name', '产品单位', $product->getData('unit_name'))->col(12),
+            Form::input('bar_code', '产品条码', $product->getData('bar_code'))->col(12),
+            Form::frameImageOne('image', '产品主图片(305*305px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')), $product->getData('image'))->icon('image')->width('100%')->height('500px'),
+            Form::frameImages('slider_image', '产品轮播图(640*640px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'slider_image')), json_decode($product->getData('slider_image'), 1) ?: [])->maxLength(5)->icon('images')->width('100%')->height('500px'),
+            Form::number('price', '产品售价', $product->getData('price'))->min(0)->col(8),
+            Form::number('ot_price', '产品市场价', $product->getData('ot_price'))->min(0)->col(8),
+            Form::number('give_integral', '赠送积分', $product->getData('give_integral'))->min(0)->col(8),
+            Form::number('postage', '邮费', $product->getData('postage'))->min(0)->col(8),
+            Form::number('sales', '销量', $product->getData('sales'))->min(0)->precision(0)->col(8)->readonly(1),
+            Form::number('ficti', '虚拟销量', $product->getData('ficti'))->min(0)->precision(0)->col(8),
+            Form::number('stock', '库存', ProductModel::getStock($id) > 0 ? ProductModel::getStock($id) : $product->getData('stock'))->min(0)->precision(0)->col(8),
+            Form::number('cost', '产品成本价', $product->getData('cost'))->min(0)->col(8),
+            Form::number('sort', '排序', $product->getData('sort'))->col(8),
+            Form::radio('is_show', '产品状态', $product->getData('is_show'))->options([['label' => '上架', 'value' => 1], ['label' => '下架', 'value' => 0]])->col(8),
+            Form::radio('is_hot', '热卖单品', $product->getData('is_hot'))->options([['label' => '是', 'value' => 1], ['label' => '否', 'value' => 0]])->col(8),
+            Form::radio('is_benefit', '促销单品', $product->getData('is_benefit'))->options([['label' => '是', 'value' => 1], ['label' => '否', 'value' => 0]])->col(8),
+            Form::radio('is_best', '精品推荐', $product->getData('is_best'))->options([['label' => '是', 'value' => 1], ['label' => '否', 'value' => 0]])->col(8),
+            Form::radio('is_new', '首发新品', $product->getData('is_new'))->options([['label' => '是', 'value' => 1], ['label' => '否', 'value' => 0]])->col(8),
+            Form::radio('is_postage', '是否包邮', $product->getData('is_postage'))->options([['label' => '是', 'value' => 1], ['label' => '否', 'value' => 0]])->col(8),
+            Form::radio('is_good', '是否优品推荐', $product->getData('is_good'))->options([['label' => '是', 'value' => 1], ['label' => '否', 'value' => 0]])->col(8),
+        ];
+        $form = Form::make_post_form('编辑产品', $field, Url::buildUrl('update', array('id' => $id)), 2);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+
+    /**
+     * 保存更新的资源
+     *
+     * @param $id
+     */
+    public function update($id)
+    {
+        $data = Util::postMore([
+            ['cate_id', []],
+            'store_name',
+            'store_info',
+            'keyword',
+            'bar_code',
+            ['unit_name', '件'],
+            ['image', []],
+            ['slider_image', []],
+            ['postage', 0],
+            ['ot_price', 0],
+            ['price', 0],
+            ['sort', 0],
+            ['stock', 0],
+            ['temp_id', 0],
+            ['ficti', 100],
+            ['give_integral', 0],
+            ['is_show', 0],
+            ['cost', 0],
+            ['is_hot', 0],
+            ['is_benefit', 0],
+            ['is_best', 0],
+            ['is_new', 0],
+            ['mer_use', 0],
+            ['is_postage', 0],
+            ['is_good', 0],
+        ]);
+        if (count($data['cate_id']) < 1) return Json::fail('请选择产品分类');
+        $cate_id = $data['cate_id'];
+        $data['cate_id'] = implode(',', $data['cate_id']);
+        if (!$data['store_name']) return Json::fail('请输入产品名称');
+        if (count($data['image']) < 1) return Json::fail('请上传产品图片');
+        if (count($data['slider_image']) < 1) return Json::fail('请上传产品轮播图');
+        // if(count($data['slider_image'])>8) return Json::fail('轮播图最多5张图');
+        if ($data['price'] == '' || $data['price'] < 0) return Json::fail('请输入产品售价');
+        if ($data['ot_price'] == '' || $data['ot_price'] < 0) return Json::fail('请输入产品市场价');
+        if ($data['stock'] == '' || $data['stock'] < 0) return Json::fail('请输入库存');
+        $data['image'] = $data['image'][0];
+        $data['slider_image'] = json_encode($data['slider_image']);
+        ProductModel::edit($data, $id);
+        StoreProductCate::where('product_id', $id)->delete();
+        foreach ($cate_id as $cid) {
+            StoreProductCate::insert(['product_id' => $id, 'cate_id' => $cid, 'add_time' => time()]);
+        }
+        return Json::successful('修改成功!');
+    }
+
+    public function attr($id)
+    {
+        if (!$id) return $this->failed('数据不存在!');
+//        $result = StoreProductAttrResult::getResult($id);
+        $result = StoreProductAttrValue::getStoreProductAttrResult($id);
+        $image = ProductModel::where('id', $id)->value('image');
+        $this->assign(compact('id', 'result', 'image'));
+        return $this->fetch();
+    }
+
+    /**
+     * 生成属性
+     * @param int $id
+     */
+    public function is_format_attr($id = 0)
+    {
+        $data = Util::postMore([
+            ['attrs', []],
+            ['items', []]
+        ]);
+        $attr = $data['attrs'];
+        $value = attr_format($attr)[1];
+        $valueNew = [];
+        $count = 0;
+        foreach ($value as $key => $item) {
+            $detail = $item['detail'];
+//            sort($item['detail'], SORT_STRING);
+            $suk = implode(',', $item['detail']);
+            if ($id) {
+                $sukValue = StoreProductAttrValue::where('product_id', $id)->where('type', 0)->where('suk', $suk)->column('bar_code,cost,price,ot_price,integral,stock,image as pic,weight,volume,brokerage,brokerage_two', 'suk');
+                if (!count($sukValue)) {
+                    $sukValue[$suk]['pic'] = '';
+                    $sukValue[$suk]['price'] = 0;
+                    $sukValue[$suk]['integral'] = 0;
+                    $sukValue[$suk]['cost'] = 0;
+                    $sukValue[$suk]['ot_price'] = 0;
+                    $sukValue[$suk]['stock'] = 0;
+                    $sukValue[$suk]['bar_code'] = '';
+                    $sukValue[$suk]['weight'] = 0;
+                    $sukValue[$suk]['volume'] = 0;
+                    $sukValue[$suk]['brokerage'] = 0;
+                    $sukValue[$suk]['brokerage_two'] = 0;
+                }
+            } else {
+                $sukValue[$suk]['pic'] = '';
+                $sukValue[$suk]['price'] = 0;
+                $sukValue[$suk]['integral'] = 0;
+                $sukValue[$suk]['cost'] = 0;
+                $sukValue[$suk]['ot_price'] = 0;
+                $sukValue[$suk]['stock'] = 0;
+                $sukValue[$suk]['bar_code'] = '';
+                $sukValue[$suk]['weight'] = 0;
+                $sukValue[$suk]['volume'] = 0;
+                $sukValue[$suk]['brokerage'] = 0;
+                $sukValue[$suk]['brokerage_two'] = 0;
+            }
+            foreach (array_keys($detail) as $k => $title) {
+                $header[$k]['title'] = $title;
+                $header[$k]['align'] = 'center';
+                $header[$k]['minWidth'] = 130;
+            }
+            foreach (array_values($detail) as $k => $v) {
+                $valueNew[$count]['value' . ($k + 1)] = $v;
+                $header[$k]['key'] = 'value' . ($k + 1);
+            }
+            $valueNew[$count]['detail'] = $detail;
+            $valueNew[$count]['pic'] = $sukValue[$suk]['pic'] ?? '';
+            $valueNew[$count]['price'] = $sukValue[$suk]['price'] ? floatval($sukValue[$suk]['price']) : 0;
+            $valueNew[$count]['integral'] = $sukValue[$suk]['integral'] ? floatval($sukValue[$suk]['integral']) : 0;
+            $valueNew[$count]['cost'] = $sukValue[$suk]['cost'] ? floatval($sukValue[$suk]['cost']) : 0;
+            $valueNew[$count]['ot_price'] = isset($sukValue[$suk]['ot_price']) ? floatval($sukValue[$suk]['ot_price']) : 0;
+            $valueNew[$count]['stock'] = $sukValue[$suk]['stock'] ? intval($sukValue[$suk]['stock']) : 0;
+            $valueNew[$count]['bar_code'] = $sukValue[$suk]['bar_code'] ?? '';
+            $valueNew[$count]['weight'] = $sukValue[$suk]['weight'] ?? 0;
+            $valueNew[$count]['volume'] = $sukValue[$suk]['volume'] ?? 0;
+            $valueNew[$count]['brokerage'] = $sukValue[$suk]['brokerage'] ?? 0;
+            $valueNew[$count]['brokerage_two'] = $sukValue[$suk]['brokerage_two'] ?? 0;
+            $count++;
+        }
+        $header[] = ['title' => '图片', 'slot' => 'pic', 'align' => 'center', 'minWidth' => 80];
+        $header[] = ['title' => '售价', 'slot' => 'price', 'align' => 'center', 'minWidth' => 120];
+        $header[] = ['title' => '积分', 'slot' => 'integral', 'align' => 'center', 'minWidth' => 120];
+        $header[] = ['title' => '成本价', 'slot' => 'cost', 'align' => 'center', 'minWidth' => 140];
+        $header[] = ['title' => '原价', 'slot' => 'ot_price', 'align' => 'center', 'minWidth' => 140];
+        $header[] = ['title' => '库存', 'slot' => 'stock', 'align' => 'center', 'minWidth' => 140];
+        $header[] = ['title' => '产品编号', 'slot' => 'bar_code', 'align' => 'center', 'minWidth' => 140];
+        $header[] = ['title' => '重量(KG)', 'slot' => 'weight', 'align' => 'center', 'minWidth' => 140];
+        $header[] = ['title' => '体积(m³)', 'slot' => 'volume', 'align' => 'center', 'minWidth' => 140];
+        $header[] = ['title' => '操作', 'slot' => 'action', 'align' => 'center', 'minWidth' => 70];
+        $info = ['attr' => $attr, 'value' => $valueNew, 'header' => $header];
+        return Json::successful($info);
+    }
+
+    public function set_attr($id)
+    {
+        if (!$id) return $this->failed('产品不存在!');
+        list($attr, $detail) = Util::postMore([
+            ['items', []],
+            ['attrs', []]
+        ], null, true);
+        $res = StoreProductAttr::createProductAttr($attr, $detail, $id);
+        if ($res)
+            return $this->successful('编辑属性成功!');
+        else
+            return $this->failed(StoreProductAttr::getErrorInfo());
+    }
+
+    public function clear_attr($id)
+    {
+        if (!$id) return $this->failed('产品不存在!');
+        if (false !== StoreProductAttr::clearProductAttr($id) && false !== StoreProductAttrResult::clearResult($id))
+            return $this->successful('清空产品属性成功!');
+        else
+            return $this->failed(StoreProductAttr::getErrorInfo('清空产品属性失败!'));
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function delete($id)
+    {
+
+        if (!$id) return $this->failed('数据不存在');
+        if (!ProductModel::be(['id' => $id])) return $this->failed('产品数据不存在');
+        if (ProductModel::be(['id' => $id, 'is_del' => 1])) {
+            $data['is_del'] = 0;
+            if (!ProductModel::edit($data, $id))
+                return Json::fail(ProductModel::getErrorInfo('恢复失败,请稍候再试!'));
+            else
+                return Json::successful('成功恢复产品!');
+        } else {
+            $res1 = StoreSeckill::where('product_id', $id)->where('is_del', 0)->find();
+            $res2 = StoreBargain::where('product_id', $id)->where('is_del', 0)->find();
+            $res3 = StoreCombination::where('product_id', $id)->where('is_del', 0)->find();
+            if ($res1 || $res2 || $res3) {
+                return Json::fail(ProductModel::getErrorInfo('该商品已参加活动,无法删除!'));
+            } else {
+                $data['is_del'] = 1;
+                if (!ProductModel::edit($data, $id))
+                    return Json::fail(ProductModel::getErrorInfo('删除失败,请稍候再试!'));
+                else
+                    return Json::successful('成功移到回收站!');
+            }
+
+        }
+
+    }
+
+
+    /**
+     * 点赞
+     * @param $id
+     * @return mixed|\think\response\Json|void
+     */
+    public function collect($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = ProductModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $this->assign(StoreProductRelation::getCollect($id));
+        return $this->fetch();
+    }
+
+    /**
+     * 收藏
+     * @param $id
+     * @return mixed|\think\response\Json|void
+     */
+    public function like($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = ProductModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $this->assign(StoreProductRelation::getLike($id));
+        return $this->fetch();
+    }
+
+    /**
+     * 修改产品价格
+     */
+    public function edit_product_price()
+    {
+        $data = Util::postMore([
+            ['id', 0],
+            ['price', 0],
+        ]);
+        if (!$data['id']) return Json::fail('参数错误');
+        $res = ProductModel::edit(['price' => $data['price']], $data['id']);
+        if ($res) return Json::successful('修改成功');
+        else return Json::fail('修改失败');
+    }
+
+    /**
+     * 修改产品库存
+     *
+     */
+    public function edit_product_stock()
+    {
+        $data = Util::postMore([
+            ['id', 0],
+            ['stock', 0],
+        ]);
+        if (!$data['id']) return Json::fail('参数错误');
+        $res = ProductModel::edit(['stock' => $data['stock']], $data['id']);
+        if ($res) return Json::successful('修改成功');
+        else return Json::fail('修改失败');
+    }
+
+    /**
+     * 检测商品是否开活动
+     * @param $id
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function check_activity($id)
+    {
+        if ($id != 0) {
+            $res1 = StoreSeckill::where('product_id', $id)->where('is_del', 0)->find();
+            $res2 = StoreBargain::where('product_id', $id)->where('is_del', 0)->find();
+            $res3 = StoreCombination::where('product_id', $id)->where('is_del', 0)->find();
+            if ($res1 || $res2 || $res3) {
+                return Json::successful('该商品有活动开启,无法删除属性');
+            } else {
+                return Json::fail();
+            }
+        } else {
+            return Json::fail();
+        }
+    }
+}

+ 175 - 0
app/admin/controller/store/StoreProductReply.php

@@ -0,0 +1,175 @@
+<?php
+
+namespace app\admin\controller\store;
+
+use app\admin\controller\AuthController;
+use app\models\store\StoreOrder;
+use crmeb\traits\CurdControllerTrait;
+use think\facade\Route as Url;
+use app\admin\model\store\StoreProductReply as ProductReplyModel;
+use crmeb\services\{
+    FormBuilder as Form, JsonService as Json, UtilService as Util
+};
+
+/**
+ * 评论管理 控制器
+ * Class StoreProductReply
+ * @package app\admin\controller\store
+ */
+class StoreProductReply extends AuthController
+{
+
+    use CurdControllerTrait;
+
+    /**
+     * 显示资源列表
+     *
+     * @return \think\Response
+     */
+    public function index()
+    {
+        $product_id = input('product_id');
+        if (!$product_id) $product_id = 0;
+        $this->assign('is_layui', true);
+        $this->assign('product_id', (int)$product_id);
+        return $this->fetch();
+    }
+
+    public function get_product_imaes_list()
+    {
+        $where = Util::getMore([
+            ['page', 1],
+            ['limit', 10],
+            ['title', ''],
+            ['is_reply', ''],
+            ['product_name', ''],
+            ['product_id', 0],
+        ]);
+        return Json::successful(ProductReplyModel::getProductImaesList($where));
+    }
+
+    public function get_product_reply_list()
+    {
+        $where = Util::getMore([
+            ['limit', 10],
+            ['title', ''],
+            ['is_reply', ''],
+            ['message_page', 1],
+            ['producr_id', 0],
+            ['order_id', ''],
+            ['nickname', ''],
+            ['score_type', ''],
+        ]);
+        return Json::successful(ProductReplyModel::getProductReplyList($where));
+    }
+
+    /**
+     * @param $id
+     * @return \think\response\Json|void
+     */
+    public function delete($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $data['is_del'] = 1;
+        if (!ProductReplyModel::edit($data, $id))
+            return Json::fail(ProductReplyModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+
+    public function set_reply()
+    {
+        $data = Util::postMore([
+            'id',
+            'content',
+        ]);
+        if (!$data['id']) return Json::fail('参数错误');
+        if ($data['content'] == '') return Json::fail('请输入回复内容');
+        $save['merchant_reply_content'] = $data['content'];
+        $save['merchant_reply_time'] = time();
+        $save['is_reply'] = 2;
+        $res = ProductReplyModel::edit($save, $data['id']);
+        if (!$res)
+            return Json::fail(ProductReplyModel::getErrorInfo('回复失败,请稍候再试!'));
+        else
+            return Json::successful('回复成功!');
+    }
+
+    public function edit_reply()
+    {
+        $data = Util::postMore([
+            'id',
+            'content',
+        ]);
+        if (!$data['id']) return Json::fail('参数错误');
+        if ($data['content'] == '') return Json::fail('请输入回复内容');
+        $save['merchant_reply_content'] = $data['content'];
+        $save['merchant_reply_time'] = time();
+        $save['is_reply'] = 2;
+        $res = ProductReplyModel::edit($save, $data['id']);
+        if (!$res)
+            return Json::fail(ProductReplyModel::getErrorInfo('回复失败,请稍候再试!'));
+        else
+            return Json::successful('回复成功!');
+    }
+
+    /**
+     * 添加虚拟评论表单
+     * @return string
+     * @throws \FormBuilder\exception\FormBuilderException
+     */
+    public function create()
+    {
+        $field = [
+            Form::frameImageOne('image', '商品', Url::buildUrl('admin/store.StoreProductReply/select', array('fodder' => 'image')))->icon('plus')->width('100%')->height('500px'),
+            Form::hidden('product_id', 0),
+            Form::input('nickname', '用户名称')->col(Form::col(24)),
+            Form::input('comment', '评价文字')->type('textarea'),
+            Form::number('product_score', '商品分数')->col(8)->value(5)->min(1)->max(5),
+            Form::number('service_score', '服务分数')->col(8)->value(5)->min(1)->max(5),
+            Form::frameImageOne('avatar', '用户头像', Url::buildUrl('admin/widget.images/index', array('fodder' => 'avatar')))->icon('image')->width('100%')->height('500px'),
+            Form::frameImages('pics', '评价图片', Url::buildUrl('admin/widget.images/index', array('fodder' => 'pics')))->maxLength(5)->icon('images')->width('100%')->height('500px')->spin(0)
+        ];
+        $form = Form::make_post_form('添加评论', $field, Url::buildUrl('save'), 2);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 选择商品
+     * @param int $id
+     */
+    public function select()
+    {
+        return $this->fetch();
+    }
+
+    /**
+     * 保存评论
+     */
+    public function save()
+    {
+        $data = Util::postMore([
+            ['nickname', ''],
+            ['avatar', ''],
+            ['product_id', ''],
+            ['product_score', 0],
+            ['service_score', 0],
+            ['comment', ''],
+            ['pics', []],
+        ]);
+        if ($data['product_id'] == 0) return Json::fail('请选择商品');
+        if ($data['nickname'] == '') return Json::fail('请填写用户名称');
+        if ($data['comment'] == '') return Json::fail('请填写评价');
+        if ($data['avatar'] == '') return Json::fail('请选择用户头像');
+        $data['uid'] = 0;
+        $data['oid'] = 0;
+        $data['unique'] = uniqid();
+        $data['reply_type'] = 'product';
+        $data['add_time'] = time();
+        $data['pics'] = json_encode($data['pics']);
+        ProductReplyModel::create($data);
+        return Json::successful('添加成功!');
+    }
+
+}

+ 112 - 0
app/admin/controller/store/StoreProductRule.php

@@ -0,0 +1,112 @@
+<?php
+
+namespace app\admin\controller\store;
+
+use app\admin\controller\AuthController;
+use app\Request;
+use crmeb\traits\CurdControllerTrait;
+use think\facade\Route as Url;
+use app\models\store\StoreProductRule as ProductRuleModel;
+use crmeb\services\{
+    JsonService as Json, UtilService
+};
+
+/**
+ * 评论管理 控制器
+ * Class StoreProductReply
+ * @package app\admin\controller\store
+ */
+class StoreProductRule extends AuthController
+{
+
+    use CurdControllerTrait;
+
+    /**
+     * 显示资源列表
+     *
+     * @return \think\Response
+     */
+    public function index()
+    {
+        if (!$this->request->isAjax()) {
+            return $this->fetch();
+        }
+        $where = UtilService::getMore([
+            ['page', 1],
+            ['limit', 15],
+            ['rule_name', '']
+        ]);
+        $list = ProductRuleModel::sysPage($where);
+        return Json::successlayui($list);
+    }
+
+    /**
+     * 创建
+     * @param int $id
+     * @return string
+     * @throws \Exception
+     */
+    public function create($id = 0)
+    {
+        $this->assign(compact('id'));
+        return $this->fetch();
+    }
+
+    /**
+     * 保存新建的资源
+     *
+     * @param \think\Request $request
+     * @return \think\Response
+     */
+    public function save(Request $request, $id = 0)
+    {
+        $data = UtilService::postMore([
+            ['rule_name', ''],
+            ['rule_value', []]
+        ]);
+        if ($data['rule_name'] == '') return $this->fail('请输入规则名称');
+        if (!$data['rule_value']) return $this->fail('缺少规则值');
+        $data['rule_value'] = json_encode($data['rule_value']);
+        if ($id) {
+            $rule = ProductRuleModel::get($id);
+            if (!$rule) return $this->fail('数据不存在');
+            ProductRuleModel::edit($data, $id);
+            return Json::success('编辑成功!');
+        } else {
+            ProductRuleModel::create($data);
+            return Json::success('规则添加成功!');
+        }
+    }
+
+    /**
+     * 显示指定的资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function read($id)
+    {
+        return Json::successful(ProductRuleModel::sysInfo($id));
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function delete()
+    {
+        $data = UtilService::postMore([
+            ['ids', '']
+        ]);
+        if ($data['ids'] == '') return $this->fail('请至少选择一条数据');
+        $ids = strval($data['ids']);
+        $res = ProductRuleModel::whereIn('id', $ids)->delete();
+        if (!$res)
+            return Json::fail(ProductRuleModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::success('删除成功!');
+    }
+
+}

+ 86 - 0
app/admin/controller/system/Clear.php

@@ -0,0 +1,86 @@
+<?php
+
+namespace app\admin\controller\system;
+
+use app\admin\controller\AuthController;
+use crmeb\services\CacheService;
+
+/**
+ * 首页控制器
+ * Class Clear
+ * @package app\admin\controller
+ *
+ */
+class Clear extends AuthController
+{
+    public function index()
+    {
+        return $this->fetch();
+    }
+
+    /**
+     * 刷新数据缓存
+     */
+    public function refresh_cache()
+    {
+        $root       = app()->getRootPath() . 'runtime' . DS;
+        $adminRoute = $root . 'admin';
+        $apiRoute   = $root . 'api';
+        $cacheRoute = $root . 'cache';
+        $cache      = [];
+
+        if (is_dir($adminRoute))
+            $cache[$adminRoute] = scandir($adminRoute);
+        if (is_dir($apiRoute))
+            $cache[$apiRoute] = scandir($apiRoute);
+        if (is_dir($cacheRoute))
+            $cache[$cacheRoute] = scandir($cacheRoute);
+
+        foreach ($cache as $p => $list) {
+            foreach ($list as $file) {
+                if (!in_array($file, ['.', '..', 'log', 'schema', 'route.php'])) {
+                    $path = $p . DS . $file;
+                    if (is_file($path)) {
+                        @unlink($path);
+                    } else {
+                        $this->delDirAndFile($path . DS);
+                    }
+                }
+            }
+        }
+        CacheService::clear();
+        return app('json')->successful('数据缓存刷新成功!');
+    }
+
+
+    /**
+     * 删除日志
+     */
+    public function delete_log()
+    {
+        $root = app()->getRootPath() . 'runtime' . DS;
+        $this->delDirAndFile($root . 'admin' . DS . 'log' . DS);
+        $this->delDirAndFile($root . 'api' . DS . 'log' . DS);
+        $this->delDirAndFile($root . 'log' . DS);
+
+        return app('json')->successful('数据缓存刷新成功!');
+    }
+
+    /** 递归删除文件
+     * @param $dirName
+     * @param bool $subdir
+     */
+    protected function delDirAndFile($dirName)
+    {
+        $list = glob($dirName . '*');
+        foreach ($list as $file) {
+            if (is_dir($file))
+                $this->delDirAndFile($file . DS);
+            else
+                @unlink($file);
+        }
+        @rmdir($dirName);
+    }
+}
+
+

+ 121 - 0
app/admin/controller/system/Express.php

@@ -0,0 +1,121 @@
+<?php
+
+namespace app\admin\controller\system;
+
+use app\admin\controller\AuthController;
+use think\facade\Route as Url;
+use app\admin\model\system\Express as ExpressModel;
+use crmeb\services\{FormBuilder as Form, UtilService as Util, JsonService as Json};
+
+/**
+ * 物流公司管理控制器
+ * Class SystemMenus
+ * @package app\admin\controller\system
+ */
+class Express extends AuthController
+{
+    /**
+     * 显示资源列表
+     *
+     * @return \think\Response
+     */
+    public function index()
+    {
+        $params = Util::getMore([
+            ['keyword', '']
+        ], $this->request);
+        $this->assign(ExpressModel::systemPage($params));
+        $this->assign(compact('params'));
+        return $this->fetch();
+    }
+
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return \think\Response
+     */
+    public function create($cid = 0)
+    {
+        $formbuider = [
+            Form::input('name', '公司名称')->required('公司名称名称必填'),
+            Form::input('code', '编码'),
+            Form::number('sort', '排序', 0),
+            Form::radio('is_show', '是否启用', 1)->options([['value' => 0, 'label' => '隐藏'], ['value' => 1, 'label' => '启用']]),
+        ];
+        $form = Form::make_post_form('添加物流公司', $formbuider, Url::buildUrl('save'), 2);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存新建的资源
+     */
+    public function save()
+    {
+        $data = Util::postMore([
+            'name',
+            'code',
+            ['sort', 0],
+            ['is_show', 0]]);
+        if (!$data['name']) return Json::fail('请输入公司名称');
+        ExpressModel::create($data);
+        return Json::successful('添加公司成功!');
+    }
+
+    /**
+     * 显示编辑资源表单页.
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function edit($id)
+    {
+        $menu = ExpressModel::get($id);
+        if (!$menu) return Json::fail('数据不存在!');
+        $formbuider = [
+            Form::input('name', '公司名称', $menu['name']),
+            Form::input('code', '编码', $menu['code']),
+            Form::number('sort', '排序', $menu['sort']),
+            Form::radio('is_show', '是否启用', $menu['is_show'])->options([['value' => 0, 'label' => '隐藏'], ['value' => 1, 'label' => '启用']])
+        ];
+        $form = Form::make_post_form('添加物流公司', $formbuider, Url::buildUrl('update', array('id' => $id)), 2);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存更新的资源
+     *
+     * @param $id
+     */
+    public function update($id)
+    {
+        $data = Util::postMore([
+            'name',
+            'code',
+            ['sort', 0],
+            ['is_show', 0]]);
+        if (!$data['name']) return Json::fail('请输入公司名称');
+        if (!ExpressModel::get($id)) return Json::fail('编辑的记录不存在!');
+        ExpressModel::edit($data, $id);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function delete($id)
+    {
+        if (!$id) return $this->failed('参数错误,请重新打开');
+        $res = ExpressModel::destroy($id);
+        if (!$res)
+            return Json::fail(ExpressModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+
+}

+ 50 - 0
app/admin/controller/system/SystemAttachment.php

@@ -0,0 +1,50 @@
+<?php
+
+namespace app\admin\controller\system;
+
+use app\admin\model\system\SystemAttachment as SystemAttachmentModel;
+use app\admin\controller\AuthController;
+use crmeb\services\upload\Upload;
+
+/**
+ * 附件管理控制器
+ * Class SystemAttachment
+ * @package app\admin\controller\system
+ *
+ */
+class SystemAttachment extends AuthController
+{
+    /**
+     * TODO 编辑器上传图片
+     */
+    public function upload()
+    {
+        $uploadType = (int)sys_config('upload_type', 1);
+        $upload = new Upload($uploadType, [
+            'accessKey' => sys_config('accessKey'),
+            'secretKey' => sys_config('secretKey'),
+            'uploadUrl' => sys_config('uploadUrl'),
+            'storageName' => sys_config('storage_name'),
+            'storageRegion' => sys_config('storage_region'),
+        ]);
+        $resInfo = $upload->to('editor/' . date('Ymd'))->validate()->move('upfile');
+        if ($resInfo === false) {
+            echo json_encode([
+                'msg' => $upload->getError(),
+                'state' => 'ERROR'
+            ]);
+        } else {
+            $res = $upload->getUploadInfo();
+            $res['image_type'] = $uploadType;
+            SystemAttachmentModel::attachmentAdd($res['name'], $res['size'], $res['type'], $res['dir'], $res['thumb_path'], 0, $res['image_type'], $res['time']);
+            $info["originalName"] = $res['name'];
+            $info["name"] = $res['name'];
+            $info["url"] = $res['dir'];
+            $info["size"] = $res['size'];
+            $info["type"] = $res['type'];
+            $info["state"] = "SUCCESS";
+            if ($res['image_type'] == 1) $info['url'] = sys_config('site_url') . str_replace('\\', '/', $res['dir']);
+            echo json_encode($info);
+        }
+    }
+}

+ 248 - 0
app/admin/controller/system/SystemCleardata.php

@@ -0,0 +1,248 @@
+<?php
+/**
+ * Created by PhpStorm.
+ * User: sugar1569
+ * Date: 2018/5/24
+ * Time: 10:58
+ */
+
+namespace app\admin\controller\system;
+
+
+use app\admin\controller\AuthController;
+use app\admin\model\store\StoreProduct;
+use crmeb\services\JsonService as Json;
+use crmeb\services\SystemConfigService;
+use think\facade\Config;
+use think\facade\Db;
+
+/**
+ * 清除默认数据理控制器
+ * Class SystemclearData
+ * @package app\admin\controller\system
+ */
+class SystemclearData extends AuthController
+{
+
+    public function index()
+    {
+        return $this->fetch();
+    }
+
+    //清除用户数据
+    public function userRelevantData()
+    {
+        self::clearData('user_recharge', 1);
+        self::clearData('user_address', 1);
+        self::clearData('user_bill', 1);
+        self::clearData('user_enter', 1);
+        self::clearData('user_extract', 1);
+        self::clearData('user_notice', 1);
+        self::clearData('user_notice_see', 1);
+        self::clearData('wechat_qrcode', 1);
+        self::clearData('wechat_message', 1);
+        self::clearData('store_visit', 1);
+        self::clearData('store_coupon_user', 1);
+        self::clearData('store_coupon_issue_user', 1);
+        self::clearData('store_bargain_user', 1);
+        self::clearData('store_bargain_user_help', 1);
+        self::clearData('store_product_reply', 1);
+        self::clearData('routine_qrcode', 1);
+        self::clearData('routine_form_id', 1);
+        self::clearData('user_sign', 1);
+        self::clearData('user_task_finish', 1);
+        self::clearData('user_level', 1);
+        self::clearData('user_token', 1);
+        self::clearData('user_group', 1);
+        $this->delDirAndFile('./public/uploads/store/comment');
+        self::clearData('store_product_relation', 1);
+        return Json::successful('清除数据成功!');
+    }
+
+    //清除商城数据
+    public function storeData()
+    {
+        self::clearData('store_coupon', 1);
+        self::clearData('store_coupon_issue', 1);
+        self::clearData('store_bargain', 1);
+        self::clearData('store_combination', 1);
+        self::clearData('store_product_attr', 1);
+        self::clearData('store_product_attr_result', 1);
+        self::clearData('store_product_attr_value', 1);
+        self::clearData('store_product_description', 1);
+        self::clearData('store_product_reply', 1);
+        self::clearData('store_seckill', 1);
+        self::clearData('store_product', 1);
+        self::clearData('store_visit', 1);
+        return Json::successful('清除数据成功!');
+    }
+
+    //清除产品分类
+    public function categoryData()
+    {
+        self::clearData('store_category', 1);
+        self::clearData('store_product_cate', 1);
+        return Json::successful('清除数据成功!');
+    }
+
+    //清除订单数据
+    public function orderData()
+    {
+        self::clearData('store_order', 1);
+        self::clearData('store_order_cart_info', 1);
+        self::clearData('store_order_status', 1);
+        self::clearData('store_pink', 1);
+        self::clearData('store_cart', 1);
+        self::clearData('store_order_status', 1);
+        return Json::successful('清除数据成功!');
+    }
+
+    //清除客服数据
+    public function kefuData()
+    {
+        self::clearData('store_service', 1);
+        $this->delDirAndFile('./public/uploads/store/service');
+        self::clearData('store_service_log', 1);
+        return Json::successful('清除数据成功!');
+    }
+
+    //清除微信管理数据
+    public function wechatData()
+    {
+        self::clearData('wechat_media', 1);
+        self::clearData('wechat_reply', 1);
+        self::clearData('cache', 1);
+        $this->delDirAndFile('./public/uploads/wechat');
+        return Json::successful('清除数据成功!');
+    }
+
+    //清除所有附件
+    public function uploadData()
+    {
+        self::clearData('system_attachment', 1);
+        self::clearData('system_attachment_category', 1);
+        $this->delDirAndFile('./public/uploads/');
+        return Json::successful('清除上传文件成功!');
+    }
+
+    //清除微信用户
+    public function wechatuserData()
+    {
+        self::clearData('wechat_user', 1);
+        self::clearData('user', 1);
+        return Json::successful('清除数据成功!');
+    }
+
+    //清除内容分类
+    public function articledata()
+    {
+        self::clearData('article_category', 1);
+        self::clearData('article', 1);
+        self::clearData('article_content', 1);
+        return Json::successful('清除数据成功!');
+    }
+
+    //清除系统记录
+    public function systemdata()
+    {
+        self::clearData('system_notice_admin', 1);
+        self::clearData('system_log', 1);
+        return Json::successful('清除数据成功!');
+    }
+
+    /**
+     * 清除数据
+     * @param int $type
+     * @throws \Exception
+     */
+    public function undata($type = 1)
+    {
+        switch ((int)$type) {
+            case 1:
+                $fileImage = \app\admin\model\system\SystemAttachment::where('module_type', 2)->field(['att_dir', 'satt_dir'])->select();
+                foreach ($fileImage as $image) {
+                    if ($image['att_dir'] && ($imagePath = strstr($image['att_dir'], 'uploads')) !== false) {
+                        if (is_file($imagePath))
+                            unlink($imagePath);
+                        unset($imagePath);
+                    }
+
+                    if ($image['satt_dir'] && ($imagePath = strstr($image['satt_dir'], 'uploads')) !== false) {
+                        if (is_file($imagePath))
+                            unlink($imagePath);
+                        unset($imagePath);
+                    }
+                }
+                \app\admin\model\system\SystemAttachment::where('module_type', 2)->delete();
+                @unlink('uploads/follow/follow.jpg');//删除海报二维码
+                break;
+            case 2:
+                StoreProduct::where('is_del', 1)->delete();
+                break;
+            case 3:
+                $value = $this->request->param('value');
+                if (!$value)
+                    return Json::fail('请输入需要更换的域名');
+                if (!verify_domain($value))
+                    return Json::fail('域名不合法');
+                $siteUrl = SystemConfigService::get('site_url', true);
+                $siteUrlJosn = str_replace('http://', 'http:\\\/\\\/', $siteUrl);
+                $valueJosn = str_replace('http://', 'http:\\\/\\\/', $value);
+                $prefix = Config::get('database.connections.' . Config::get('database.default') . '.prefix');
+                $sql = [
+                    "UPDATE `{$prefix}system_attachment` SET `att_dir` = replace(`att_dir` ,'{$siteUrl}','{$value}'),`satt_dir` = replace(`satt_dir` ,'{$siteUrl}','{$value}')",
+                    "UPDATE `{$prefix}store_product` SET `image` = replace(`image` ,'{$siteUrl}','{$value}'),`slider_image` = replace(`slider_image` ,'{$siteUrlJosn}','{$valueJosn}')",
+                    "UPDATE `{$prefix}store_product_attr_value` SET `image` = replace(`image` ,'{$siteUrl}','{$value}')",
+                    "UPDATE `{$prefix}store_seckill` SET `image` = replace(`image` ,'{$siteUrl}','{$value}'),`images` = replace(`images`,'{$siteUrlJosn}','{$valueJosn}')",
+                    "UPDATE `{$prefix}store_combination` SET `image` = replace(`image` ,'{$siteUrl}','{$value}'),`images` = replace(`images`,'{$siteUrlJosn}','{$valueJosn}')",
+                    "UPDATE `{$prefix}store_bargain` SET `image` = replace(`image` ,'{$siteUrl}','{$value}'),`images` = replace(`images`,'{$siteUrlJosn}','{$valueJosn}')",
+                    "UPDATE `{$prefix}system_config` SET `value` = replace(`value` ,'{$siteUrlJosn}','{$valueJosn}')",
+                    "UPDATE `{$prefix}article_category` SET `image` = replace(`image` ,'{$siteUrl}','{$value}')",
+                    "UPDATE `{$prefix}article` SET `image_input` = replace(`image_input` ,'{$siteUrl}','{$value}')",
+                    "UPDATE `{$prefix}article_content` SET `content` = replace(`content` ,'{$siteUrl}','{$value}')",
+                    "UPDATE `{$prefix}store_category` SET `pic` = replace(`pic` ,'{$siteUrl}','{$value}')",
+                    "UPDATE `{$prefix}system_group_data` SET `value` = replace(`value` ,'{$siteUrlJosn}','{$valueJosn}')",
+                    "UPDATE `{$prefix}store_product_description` SET `description`= replace(`description`,'{$siteUrl}','{$value}')"
+                ];
+                try {
+                    foreach ($sql as $item) {
+                        db::execute($item);
+                    }
+                } catch (\Throwable $e) {
+                    return Json::fail('替换失败,失败原因:' . $e->getMessage());
+                }
+                return Json::success('替换成功!');
+                break;
+        }
+        return Json::successful('清除数据成功!');
+    }
+
+    //清除制定表数据
+    public function clearData($table_name, $status)
+    {
+        $table_name = config('database.connections.' . config('database.default'))['prefix'] . $table_name;
+        if ($status) {
+            @db::execute('TRUNCATE TABLE ' . $table_name);
+        } else {
+            @db::execute('DELETE FROM' . $table_name);
+        }
+
+    }
+
+    //递归删除文件
+    function delDirAndFile($dirName, $subdir = true)
+    {
+        if ($handle = @opendir("$dirName")) {
+            while (false !== ($item = readdir($handle))) {
+                if ($item != "." && $item != "..") {
+                    if (is_dir("$dirName/$item"))
+                        $this->delDirAndFile("$dirName/$item", false);
+                    else
+                        @unlink("$dirName/$item");
+                }
+            }
+            closedir($handle);
+            if (!$subdir) @rmdir($dirName);
+        }
+    }
+}

+ 245 - 0
app/admin/controller/system/SystemDatabackup.php

@@ -0,0 +1,245 @@
+<?php
+
+namespace app\admin\controller\system;
+
+use app\admin\controller\AuthController;
+use crmeb\services\JsonService as Json;
+use \crmeb\services\MysqlBackupService as Backup;
+use think\facade\Config;
+use think\facade\Session;
+use think\facade\Db;
+
+/**
+ * 文件校验控制器
+ * Class SystemDatabackup
+ * @package app\admin\controller\system
+ *
+ */
+class SystemDatabackup extends AuthController
+{
+    /**
+     * @var Backup
+     */
+    protected $DB;
+
+    public function initialize()
+    {
+        parent::initialize();
+        $config = array(
+            //数据库备份卷大小
+            'compress' => 1,
+            //数据库备份文件是否启用压缩 0不压缩 1 压缩
+            'level' => 5,
+        );
+        $this->DB = new Backup($config);
+    }
+
+    /**
+     * 数据类表列表
+     */
+    public function index()
+    {
+        return $this->fetch();
+    }
+
+    /**
+     * 获取数据库表
+     */
+    public function tablelist()
+    {
+        $db = $this->DB;
+        return Json::result(0, 'sucess', $db->dataList(), count($db->dataList()));
+    }
+
+    /**
+     * 查看表结构
+     */
+    public function seetable()
+    {
+        request()->filter(['strip_tags', 'trim', 'htmlspecialchars']);
+        $database = Config::get("database.connections." . Config::get('database.default') . '.database');
+        $tablename = request()->param('tablename');
+        $res = Db::query("select * from information_schema.columns where table_name = '" . $tablename . "' and table_schema = '" . $database . "'");
+        $html = '';
+        $html .= '<table border="1" cellspacing="0" cellpadding="0" align="center">';
+        $html .= '<tbody><tr><th>字段名</th><th>数据类型</th><th>默认值</th><th>允许非空</th><th>自动递增</th><th>备注</th></tr>';
+        $html .= '';
+        foreach ($res AS $f) {
+            $html .= '<td class="c1">' . $f['COLUMN_NAME'] . '</td>';
+            $html .= '<td class="c2">' . $f['COLUMN_TYPE'] . '</td>';
+            $html .= '<td class="c3">' . $f['COLUMN_DEFAULT'] . '</td>';
+            $html .= '<td class="c4">' . $f['IS_NULLABLE'] . '</td>';
+            $html .= '<td class="c5">' . ($f['EXTRA'] == 'auto_increment' ? '是' : ' ') . '</td>';
+            $html .= '<td class="c6">' . $f['COLUMN_COMMENT'] . '</td>';
+            $html .= '</tr>';
+        }
+        $html .= '</tbody></table></p>';
+        $html .= '<p style="text-align:left;margin:20px auto;">总共:' . count($res) . '个字段</p>';
+        $html .= '</body></html>';
+        echo '<style>
+                body,td,th {font-family:"宋体"; font-size:12px;}
+                table,h1,p{width:960px;margin:0px auto;}
+                table{border-collapse:collapse;border:1px solid #CCC;background:#efefef;}
+                table caption{text-align:left; background-color:#fff; line-height:2em; font-size:14px; font-weight:bold; }
+                table th{text-align:left; font-weight:bold;height:26px; line-height:26px; font-size:12px; border:1px solid #CCC;padding-left:5px;}
+                table td{height:20px; font-size:12px; border:1px solid #CCC;background-color:#fff;padding-left:5px;}
+                .c1{ width: 150px;}
+                .c2{ width: 150px;}
+                .c3{ width: 80px;}
+                .c4{ width: 100px;}
+                .c5{ width: 100px;}
+                .c6{ width: 300px;}
+            </style>';
+        echo $html;
+    }
+
+    /**
+     * 优化表
+     */
+    public function optimize()
+    {
+        $tables = request()->post('tables/a');
+        $db = $this->DB;
+        try {
+            $db->optimize($tables);
+            return Json::successful('优化成功');
+        } catch (\Exception $e) {
+            return Json::fail($e->getMessage());
+        }
+    }
+
+    /**
+     * 修复表
+     */
+    public function repair()
+    {
+        $tables = request()->post('tables/a');
+        $db = $this->DB;
+        try {
+            $db->repair($tables);
+            return Json::successful('修复成功');
+        } catch (\Exception $e) {
+            return Json::fail($e->getMessage());
+        }
+    }
+
+    /**
+     * 备份表
+     */
+    public function backup()
+    {
+        $tables = request()->post('tables/a');
+        $db = $this->DB;
+        $data = '';
+        foreach ($tables as $t) {
+            $res = $db->backup($t, 0);
+            if ($res == false && $res != 0) {
+                $data .= $t . '|';
+            }
+        }
+        return Json::successful($data ? '备份失败' . $data : '备份成功');
+    }
+
+    /**
+     * 获取备份记录表
+     */
+    public function fileList()
+    {
+        $db = $this->DB;
+        $files = $db->fileList();
+        $data = [];
+        foreach ($files as $key => $t) {
+            $data[$key]['filename'] = $t['filename'];
+            $data[$key]['part'] = $t['part'];
+            $data[$key]['size'] = $t['size'] . 'B';
+            $data[$key]['compress'] = $t['compress'];
+            $data[$key]['backtime'] = $key;
+            $data[$key]['time'] = $t['time'];
+        }
+        krsort($data);//根据时间降序
+        return Json::result(0, 'sucess', $data, count($data));
+    }
+
+    /**
+     * @param string|null $msg
+     * @param string|null $url
+     * @param array|null $data
+     */
+    public function success(?string $msg = null, ?string $url = null, ?array $data = [])
+    {
+        return Json::success($msg, $data);
+    }
+
+    /**
+     * @param string|null $msg
+     */
+    public function error(?string $msg = null)
+    {
+        return Json::fail($msg);
+    }
+
+    /**
+     * 删除备份记录表
+     */
+    public function delFile()
+    {
+        $feilname = intval(request()->post('feilname'));
+        $files = $this->DB->delFile($feilname);
+        return Json::result(0, 'sucess');
+    }
+
+    /**
+     * 导入备份记录表
+     */
+    public function import()
+    {
+        $part = request()->post('part') != '' ? intval(request()->post('part')) : null;
+        $start = request()->post('start') != '' ? intval(request()->post('start')) : null;
+        $time = intval(request()->post('time'));
+        $db = $this->DB;
+        if (is_numeric($time) && is_null($part) && is_null($start)) {
+            $list = $db->getFile('timeverif', $time);
+            if (is_array($list)) {
+                session::set('backup_list', $list);
+                $this->success('初始化完成!', '', array('part' => 1, 'start' => 0));
+            } else {
+                $this->error('备份文件可能已经损坏,请检查!');
+            }
+        } else if (is_numeric($part) && is_numeric($start)) {
+            $list = session::get('backup_list');
+            $start = $db->setFile($list)->import($start);
+            if (false === $start) {
+                $this->error('还原数据出错!');
+            } elseif (0 === $start) {
+                if (isset($list[++$part])) {
+                    $data = array('part' => $part, 'start' => 0);
+                    $this->success("正在还原...#{$part}", '', $data);
+                } else {
+                    session::delete('backup_list');
+                    $this->success('还原完成!');
+                }
+            } else {
+                $data = array('part' => $part, 'start' => $start[0]);
+                if ($start[1]) {
+                    $rate = floor(100 * ($start[0] / $start[1]));
+                    $this->success("正在还原...#{$part}({$rate}%)", '', $data);
+                } else {
+                    $data['gz'] = 1;
+                    $this->success("正在还原...#{$part}", '', $data);
+                }
+                $this->success("正在还原...#{$part}", '');
+            }
+        } else {
+            $this->error('参数错误!');
+        }
+    }
+
+    /**
+     * 下载备份记录表
+     */
+    public function downloadFile()
+    {
+        $time = intval(request()->param('feilname'));
+        $this->DB->downloadFile($time);
+    }
+}

+ 303 - 0
app/admin/controller/system/SystemFile.php

@@ -0,0 +1,303 @@
+<?php
+
+namespace app\admin\controller\system;
+
+use app\admin\model\system\SystemFile as SystemFileModel;
+use app\admin\controller\AuthController;
+use crmeb\services\FormBuilder as Form;
+use crmeb\services\FileService as FileClass;
+use crmeb\services\JsonService as Json;
+
+/**
+ * 文件校验控制器
+ * Class SystemFile
+ * @package app\admin\controller\system
+ *
+ */
+class SystemFile extends AuthController
+{
+    //打开目录
+    public function opendir($filedir = '')
+    {
+        $fileAll = array('dir' => [], 'file' => []);
+        //根目录
+        $rootdir = app()->getRootPath();
+        //当前目录
+        $request_dir = app('request')->param('dir');
+        //防止查看站点以外的目录
+        if (strpos($request_dir, $rootdir) === false) {
+            $request_dir = $rootdir;
+        }
+        //判断是否是返回上级
+        if (app('request')->param('superior') && !empty($request_dir)) {
+            if (strpos(dirname($request_dir), $rootdir) !== false) {
+                $dir = dirname($request_dir);
+            } else {
+                $dir = $rootdir;
+            }
+
+        } else {
+            $dir = !empty($request_dir) ? $request_dir : $rootdir;
+            $dir = rtrim($dir, DS) . DS . app('request')->param('filedir');
+        }
+        $list = scandir($dir);
+        foreach ($list as $key => $v) {
+            if ($v != '.' && $v != '..') {
+                if (is_dir($dir . DS . $v)) {
+                    $fileAll['dir'][] = FileClass::list_info($dir . DS . $v);
+                }
+                if (is_file($dir . DS . $v)) {
+                    $fileAll['file'][] = FileClass::list_info($dir . DS . $v);
+                }
+            }
+        }
+        //兼容windows
+        $uname = php_uname('s');
+        if (strstr($uname, 'Windows') !== false) $dir = ltrim($dir, '\\');
+        $this->assign(compact('fileAll', 'dir'));
+        return $this->fetch();
+    }
+
+    //读取文件
+    public function openfile($file = '')
+    {
+        $file = $this->request->param('file');
+        if (empty($file)) return Json::fail('出现错误');
+        $filepath = $file;
+        $content = FileClass::read_file($filepath);//防止页面内嵌textarea标签
+        $ext = FileClass::get_ext($filepath);
+        $extarray = [
+            'js' => 'text/javascript'
+            , 'php' => 'text/x-php'
+            , 'html' => 'text/html'
+            , 'sql' => 'text/x-mysql'
+            , 'css' => 'text/x-scss'];
+        $mode = empty($extarray[$ext]) ? '' : $extarray[$ext];
+        $this->assign(compact('content', 'mode', 'filepath'));
+        return $this->fetch();
+    }
+
+    //保存文件
+    public function savefile()
+    {
+        $comment = $this->request->post('comment');
+        $filepath = $this->request->post('filepath');
+        if (!empty($comment) && !empty($filepath)) {
+            //兼容windows
+            $uname = php_uname('s');
+            if (strstr($uname, 'Windows') !== false)
+                $filepath = ltrim(str_replace('/', DS, $filepath), '.');
+            if (FileClass::isWritable($filepath)) {
+                $res = FileClass::write_file($filepath, $comment);
+                if ($res) {
+                    return Json::successful('保存成功!');
+                } else {
+                    return Json::fail('保存失败');
+                }
+            } else {
+                return Json::fail('没有权限!');
+            }
+
+        } else {
+            return Json::fail('出现错误');
+        }
+
+    }
+
+    public function index()
+    {
+        $rootPath = app()->getRootPath();
+        $app = $this->getDir($rootPath . 'app');
+        $extend = $this->getDir($rootPath . 'crmeb');
+        $arr = [];
+        $arr = array_merge($app, $extend);
+        $fileAll = [];//本地文件
+        $cha = [];//不同的文件
+        foreach ($arr as $k => $v) {
+            $fp = fopen($v, 'r');
+            if (filesize($v)) $ct = fread($fp, filesize($v));
+            else $ct = null;
+            fclose($fp);
+            $cthash = md5($ct);
+            $update_time = stat($v);
+            $fileAll[$k]['cthash'] = $cthash;
+            $fileAll[$k]['filename'] = str_replace($rootPath, '', $v);
+            $fileAll[$k]['atime'] = $update_time['atime'];
+            $fileAll[$k]['mtime'] = $update_time['mtime'];
+            $fileAll[$k]['ctime'] = $update_time['ctime'];
+        }
+        $file = SystemFileModel::all(function ($query) {
+            $query->order('atime', 'desc');
+        })->toArray();//数据库中的文件
+        if (empty($file)) {
+            $data_num = array_chunk($fileAll, 10);
+            SystemFileModel::beginTrans();
+            $res = true;
+            foreach ($data_num as $k => $v) {
+                $res = $res && SystemFileModel::insertAll($v);
+            }
+            SystemFileModel::checkTrans($res);
+            if ($res) {
+                $cha = [];//不同的文件
+            } else {
+                $cha = $fileAll;
+            }
+        } else {
+            $cha = [];//差异文件
+            foreach ($file as $k => $v) {
+                foreach ($fileAll as $ko => $vo) {
+                    if ($v['filename'] == $vo['filename']) {
+                        if ($v['cthash'] != $vo['cthash']) {
+                            $cha[$k]['filename'] = str_replace($rootPath, '', $v['filename']);
+                            $cha[$k]['cthash'] = $v['cthash'];
+                            $cha[$k]['atime'] = $v['atime'];
+                            $cha[$k]['mtime'] = $v['mtime'];
+                            $cha[$k]['ctime'] = $v['ctime'];
+                            $cha[$k]['type'] = '已修改';
+                        }
+                        unset($fileAll[$ko]);
+                        unset($file[$k]);
+                    }
+                }
+
+            }
+            foreach ($file as $k => $v) {
+                $cha[$k]['filename'] = str_replace($rootPath, '', $v['filename']);
+                $cha[$k]['cthash'] = $v['cthash'];
+                $cha[$k]['atime'] = $v['atime'];
+                $cha[$k]['mtime'] = $v['mtime'];
+                $cha[$k]['ctime'] = $v['ctime'];
+                $cha[$k]['type'] = '已删除';
+            }
+            foreach ($fileAll as $k => $v) {
+                $cha[$k]['filename'] = str_replace($rootPath, '', $v['filename']);
+                $cha[$k]['cthash'] = $v['cthash'];
+                $cha[$k]['atime'] = $v['atime'];
+                $cha[$k]['mtime'] = $v['mtime'];
+                $cha[$k]['ctime'] = $v['ctime'];
+                $cha[$k]['type'] = '新增的';
+            }
+
+        }
+//   dump($file);
+//   dump($fileAll);
+        $this->assign('cha', $cha);
+        return $this->fetch();
+    }
+
+
+    /**
+     * 获取文件夹中的文件 不包括子文件
+     * @param $dir
+     * @return array
+     */
+    public function getNextDir()
+    {
+        $dir = './';
+        $list = scandir($dir);
+        $dirlist = [];
+        $filelist = [];
+        foreach ($list as $key => $v) {
+            if ($v != '.' && $v != '..') {
+                if (is_dir($dir . '/' . $v)) {
+                    $dirlist['dir'][$key] = $v;
+                }
+                if (is_file($dir . '/' . $v)) {
+                    $filelist['file'][$key] = $v;
+                }
+            }
+        }
+        $filesarr = array_merge($dirlist, $filelist);
+        print_r($filesarr);
+    }
+
+    /**
+     * 获取文件夹中的文件 包括子文件 不能直接用  直接使用  $this->getDir()方法 P156
+     * @param $path
+     * @param $data
+     */
+    public function searchDir($path, &$data)
+    {
+        if (is_dir($path) && !strpos($path, 'uploads')) {
+            $dp = dir($path);
+            while ($file = $dp->read()) {
+                if ($file != '.' && $file != '..') {
+                    $this->searchDir($path . '/' . $file, $data);
+                }
+            }
+            $dp->close();
+        }
+        if (is_file($path)) {
+            $data[] = $path;
+        }
+    }
+
+    /**
+     * 获取文件夹中的文件 包括子文件
+     * @param $dir
+     * @return array
+     */
+    public function getDir($dir)
+    {
+        $data = [];
+        $this->searchDir($dir, $data);
+        return $data;
+    }
+
+    //测试
+    public function ceshi()
+    {
+        //创建form
+        $form = Form::create('/save.php', [
+            Form::input('goods_name', '商品名称')
+            , Form::input('goods_name1', 'password')->type('password')
+            , Form::input('goods_name2', 'textarea')->type('textarea')
+            , Form::input('goods_name3', 'email')->type('email')
+            , Form::input('goods_name4', 'date')->type('date')
+            , Form::city('address', 'cityArea',
+                '陕西省', '西安市'
+            )
+            , Form::dateRange('limit_time', 'dateRange',
+                strtotime('- 10 day'),
+                time()
+            )
+            , Form::dateTime('add_time', 'dateTime')
+            , Form::color('color', 'color', '#ff0000')
+            , Form::checkbox('checkbox', 'checkbox', [1])->options([['value' => 1, 'label' => '白色'], ['value' => 2, 'label' => '红色'], ['value' => 31, 'label' => '黑色']])
+            , Form::date('riqi', 'date', '2018-03-1')
+            , Form::dateTimeRange('dateTimeRange', '区间时间段')
+            , Form::year('year', 'year')
+            , Form::month('month', 'month')
+            , Form::frame('frame', 'frame', '/admin/system.system_attachment/index.html?fodder=frame')
+            , Form::frameInputs('frameInputs', 'frameInputs', '/admin/system.system_attachment/index.html?fodder=frameInputs')
+            , Form::frameFiles('month1', 'frameFiles', '/admin/system.system_attachment/index.html?fodder=month1')
+            , Form::frameImages('fodder1', 'frameImages', '/admin/system.system_attachment/index.html?fodder=fodder1')->maxLength(3)->width('800px')->height('400px')
+            , Form::frameImages('fodder11', 'frameImages', '/admin/system.system_attachment/index.html?fodder=fodder11')->icon('images')
+            , Form::frameInputOne('month3', 'frameInputOne', '/admin/system.system_attachment/index.html?fodder=month3')->icon('ionic')
+            , Form::frameFileOne('month4', 'frameFileOne', '/admin/system.system_attachment/index.html?fodder=month4')
+            , Form::frameImageOne('month5', 'frameImageOne', '/admin/system.system_attachment/index.html?fodder=month5')->icon('image')
+            , Form::hidden('month6', 'hidden')
+            , Form::number('month7', 'number')
+//            ,Form::input input输入框,其他type: text类型Form::text,password类型Form::password,textarea类型Form::textarea,url类型Form::url,email类型Form::email,date类型Form::idate
+            , Form::radio('month8', 'radio')->options([['value' => 1, 'label' => '白色'], ['value' => 2, 'label' => '红色'], ['value' => 31, 'label' => '黑色']])
+            , Form::rate('month9', 'rate')
+            , Form::select('month10', 'select')->options([['value' => 1, 'label' => '白色'], ['value' => 2, 'label' => '红色'], ['value' => 31, 'label' => '黑色']])
+            , Form::selectMultiple('month11', 'selectMultiple')
+            , Form::selectOne('month12', 'selectOne')
+            , Form::slider('month13', 'slider', 2)
+            , Form::sliderRange('month23', 'sliderRange', 2, 13)
+            , Form::switches('month14', '区间时间段')
+            , Form::timePicker('month15', '区间时间段')
+            , Form::time('month16', '区间时间段')
+            , Form::timeRange('month17', '区间时间段')
+//            ,Form::upload('month','区间时间段')
+//            ,Form::uploadImages('month','区间时间段')
+//            ,Form::uploadFiles('month','区间时间段')
+//            ,Form::uploadImageOne('month','区间时间段')
+//            ,Form::uploadFileOne('month','区间时间段')
+
+        ]);
+        $html = $form->setMethod('get')->setTitle('编辑商品')->view();
+        echo $html;
+    }
+}

+ 39 - 0
app/admin/controller/system/SystemLog.php

@@ -0,0 +1,39 @@
+<?php
+
+namespace app\admin\controller\system;
+
+use app\admin\controller\AuthController;
+use app\admin\model\system\SystemAdmin;
+use app\admin\model\system\SystemLog as LogModel;
+use crmeb\services\UtilService as Util;
+
+/**
+ * 管理员操作记录表控制器
+ * Class SystemLog
+ * @package app\admin\controller\system
+ */
+class SystemLog extends AuthController
+{
+    /**
+     * 显示操作记录
+     */
+    public function index()
+    {
+        LogModel::deleteLog();
+        $where = Util::getMore([
+            ['pages', ''],
+            ['path', ''],
+            ['ip', ''],
+            ['admin_id', ''],
+            ['data', ''],
+        ], $this->request);
+        $where['level'] = $this->adminInfo['level'];
+        $this->assign('where', $where);
+        $this->assign('admin', SystemAdmin::getOrdAdmin('id,real_name', $this->adminInfo['level']));
+        $this->assign(LogModel::systemPage($where));
+        return $this->fetch();
+    }
+
+
+}
+

+ 177 - 0
app/admin/controller/system/SystemStore.php

@@ -0,0 +1,177 @@
+<?php
+
+namespace app\admin\controller\system;
+
+use app\admin\controller\AuthController;
+use app\models\system\SystemCity;
+use crmeb\services\CacheService;
+use crmeb\services\JsonService;
+use crmeb\services\JsonService as Json;
+use app\admin\model\system\SystemStore as SystemStoreModel;
+use crmeb\services\UtilService;
+
+/**
+ * 门店管理控制器
+ * Class SystemAttachment
+ * @package app\admin\controller\system
+ *
+ */
+class SystemStore extends AuthController
+{
+
+    /**
+     * 门店列表
+     */
+    public function list()
+    {
+        $where = UtilService::getMore([
+            ['page', 1],
+            ['limit', 20],
+            ['name', ''],
+            ['excel', 0],
+            ['type', $this->request->param('type')]
+        ]);
+        return JsonService::successlayui(SystemStoreModel::getStoreList($where));
+    }
+
+    /**
+     * 门店设置
+     * @return string
+     */
+    public function index()
+    {
+        $type = $this->request->param('type');
+        $show = SystemStoreModel::where('is_show', 1)->where('is_del', 0)->count();//显示中的门店
+        $hide = SystemStoreModel::where('is_show', 0)->count();//隐藏的门店
+        $recycle = SystemStoreModel::where('is_del', 1)->count();//删除的门店
+        if ($type == null) $type = 1;
+        $this->assign(compact('type', 'show', 'hide', 'recycle'));
+        return $this->fetch();
+    }
+
+    /**
+     * 门店添加
+     * @param int $id
+     * @return string
+     */
+    public function add($id = 0)
+    {
+        $store = SystemStoreModel::getStoreDispose($id);
+        $store['slider_image'] = empty($store['slider_image']) ? [] : json_decode($store['slider_image']);
+        $store['images'] = empty($store['images']) ? [] : json_decode($store['images']);
+        $this->assign(compact('store'));
+        return $this->fetch();
+    }
+
+    /**
+     * 删除恢复门店
+     * @param $id
+     */
+    public function delete($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        if (!SystemStoreModel::be(['id' => $id])) return $this->failed('产品数据不存在');
+        if (SystemStoreModel::be(['id' => $id, 'is_del' => 1])) {
+            $data['is_del'] = 0;
+            if (!SystemStoreModel::edit($data, $id))
+                return Json::fail(SystemStoreModel::getErrorInfo('恢复失败,请稍候再试!'));
+            else
+                return Json::successful('恢复门店成功!');
+        } else {
+            $data['is_del'] = 1;
+            if (!SystemStoreModel::edit($data, $id))
+                return Json::fail(SystemStoreModel::getErrorInfo('删除失败,请稍候再试!'));
+            else
+                return Json::successful('删除门店成功!');
+        }
+    }
+
+    /**
+     * 设置单个门店是否显示
+     * @param string $is_show
+     * @param string $id
+     * @return json
+     */
+    public function set_show($is_show = '', $id = '')
+    {
+        ($is_show == '' || $id == '') && JsonService::fail('缺少参数');
+        $res = SystemStoreModel::where(['id' => $id])->update(['is_show' => (int)$is_show]);
+        if ($res) {
+            return JsonService::successful($is_show == 1 ? '设置显示成功' : '设置隐藏成功');
+        } else {
+            return JsonService::fail($is_show == 1 ? '设置显示失败' : '设置隐藏失败');
+        }
+    }
+
+    /**
+     * 位置选择
+     * @return string|void
+     */
+    public function select_address()
+    {
+        $key = sys_config('tengxun_map_key');
+        if (!$key) return $this->failed('请前往设置->物流设置->物流配置 配置腾讯地图KEY', '#');
+        $this->assign(compact('key'));
+        return $this->fetch();
+    }
+
+    /**
+     * 保存修改门店信息
+     * @param int $id
+     */
+    public function save($id = 0)
+    {
+        $data = UtilService::postMore([
+            ['name', ''],
+            ['introduction', ''],
+            ['image', ''],
+            ['phone', ''],
+            ['address', ''],
+            ['detailed_address', ''],
+            ['latlng', ''],
+            ['valid_time', []],
+            ['day_time', []],
+            ['slider_image', []],
+            ['images', []],
+        ]);
+        SystemStoreModel::beginTrans();
+        try {
+            $data['slider_image'] = json_encode($data['slider_image']);
+            $data['images'] = json_encode($data['images']);
+            $data['address'] = implode(',', $data['address']);
+            $data['latlng'] = is_string($data['latlng']) ? explode(',', $data['latlng']) : $data['latlng'];
+            if (!isset($data['latlng'][0]) || !isset($data['latlng'][1])) return JsonService::fail('请选择门店位置');
+            $data['latitude'] = $data['latlng'][0];
+            $data['longitude'] = $data['latlng'][1];
+            $data['valid_time'] = implode(' - ', $data['valid_time']);
+            $data['day_time'] = implode(' - ', $data['day_time']);
+            unset($data['latlng']);
+            if ($data['image'] && strstr($data['image'], 'http') === false) {
+                $site_url = sys_config('site_url');
+                $data['image'] = $site_url . $data['image'];
+            }
+            if ($id) {
+                if (SystemStoreModel::where('id', $id)->update($data)) {
+                    SystemStoreModel::commitTrans();
+                    return JsonService::success('修改成功');
+                } else {
+                    SystemStoreModel::rollbackTrans();
+                    return JsonService::fail('修改失败或者您没有修改什么!');
+                }
+            } else {
+                $data['add_time'] = time();
+                $data['is_show'] = 1;
+                if ($res = SystemStoreModel::create($data)) {
+                    SystemStoreModel::commitTrans();
+                    return JsonService::success('保存成功', ['id' => $res->id]);
+                } else {
+                    SystemStoreModel::rollbackTrans();
+                    return JsonService::fail('保存失败!');
+                }
+            }
+        } catch (\Exception $e) {
+            SystemStoreModel::rollbackTrans();
+            return JsonService::fail($e->getMessage());
+        }
+    }
+}

+ 198 - 0
app/admin/controller/system/SystemStoreStaff.php

@@ -0,0 +1,198 @@
+<?php
+
+namespace app\admin\controller\system;
+
+use app\admin\controller\AuthController;
+use app\admin\model\system\SystemStore as StoreModel;
+use crmeb\services\FormBuilder as Form;
+use crmeb\services\JsonService;
+use crmeb\services\JsonService as Json;
+use app\admin\model\system\SystemStoreStaff as StaffModel;
+use app\admin\model\system\SystemStore;
+use crmeb\services\UtilService;
+use think\facade\Route as Url;
+
+/**
+ * 店员管理
+ * Class StoreStaff
+ * @package app\store_admin\controller\store
+ */
+class SystemStoreStaff extends AuthController
+{
+    /**
+     * 店员列表
+     */
+    public function list()
+    {
+        $where = UtilService::getMore([
+            ['page', 1],
+            ['limit', 20],
+            ['name', ''],
+            ['store_id', '']
+        ]);
+        return JsonService::successlayui(StaffModel::lst($where));
+    }
+
+    /**
+     * 门店设置
+     * @return string
+     */
+    public function index()
+    {
+        $store_list = StoreModel::dropList();
+        $this->assign('store_list', $store_list);
+        return $this->fetch();
+    }
+
+    /**
+     * 店员添加
+     * @param int $id
+     * @return string
+     */
+    public function create()
+    {
+        $field = [
+            Form::frameImageOne('image', '商城用户', Url::buildUrl('admin/system.SystemStoreStaff/select', array('fodder' => 'image')))->icon('plus')->width('100%')->height('500px'),
+            Form::hidden('uid', 0),
+            Form::hidden('avatar', ''),
+            Form::select('store_id', '所属门店')->setOptions(function () {
+                $list = SystemStore::dropList();
+//                $menus[] = ['value' => 0, 'label' => '顶级分类'];
+                $menus = [];
+                foreach ($list as $menu) {
+                    $menus[] = ['value' => $menu['id'], 'label' => $menu['name']];
+                }
+                return $menus;
+            })->filterable(1),
+            Form::input('staff_name', '店员名称')->col(Form::col(24)),
+            Form::input('phone', '手机号码')->col(Form::col(24)),
+            Form::radio('verify_status', '核销开关', 1)->options([['value' => 1, 'label' => '开启'], ['value' => 0, 'label' => '关闭']]),
+            Form::radio('status', '状态', 1)->options([['value' => 1, 'label' => '开启'], ['value' => 0, 'label' => '关闭']])
+        ];
+        $form = Form::make_post_form('添加评论', $field, Url::buildUrl('save'), 2);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 选择用户
+     * @param int $id
+     */
+    public function select()
+    {
+        return $this->fetch();
+    }
+
+    /**
+     * 编辑表单
+     * @param $id
+     * @return string|void
+     * @throws \FormBuilder\exception\FormBuilderException
+     */
+    public function edit($id)
+    {
+        $service = StaffModel::get($id);
+        if (!$service) return Json::fail('数据不存在!');
+        $f = [
+            Form::frameImageOne('image', '商城用户', Url::buildUrl('admin/system.SystemStoreStaff/select', array('fodder' => 'image')), $service['avatar'])->icon('plus')->width('100%')->height('500px'),
+            Form::hidden('uid', $service['uid']),
+            Form::hidden('avatar', $service['avatar']),
+            Form::select('store_id', '所属门店', (string)$service->getData('store_id'))->setOptions(function () {
+                $list = SystemStore::dropList();
+//                $menus[] = ['value' => 0, 'label' => '顶级分类'];
+                foreach ($list as $menu) {
+                    $menus[] = ['value' => $menu['id'], 'label' => $menu['name']];
+                }
+                return $menus;
+            })->filterable(1),
+            Form::input('staff_name', '店员名称', $service['staff_name'])->col(Form::col(24)),
+            Form::input('phone', '手机号码', $service['phone'])->col(Form::col(24)),
+            Form::radio('verify_status', '核销开关', $service['verify_status'])->options([['value' => 1, 'label' => '开启'], ['value' => 0, 'label' => '关闭']]),
+            Form::radio('status', '状态', $service['status'])->options([['value' => 1, 'label' => '开启'], ['value' => 0, 'label' => '关闭']])
+        ];
+
+        $form = Form::make_post_form('修改数据', $f, Url::buildUrl('save', compact('id')));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 删除店员
+     * @param $id
+     */
+    public function delete($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        if (!StaffModel::be(['id' => $id])) return $this->failed('数据不存在');
+        if (!StaffModel::del($id))
+            return Json::fail(StaffModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+
+    /**
+     * 设置单个店员是否开启
+     * @param string $is_show
+     * @param string $id
+     * @return json
+     */
+    public function set_show($is_show = '', $id = '')
+    {
+        ($is_show == '' || $id == '') && JsonService::fail('缺少参数');
+        $res = StaffModel::where(['id' => $id])->update(['status' => (int)$is_show]);
+        if ($res) {
+            return JsonService::successful($is_show == 1 ? '开启成功' : '关闭成功');
+        } else {
+            return JsonService::fail($is_show == 1 ? '开启失败' : '关闭失败');
+        }
+    }
+
+    /**
+     * 保存店员信息
+     */
+    public function save($id = 0)
+    {
+        $data = UtilService::postMore([
+            ['uid', 0],
+            ['avatar', ''],
+            ['store_id', ''],
+            ['staff_name', ''],
+            ['phone', ''],
+            ['verify_status', 1],
+            ['status', 1],
+        ]);
+        if (!$id) {
+            if (StaffModel::where('uid', $data['uid'])->count()) return Json::fail('添加的店员用户已存在!');
+        }
+        if ($data['uid'] == 0) return Json::fail('请选择用户');
+        if ($data['store_id'] == '') return Json::fail('请选择所属门店');
+        if ($id) {
+            $res = StaffModel::edit($data, $id);
+            if ($res) {
+                return Json::successful('编辑成功');
+            } else {
+                return Json::fail('编辑失败');
+            }
+        } else {
+            $data['add_time'] = time();
+            $res = StaffModel::create($data);
+            if ($res) {
+                return Json::successful('店员添加成功');
+            } else {
+                return Json::fail('店员添加失败,请稍后再试');
+            }
+        }
+    }
+
+    /**
+     * 获取user表
+     * @param int $page
+     * @param int $limit
+     * @param string $nickname
+     */
+    public function get_user_list($page = 0, $limit = 10, $nickname = '')
+    {
+        return Json::successlayui(StaffModel::getUserList($page, $limit, $nickname));
+    }
+
+}

+ 377 - 0
app/admin/controller/system/SystemUpgradeclient.php

@@ -0,0 +1,377 @@
+<?php
+
+namespace app\admin\controller\system;
+
+use app\admin\controller\AuthController;
+use crmeb\services\JsonService as Json;
+use crmeb\services\MysqlBackupService;
+use crmeb\services\UpgradeService as uService;
+use think\facade\Db;
+
+/**
+ * 在线升级控制器
+ * Class SystemUpgradeclient
+ * @package app\admin\controller\system
+ *
+ */
+class SystemUpgradeclient extends AuthController
+{
+
+    protected $serverweb = array('version' => '1.0', 'version_code' => 0);//本站点信息
+
+    public function initialize()
+    {
+        parent::initialize();
+        //屏蔽所有错误避免操作文件夹发生错误提示
+        ini_set('display_errors', 0);
+        error_reporting(0);
+        self::snyweninfo();//更新站点信息
+        $this->assign(['auth' => self::isauth(), 'app' => uService::isWritable(app()->getRootPath()), 'extend' => uService::isWritable(EXTEND_PATH), 'public' => uService::isWritable(app()->getRootPath() . 'public')]);
+    }
+
+    //同步更新站点信息
+    public function snyweninfo()
+    {
+        $this->serverweb['ip'] = $this->request->ip();
+        $this->serverweb['host'] = $this->request->host();
+        $this->serverweb['https'] = !empty($this->request->domain()) ? $this->request->domain() : sys_config('site_url');
+        $this->serverweb['webname'] = sys_config('site_name');
+        $local = uService::getVersion();
+        if ($local['code'] == 200 && isset($local['msg']['version']) && isset($local['msg']['version_code'])) {
+            $this->serverweb['version'] = uService::replace($local['msg']['version']);
+            $this->serverweb['version_code'] = (int)uService::replace($local['msg']['version_code']);
+        }
+        uService::snyweninfo($this->serverweb);
+    }
+
+    //是否授权
+    public function isauth()
+    {
+        return uService::isauth();
+    }
+
+    public function index()
+    {
+        $server = uService::start();
+        $version = $this->serverweb['version'];
+        $version_code = $this->serverweb['version_code'];
+        $this->assign(compact('server', 'version', 'version_code'));
+        return $this->fetch();
+    }
+
+    public function get_list()
+    {
+        $list = uService::request_post(uService::$isList, ['page' => input('post.page/d'), 'limit' => input('post.limit/d')]);
+        if (is_array($list) && isset($list['code']) && isset($list['data']) && $list['code'] == 200) {
+            $list = $list['data'];
+        } else {
+            $list = [];
+        }
+        Json::successful('ok', ['list' => $list, 'page' => input('post.page/d') + 1]);
+    }
+
+    //删除备份文件
+    public function setcopydel()
+    {
+        $post = input('post.');
+        if (!isset($post['id'])) Json::fail('删除备份文件失败,缺少参数ID');
+        if (!isset($post['ids'])) Json::fail('删除备份文件失败,缺少参数IDS');
+        $fileservice = new uService;
+        if (is_array($post['ids'])) {
+            foreach ($post['ids'] as $file) {
+                $fileservice->del_dir(app()->getRootPath() . 'public' . DS . 'copyfile' . $file);
+            }
+        }
+        if ($post['id']) {
+            $copyFile = app()->getRootPath() . 'public' . DS . 'copyfile' . $post['id'];
+            $fileservice->del_dir($copyFile);
+        }
+        Json::successful('删除成功');
+    }
+
+    public function get_new_version_conte()
+    {
+        $post = $this->request->post();
+        if (!isset($post['id'])) Json::fail('缺少参数ID');
+        $versionInfo = uService::request_post(uService::$NewVersionCount, ['id' => $post['id']]);
+        if (isset($versionInfo['code']) && isset($versionInfo['data']['count']) && $versionInfo['code'] == 200) {
+            return Json::successful(['count' => $versionInfo['data']['count']]);
+        } else {
+            return Json::fail('服务器异常');
+        }
+    }
+
+    //一键升级
+    public function auto_upgrad()
+    {
+        $prefix = config('database.prefix');
+        $fileservice = new uService;
+        $post = $this->request->post();
+        if (!isset($post['id'])) Json::fail('缺少参数ID');
+        $versionInfo = $fileservice->request_post(uService::$isNowVersion, ['id' => $post['id']]);
+        if ($versionInfo === null) Json::fail('服务器异常,请稍后再试');
+        if (isset($versionInfo['code']) && $versionInfo['code'] == 400) Json::fail(isset($versionInfo['msg']) ? $versionInfo['msg'] : '您暂时没有权限升级,请联系管理员!');
+        if (is_array($versionInfo) && isset($versionInfo['data'])) {
+            $list = $versionInfo['data'];
+            $id = [];
+            foreach ($list as $key => $val) {
+                $savefile = app()->getRootPath() . 'public' . DS . 'upgrade_lv';
+                //1,检查远程下载文件,并下载
+                if (($save_path = $fileservice->check_remote_file_exists($val['zip_name'], $savefile)) === false) Json::fail('远程升级包不存在');
+                //2,首先解压文件
+                $savename = app()->getRootPath() . 'public' . DS . 'upgrade_lv' . DS . time();
+                $fileservice->zipopen($save_path, $savename);
+                //3,执行SQL文件
+                Db::startTrans();
+                try {
+                    //参数3不介意大小写的
+                    $sqlfile = $fileservice->list_dir_info($savename . DS, true, 'sql');
+                    if (is_array($sqlfile) && !empty($sqlfile)) {
+                        foreach ($sqlfile as $file) {
+                            if (file_exists($file)) {
+                                //为一键安装做工作记得表前缀要改为[#DB_PREFIX#]哦
+                                $execute_sql = explode(";\r", str_replace(['[#DB_PREFIX#]', "\n"], [$prefix, "\r"], file_get_contents($file)));
+                                foreach ($execute_sql as $_sql) {
+                                    if ($query_string = trim(str_replace(array(
+                                        "\r",
+                                        "\n",
+                                        "\t"
+                                    ), '', $_sql))) Db::execute($query_string);
+                                }
+                                //执行完sql记得删掉哦
+                                $fileservice->unlink_file($file);
+                            }
+                        }
+                    }
+                    Db::commit();
+                } catch (\Exception $e) {
+                    Db::rollback();
+                    //删除解压下的文件
+                    $fileservice->del_dir(app()->getRootPath() . 'public' . DS . 'upgrade_lv');
+                    //删除压缩包
+                    $fileservice->unlink_file($save_path);
+                    //升级失败发送错误信息
+                    $fileservice->request_post(uService::$isInsertLog, [
+                        'content' => '升级失败,错误信息为:' . $e->getMessage(),
+                        'add_time' => time(),
+                        'ip' => $this->request->ip(),
+                        'http' => $this->request->domain(),
+                        'type' => 'error',
+                        'version' => $val['version']
+                    ]);
+                    return Json::fail('升级失败SQL文件执行有误');
+                }
+                //4,备份文件
+                $copyFile = app()->getRootPath() . 'public' . DS . 'copyfile' . $val['id'];
+                $copyList = $fileservice->get_dirs($savename . DS);
+                if (isset($copyList['dir'])) {
+                    if ($copyList['dir'][0] == '.' && $copyList['dir'][1] == '..') {
+                        array_shift($copyList['dir']);
+                        array_shift($copyList['dir']);
+                    }
+                    foreach ($copyList['dir'] as $dir) {
+                        if (file_exists(app()->getRootPath() . $dir, $copyFile . DS . $dir)) {
+                            $fileservice->copy_dir(app()->getRootPath() . $dir, $copyFile . DS . $dir);
+                        }
+                    }
+                }
+                //5,覆盖文件
+                $fileservice->handle_dir($savename, app()->getRootPath());
+                //6,删除升级生成的目录
+                $fileservice->del_dir(app()->getRootPath() . 'public' . DS . 'upgrade_lv');
+                //7,删除压缩包
+                $fileservice->unlink_file($save_path);
+                //8,改写本地升级文件
+                $handle = fopen(app()->getRootPath() . '.version', 'w+');
+                if ($handle === false) Json::fail(app()->getRootPath() . '.version' . '无法写入打开');
+                $content = <<<EOT
+version={$val['version']}
+version_code={$val['id']}
+EOT;
+                if (fwrite($handle, $content) === false) Json::fail('升级包写入失败');
+                fclose($handle);
+                //9,向服务端发送升级日志
+                $posts = [
+                    'ip' => $this->request->ip(),
+                    'https' => $this->request->domain(),
+                    'update_time' => time(),
+                    'content' => '一键升级成功,升级版本号为:' . $val['version'] . '。版本code为:' . $val['id'],
+                    'type' => 'log',
+                    'versionbefor' => $this->serverweb['version'],
+                    'versionend' => $val['version']
+                ];
+                $inset = $fileservice->request_post(uService::$isInsertLog, $posts);
+                $id[] = $val['id'];
+            }
+            //10,升级完成
+            Json::successful('升级成功', ['code' => end($id), 'version' => $val['version']]);
+        } else {
+            Json::fail('服务器异常,请稍后再试');
+        }
+    }
+
+    //在线升级
+    public function online_upgrad()
+    {
+        $prefix = config('database.prefix');
+        $fileservice = new uService;
+        $post = $this->request->post();
+        if (!isset($post['id'])) Json::fail('缺少参数ID');
+        //获取升级列表
+        $versionInfo = $fileservice->request_post(uService::$isNowVersion, ['id' => 18]);
+        if ($versionInfo === null) Json::fail('服务器异常,请稍后再试');
+        //检测授权
+        if(!$fileservice->isauth()) Json::fail('请先去授权后在升级');
+        if (isset($versionInfo['code']) && $versionInfo['code'] == 400) Json::fail(isset($versionInfo['msg']) ? $versionInfo['msg'] : '您暂时没有权限升级,请联系管理员!');
+        if(!is_array($versionInfo) || !isset($versionInfo['data'])) Json::fail('服务器异常,请稍后再试');
+        $rootpath = app()->getRootPath();
+        $list = $versionInfo['data'];
+        $id = [];
+        $savefile = $rootpath . 'public' . DS . 'upgrade_lv';
+        foreach ($list as $key => $val) {
+
+            //1,检查远程下载文件,并下载
+            if (($save_path = $fileservice->check_remote_file_exists($val['zip_name'], $savefile)) === false) Json::fail('远程升级包不存在');
+            //2,首先解压文件
+            $savename = $rootpath . 'public' . DS . 'upgrade_lv' . DS . time();
+            $fileservice->zipopen($save_path, $savename);
+        }
+        //3,备份文件
+        $saveDir = $rootpath . 'backup\\'.date('Ymd',time()).'\\';
+        $filepath = $saveDir . 'crmeb_'.time().'.zip';
+        $zip = new \ZipArchive();
+        if(!$zip->open($filepath,\ZIPARCHIVE::CREATE))
+        {
+            Json::fail("创建[$filepath]失败");
+        }
+        try{
+            $this->createZip($rootpath,$zip);
+        }catch (\think\Exception $e){
+            $message  = '[异常时间]: '. date('Y-m-d H:i:s') . PHP_EOL;
+            $message .= '[异常消息]: '. $e->getMessage() . PHP_EOL;
+            $message .= '[异常文件]: '. $e->getFile() . PHP_EOL;
+            $message .= '[异常行数]: '. $e->getLine() . PHP_EOL;
+            Json::fail($message);
+        }
+        $zip->close();
+        //4 备份sql
+        if(!$this->backupSql($saveDir)){
+            Json::fail('备份数据库失败');
+        }
+        //5 执行SQL文件
+        Db::startTrans();
+        try {
+            //参数3不介意大小写的
+            $sqlfile = $fileservice->list_dir_info($savename . DS, true, 'sql');
+            if (is_array($sqlfile) && !empty($sqlfile)) {
+                foreach ($sqlfile as $file) {
+                    if (file_exists($file)) {
+                        //为一键安装做工作记得表前缀要改为[#DB_PREFIX#]哦
+                        $execute_sql = explode(";\r", str_replace(['[#DB_PREFIX#]', "\n"], [$prefix, "\r"], file_get_contents($file)));
+                        foreach ($execute_sql as $_sql) {
+                            if ($query_string = trim(str_replace(array(
+                                "\r",
+                                "\n",
+                                "\t"
+                            ), '', $_sql))) Db::execute($query_string);
+                        }
+                        //执行完sql记得删掉哦
+                        $fileservice->unlink_file($file);
+                    }
+                }
+            }
+            Db::commit();
+        } catch (\Exception $e) {
+            Db::rollback();
+            //删除解压下的文件
+            $fileservice->del_dir(app()->getRootPath() . 'public' . DS . 'upgrade_lv');
+            //删除压缩包
+            $fileservice->unlink_file($save_path);
+            //升级失败发送错误信息
+            $fileservice->request_post(uService::$isInsertLog, [
+                'content' => '升级失败,错误信息为:' . $e->getMessage(),
+                'add_time' => time(),
+                'ip' => $this->request->ip(),
+                'http' => $this->request->domain(),
+                'type' => 'error',
+                'version' => $val['version']
+            ]);
+            return Json::fail('升级失败SQL文件执行有误');
+        }
+
+        //6 覆盖文件
+        $fileservice->handle_dir($savename, app()->getRootPath());
+        //7 删除升级生成的目录
+        $fileservice->del_dir(app()->getRootPath() . 'public' . DS . 'upgrade_lv');
+        //8 删除压缩包
+        $fileservice->unlink_file($save_path);
+        //9 改写本地升级文件
+        $handle = fopen(app()->getRootPath() . '.version', 'w+');
+        if ($handle === false) Json::fail(app()->getRootPath() . '.version' . '无法写入打开');
+        $content = <<<EOT
+version={$val['version']}
+version_code={$val['id']}
+EOT;
+        if (fwrite($handle, $content) === false) Json::fail('升级包写入失败');
+        fclose($handle);
+        //10 向服务端发送升级日志
+        $posts = [
+            'ip' => $this->request->ip(),
+            'https' => $this->request->domain(),
+            'update_time' => time(),
+            'content' => '一键升级成功,升级版本号为:' . $val['version'] . '。版本code为:' . $val['id'],
+            'type' => 'log',
+            'versionbefor' => $this->serverweb['version'],
+            'versionend' => $val['version']
+        ];
+        $inset = $fileservice->request_post(uService::$isInsertLog, $posts);
+        $id[] = $val['id'];
+
+        //11 升级完成
+        Json::successful('升级成功', ['code' => end($id), 'version' => $val['version']]);
+
+    }
+    //备份sql
+    public function backupSql($saveDir)
+    {
+        $config = array(
+            'path'=>$saveDir,
+            //数据库备份卷大小
+            'compress' => 1,
+            //数据库备份文件是否启用压缩 0不压缩 1 压缩
+            'level' => 5,
+        );
+        $back = new MysqlBackupService($config);
+        $list = $back->dataList(null);
+        $tables = array_column($list,'name');
+        $back->setFile(['name'=>'crmeb','part'=>time()]);
+        $data = '';
+        foreach ($tables as $t) {
+            $res = $back->backup($t, 0);
+            if ($res == false && $res != 0) {
+                $data .= $t . '|';
+            }
+        }
+        return $data ? false : true;
+    }
+    //创建zip
+    private function createZip($dir,$zipObj)
+    {
+        $dir_source = opendir($dir);
+        while(($file = readdir($dir_source)) != false)
+        {
+            if($file=="." || $file==".." ) continue;
+
+            $sub_file = $dir.'/'.$file;
+            if(is_dir($sub_file) && $file != 'backup' && $file != 'runtime' && $file = 'uploads')
+            {
+                $zipObj->addEmptyDir($sub_file);
+                $this->createZip($sub_file,$zipObj);
+            }
+            if(is_file($sub_file))
+            {
+                $zipObj->addFile($sub_file);
+            }
+        }
+    }
+}

+ 88 - 0
app/admin/controller/system/SystemVerifyOrder.php

@@ -0,0 +1,88 @@
+<?php
+/**
+ *
+ * @author: xaboy<365615158@qq.com>
+ * @day: 2017/11/11
+ */
+
+namespace app\admin\controller\system;
+
+use app\admin\controller\AuthController;
+use crmeb\services\{
+    UtilService as Util,
+    JsonService as Json
+};
+use app\admin\model\system\SystemVerifyOrder as VerifyOrderModel;
+use app\admin\model\system\SystemStore as StoreModel;
+
+/**
+ * 核销订单管理控制器
+ * Class SystemVerifyOrder
+ * @package app\admin\controller\system
+ */
+class SystemVerifyOrder extends AuthController
+{
+    /**
+     * @return mixed
+     */
+    public function index()
+    {
+        $this->assign([
+            'year' => get_month(),
+            'real_name' => $this->request->get('real_name', ''),
+            'store_list' => StoreModel::dropList()
+        ]);
+        return $this->fetch();
+    }
+
+    /**
+     * 获取头部订单金额等信息
+     * return json
+     */
+    public function getBadge()
+    {
+        $where = Util::postMore([
+            ['status', ''],
+            ['real_name', ''],
+            ['is_del', 0],
+            ['data', ''],
+            ['store_id', ''],
+            ['order', '']
+        ]);
+        return Json::successful(VerifyOrderModel::getBadge($where));
+    }
+
+    /**
+     * 获取订单列表
+     * return json
+     */
+    public function order_list()
+    {
+        $where = Util::getMore([
+            ['real_name', $this->request->param('real_name', '')],
+            ['is_del', 0],
+            ['data', ''],
+            ['store_id', ''],
+            ['page', 1],
+            ['limit', 20],
+        ]);
+        return Json::successlayui(VerifyOrderModel::OrderList($where));
+    }
+
+    /**
+     * 删除订单
+     * */
+    public function del_order()
+    {
+        $ids = Util::postMore(['ids'])['ids'];
+        if (!count($ids)) return Json::fail('请选择需要删除的订单');
+        if (VerifyOrderModel::where('is_del', 0)->where('id', 'in', $ids)->count())
+            return Json::fail('您选择的的订单存在用户未删除的订单,无法删除用户未删除的订单');
+        $res = VerifyOrderModel::where('id', 'in', $ids)->update(['is_system_del' => 1]);
+        if ($res)
+            return Json::successful('删除成功');
+        else
+            return Json::fail('删除失败');
+    }
+
+}

+ 522 - 0
app/admin/controller/ump/StoreBargain.php

@@ -0,0 +1,522 @@
+<?php
+/**
+ * Created by PhpStorm.
+ * User: Administrator
+ * Date: 2018/4/16 0016
+ * Time: 10:39
+ */
+
+namespace app\admin\controller\ump;
+
+use app\admin\controller\AuthController;
+use app\admin\model\store\{StoreCategory,
+    StoreDescription,
+    StoreProductAttr,
+    StoreProductAttrResult,
+    StoreProduct as ProductModel,
+    StoreProductAttrValue
+};
+use crmeb\traits\CurdControllerTrait;
+use think\facade\Route as Url;
+use app\admin\model\system\{SystemAttachment, ShippingTemplates};
+use app\admin\model\ump\StoreBargain as StoreBargainModel;
+use crmeb\services\{UtilService as Util, FormBuilder as Form, JsonService as Json};
+
+//砍价
+class StoreBargain extends AuthController
+{
+    use CurdControllerTrait;
+
+    protected $bindModel = StoreBargainModel::class;
+
+    /**
+     * 显示资源列表
+     *
+     * @return \think\Response
+     */
+    public function index()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['store_name', ''],
+            ['export', 0],
+            ['data', ''],
+        ], $this->request);
+        $limitTimeList = [
+            'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
+            'week' => implode(' - ', [
+                date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
+                date('Y/m/d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
+            ]),
+            'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
+            'quarter' => implode(' - ', [
+                date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
+                date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
+            ]),
+            'year' => implode(' - ', [
+                date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
+            ])
+        ];
+        $this->assign('where', $where);
+        $this->assign('countBargain', StoreBargainModel::getCountBargain());
+        $this->assign('limitTimeList', $limitTimeList);
+        $this->assign(StoreBargainModel::systemPage($where));
+        $this->assign('bargainId', StoreBargainModel::getBargainIdAll($where));
+        return $this->fetch();
+    }
+
+    /**
+     * 异步获取砍价数据
+     */
+    public function get_bargain_list()
+    {
+        $where = Util::getMore([
+            ['page', 1],
+            ['limit', 20],
+            ['export', 0],
+            ['store_name', ''],
+            ['status', ''],
+            ['data', '']
+        ]);
+        $bargainList = StoreBargainModel::systemPage($where);
+        if (is_object($bargainList['list'])) $bargainList['list'] = $bargainList['list']->toArray();
+        $data = $bargainList['list']['data'];
+        foreach ($data as $k => $v) {
+            $data[$k]['_stop_time'] = date('Y/m/d H:i:s', $v['stop_time']);
+        }
+        return Json::successlayui(['count' => $bargainList['list']['total'], 'data' => $data]);
+    }
+
+
+    /**
+     * 添加砍价
+     * @param int $id
+     * @return \think\Response
+     */
+    public function create()
+    {
+        $f = [];
+        $f[] = Form::frameImageOne('product', '选择商品', Url::buildUrl('productList', array('fodder' => 'product')))->icon('plus')->width('100%')->height('500px');
+        $f[] = Form::hidden('product_id', '');
+        $f[] = Form::input('title', '砍价活动名称');
+        $f[] = Form::input('info', '砍价活动简介')->type('textarea');
+        $f[] = Form::input('unit_name', '单位')->placeholder('个、位');
+        $f[] = Form::select('temp_id', '砍价运费模板')->setOptions(function () {
+            $list = ShippingTemplates::getList(['page' => 1, 'limit' => 20]);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['name']];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::dateTimeRange('section_time', '活动时间');//->format("yyyy-MM-dd HH:mm:ss");
+        $f[] = Form::frameImageOne('image', '商品主图片(305*305px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')))->icon('image')->width('100%')->height('500px');
+        $f[] = Form::frameImages('images', '商品轮播图(640*640px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'images')))->maxLength(5)->icon('images')->width('100%')->height('500px');
+        $f[] = Form::number('bargain_max_price', '单次砍价的最大金额', 10)->min(0)->col(12);
+        $f[] = Form::number('bargain_min_price', '单次砍价的最小金额', 0.01)->min(0)->col(12);
+        $f[] = Form::number('sort', '排序')->col(12);
+        $f[] = Form::number('give_integral', '赠送积分')->min(0)->col(12);
+        $f[] = Form::radio('is_hot', '热门推荐', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        $form = Form::make_post_form('开启砍价活动', $f, Url::buildUrl('update'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 显示编辑资源表单页.
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function edit($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreBargainModel::get($id);
+        if (!$product) return $this->failed('数据不存在!');
+        $f = [];
+        $f[] = Form::input('product_id', '产品ID', $product->getData('product_id'))->disabled(true);
+        $f[] = Form::input('title', '砍价活动名称', $product->getData('title'));
+        $f[] = Form::input('info', '砍价活动简介', $product->getData('info'))->type('textarea');
+        $f[] = Form::input('unit_name', '单位', $product->getData('unit_name'))->placeholder('个、位');
+        $f[] = Form::select('temp_id', '砍价运费模板', (string)$product->getData('temp_id'))->setOptions(function () {
+            $list = ShippingTemplates::getList(['page' => 1, 'limit' => 20]);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['name']];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::dateTimeRange('section_time', '活动时间', date("Y-m-d H:i:s", $product->getData('start_time')), date("Y-m-d H:i:s", $product->getData('stop_time')));//->format("yyyy-MM-dd HH:mm:ss");
+        $f[] = Form::frameImageOne('image', '商品主图片(305*305px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')), $product->getData('image'))->icon('image')->width('100%')->height('500px');
+        $f[] = Form::frameImages('images', '商品轮播图(640*640px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'images')), json_decode($product->getData('images'), 1))->maxLength(5)->icon('images')->width('100%')->height('500px');
+        $f[] = Form::number('bargain_max_price', '单次砍价的最大金额', $product->getData('bargain_max_price'))->min(0)->col(12);
+        $f[] = Form::number('bargain_min_price', '单次砍价的最小金额', $product->getData('bargain_min_price'))->min(0)->col(12);
+        $f[] = Form::hidden('stock', $product->getData('stock'));
+        $f[] = Form::hidden('sales', $product->getData('sales'));
+        $f[] = Form::number('sort', '排序', $product->getData('sort'))->col(12);
+        $f[] = Form::number('give_integral', '赠送积分', $product->getData('give_integral'))->min(0)->col(12);
+        $f[] = Form::radio('is_hot', '热门推荐', $product->getData('is_hot'))->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        $f[] = Form::hidden('status', $product->getData('status'));
+        $form = Form::make_post_form('添加用户通知', $f, Url::buildUrl('update', array('id' => $id)));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存更新的资源
+     * @param string $id
+     */
+    public function update($id = '')
+    {
+        $data = Util::postMore([
+            ['title', ''],
+            ['info', ''],
+            ['store_name', ''],
+            ['unit_name', ''],
+            ['section_time', []],
+            ['image', ''],
+            ['images', []],
+            ['price', 0],
+            ['min_price', 0],
+            ['bargain_max_price', 0],
+            ['bargain_min_price', 0],
+            ['cost', 0],
+            ['bargain_num', 1],
+            ['stock', 0],
+            ['sales', 0],
+            ['sort', 0],
+            ['num', 1],
+            ['give_integral', 0],
+            ['postage', 0],
+            ['is_postage', 0],
+            ['is_hot', 0],
+            ['status', 0],
+            ['product_id', 0],
+            ['temp_id', ''],
+            ['weight', ''],
+            ['volume', ''],
+        ]);
+        $data['description'] = StoreDescription::getDescription($data['product_id']);
+        $data['store_name'] = $data['title'];
+        if ($data['title'] == '') return Json::fail('请输入砍价活动名称');
+        if ($data['info'] == '') return Json::fail('请输入砍价活动简介');
+        if ($data['store_name'] == '') return Json::fail('请输入砍价商品名称');
+        if ($data['unit_name'] == '') return Json::fail('请输入商品单位');
+        if (count($data['section_time']) < 1) return Json::fail('请选择活动时间');
+        if (!$data['section_time'][0]) return Json::fail('请选择活动时间');
+        if (!$data['section_time'][1]) return Json::fail('请选择活动时间');
+        $data['start_time'] = strtotime($data['section_time'][0]);
+        $data['stop_time'] = strtotime($data['section_time'][1]);
+        unset($data['section_time']);
+        if (!($data['image'])) return Json::fail('请选择推荐图');
+        if (count($data['images']) < 1) return Json::fail('请选择轮播图');
+        $data['images'] = json_encode($data['images']);
+        if ($data['bargain_max_price'] == '' || $data['bargain_max_price'] < 0) return Json::fail('请输入用户单次砍价的最大金额');
+        if ($data['bargain_min_price'] == '' || $data['bargain_min_price'] < 0) return Json::fail('请输入用户单次砍价的最小金额');
+        if ($data['bargain_num'] == '' || $data['bargain_num'] < 0) return Json::fail('请输入用户单次砍价的次数');
+        if ($data['num'] == '' || $data['num'] < 0) return Json::fail('请输入单次购买的砍价商品数量');
+        unset($data['img']);
+        if ($id) {
+            $product = StoreBargainModel::get($id);
+            if (!$product) return Json::fail('数据不存在!');
+            unset($data['price'], $data['min_price']);
+            $res = StoreBargainModel::edit($data, $id);
+            if ($res) return Json::successful('修改成功');
+            else return Json::fail('修改失败');
+        } else {
+            $data['add_time'] = time();
+            $res = StoreBargainModel::create($data);
+            $description['product_id'] = $res['id'];
+            $description['description'] = htmlspecialchars_decode($data['description']);
+            $description['type'] = 2;
+            StoreDescription::create($description);
+            if ($res) return Json::successful('添加成功');
+            else return Json::fail('添加成功');
+        }
+
+
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function delete($id)
+    {
+        if (!$id) return Json::fail('数据不存在');
+        $product = StoreBargainModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['is_del']) return Json::fail('已删除!');
+        $data['is_del'] = 1;
+        if (StoreBargainModel::edit($data, $id))
+            return Json::successful('删除成功!');
+        else
+            return Json::fail(StoreBargainModel::getErrorInfo('删除失败,请稍候再试!'));
+    }
+
+    /**
+     * 显示内容窗口
+     * @param $id
+     * @return mixed|\think\response\Json|void
+     */
+    public function edit_content($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $seckill = StoreBargainModel::get($id);
+        if (!$seckill) return $this->failed('数据不存在');
+        $this->assign([
+            'content' => htmlspecialchars_decode(StoreDescription::getDescription($id, 2)),
+            'field' => 'description',
+            'action' => Url::buildUrl('change_field', ['id' => $id, 'field' => 'description'])
+        ]);
+        return $this->fetch('public/edit_content');
+    }
+
+    public function change_field($id, $field)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $bargain = StoreBargainModel::get($id);
+        if (!$bargain) return Json::fail('数据不存在!');
+        if ($field == 'rule') {
+            $data['rule'] = request()->post('rule');
+        } else {
+            $data['description'] = request()->post('description');
+            StoreDescription::saveDescription($data['description'], $id, 2);
+        }
+        $res = StoreBargainModel::edit($data, $id);
+        if ($res)
+            return Json::successful('添加成功');
+        else
+            return Json::fail('添加失败');
+    }
+
+    public function edit_rule($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $seckill = StoreBargainModel::get($id);
+        if (!$seckill) return $this->failed('数据不存在');
+        $this->assign([
+            'content' => htmlspecialchars_decode(StoreBargainModel::where('id', $id)->value('rule')),
+            'field' => 'rule',
+            'action' => Url::buildUrl('change_field', ['id' => $id, 'field' => 'rule'])
+        ]);
+        return $this->fetch('public/edit_content');
+    }
+
+    /**
+     * 开启砍价商品
+     * @param int $id
+     * @return mixed|\think\response\Json|void
+     */
+    public function bargain($id = 0)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = ProductModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $f = [];
+        $f[] = Form::input('title', '砍价活动名称');
+        $f[] = Form::input('info', '砍价活动简介')->type('textarea');
+        $f[] = Form::hidden('product_id', $product->getData('id'));
+        $f[] = Form::input('store_name', '砍价商品名称', $product->getData('store_name'));
+        $f[] = Form::input('unit_name', '单位', $product->getData('unit_name'))->placeholder('个、位');
+        $f[] = Form::select('temp_id', '砍价运费模板', (string)$product->getData('temp_id'))->setOptions(function () {
+            $list = ShippingTemplates::getList(['page' => 1, 'limit' => 20]);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['name']];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::dateTimeRange('section_time', '活动时间');//->format("yyyy-MM-dd HH:mm:ss");
+        $f[] = Form::frameImageOne('image', '商品主图片(305*305px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')), $product->getData('image'))->icon('image')->width('100%')->height('500px');
+        $f[] = Form::frameImages('images', '商品轮播图(640*640px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'images')), json_decode($product->getData('slider_image'), 1))->maxLength(5)->icon('images')->width('100%')->height('500px');
+        $f[] = Form::number('price', '砍价金额')->min(0)->col(12);
+        $f[] = Form::number('min_price', '砍价最低金额', 0)->min(0)->col(12);
+        $f[] = Form::number('bargain_max_price', '单次砍价的最大金额', 10)->min(0)->col(12);
+        $f[] = Form::number('bargain_min_price', '单次砍价的最小金额', 0.01)->min(0)->precision(2)->col(12);
+        $f[] = Form::number('cost', '成本价', $product->getData('cost'))->min(0)->col(12);
+        $f[] = Form::number('bargain_num', '单次砍价的次数', 1)->min(0)->col(12);
+        $f[] = Form::number('stock', '库存', $product->getData('stock'))->min(1)->col(12);
+        $f[] = Form::number('sales', '销量', $product->getData('sales'))->min(0)->col(12);
+        $f[] = Form::number('sort', '排序', $product->getData('sort'))->col(12);
+        $f[] = Form::number('num', '单次购买的砍价商品数量', 1)->col(12);
+        $f[] = Form::number('give_integral', '赠送积分', $product->getData('give_integral'))->min(0)->col(12);
+        $f[] = Form::number('weight', '重量', 0)->min(0)->col(12);
+        $f[] = Form::number('volume', '体积', 0)->min(0)->col(12);
+        $f[] = Form::radio('is_hot', '热门推荐', $product->getData('is_hot'))->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        $f[] = Form::radio('status', '活动状态', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        $form = Form::make_post_form('开启砍价活动', $f, Url::buildUrl('update'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 修改砍价状态
+     * @param $status
+     * @param int $id
+     */
+    public function set_bargain_status($status, $id = 0)
+    {
+        if (!$id) return Json::fail('参数错误');
+        $res = StoreProductAttrValue::where('product_id', $id)->where('type', 2)->find();
+        if (!$res) return Json::fail('请先配置规格');
+        $res = StoreBargainModel::edit(['status' => $status], $id);
+        if ($res) return Json::successful('修改成功');
+        else return Json::fail('修改失败');
+    }
+
+    /**
+     * 砍价属性选择页面
+     * @param $id
+     * @return string|void
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function attr_list($id)
+    {
+        if (!$id) return $this->failed('数据不存在!');
+        $bargainInfo = StoreBargainModel::where('id', $id)->find();
+        $bargainResult = StoreProductAttrResult::where('product_id', $id)->where('type', 2)->value('result');
+        $productResult = StoreProductAttrResult::where('product_id', $bargainInfo['product_id'])->where('type', 0)->value('result');
+        if ($productResult) {
+            $attr = json_decode($productResult, true)['attr'];
+            $productAttr = $this->get_attr($attr, $bargainInfo['product_id'], 0);
+            $bargainAttr = $this->get_attr($attr, $id, 2);
+            foreach ($productAttr as $pk => $pv) {
+                foreach ($bargainAttr as $sv) {
+                    if ($pv['detail'] == $sv['detail']) {
+                        $productAttr[$pk] = $sv;
+                    }
+                }
+            }
+        } else {
+            if ($bargainResult) {
+                $attr = json_decode($bargainResult, true)['attr'];
+                $productAttr = $this->get_attr($attr, $id, 2);
+            } else {
+                $attr[0]['value'] = '默认';
+                $attr[0]['detailValue'] = '';
+                $attr[0]['attrHidden'] = '';
+                $attr[0]['detail'][0] = '默认';
+                $productAttr[0]['value1'] = '默认';
+                $productAttr[0]['detail'] = json_encode(['默认' => '默认']);
+                $productAttr[0]['pic'] = $bargainInfo['image'];
+                $productAttr[0]['price'] = $bargainInfo['price'];
+                $productAttr[0]['min_price'] = 0;
+                $productAttr[0]['cost'] = $bargainInfo['cost'];
+                $productAttr[0]['ot_price'] = $bargainInfo['ot_price'];
+                $productAttr[0]['stock'] = $bargainInfo['stock'];
+                $productAttr[0]['quota'] = 0;
+                $productAttr[0]['bar_code'] = $bargainInfo['bar_code'];
+                $productAttr[0]['weight'] = 0;
+                $productAttr[0]['volume'] = 0;
+                $productAttr[0]['brokerage'] = 0;
+                $productAttr[0]['brokerage_two'] = 0;
+                $productAttr[0]['check'] = 0;
+            }
+        }
+        $attrs['attr'] = $attr;
+        $attrs['value'] = $productAttr;
+        $this->assign('attr', $attrs);
+        $this->assign('id', $id);
+        return $this->fetch();
+    }
+
+    /**
+     * 砍价属性添加
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function save_attr()
+    {
+        $data = Util::postMore([
+            ['attr', []],
+            ['ids', []],
+            ['id', 0],
+        ]);
+        if (!$data['id']) return Json::fail('数据不存在!');
+        if (!$data['ids']) return Json::fail('你没有选择任何规格!');
+        $productId = StoreBargainModel::where('id', $data['id'])->value('product_id');
+        $attr = json_decode(StoreProductAttrResult::where('product_id', $productId)->where('type', 0)->value('result'), true)['attr'];
+        foreach ($data['attr'] as $k => $v) {
+            if (in_array($k, $data['ids'])) {
+                $v['detail'] = json_decode(htmlspecialchars_decode($v['detail']), true);
+                $min_price = $v['min_price'];
+                unset($v['min_price']);
+                $detail[$k] = $v;
+                break;
+            }
+        }
+        if (min(array_column($detail, 'quota')) == 0) return Json::fail('限购不能为0');
+        $price = min(array_column($detail, 'price'));
+        $quota = array_sum(array_column($detail, 'quota'));
+        $stock = array_sum(array_column($detail, 'stock'));
+        if (!$attr) {
+            $attr[0]['value'] = '默认';
+            $attr[0]['detailValue'] = '';
+            $attr[0]['attrHidden'] = '';
+            $attr[0]['detail'][0] = '默认';
+        }
+        StoreProductAttr::createProductAttr($attr, $detail, $data['id'], 2);
+        StoreBargainModel::where('id', $data['id'])->update(['stock' => $stock, 'quota' => $quota, 'quota_show' => $quota, 'price' => $price, 'min_price' => $min_price]);
+        return Json::successful('添加成功!');
+    }
+
+    /**
+     * 添加砍价获取商品列表
+     * @return string
+     * @throws \Exception
+     */
+    public function productList()
+    {
+        $cate = StoreCategory::getTierList(null, 1);
+        $this->assign('cate', $cate);
+        return $this->fetch();
+    }
+
+    /**
+     * 获取砍价商品规格
+     * @param $attr
+     * @param $id
+     * @param $type
+     * @return array
+     */
+    public function get_attr($attr, $id, $type)
+    {
+        $value = attr_format($attr)[1];
+        $valueNew = [];
+        $count = 0;
+        $min_price = StoreBargainModel::where('id', $id)->value('min_price');
+        foreach ($value as $key => $item) {
+            $detail = $item['detail'];
+            sort($item['detail'], SORT_STRING);
+            $suk = implode(',', $item['detail']);
+            $sukValue = StoreProductAttrValue::where('product_id', $id)->where('type', $type)->where('suk', $suk)->column('bar_code,cost,price,ot_price,stock,image as pic,weight,volume,brokerage,brokerage_two,quota', 'suk');
+            if (count($sukValue)) {
+                foreach (array_values($detail) as $k => $v) {
+                    $valueNew[$count]['value' . ($k + 1)] = $v;
+                }
+                $valueNew[$count]['detail'] = json_encode($detail);
+                $valueNew[$count]['pic'] = $sukValue[$suk]['pic'] ?? '';
+                $valueNew[$count]['price'] = isset($sukValue[$suk]['price']) ? floatval($sukValue[$suk]['price']) : 0;
+                $valueNew[$count]['min_price'] = $min_price;
+                $valueNew[$count]['cost'] = isset($sukValue[$suk]['cost']) ? floatval($sukValue[$suk]['cost']) : 0;
+                $valueNew[$count]['ot_price'] = isset($sukValue[$suk]['ot_price']) ? floatval($sukValue[$suk]['ot_price']) : 0;
+                $valueNew[$count]['stock'] = isset($sukValue[$suk]['stock']) ? intval($sukValue[$suk]['stock']) : 0;
+                $valueNew[$count]['quota'] = isset($sukValue[$suk]['quota']) ? intval($sukValue[$suk]['quota']) : 0;
+                $valueNew[$count]['bar_code'] = $sukValue[$suk]['bar_code'] ?? '';
+                $valueNew[$count]['weight'] = $sukValue[$suk]['weight'] ?? 0;
+                $valueNew[$count]['volume'] = $sukValue[$suk]['volume'] ?? 0;
+                $valueNew[$count]['brokerage'] = $sukValue[$suk]['brokerage'] ?? 0;
+                $valueNew[$count]['brokerage_two'] = $sukValue[$suk]['brokerage_two'] ?? 0;
+                $valueNew[$count]['check'] = $type != 0 ? 1 : 0;
+                $count++;
+            }
+        }
+        return $valueNew;
+    }
+}

+ 572 - 0
app/admin/controller/ump/StoreCombination.php

@@ -0,0 +1,572 @@
+<?php
+
+namespace app\admin\controller\ump;
+
+use app\admin\controller\AuthController;
+use app\admin\model\store\{StoreCategory,
+    StoreDescription,
+    StoreProductAttr,
+    StoreProductAttrResult,
+    StoreProduct as ProductModel,
+    StoreProductAttrValue};
+use crmeb\traits\CurdControllerTrait;
+use app\admin\model\ump\{StorePink,
+    StoreCombinationAttr,
+    StoreCombinationAttrResult,
+    StoreCombination as StoreCombinationModel};
+use think\facade\Route as Url;
+use app\admin\model\system\{SystemAttachment, ShippingTemplates};
+use crmeb\services\{FormBuilder as Form, UtilService as Util, JsonService as Json};
+
+/**
+ * 拼团管理
+ * Class StoreCombination
+ * @package app\admin\controller\store
+ */
+class StoreCombination extends AuthController
+{
+
+    use CurdControllerTrait;
+
+    protected $bindModel = StoreCombinationModel::class;
+
+    /**
+     * @return mixed
+     */
+    public function index()
+    {
+        $this->assign('countCombination', StoreCombinationModel::getCombinationCount());
+        $this->assign(StoreCombinationModel::getStatistics());
+        $this->assign('combinationId', StoreCombinationModel::getCombinationIdAll());
+        return $this->fetch();
+    }
+
+    public function save_excel()
+    {
+        $where = Util::getMore([
+            ['is_show', ''],
+            ['store_name', ''],
+        ]);
+        StoreCombinationModel::SaveExcel($where);
+    }
+
+    /**
+     * 异步获取拼团数据
+     */
+    public function get_combination_list()
+    {
+        $where = Util::getMore([
+            ['page', 1],
+            ['limit', 20],
+            ['export', 0],
+            ['is_show', ''],
+            ['is_host', ''],
+            ['store_name', '']
+        ]);
+        $combinationList = StoreCombinationModel::systemPage($where);
+        if (is_object($combinationList['list'])) $combinationList['list'] = $combinationList['list']->toArray();
+        $data = $combinationList['list']['data'];
+        foreach ($data as $k => $v) {
+            $data[$k]['_stop_time'] = date('Y/m/d H:i:s', $v['stop_time']);
+        }
+        return Json::successlayui(['count' => $combinationList['list']['total'], 'data' => $data]);
+    }
+
+    public function combination($id = 0)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = ProductModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $f = [];
+        $f[] = Form::hidden('product_id', $id);
+        $f[] = Form::input('title', '拼团名称', $product->getData('store_name'));
+        $f[] = Form::input('info', '拼团简介', $product->getData('store_info'))->type('textarea');
+        $f[] = Form::input('unit_name', '单位', $product->getData('unit_name'))->placeholder('个、位');
+        $f[] = Form::select('temp_id', '砍价运费模板', (string)$product->getData('temp_id'))->setOptions(function () {
+            $list = ShippingTemplates::getList(['page' => 1, 'limit' => 20]);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['name']];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::dateTimeRange('section_time', '拼团时间');
+        $f[] = Form::frameImageOne('image', '商品主图片(305*305px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')), $product->getData('image'))->icon('image')->width('100%')->height('500px');
+        $f[] = Form::frameImages('images', '商品轮播图(640*640px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'images')), json_decode($product->getData('slider_image')))->maxLength(5)->icon('images')->width('100%')->height('500px');
+        $f[] = Form::number('effective_time', '拼团时效(单位 小时)', 24)->placeholder('请输入拼团有效时间,单位:小时');
+        $f[] = Form::number('price', '拼团价')->min(0)->col(12);
+        $f[] = Form::number('people', '拼团人数')->min(2)->col(12);
+        $f[] = Form::number('stock', '库存', $product->getData('stock'))->min(0)->precision(0)->col(12);
+        $f[] = Form::number('sales', '销量', $product->getData('sales'))->min(0)->precision(0)->col(12);
+        $f[] = Form::number('sort', '排序')->col(12);
+        $f[] = Form::number('weight', '重量', 0)->min(0)->col(12);
+        $f[] = Form::number('volume', '体积', 0)->min(0)->col(12);
+        $f[] = Form::radio('is_host', '热门推荐', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        $f[] = Form::radio('is_show', '活动状态', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        $form = Form::make_post_form('添加用户通知', $f, Url::buildUrl('save'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return \think\Response
+     */
+    public function create()
+    {
+        $f = [];
+        $f[] = Form::frameImageOne('product', '选择商品', Url::buildUrl('productList', array('fodder' => 'product')))->icon('plus')->width('100%')->height('500px');
+        $f[] = Form::hidden('product_id', '');
+        $f[] = Form::input('title', '拼团名称');
+        $f[] = Form::input('info', '拼团简介')->type('textarea');
+        $f[] = Form::input('unit_name', '单位')->placeholder('个、位');
+        $f[] = Form::select('temp_id', '秒杀运费模板')->setOptions(function () {
+            $list = ShippingTemplates::getList(['page' => 1, 'limit' => 20]);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['name']];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::dateTimeRange('section_time', '拼团时间');
+        $f[] = Form::frameImageOne('image', '商品主图片(305*305px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')))->icon('image')->width('100%')->height('500px');
+        $f[] = Form::frameImages('images', '商品轮播图(640*640px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'images')))->maxLength(5)->icon('images')->width('100%')->height('500px');
+        $f[] = Form::number('effective_time', '拼团时效', '24')->placeholder('请输入拼团订单有效时间,单位:小时')->col(12);
+        $f[] = Form::number('people', '拼团人数', 2)->min(2)->col(12);
+        $f[] = Form::number('num', '单次购买商品个数', 1)->min(1)->col(12);
+        $f[] = Form::number('sort', '排序')->col(12);
+        $f[] = Form::radio('is_host', '热门推荐', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        $form = Form::make_post_form('添加用户通知', $f, Url::buildUrl('save'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存新建的资源
+     * @param int $id
+     */
+    public function save($id = 0)
+    {
+        $data = Util::postMore([
+            'product_id',
+            'title',
+            'info',
+            ['unit_name', '个'],
+            ['image', ''],
+            ['images', []],
+            ['section_time', []],
+            ['effective_time', 0],
+            ['postage', 0],
+            ['price', 0],
+            ['people', 0],
+            ['sort', 0],
+            ['stock', 0],
+            ['sales', 0],
+            ['is_show', 0],
+            ['is_host', 0],
+            ['is_postage', 0],
+            ['temp_id', ''],
+            ['weight', ''],
+            ['volume', ''],
+            ['num', 1],
+        ]);
+        $data['description'] = StoreDescription::getDescription($data['product_id']);
+        if (!$data['title']) return Json::fail('请输入拼团名称');
+        if (!$data['info']) return Json::fail('请输入拼团简介');
+        if (!$data['image']) return Json::fail('请上传商品图片');
+        if (count($data['images']) < 1) return Json::fail('请上传商品轮播图');
+        if ($data['effective_time'] == 0 || $data['effective_time'] < 0) return Json::fail('请输入拼团有效时间');
+        if ($data['people'] == '' || $data['people'] < 1) return Json::fail('请输入拼团人数');
+        if (count($data['section_time']) < 1) return Json::fail('请选择活动时间');
+        $data['images'] = json_encode($data['images']);
+        $data['start_time'] = strtotime($data['section_time'][0]);
+        $data['stop_time'] = strtotime($data['section_time'][1]);
+        unset($data['section_time']);
+        if ($id) {
+            unset($data['description']);
+            $product = StoreCombinationModel::get($id);
+            if (!$product) return Json::fail('数据不存在!');
+            $data['product_id'] = $product['product_id'];
+            StoreCombinationModel::edit($data, $id);
+            return Json::successful('编辑成功!');
+        } else {
+            $data['add_time'] = time();
+            $res = StoreCombinationModel::create($data);
+            $description['product_id'] = $res['id'];
+            $description['description'] = htmlspecialchars_decode($data['description']);
+            $description['type'] = 3;
+            StoreDescription::create($description);
+            return Json::successful('添加拼团成功!');
+        }
+
+    }
+
+    /**
+     * 显示编辑资源表单页.
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function edit($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreCombinationModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $f = [];
+        $f[] = Form::input('product_id', '产品ID', $product->getData('product_id'))->disabled(true);
+        $f[] = Form::input('title', '拼团名称', $product->getData('title'));
+        $f[] = Form::input('info', '拼团简介', $product->getData('info'))->type('textarea');
+        $f[] = Form::input('unit_name', '单位', $product->getData('unit_name'))->placeholder('个、位');
+        $f[] = Form::select('temp_id', '砍价运费模板', (string)$product->getData('temp_id'))->setOptions(function () {
+            $list = ShippingTemplates::getList(['page' => 1, 'limit' => 20]);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['name']];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::dateTimeRange('section_time', '拼团时间', date("Y-m-d H:i:s", $product->getData('start_time')), date("Y-m-d H:i:s", $product->getData('stop_time')));
+        $f[] = Form::frameImageOne('image', '商品主图片(305*305px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')), $product->getData('image'))->icon('image')->width('100%')->height('500px');
+        $f[] = Form::frameImages('images', '商品轮播图(640*640px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'images')), json_decode($product->getData('images')))->maxLength(5)->icon('images')->width('100%')->height('500px');
+        $f[] = Form::number('effective_time', '拼团时效(单位 小时)', $product->getData('effective_time'))->placeholder('请输入拼团订单有效时间,单位:小时')->col(12);
+        $f[] = Form::hidden('price', $product->getData('price'));
+        $f[] = Form::number('people', '拼团人数', $product->getData('people'))->min(2)->col(12);
+        $f[] = Form::number('num', '单次购买商品个数', $product->getData('num'))->min(1)->col(12);
+        $f[] = Form::hidden('stock', $product->getData('stock'));
+        $f[] = Form::hidden('sales', $product->getData('sales'));
+        $f[] = Form::number('sort', '排序', $product->getData('sort'))->col(12);
+        $f[] = Form::radio('is_host', '热门推荐', $product->getData('is_host'))->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        $f[] = Form::hidden('is_show', $product->getData('is_show'));
+        $form = Form::make_post_form('添加用户通知', $f, Url::buildUrl('save', compact('id')));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function delete($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreCombinationModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['is_del']) return Json::fail('已删除!');
+        $data['is_del'] = 1;
+        if (!StoreCombinationModel::edit($data, $id))
+            return Json::fail(StoreCombinationModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+
+    /**
+     * 属性页面
+     * @param $id
+     * @return mixed|void
+     */
+    public function attr($id)
+    {
+        if (!$id) return $this->failed('数据不存在!');
+        $result = StoreCombinationAttrResult::getResult($id);
+        $image = StoreCombinationModel::where('id', $id)->value('image');
+        $this->assign(compact('id', 'result', 'product', 'image'));
+        return $this->fetch();
+    }
+
+    /**
+     * 拼团属性选择页面
+     * @param $id
+     * @return string|void
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function attr_list($id)
+    {
+        if (!$id) return $this->failed('数据不存在!');
+        $combinationInfo = StoreCombinationModel::where('id', $id)->find();
+        $combinationResult = StoreProductAttrResult::where('product_id', $id)->where('type', 3)->value('result');
+        $productResult = StoreProductAttrResult::where('product_id', $combinationInfo['product_id'])->where('type', 0)->value('result');
+        if ($productResult) {
+            $attr = json_decode($productResult, true)['attr'];
+            $productAttr = $this->get_attr($attr, $combinationInfo['product_id'], 0);
+            $combinationAttr = $this->get_attr($attr, $id, 3);
+            foreach ($productAttr as $pk => $pv) {
+                foreach ($combinationAttr as $sv) {
+                    if ($pv['detail'] == $sv['detail']) {
+                        $productAttr[$pk] = $sv;
+                    }
+                }
+            }
+        } else {
+            if ($combinationResult) {
+                $attr = json_decode($combinationResult, true)['attr'];
+                $productAttr = $this->get_attr($attr, $id, 3);
+            } else {
+                $attr[0]['value'] = '默认';
+                $attr[0]['detailValue'] = '';
+                $attr[0]['attrHidden'] = '';
+                $attr[0]['detail'][0] = '默认';
+                $productAttr[0]['value1'] = '默认';
+                $productAttr[0]['detail'] = json_encode(['默认' => '默认']);
+                $productAttr[0]['pic'] = $combinationInfo['image'];
+                $productAttr[0]['price'] = $combinationInfo['price'];
+                $productAttr[0]['cost'] = $combinationInfo['cost'];
+                $productAttr[0]['ot_price'] = $combinationInfo['ot_price'];
+                $productAttr[0]['stock'] = $combinationInfo['stock'];
+                $productAttr[0]['quota'] = 0;
+                $productAttr[0]['bar_code'] = $combinationInfo['bar_code'];
+                $productAttr[0]['weight'] = 0;
+                $productAttr[0]['volume'] = 0;
+                $productAttr[0]['brokerage'] = 0;
+                $productAttr[0]['brokerage_two'] = 0;
+                $productAttr[0]['check'] = 0;
+            }
+        }
+        $attrs['attr'] = $attr;
+        $attrs['value'] = $productAttr;
+        $this->assign('attr', $attrs);
+        $this->assign('id', $id);
+        return $this->fetch();
+    }
+
+    /**
+     * 拼团属性添加
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function save_attr()
+    {
+        $data = Util::postMore([
+            ['attr', []],
+            ['ids', []],
+            ['id', 0],
+        ]);
+        if (!$data['id']) return Json::fail('数据不存在!');
+        if (!$data['ids']) return Json::fail('你没有选择任何规格!');
+        $productId = StoreCombinationModel::where('id', $data['id'])->value('product_id');
+        $attr = json_decode(StoreProductAttrResult::where('product_id', $productId)->where('type', 0)->value('result'), true)['attr'];
+        foreach ($data['attr'] as $k => $v) {
+            if (in_array($k, $data['ids'])) {
+                $v['detail'] = json_decode(htmlspecialchars_decode($v['detail']), true);
+                if($v['price'] > $v['ot_price']){
+                    return Json::fail('售价不能大于原价');
+                }
+                $detail[$k] = $v;
+            }
+        }
+        if (min(array_column($detail, 'quota')) == 0) return Json::fail('限购不能为0');
+        $price = min(array_column($detail, 'price'));
+        $quota = array_sum(array_column($detail, 'quota'));
+        $stock = array_sum(array_column($detail, 'stock'));
+        if (!$attr) {
+            $attr[0]['value'] = '默认';
+            $attr[0]['detailValue'] = '';
+            $attr[0]['attrHidden'] = '';
+            $attr[0]['detail'][0] = '默认';
+        }
+        StoreProductAttr::createProductAttr($attr, $detail, $data['id'], 3);
+        StoreCombinationModel::where('id', $data['id'])->update(['stock' => $stock, 'quota' => $quota, 'quota_show' => $quota, 'price' => $price]);
+        return Json::successful('添加成功!');
+    }
+
+    /**
+     * 生成属性
+     * @param int $id
+     */
+    public function is_format_attr($id = 0)
+    {
+        if (!$id) return Json::fail('商品不存在');
+        list($attr, $detail) = Util::postMore([
+            ['items', []],
+            ['attrs', []]
+        ], $this->request, true);
+        $product = StoreCombinationModel::get($id);
+        if (!$product) return Json::fail('商品不存在');
+        $attrFormat = attr_format($attr)[1];
+        if (count($detail)) {
+            foreach ($attrFormat as $k => $v) {
+                foreach ($detail as $kk => $vv) {
+                    if ($v['detail'] == $vv['detail']) {
+                        $attrFormat[$k]['price'] = $vv['price'];
+                        $attrFormat[$k]['sales'] = $vv['sales'];
+                        $attrFormat[$k]['pic'] = $vv['pic'];
+                        $attrFormat[$k]['check'] = false;
+                        break;
+                    } else {
+                        $attrFormat[$k]['price'] = '';
+                        $attrFormat[$k]['sales'] = '';
+                        $attrFormat[$k]['pic'] = $product['image'];
+                        $attrFormat[$k]['check'] = true;
+                    }
+                }
+            }
+        } else {
+            foreach ($attrFormat as $k => $v) {
+                $attrFormat[$k]['price'] = $product['price'];
+                $attrFormat[$k]['sales'] = $product['stock'];
+                $attrFormat[$k]['pic'] = $product['image'];
+                $attrFormat[$k]['check'] = false;
+            }
+        }
+        return Json::successful($attrFormat);
+    }
+
+    /**
+     * 添加 修改属性
+     * @param $id
+     */
+    public function set_attr($id)
+    {
+        if (!$id) return $this->failed('商品不存在!');
+        list($attr, $detail) = Util::postMore([
+            ['items', []],
+            ['attrs', []]
+        ], $this->request, true);
+        $res = StoreCombinationAttr::createProductAttr($attr, $detail, $id);
+        if ($res)
+            return $this->successful('编辑属性成功!');
+        else
+            return $this->failed(StoreCombinationAttr::getErrorInfo());
+    }
+
+    /**
+     * 清除属性
+     * @param $id
+     */
+    public function clear_attr($id)
+    {
+        if (!$id) return $this->failed('商品不存在!');
+        if (false !== StoreCombinationAttr::clearProductAttr($id) && false !== StoreCombinationAttrResult::clearResult($id))
+            return $this->successful('清空商品属性成功!');
+        else
+            return $this->failed(StoreCombinationAttr::getErrorInfo('清空商品属性失败!'));
+    }
+
+    public function edit_content($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreCombinationModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $this->assign([
+            'content' => htmlspecialchars_decode(StoreDescription::getDescription($id, 3)),
+            'field' => 'description',
+            'action' => Url::buildUrl('change_field', ['id' => $id, 'field' => 'description'])
+        ]);
+        return $this->fetch('public/edit_content');
+    }
+
+    public function change_field($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $combination = StoreCombinationModel::get($id);
+        if (!$combination) return Json::fail('数据不存在!');
+        $data['description'] = request()->post('description');
+        StoreDescription::saveDescription($data['description'], $id, 3);
+        $res = StoreCombinationModel::edit($data, $id);
+        if ($res)
+            return Json::successful('添加成功');
+        else
+            return Json::fail('添加失败');
+    }
+
+    /**拼团列表
+     * @return mixed
+     */
+    public function combina_list()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['data', ''],
+        ], $this->request);
+        $this->assign('where', $where);
+        $this->assign(StorePink::systemPage($where));
+
+        return $this->fetch();
+    }
+
+    /**拼团人列表
+     * @return mixed
+     */
+    public function order_pink($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $StorePink = StorePink::getPinkUserOne($id);
+        if (!$StorePink) return $this->failed('数据不存在!');
+        $list = StorePink::getPinkMember($id);
+        $list[] = $StorePink;
+        $this->assign('list', $list);
+        return $this->fetch();
+    }
+
+    /**
+     * 修改拼团状态
+     * @param $status
+     * @param int $idd
+     */
+    public function set_combination_status($status, $id = 0)
+    {
+        if (!$id) return Json::fail('参数错误');
+        $res = StoreProductAttrValue::where('product_id', $id)->where('type', 3)->find();
+        if (!$res) return Json::fail('请先配置规格');
+        $res = StoreCombinationModel::edit(['is_show' => $status], $id);
+        if ($res) return Json::successful('修改成功');
+        else return Json::fail('修改失败');
+    }
+
+    /**
+     * 添加拼团获取商品列表
+     * @return string
+     * @throws \Exception
+     */
+    public function productList()
+    {
+        $cate = StoreCategory::getTierList(null, 1);
+        $this->assign('cate', $cate);
+        return $this->fetch();
+    }
+
+    /**
+     * 获取拼团商品规格
+     * @param $attr
+     * @param $id
+     * @param $type
+     * @return array
+     */
+    public function get_attr($attr, $id, $type)
+    {
+        $value = attr_format($attr)[1];
+        $valueNew = [];
+        $count = 0;
+        foreach ($value as $key => $item) {
+            $detail = $item['detail'];
+            sort($item['detail'], SORT_STRING);
+            $suk = implode(',', $item['detail']);
+            $sukValue = StoreProductAttrValue::where('product_id', $id)->where('type', $type)->where('suk', $suk)->column('bar_code,cost,price,ot_price,stock,image as pic,weight,volume,brokerage,brokerage_two,quota', 'suk');
+            if (count($sukValue)) {
+                foreach (array_values($detail) as $k => $v) {
+                    $valueNew[$count]['value' . ($k + 1)] = $v;
+                }
+                $valueNew[$count]['detail'] = json_encode($detail);
+                $valueNew[$count]['pic'] = $sukValue[$suk]['pic'] ?? '';
+                $valueNew[$count]['price'] = isset($sukValue[$suk]['price']) ? floatval($sukValue[$suk]['price']) : 0;
+                $valueNew[$count]['cost'] = isset($sukValue[$suk]['cost']) ? floatval($sukValue[$suk]['cost']) : 0;
+                $valueNew[$count]['ot_price'] = isset($sukValue[$suk]['ot_price']) ? floatval($sukValue[$suk]['ot_price']) : 0;
+                $valueNew[$count]['stock'] = isset($sukValue[$suk]['stock']) ? intval($sukValue[$suk]['stock']) : 0;
+                $valueNew[$count]['quota'] = isset($sukValue[$suk]['quota']) ? intval($sukValue[$suk]['quota']) : 0;
+                $valueNew[$count]['bar_code'] = $sukValue[$suk]['bar_code'] ?? '';
+                $valueNew[$count]['weight'] = $sukValue[$suk]['weight'] ?? 0;
+                $valueNew[$count]['volume'] = $sukValue[$suk]['volume'] ?? 0;
+                $valueNew[$count]['brokerage'] = $sukValue[$suk]['brokerage'] ?? 0;
+                $valueNew[$count]['brokerage_two'] = $sukValue[$suk]['brokerage_two'] ?? 0;
+                $valueNew[$count]['check'] = $type != 0 ? 1 : 0;
+                $count++;
+            }
+        }
+        return $valueNew;
+    }
+}

+ 321 - 0
app/admin/controller/ump/StoreCoupon.php

@@ -0,0 +1,321 @@
+<?php
+
+namespace app\admin\controller\ump;
+
+use app\admin\controller\AuthController;
+use app\admin\model\store\StoreCategory as CategoryModel;
+use think\facade\Route as Url;
+use app\admin\model\wechat\WechatUser as UserModel;
+use app\admin\model\ump\{StoreCouponIssue, StoreCoupon as CouponModel};
+use crmeb\services\{FormBuilder as Form, UtilService as Util, JsonService as Json};
+
+/**
+ * 优惠券控制器
+ * Class StoreCategory
+ * @package app\admin\controller\system
+ */
+class StoreCoupon extends AuthController
+{
+
+    /**
+     * @return mixed
+     */
+    public function index()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['title', ''],
+            ['type','']
+        ], $this->request);
+        $this->assign('where', $where);
+        $this->assign(CouponModel::systemPage($where));
+        return $this->fetch();
+    }
+
+    /**
+     * @return mixed
+     */
+    public function create()
+    {
+        $data = Util::getMore(['type',]);//接收参数
+        $tab_id = !empty(request()->param('tab_id')) ? request()->param('tab_id') : 1;
+        //前面通用字段
+        $f = [];
+        $f[] = Form::input('title', '优惠券名称');
+        //不同类型不同字段
+        $formbuider = [];
+        switch ($data['type']) {
+            case 1://品类券
+                $formbuider = CouponModel::createClassRule($tab_id);
+                break;
+            case 2://商品券
+                $formbuider = CouponModel::createProductRule($tab_id);
+                break;
+        }
+        //后面通用字段
+        $formbuiderfoot = array();
+        $formbuiderfoot[] = Form::number('coupon_price', '优惠券面值', 0)->min(0);
+        $formbuiderfoot[] = Form::number('use_min_price', '最低消费')->min(0);
+        $formbuiderfoot[] = Form::number('coupon_time', '有效期限')->min(0);
+        $formbuiderfoot[] = Form::number('sort', '排序');
+        $formbuiderfoot[] = Form::hidden('type', $data['type']);
+        $formbuiderfoot[] = Form::radio('status', '状态', 0)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->value(1);
+        $formbuiders = array_merge($f, $formbuider, $formbuiderfoot);
+        $form = Form::make_post_form('添加优惠券', $formbuiders, Url::buildUrl('save'));
+        $this->assign(compact('form'));
+        $this->assign('get', request()->param());
+        return $this->fetch();
+    }
+
+    /**
+     * 选择商品
+     * @param int $id
+     */
+    public function select()
+    {
+        return $this->fetch();
+    }
+
+    /**
+     * 保存
+     */
+    public function save()
+    {
+        $data = Util::postMore([
+            'title',
+            ['product_id', []],
+            ['category_id', 0],
+            'coupon_price',
+            'use_min_price',
+            'coupon_time',
+            'sort',
+            ['status', 0],
+            ['type', 0]
+        ]);
+        if (!in_array($data['type'],[0,1,2])) return Json::fail('优惠券类型有误');
+        if (!$data['title']) return Json::fail('请输入优惠券名称');
+        if (!$data['coupon_price']) return Json::fail('请输入优惠券面值');
+        if (!$data['coupon_time']) return Json::fail('请输入优惠券有效期限');
+        $data['product_id'] = implode(',', $data['product_id']);
+        $data['add_time'] = time();
+        CouponModel::create($data);
+        return Json::successful('添加优惠券成功!');
+    }
+
+    /**
+     * 显示编辑资源表单页.
+     * @param $id
+     * @return string|void
+     * @throws \FormBuilder\exception\FormBuilderException
+     */
+    public function edit($id)
+    {
+        $coupon = CouponModel::get($id);
+        if (!$coupon) return Json::fail('数据不存在!');
+        $f = [];
+        $f[] = Form::input('title', '优惠券名称', $coupon->getData('title'));
+        $f[] = Form::number('coupon_price', '优惠券面值', $coupon->getData('coupon_price'))->min(0);
+        $f[] = Form::number('use_min_price', '优惠券最低消费', $coupon->getData('use_min_price'))->min(0);
+        $f[] = Form::number('coupon_time', '优惠券有效期限', $coupon->getData('coupon_time'))->min(0);
+        $f[] = Form::number('sort', '排序', $coupon->getData('sort'));
+        $f[] = Form::radio('status', '状态', $coupon->getData('status'))->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]]);
+
+        $form = Form::make_post_form('添加优惠券', $f, Url::buildUrl('update', array('id' => $id)));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+
+    /**
+     * 保存更新的资源
+     *
+     * @param $id
+     */
+    public function update($id)
+    {
+        $data = Util::postMore([
+            'title',
+            'coupon_price',
+            'use_min_price',
+            'coupon_time',
+            'sort',
+            ['status', 0]
+        ]);
+        if (!$data['title']) return Json::fail('请输入优惠券名称');
+        if (!$data['coupon_price']) return Json::fail('请输入优惠券面值');
+        if (!$data['coupon_time']) return Json::fail('请输入优惠券有效期限');
+        CouponModel::edit($data, $id);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function delete($id)
+    {
+        if (!$id) return Json::fail('数据不存在!');
+        $data['is_del'] = 1;
+        if (!CouponModel::edit($data, $id))
+            return Json::fail(CouponModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+
+    /**
+     * 修改优惠券状态
+     * @param $id
+     * @return \think\response\Json
+     */
+    public function status($id)
+    {
+        if (!$id) return Json::fail('数据不存在!');
+        if (!CouponModel::editIsDel($id))
+            return Json::fail(CouponModel::getErrorInfo('修改失败,请稍候再试!'));
+        else
+            return Json::successful('修改成功!');
+    }
+
+    /**
+     * @return mixed
+     */
+    public function grant_subscribe()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['title', ''],
+            ['is_del', 0],
+        ], $this->request);
+        $this->assign('where', $where);
+        $this->assign(CouponModel::systemPageCoupon($where));
+        return $this->fetch();
+    }
+
+    /**
+     * @return mixed
+     */
+    public function grant_all()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['title', ''],
+            ['is_del', 0],
+        ], $this->request);
+        $this->assign('where', $where);
+        $this->assign(CouponModel::systemPageCoupon($where));
+        return $this->fetch();
+    }
+
+    /**
+     * @param $id
+     */
+    public function grant($id)
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['title', ''],
+            ['is_del', 0],
+        ], $this->request);
+        $nickname = UserModel::where('uid', 'IN', $id)->column('nickname', 'uid');
+        $this->assign('where', $where);
+        $this->assign('uid', $id);
+        $this->assign('nickname', implode(',', $nickname));
+        $this->assign(CouponModel::systemPageCoupon($where));
+        return $this->fetch();
+    }
+
+    public function issue($id)
+    {
+        if (!CouponModel::be(['id' => $id, 'status' => 1, 'is_del' => 0]))
+            return $this->failed('发布的优惠劵已失效或不存在!');
+        $f = [];
+        $f[] = Form::input('id', '优惠劵ID', $id)->disabled(1);
+        $f[] = Form::dateTimeRange('range_date', '领取时间')->placeholder('不填为永久有效');
+        $f[] = Form::radio('is_permanent', '是否不限量', 0)->options([['label' => '限量', 'value' => 0], ['label' => '不限量', 'value' => 1]]);
+        $f[] = Form::number('count', '发布数量', 0)->min(0)->placeholder('不填或填0,为不限量');
+        $f[] = Form::radio('is_full_give', '消费满赠', 0)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]]);
+        $f[] = Form::number('full_reduction', '满赠金额')->min(0)->placeholder('赠送优惠券的最低消费金额');
+        $f[] = Form::radio('is_give_subscribe', '首次关注赠送', 0)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]]);
+        $f[] = Form::radio('status', '状态', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]]);
+
+        $form = Form::make_post_form('添加优惠券', $f, Url::buildUrl('update_issue', array('id' => $id)));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+
+//        FormBuilder::text('id','优惠劵ID',$id)->disabled();
+//        FormBuilder::dateTimeRange('range_date','领取时间')->placeholder('不填为永久有效');
+//        FormBuilder::text('count','发布数量')->placeholder('不填或填0,为不限量');
+//        FormBuilder::radio('status','是否开启',[
+//            ['value'=>1,'label'=>'开启'],
+//            ['value'=>0,'label'=>'关闭']
+//        ],1);
+//        $this->assign(['title'=>'发布优惠券','rules'=>FormBuilder::builder()->getContent(),'action'=>Url::buildUrl('update_issue',array('id'=>$id))]);
+//        return $this->fetch('public/common_form');
+    }
+
+    public function update_issue($id)
+    {
+        list($_id, $rangeTime, $count, $status, $is_permanent, $full_reduction, $is_give_subscribe, $is_full_give) = Util::postMore([
+            'id',
+            ['range_date', ['', '']],
+            ['count', 0],
+            ['status', 0],
+            ['is_permanent', 0],
+            ['full_reduction', 0],
+            ['is_give_subscribe', 0],
+            ['is_full_give', 0]
+        ], null, true);
+        if ($_id != $id) return Json::fail('操作失败,信息不对称');
+        if (!$count) $count = 0;
+        if (!CouponModel::be(['id' => $id, 'status' => 1, 'is_del' => 0])) return Json::fail('发布的优惠劵已失效或不存在!');
+        if (count($rangeTime) != 2) return Json::fail('请选择正确的时间区间');
+
+        list($startTime, $endTime) = $rangeTime;
+//        echo $startTime;echo $endTime;var_dump($rangeTime);die;
+        if (!$startTime) $startTime = 0;
+        if (!$endTime) $endTime = 0;
+        if (!$startTime && $endTime) return Json::fail('请选择正确的开始时间');
+        if ($startTime && !$endTime) return Json::fail('请选择正确的结束时间');
+        if (StoreCouponIssue::setIssue($id, $count, strtotime($startTime), strtotime($endTime), $count, $status, $is_permanent,$full_reduction, $is_give_subscribe, $is_full_give))
+            return Json::successful('发布优惠劵成功!');
+        else
+            return Json::fail('发布优惠劵失败!');
+    }
+
+
+    /**
+     * 给分组用户发放优惠券
+     */
+    public function grant_group()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['title', ''],
+            ['is_del', 0],
+        ], $this->request);
+        $group = UserModel::getUserGroup();
+        $this->assign('where', $where);
+        $this->assign('group', json_encode($group));
+        $this->assign(CouponModel::systemPageCoupon($where));
+        return $this->fetch();
+    }
+
+    /**
+     * 给标签用户发放优惠券
+     */
+    public function grant_tag()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['title', ''],
+            ['is_del', 0],
+        ], $this->request);
+        $tag = UserModel::getUserTag();;//获取所有标签
+        $this->assign('where', $where);
+        $this->assign('tag', json_encode($tag));
+        $this->assign(CouponModel::systemPageCoupon($where));
+        return $this->fetch();
+    }
+}

+ 60 - 0
app/admin/controller/ump/StoreCouponIssue.php

@@ -0,0 +1,60 @@
+<?php
+/**
+ *
+ * @author: xaboy<365615158@qq.com>
+ * @day: 2018/01/17
+ */
+
+namespace app\admin\controller\ump;
+
+use app\admin\controller\AuthController;
+use think\facade\Route as Url;
+use crmeb\traits\CurdControllerTrait;
+use crmeb\services\{JsonService, FormBuilder as Form, UtilService as Util};
+use app\admin\model\ump\{StoreCouponIssue as CouponIssueModel, StoreCouponIssueUser};
+
+class StoreCouponIssue extends AuthController
+{
+    use CurdControllerTrait;
+
+    protected $bindModel = CouponIssueModel::class;
+
+    public function index()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['coupon_title', ''],
+            ['type','']
+        ]);
+        $this->assign(CouponIssueModel::stsypage($where));
+        $this->assign('where', $where);
+        return $this->fetch();
+    }
+
+    public function delete($id = '')
+    {
+        if (!$id) return JsonService::fail('参数有误!');
+        if (CouponIssueModel::edit(['is_del' => 1], $id, 'id'))
+            return JsonService::successful('删除成功!');
+        else
+            return JsonService::fail('删除失败!');
+    }
+
+    public function edit($id = '')
+    {
+        if (!$id) return JsonService::fail('参数有误!');
+        $issueInfo = CouponIssueModel::get($id);
+        if (-1 == $issueInfo['status'] || 1 == $issueInfo['is_del']) return $this->failed('状态错误,无法修改');
+        $f = [Form::radio('status', '是否开启', $issueInfo['status'])->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])];
+        $form = Form::make_post_form('状态修改', $f, Url::buildUrl('change_field', array('id' => $id, 'field' => 'status')));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    public function issue_log($id = '')
+    {
+        if (!$id) return JsonService::fail('参数有误!');
+        $this->assign(StoreCouponIssueUser::systemCouponIssuePage($id));
+        return $this->fetch();
+    }
+}

+ 117 - 0
app/admin/controller/ump/StoreCouponUser.php

@@ -0,0 +1,117 @@
+<?php
+
+namespace app\admin\controller\ump;
+
+use app\admin\controller\AuthController;
+use app\admin\model\wechat\WechatUser;
+use crmeb\services\UtilService as Util;
+use crmeb\services\JsonService as Json;
+use app\admin\model\ump\StoreCoupon as CouponModel;
+use app\admin\model\ump\StoreCouponUser as CouponUserModel;
+use app\admin\model\wechat\WechatUser as UserModel;
+
+/**
+ * 优惠券发放记录控制器
+ * Class StoreCategory
+ * @package app\admin\controller\system
+ */
+class StoreCouponUser extends AuthController
+{
+    /**
+     * @return mixed
+     */
+    public function index()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['is_fail', ''],
+            ['coupon_title', ''],
+            ['nickname', ''],
+        ], $this->request);
+        $this->assign('where', $where);
+        $this->assign(CouponUserModel::systemPage($where));
+        return $this->fetch();
+    }
+
+    /**
+     * 给已关注的用户发放优惠券
+     * @param $id
+     */
+    public function grant_subscribe($id)
+    {
+        if (!$id) return Json::fail('数据不存在!');
+        $coupon = CouponModel::get($id)->toArray();
+        if (!$coupon) return Json::fail('数据不存在!');
+        $user = UserModel::getSubscribe('uid');
+        if (!CouponUserModel::setCoupon($coupon, $user))
+            return Json::fail(CouponUserModel::getErrorInfo('发放失败,请稍候再试!'));
+        else
+            return Json::successful('发放成功!');
+    }
+
+    /**
+     * 给所有人发放优惠券
+     * @param $id
+     */
+    public function grant_all($id)
+    {
+        if (!$id) return Json::fail('数据不存在!');
+        $coupon = CouponModel::get($id)->toArray();
+        if (!$coupon) return Json::fail('数据不存在!');
+        $user = UserModel::getUserAll('uid');
+        if (!CouponUserModel::setCoupon($coupon, $user))
+            return Json::fail(CouponUserModel::getErrorInfo('发放失败,请稍候再试!'));
+        else
+            return Json::successful('发放成功!');
+    }
+
+    /**
+     * 发放优惠券到指定个人
+     * @param $id
+     * @param $uid
+     * @return \think\response\Json
+     */
+    public function grant($id, $uid)
+    {
+        if (!$id) return Json::fail('数据不存在!');
+        $coupon = CouponModel::get($id)->toArray();
+        if (!$coupon) return Json::fail('数据不存在!');
+        $user = explode(',', $uid);
+        if (!CouponUserModel::setCoupon($coupon, $user))
+            return Json::fail(CouponUserModel::getErrorInfo('发放失败,请稍候再试!'));
+        else
+            return Json::successful('发放成功!');
+
+    }
+
+    public function grant_group($id)
+    {
+        $data = Util::postMore([
+            ['group', 0]
+        ]);
+        if (!$id) return Json::fail('数据不存在!');
+        $coupon = CouponModel::get($id)->toArray();
+        if (!$coupon) return Json::fail('数据不存在!');
+        $user = WechatUser::where('groupid', $data['group'])->column('uid', 'uid');
+        if (!CouponUserModel::setCoupon($coupon, $user))
+            return Json::fail(CouponUserModel::getErrorInfo('发放失败,请稍候再试!'));
+        else
+            return Json::successful('发放成功!');
+    }
+
+    public function grant_tag($id)
+    {
+        $data = Util::postMore([
+            ['tag', 0]
+        ]);
+        if (!$id) return Json::fail('数据不存在!');
+        $coupon = CouponModel::get($id)->toArray();
+        if (!$coupon) return Json::fail('数据不存在!');
+        $user = WechatUser::where("tagid_list", "LIKE", "%$data[tag]%")->column('uid', 'uid');
+        if (!CouponUserModel::setCoupon($coupon, $user))
+            return Json::fail(CouponUserModel::getErrorInfo('发放失败,请稍候再试!'));
+        else
+            return Json::successful('发放成功!');
+    }
+
+}

+ 592 - 0
app/admin/controller/ump/StoreMix.php

@@ -0,0 +1,592 @@
+<?php
+
+namespace app\admin\controller\ump;
+
+use app\admin\controller\AuthController;
+use app\admin\model\store\{StoreDescription,
+    StoreProductAttr,
+    StoreProductAttrResult,
+    StoreProduct as ProductModel,
+    StoreProductAttrValue};
+use crmeb\traits\CurdControllerTrait;
+use think\Exception;
+use think\exception\ErrorException;
+use think\exception\ValidateException;
+use think\facade\Route as Url;
+use app\admin\model\system\{SystemAttachment, SystemGroupData, ShippingTemplates};
+use app\admin\model\ump\{StoreSeckillAttr, StoreSeckillAttrResult, StoreMix as StoreSeckillModel, StoreSeckillTime};
+use crmeb\services\{
+    FormBuilder as Form, UtilService as Util, JsonService as Json
+};
+use app\admin\model\store\StoreCategory;
+
+/**
+ * 限时秒杀  控制器
+ * Class StoreSeckill
+ * @package app\admin\controller\store
+ */
+class StoreMix extends AuthController
+{
+
+    use CurdControllerTrait;
+
+    protected $bindModel = StoreSeckillModel::class;
+
+    /**
+     * 显示资源列表
+     *
+     * @return \think\Response
+     */
+    public function index()
+    {
+        $this->assign('countSeckill', StoreSeckillModel::getSeckillCount());
+        $this->assign('seckillId', StoreSeckillModel::getSeckillIdAll());
+        return $this->fetch();
+    }
+
+    public function save_excel()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['store_name', '']
+        ]);
+        StoreSeckillModel::SaveExcel($where);
+    }
+
+    /**
+     * 异步获取砍价数据
+     */
+    public function get_seckill_list()
+    {
+        $where = Util::getMore([
+            ['page', 1],
+            ['limit', 20],
+            ['status', ''],
+            ['store_name', '']
+        ]);
+        $seckillList = StoreSeckillModel::systemPage($where);
+        if (is_object($seckillList['list'])) $seckillList['list'] = $seckillList['list']->toArray();
+        $data = $seckillList['list']['data'];
+        foreach ($data as $k => $v) {
+            $end_time = $v['stop_time'] ? date('Y/m/d', $v['stop_time']) : '';
+            if ($end_time) {
+                $config = SystemGroupData::get($v['time_id']);
+                if ($config) {
+                    $arr = json_decode($config->value, true);
+                    $start_hour = intval($arr['time']['value']);
+                    $continued = intval($arr['continued']['value']);
+                    $end_hour = $start_hour + $continued;
+                    $end_time = $end_time . ' ' . $end_hour . ':00:00';
+                }
+            }
+            $data[$k]['_stop_time'] = $end_time;
+        }
+        return Json::successlayui(['count' => $seckillList['list']['total'], 'data' => $data]);
+    }
+
+    public function get_seckill_id()
+    {
+        return Json::successlayui(StoreSeckillModel::getSeckillIdAll());
+    }
+
+    /**
+     * 添加秒杀商品
+     * @return form-builder
+     */
+    public function create()
+    {
+        $f = array();
+        $f[] = Form::frameImageOne('product', '选择商品', Url::buildUrl('productList', array('fodder' => 'product')))->icon('plus')->width('100%')->height('500px');
+        $f[] = Form::hidden('product_id', '');
+        $f[] = Form::hidden('description', '');
+        $f[] = Form::input('title', '商品标题');
+        $f[] = Form::input('info', '秒杀活动简介')->type('textarea');
+        $f[] = Form::input('unit_name', '单位')->placeholder('个、位');
+        $f[] = Form::select('temp_id', '秒杀运费模板')->setOptions(function () {
+            $list = ShippingTemplates::getList(['page' => 1, 'limit' => 20]);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['name']];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::dateRange('section_time', '活动日期');
+        $f[] = Form::select('time_id', '开始时间')->setOptions(function () {
+            $list = SystemGroupData::getGroupData('routine_seckill_time', 20);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['time'] . '点开始,持续' . $menu['continued'] . '小时'];//,'disabled'=>$menu['pid']== 0];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::frameImageOne('image', '商品主图片(305*305px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')))->icon('image')->width('100%')->height('500px');
+        $f[] = Form::frameImages('images', '商品轮播图(640*640px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'images')))->maxLength(5)->icon('images')->width('100%')->height('500px');
+        $f[] = Form::number('sort', '排序')->col(12);
+        $f[] = Form::number('num', '单次购买商品个数')->precision(0)->col(12);
+        $f[] = Form::number('give_integral', '赠送积分')->min(0)->precision(0)->col(12);
+        $f[] = Form::radio('is_hot', '热门推荐', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        $form = Form::make_post_form('添加用户通知', $f, Url::buildUrl('save'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存秒杀商品
+     * @param int $id
+     */
+    public function save($id = 0)
+    {
+        $data = Util::postMore([
+            'title',
+            'product_id',
+            'info',
+            'unit_name',
+            ['image', ''],
+            ['images', []],
+            ['price', 0],
+            ['ot_price', 0],
+            ['cost', 0],
+            ['sales', 0],
+            ['stock', 0],
+            ['sort', 0],
+            ['give_integral', 0],
+            ['postage', 0],
+            ['section_time', []],
+            ['is_postage', 0],
+            ['cost', 0],
+            ['is_hot', 0],
+            ['status', 0],
+            ['num', 0],
+            'time_id',
+            'temp_id',
+            ['weight', 0],
+            ['volume', 0],
+        ]);
+        $data['description'] = StoreDescription::getDescription($data['product_id']);
+        if (!$data['title']) return Json::fail('请输入商品标题');
+        if (!$data['unit_name']) return Json::fail('请输入商品单位');
+        if (!$data['product_id']) return Json::fail('商品ID不能为空');
+        if (count($data['section_time']) < 1) return Json::fail('请选择活动时间');
+        if (!$data['time_id']) return Json::fail('时间段不能为空');
+        $data['start_time'] = strtotime($data['section_time'][0] .' 00:00:00');
+        $data['stop_time'] = strtotime($data['section_time'][1].' 23:59:59');
+        unset($data['section_time']);
+        if (!$data['image']) return Json::fail('请选择推荐图');
+        if (count($data['images']) < 1) return Json::fail('请选择轮播图');
+        $data['images'] = json_encode($data['images']);
+        if ($data['num'] < 1) return Json::fail('请输入单次秒杀个数');
+        if ($id) {
+            unset($data['description']);
+            $product = StoreSeckillModel::get($id);
+            if (!$product) return Json::fail('数据不存在!');
+            StoreSeckillModel::edit($data, $id);
+            return Json::successful('编辑成功!');
+        } else {
+            if(StoreSeckillModel::checkSeckill($data['product_id'],$data['time_id'])) return Json::fail('该商品当前时间段已有秒杀活动');
+            $data['add_time'] = time();
+            $res = StoreSeckillModel::create($data);
+            $description['product_id'] = $res['id'];
+            $description['description'] = htmlspecialchars_decode($data['description']);
+            $description['type'] = 1;
+            StoreDescription::create($description);
+            return Json::successful('添加成功!');
+        }
+
+    }
+
+    /** 开启秒杀
+     * @param $id
+     * @return mixed|void
+     */
+    public function seckill($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = ProductModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $f = array();
+        $f[] = Form::input('title', '商品标题', $product->getData('store_name'));
+        $f[] = Form::hidden('product_id', $id);
+        $f[] = Form::input('info', '秒杀活动简介', $product->getData('store_info'))->type('textarea');
+        $f[] = Form::input('unit_name', '单位', $product->getData('unit_name'))->placeholder('个、位');
+        $f[] = Form::select('temp_id', '秒杀运费模板', (string)$product->getData('temp_id'))->setOptions(function () {
+            $list = ShippingTemplates::getList(['page' => 1, 'limit' => 20]);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['name']];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::dateRange('section_time', '活动日期');
+        $f[] = Form::select('time_id', '开始时间')->setOptions(function () {
+            $list = SystemGroupData::getGroupData('routine_seckill_time', 20);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['time'] . '点开始,持续' . $menu['continued'] . '小时'];//,'disabled'=>$menu['pid']== 0];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::frameImageOne('image', '商品主图片(305*305px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')), $product->getData('image'))->icon('image')->width('100%')->height('500px');
+        $f[] = Form::frameImages('images', '商品轮播图(640*640px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'images')), json_decode($product->getData('slider_image')))->maxLength(5)->icon('images')->width('100%')->height('500px');
+        $f[] = Form::number('price', '秒杀价')->min(0)->col(12);
+        $f[] = Form::number('ot_price', '原价', $product->getData('price'))->min(0)->col(12);
+        $f[] = Form::number('cost', '成本价', $product->getData('cost'))->min(0)->col(12);
+        $f[] = Form::number('stock', '库存', $product->getData('stock'))->min(0)->precision(0)->col(12);
+        $f[] = Form::number('sales', '销量', $product->getData('sales'))->min(0)->precision(0)->col(12);
+        $f[] = Form::number('sort', '排序', $product->getData('sort'))->col(12);
+        $f[] = Form::number('num', '单次购买商品个数', 1)->precision(0)->col(12);
+        $f[] = Form::number('give_integral', '赠送积分', $product->getData('give_integral'))->min(0)->precision(0)->col(12);
+        $f[] = Form::number('weight', '重量', 0)->min(0)->col(12);
+        $f[] = Form::number('volume', '体积', 0)->min(0)->col(12);
+        $f[] = Form::radio('is_hot', '热门推荐', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        $f[] = Form::radio('status', '活动状态', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        $form = Form::make_post_form('添加用户通知', $f, Url::buildUrl('save'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 显示编辑资源表单页.
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function edit($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreSeckillModel::get($id);
+//        $time = StoreSeckillTime::getSeckillTime($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $f = array();
+        $f[] = Form::input('product_id','产品ID', $product->getData('product_id'))->disabled(true);
+        $f[] = Form::input('title', '商品标题', $product->getData('title'));
+        $f[] = Form::input('info', '秒杀活动简介', $product->getData('info'))->type('textarea');
+        $f[] = Form::input('unit_name', '单位', $product->getData('unit_name'))->placeholder('个、位');
+        $f[] = Form::select('temp_id', '秒杀运费模板', (string)$product->getData('temp_id'))->setOptions(function () {
+            $list = ShippingTemplates::getList(['page' => 1, 'limit' => 20]);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['name']];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::dateRange('section_time', '活动时间', date('Y-m-d H:i:s', (int)$product->getData('start_time')), date('Y-m-d H:i:s', (int)$product->getData('stop_time')));
+        $f[] = Form::select('time_id', '开始时间', (string)$product->getData('time_id'))->setOptions(function () {
+            $list = SystemGroupData::getGroupData('routine_seckill_time', 20);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['time'] . '点开始,持续' . $menu['continued'] . '小时'];//,'disabled'=>$menu['pid']== 0];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::frameImageOne('image', '商品主图片(305*305px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')), $product->getData('image'))->icon('image')->width('100%')->height('500px');
+        $f[] = Form::frameImages('images', '商品轮播图(640*640px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'images')), json_decode($product->getData('images')))->maxLength(5)->icon('images')->width('100%')->height('500px');
+        $f[] = Form::number('sort', '排序', $product->getData('sort'))->col(12);
+        $f[] = Form::hidden('stock', $product->getData('stock'));
+        $f[] = Form::hidden('price', $product->getData('price'));
+        $f[] = Form::hidden('ot_price', $product->getData('ot_price'));
+        $f[] = Form::hidden('sales', $product->getData('sales'));
+        $f[] = Form::number('num', '单次购买商品个数', $product->getData('num'))->precision(0)->col(12);
+        $f[] = Form::number('give_integral', '赠送积分', $product->getData('give_integral'))->min(0)->precision(0)->col(12);
+        $f[] = Form::radio('is_hot', '热门推荐', $product->getData('is_hot'))->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        $f[] = Form::hidden('status', $product->getData('status'));
+        $form = Form::make_post_form('添加用户通知', $f, Url::buildUrl('save', compact('id')));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function delete($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreSeckillModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['is_del']) return Json::fail('已删除!');
+        $data['is_del'] = 1;
+        if (!StoreSeckillModel::edit($data, $id))
+            return Json::fail(StoreSeckillModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+
+    public function edit_content($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $seckill = StoreSeckillModel::get($id);
+        if (!$seckill) return Json::fail('数据不存在!');
+        $this->assign([
+            'content' => htmlspecialchars_decode(StoreDescription::getDescription($id, 1)),
+            'field' => 'description',
+            'action' => Url::buildUrl('change_field', ['id' => $id, 'field' => 'description'])
+        ]);
+        return $this->fetch('public/edit_content');
+    }
+
+    public function change_field($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $seckill = StoreSeckillModel::get($id);
+        if (!$seckill) return Json::fail('数据不存在!');
+        $data['description'] = request()->post('description');
+        StoreDescription::saveDescription($data['description'], $id, 1);
+        $res = StoreSeckillModel::edit($data, $id);
+        if ($res)
+            return Json::successful('添加成功');
+        else
+            return Json::fail('添加失败');
+    }
+
+    /**
+     * 属性页面
+     * @param $id
+     * @return mixed|void
+     */
+    public function attr($id)
+    {
+        if (!$id) return $this->failed('数据不存在!');
+        $result = StoreSeckillAttrResult::getResult($id);
+        $image = StoreSeckillModel::where('id', $id)->value('image');
+        $this->assign(compact('id', 'result', 'image'));
+        return $this->fetch();
+    }
+
+    /**
+     * 秒杀属性选择页面
+     * @param $id
+     * @return string|void
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function attr_list($id)
+    {
+        if (!$id) return $this->failed('数据不存在!');
+        $seckillInfo = StoreSeckillModel::where('id', $id)->find();
+        $seckillResult = StoreProductAttrResult::where('product_id', $id)->where('type', 1)->value('result');
+        $productResult = StoreProductAttrResult::where('product_id', $seckillInfo['product_id'])->where('type', 0)->value('result');
+        if ($productResult) {
+            $attr = json_decode($productResult, true)['attr'];
+            $productAttr = $this->get_attr($attr, $seckillInfo['product_id'], 0);
+            $seckillAttr = $this->get_attr($attr, $id, 1);
+            foreach ($productAttr as $pk => $pv) {
+                foreach ($seckillAttr as $sv) {
+                    if ($pv['detail'] == $sv['detail']) {
+                        $productAttr[$pk] = $sv;
+                    }
+                }
+            }
+        } else {
+            if ($seckillResult) {
+                $attr = json_decode($seckillResult, true)['attr'];
+                $productAttr = $this->get_attr($attr, $id, 1);
+            } else {
+                $attr[0]['value'] = '默认';
+                $attr[0]['detailValue'] = '';
+                $attr[0]['attrHidden'] = '';
+                $attr[0]['detail'][0] = '默认';
+                $productAttr[0]['value1'] = '默认';
+                $productAttr[0]['detail'] = json_encode(['默认' => '默认']);
+                $productAttr[0]['pic'] = $seckillInfo['image'];
+                $productAttr[0]['price'] = $seckillInfo['price'];
+                $productAttr[0]['cost'] = $seckillInfo['cost'];
+                $productAttr[0]['ot_price'] = $seckillInfo['ot_price'];
+                $productAttr[0]['stock'] = $seckillInfo['stock'];
+                $productAttr[0]['quota'] = 0;
+                $productAttr[0]['bar_code'] = $seckillInfo['bar_code'];
+                $productAttr[0]['weight'] = 0;
+                $productAttr[0]['volume'] = 0;
+                $productAttr[0]['brokerage'] = 0;
+                $productAttr[0]['brokerage_two'] = 0;
+                $productAttr[0]['check'] = 0;
+            }
+        }
+        $attrs['attr'] = $attr;
+        $attrs['value'] = $productAttr;
+        $this->assign('attr', $attrs);
+        $this->assign('id', $id);
+        return $this->fetch();
+    }
+
+    /**
+     * 秒杀属性保存页面
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function save_attr()
+    {
+        $data = Util::postMore([
+            ['attr', []],
+            ['ids', []],
+            ['id', 0],
+        ]);
+        if (!$data['id']) return Json::fail('数据不存在!');
+        if (!$data['ids']) return Json::fail('你没有选择任何规格!');
+        $productId = StoreSeckillModel::where('id', $data['id'])->value('product_id');
+        $attr = json_decode(StoreProductAttrResult::where('product_id', $productId)->where('type', 0)->value('result'), true)['attr'];
+        foreach ($data['attr'] as $k => $v) {
+            if (in_array($k, $data['ids'])) {
+                $v['detail'] = json_decode(htmlspecialchars_decode($v['detail']), true);
+                $detail[$k] = $v;
+            }
+        }
+        if (min(array_column($detail, 'quota')) == 0) return Json::fail('限购不能为0');
+        $price = min(array_column($detail, 'price'));
+        $otPrice = min(array_column($detail, 'ot_price'));
+        $quota = array_sum(array_column($detail, 'quota'));
+        $stock = array_sum(array_column($detail, 'stock'));
+        if (!$attr) {
+            $attr[0]['value'] = '默认';
+            $attr[0]['detailValue'] = '';
+            $attr[0]['attrHidden'] = '';
+            $attr[0]['detail'][0] = '默认';
+        }
+        StoreProductAttr::createProductAttr($attr, $detail, $data['id'], 1);
+        StoreSeckillModel::where('id', $data['id'])->update(['stock' => $stock, 'quota' => $quota, 'quota_show' => $quota, 'price' => $price, 'ot_price' => $otPrice]);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 生成属性
+     * @param int $id
+     */
+    public function is_format_attr($id = 0)
+    {
+        if (!$id) return Json::fail('商品不存在');
+        list($attr, $detail) = Util::postMore([
+            ['items', []],
+            ['attrs', []]
+        ], $this->request, true);
+        $product = StoreSeckillModel::get($id);
+        if (!$product) return Json::fail('商品不存在');
+        $attrFormat = attr_format($attr)[1];
+        if (count($detail)) {
+            foreach ($attrFormat as $k => $v) {
+                foreach ($detail as $kk => $vv) {
+                    if ($v['detail'] == $vv['detail']) {
+                        $attrFormat[$k]['price'] = $vv['price'];
+                        $attrFormat[$k]['sales'] = $vv['sales'];
+                        $attrFormat[$k]['pic'] = $vv['pic'];
+                        $attrFormat[$k]['check'] = false;
+                        break;
+                    } else {
+                        $attrFormat[$k]['price'] = '';
+                        $attrFormat[$k]['sales'] = '';
+                        $attrFormat[$k]['pic'] = $product['image'];
+                        $attrFormat[$k]['check'] = true;
+                    }
+                }
+            }
+        } else {
+            foreach ($attrFormat as $k => $v) {
+                $attrFormat[$k]['price'] = $product['price'];
+                $attrFormat[$k]['sales'] = $product['stock'];
+                $attrFormat[$k]['pic'] = $product['image'];
+                $attrFormat[$k]['check'] = false;
+            }
+        }
+        return Json::successful($attrFormat);
+    }
+
+    /**
+     * 添加 修改属性
+     * @param $id
+     */
+    public function set_attr($id)
+    {
+        if (!$id) return $this->failed('商品不存在!');
+        list($attr, $detail) = Util::postMore([
+            ['items', []],
+            ['attrs', []]
+        ], $this->request, true);
+        $res = StoreSeckillAttr::createProductAttr($attr, $detail, $id);
+        if ($res)
+            return $this->successful('编辑属性成功!');
+        else
+            return $this->failed(StoreSeckillAttr::getErrorInfo());
+    }
+
+    /**
+     * 清除属性
+     * @param $id
+     */
+    public function clear_attr($id)
+    {
+        if (!$id) return $this->failed('商品不存在!');
+        if (false !== StoreSeckillAttr::clearProductAttr($id) && false !== StoreSeckillAttrResult::clearResult($id))
+            return $this->successful('清空商品属性成功!');
+        else
+            return $this->failed(StoreSeckillAttr::getErrorInfo('清空商品属性失败!'));
+    }
+
+    /**
+     * 修改秒杀商品状态
+     * @param $status
+     * @param int $id
+     */
+    public function set_seckill_status($status, $id = 0)
+    {
+        if (!$id) return Json::fail('参数错误');
+        $res = StoreProductAttrValue::where('product_id', $id)->where('type', 1)->find();
+        if (!$res) return Json::fail('请先配置规格');
+        $res = StoreSeckillModel::edit(['status' => $status], $id);
+        if ($res) return Json::successful('修改成功');
+        else return Json::fail('修改失败');
+    }
+
+    /**
+     * 秒杀获取商品列表
+     * @return string
+     * @throws \Exception
+     */
+    public function productList()
+    {
+        $cate = StoreCategory::getTierList(null, 1);
+        $this->assign('cate', $cate);
+        return $this->fetch();
+    }
+
+    /**
+     * 获取秒杀商品规格
+     * @param $attr
+     * @param $id
+     * @param $type
+     * @return array
+     */
+    public function get_attr($attr, $id, $type)
+    {
+        $value = attr_format($attr)[1];
+        $valueNew = [];
+        $count = 0;
+        foreach ($value as $key => $item) {
+            $detail = $item['detail'];
+            sort($item['detail'], SORT_STRING);
+            $suk = implode(',', $item['detail']);
+            $sukValue = StoreProductAttrValue::where('product_id', $id)->where('type', $type)->where('suk', $suk)->column('bar_code,cost,price,ot_price,stock,image as pic,weight,volume,brokerage,brokerage_two,quota', 'suk');
+            if (count($sukValue)) {
+                foreach (array_values($detail) as $k => $v) {
+                    $valueNew[$count]['value' . ($k + 1)] = $v;
+                }
+                $valueNew[$count]['detail'] = json_encode($detail);
+                $valueNew[$count]['pic'] = $sukValue[$suk]['pic'] ?? '';
+                $valueNew[$count]['price'] = isset($sukValue[$suk]['price']) ? floatval($sukValue[$suk]['price']) : 0;
+                $valueNew[$count]['cost'] = isset($sukValue[$suk]['cost']) ? floatval($sukValue[$suk]['cost']) : 0;
+                $valueNew[$count]['ot_price'] = isset($sukValue[$suk]['ot_price']) ? floatval($sukValue[$suk]['ot_price']) : 0;
+                $valueNew[$count]['stock'] = isset($sukValue[$suk]['stock']) ? intval($sukValue[$suk]['stock']) : 0;
+                $valueNew[$count]['quota'] = isset($sukValue[$suk]['quota']) ? intval($sukValue[$suk]['quota']) : 0;
+                $valueNew[$count]['bar_code'] = $sukValue[$suk]['bar_code'] ?? '';
+                $valueNew[$count]['weight'] = $sukValue[$suk]['weight'] ?? 0;
+                $valueNew[$count]['volume'] = $sukValue[$suk]['volume'] ?? 0;
+                $valueNew[$count]['brokerage'] = $sukValue[$suk]['brokerage'] ?? 0;
+                $valueNew[$count]['brokerage_two'] = $sukValue[$suk]['brokerage_two'] ?? 0;
+                $valueNew[$count]['check'] = $type != 0 ? 1 : 0;
+                $count++;
+            }
+        }
+        return $valueNew;
+    }
+}

+ 592 - 0
app/admin/controller/ump/StoreSeckill.php

@@ -0,0 +1,592 @@
+<?php
+
+namespace app\admin\controller\ump;
+
+use app\admin\controller\AuthController;
+use app\admin\model\store\{StoreDescription,
+    StoreProductAttr,
+    StoreProductAttrResult,
+    StoreProduct as ProductModel,
+    StoreProductAttrValue};
+use crmeb\traits\CurdControllerTrait;
+use think\Exception;
+use think\exception\ErrorException;
+use think\exception\ValidateException;
+use think\facade\Route as Url;
+use app\admin\model\system\{SystemAttachment, SystemGroupData, ShippingTemplates};
+use app\admin\model\ump\{StoreSeckillAttr, StoreSeckillAttrResult, StoreSeckill as StoreSeckillModel, StoreSeckillTime};
+use crmeb\services\{
+    FormBuilder as Form, UtilService as Util, JsonService as Json
+};
+use app\admin\model\store\StoreCategory;
+
+/**
+ * 限时秒杀  控制器
+ * Class StoreSeckill
+ * @package app\admin\controller\store
+ */
+class StoreSeckill extends AuthController
+{
+
+    use CurdControllerTrait;
+
+    protected $bindModel = StoreSeckillModel::class;
+
+    /**
+     * 显示资源列表
+     *
+     * @return \think\Response
+     */
+    public function index()
+    {
+        $this->assign('countSeckill', StoreSeckillModel::getSeckillCount());
+        $this->assign('seckillId', StoreSeckillModel::getSeckillIdAll());
+        return $this->fetch();
+    }
+
+    public function save_excel()
+    {
+        $where = Util::getMore([
+            ['status', ''],
+            ['store_name', '']
+        ]);
+        StoreSeckillModel::SaveExcel($where);
+    }
+
+    /**
+     * 异步获取砍价数据
+     */
+    public function get_seckill_list()
+    {
+        $where = Util::getMore([
+            ['page', 1],
+            ['limit', 20],
+            ['status', ''],
+            ['store_name', '']
+        ]);
+        $seckillList = StoreSeckillModel::systemPage($where);
+        if (is_object($seckillList['list'])) $seckillList['list'] = $seckillList['list']->toArray();
+        $data = $seckillList['list']['data'];
+        foreach ($data as $k => $v) {
+            $end_time = $v['stop_time'] ? date('Y/m/d', $v['stop_time']) : '';
+            if ($end_time) {
+                $config = SystemGroupData::get($v['time_id']);
+                if ($config) {
+                    $arr = json_decode($config->value, true);
+                    $start_hour = intval($arr['time']['value']);
+                    $continued = intval($arr['continued']['value']);
+                    $end_hour = $start_hour + $continued;
+                    $end_time = $end_time . ' ' . $end_hour . ':00:00';
+                }
+            }
+            $data[$k]['_stop_time'] = $end_time;
+        }
+        return Json::successlayui(['count' => $seckillList['list']['total'], 'data' => $data]);
+    }
+
+    public function get_seckill_id()
+    {
+        return Json::successlayui(StoreSeckillModel::getSeckillIdAll());
+    }
+
+    /**
+     * 添加秒杀商品
+     * @return form-builder
+     */
+    public function create()
+    {
+        $f = array();
+        $f[] = Form::frameImageOne('product', '选择商品', Url::buildUrl('productList', array('fodder' => 'product')))->icon('plus')->width('100%')->height('500px');
+        $f[] = Form::hidden('product_id', '');
+        $f[] = Form::hidden('description', '');
+        $f[] = Form::input('title', '商品标题');
+        $f[] = Form::input('info', '秒杀活动简介')->type('textarea');
+        $f[] = Form::input('unit_name', '单位')->placeholder('个、位');
+        $f[] = Form::select('temp_id', '秒杀运费模板')->setOptions(function () {
+            $list = ShippingTemplates::getList(['page' => 1, 'limit' => 20]);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['name']];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::dateRange('section_time', '活动日期');
+        $f[] = Form::select('time_id', '开始时间')->setOptions(function () {
+            $list = SystemGroupData::getGroupData('routine_seckill_time', 20);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['time'] . '点开始,持续' . $menu['continued'] . '小时'];//,'disabled'=>$menu['pid']== 0];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::frameImageOne('image', '商品主图片(305*305px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')))->icon('image')->width('100%')->height('500px');
+        $f[] = Form::frameImages('images', '商品轮播图(640*640px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'images')))->maxLength(5)->icon('images')->width('100%')->height('500px');
+        $f[] = Form::number('sort', '排序')->col(12);
+        $f[] = Form::number('num', '单次购买商品个数')->precision(0)->col(12);
+        $f[] = Form::number('give_integral', '赠送积分')->min(0)->precision(0)->col(12);
+        $f[] = Form::radio('is_hot', '热门推荐', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        $form = Form::make_post_form('添加用户通知', $f, Url::buildUrl('save'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存秒杀商品
+     * @param int $id
+     */
+    public function save($id = 0)
+    {
+        $data = Util::postMore([
+            'title',
+            'product_id',
+            'info',
+            'unit_name',
+            ['image', ''],
+            ['images', []],
+            ['price', 0],
+            ['ot_price', 0],
+            ['cost', 0],
+            ['sales', 0],
+            ['stock', 0],
+            ['sort', 0],
+            ['give_integral', 0],
+            ['postage', 0],
+            ['section_time', []],
+            ['is_postage', 0],
+            ['cost', 0],
+            ['is_hot', 0],
+            ['status', 0],
+            ['num', 0],
+            'time_id',
+            'temp_id',
+            ['weight', 0],
+            ['volume', 0],
+        ]);
+        $data['description'] = StoreDescription::getDescription($data['product_id']);
+        if (!$data['title']) return Json::fail('请输入商品标题');
+        if (!$data['unit_name']) return Json::fail('请输入商品单位');
+        if (!$data['product_id']) return Json::fail('商品ID不能为空');
+        if (count($data['section_time']) < 1) return Json::fail('请选择活动时间');
+        if (!$data['time_id']) return Json::fail('时间段不能为空');
+        $data['start_time'] = strtotime($data['section_time'][0] .' 00:00:00');
+        $data['stop_time'] = strtotime($data['section_time'][1].' 23:59:59');
+        unset($data['section_time']);
+        if (!$data['image']) return Json::fail('请选择推荐图');
+        if (count($data['images']) < 1) return Json::fail('请选择轮播图');
+        $data['images'] = json_encode($data['images']);
+        if ($data['num'] < 1) return Json::fail('请输入单次秒杀个数');
+        if ($id) {
+            unset($data['description']);
+            $product = StoreSeckillModel::get($id);
+            if (!$product) return Json::fail('数据不存在!');
+            StoreSeckillModel::edit($data, $id);
+            return Json::successful('编辑成功!');
+        } else {
+            if(StoreSeckillModel::checkSeckill($data['product_id'],$data['time_id'])) return Json::fail('该商品当前时间段已有秒杀活动');
+            $data['add_time'] = time();
+            $res = StoreSeckillModel::create($data);
+            $description['product_id'] = $res['id'];
+            $description['description'] = htmlspecialchars_decode($data['description']);
+            $description['type'] = 1;
+            StoreDescription::create($description);
+            return Json::successful('添加成功!');
+        }
+
+    }
+
+    /** 开启秒杀
+     * @param $id
+     * @return mixed|void
+     */
+    public function seckill($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = ProductModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $f = array();
+        $f[] = Form::input('title', '商品标题', $product->getData('store_name'));
+        $f[] = Form::hidden('product_id', $id);
+        $f[] = Form::input('info', '秒杀活动简介', $product->getData('store_info'))->type('textarea');
+        $f[] = Form::input('unit_name', '单位', $product->getData('unit_name'))->placeholder('个、位');
+        $f[] = Form::select('temp_id', '秒杀运费模板', (string)$product->getData('temp_id'))->setOptions(function () {
+            $list = ShippingTemplates::getList(['page' => 1, 'limit' => 20]);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['name']];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::dateRange('section_time', '活动日期');
+        $f[] = Form::select('time_id', '开始时间')->setOptions(function () {
+            $list = SystemGroupData::getGroupData('routine_seckill_time', 20);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['time'] . '点开始,持续' . $menu['continued'] . '小时'];//,'disabled'=>$menu['pid']== 0];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::frameImageOne('image', '商品主图片(305*305px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')), $product->getData('image'))->icon('image')->width('100%')->height('500px');
+        $f[] = Form::frameImages('images', '商品轮播图(640*640px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'images')), json_decode($product->getData('slider_image')))->maxLength(5)->icon('images')->width('100%')->height('500px');
+        $f[] = Form::number('price', '秒杀价')->min(0)->col(12);
+        $f[] = Form::number('ot_price', '原价', $product->getData('price'))->min(0)->col(12);
+        $f[] = Form::number('cost', '成本价', $product->getData('cost'))->min(0)->col(12);
+        $f[] = Form::number('stock', '库存', $product->getData('stock'))->min(0)->precision(0)->col(12);
+        $f[] = Form::number('sales', '销量', $product->getData('sales'))->min(0)->precision(0)->col(12);
+        $f[] = Form::number('sort', '排序', $product->getData('sort'))->col(12);
+        $f[] = Form::number('num', '单次购买商品个数', 1)->precision(0)->col(12);
+        $f[] = Form::number('give_integral', '赠送积分', $product->getData('give_integral'))->min(0)->precision(0)->col(12);
+        $f[] = Form::number('weight', '重量', 0)->min(0)->col(12);
+        $f[] = Form::number('volume', '体积', 0)->min(0)->col(12);
+        $f[] = Form::radio('is_hot', '热门推荐', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        $f[] = Form::radio('status', '活动状态', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        $form = Form::make_post_form('添加用户通知', $f, Url::buildUrl('save'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 显示编辑资源表单页.
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function edit($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreSeckillModel::get($id);
+//        $time = StoreSeckillTime::getSeckillTime($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $f = array();
+        $f[] = Form::input('product_id','产品ID', $product->getData('product_id'))->disabled(true);
+        $f[] = Form::input('title', '商品标题', $product->getData('title'));
+        $f[] = Form::input('info', '秒杀活动简介', $product->getData('info'))->type('textarea');
+        $f[] = Form::input('unit_name', '单位', $product->getData('unit_name'))->placeholder('个、位');
+        $f[] = Form::select('temp_id', '秒杀运费模板', (string)$product->getData('temp_id'))->setOptions(function () {
+            $list = ShippingTemplates::getList(['page' => 1, 'limit' => 20]);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['name']];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::dateRange('section_time', '活动时间', date('Y-m-d H:i:s', (int)$product->getData('start_time')), date('Y-m-d H:i:s', (int)$product->getData('stop_time')));
+        $f[] = Form::select('time_id', '开始时间', (string)$product->getData('time_id'))->setOptions(function () {
+            $list = SystemGroupData::getGroupData('routine_seckill_time', 20);
+            $menus = [];
+            foreach ($list['data'] as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['time'] . '点开始,持续' . $menu['continued'] . '小时'];//,'disabled'=>$menu['pid']== 0];
+            }
+            return $menus;
+        })->filterable(1)->col(12);
+        $f[] = Form::frameImageOne('image', '商品主图片(305*305px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')), $product->getData('image'))->icon('image')->width('100%')->height('500px');
+        $f[] = Form::frameImages('images', '商品轮播图(640*640px)', Url::buildUrl('admin/widget.images/index', array('fodder' => 'images')), json_decode($product->getData('images')))->maxLength(5)->icon('images')->width('100%')->height('500px');
+        $f[] = Form::number('sort', '排序', $product->getData('sort'))->col(12);
+        $f[] = Form::hidden('stock', $product->getData('stock'));
+        $f[] = Form::hidden('price', $product->getData('price'));
+        $f[] = Form::hidden('ot_price', $product->getData('ot_price'));
+        $f[] = Form::hidden('sales', $product->getData('sales'));
+        $f[] = Form::number('num', '单次购买商品个数', $product->getData('num'))->precision(0)->col(12);
+        $f[] = Form::number('give_integral', '赠送积分', $product->getData('give_integral'))->min(0)->precision(0)->col(12);
+        $f[] = Form::radio('is_hot', '热门推荐', $product->getData('is_hot'))->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]])->col(12);
+        $f[] = Form::hidden('status', $product->getData('status'));
+        $form = Form::make_post_form('添加用户通知', $f, Url::buildUrl('save', compact('id')));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function delete($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = StoreSeckillModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        if ($product['is_del']) return Json::fail('已删除!');
+        $data['is_del'] = 1;
+        if (!StoreSeckillModel::edit($data, $id))
+            return Json::fail(StoreSeckillModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+
+    public function edit_content($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $seckill = StoreSeckillModel::get($id);
+        if (!$seckill) return Json::fail('数据不存在!');
+        $this->assign([
+            'content' => htmlspecialchars_decode(StoreDescription::getDescription($id, 1)),
+            'field' => 'description',
+            'action' => Url::buildUrl('change_field', ['id' => $id, 'field' => 'description'])
+        ]);
+        return $this->fetch('public/edit_content');
+    }
+
+    public function change_field($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $seckill = StoreSeckillModel::get($id);
+        if (!$seckill) return Json::fail('数据不存在!');
+        $data['description'] = request()->post('description');
+        StoreDescription::saveDescription($data['description'], $id, 1);
+        $res = StoreSeckillModel::edit($data, $id);
+        if ($res)
+            return Json::successful('添加成功');
+        else
+            return Json::fail('添加失败');
+    }
+
+    /**
+     * 属性页面
+     * @param $id
+     * @return mixed|void
+     */
+    public function attr($id)
+    {
+        if (!$id) return $this->failed('数据不存在!');
+        $result = StoreSeckillAttrResult::getResult($id);
+        $image = StoreSeckillModel::where('id', $id)->value('image');
+        $this->assign(compact('id', 'result', 'image'));
+        return $this->fetch();
+    }
+
+    /**
+     * 秒杀属性选择页面
+     * @param $id
+     * @return string|void
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function attr_list($id)
+    {
+        if (!$id) return $this->failed('数据不存在!');
+        $seckillInfo = StoreSeckillModel::where('id', $id)->find();
+        $seckillResult = StoreProductAttrResult::where('product_id', $id)->where('type', 1)->value('result');
+        $productResult = StoreProductAttrResult::where('product_id', $seckillInfo['product_id'])->where('type', 0)->value('result');
+        if ($productResult) {
+            $attr = json_decode($productResult, true)['attr'];
+            $productAttr = $this->get_attr($attr, $seckillInfo['product_id'], 0);
+            $seckillAttr = $this->get_attr($attr, $id, 1);
+            foreach ($productAttr as $pk => $pv) {
+                foreach ($seckillAttr as $sv) {
+                    if ($pv['detail'] == $sv['detail']) {
+                        $productAttr[$pk] = $sv;
+                    }
+                }
+            }
+        } else {
+            if ($seckillResult) {
+                $attr = json_decode($seckillResult, true)['attr'];
+                $productAttr = $this->get_attr($attr, $id, 1);
+            } else {
+                $attr[0]['value'] = '默认';
+                $attr[0]['detailValue'] = '';
+                $attr[0]['attrHidden'] = '';
+                $attr[0]['detail'][0] = '默认';
+                $productAttr[0]['value1'] = '默认';
+                $productAttr[0]['detail'] = json_encode(['默认' => '默认']);
+                $productAttr[0]['pic'] = $seckillInfo['image'];
+                $productAttr[0]['price'] = $seckillInfo['price'];
+                $productAttr[0]['cost'] = $seckillInfo['cost'];
+                $productAttr[0]['ot_price'] = $seckillInfo['ot_price'];
+                $productAttr[0]['stock'] = $seckillInfo['stock'];
+                $productAttr[0]['quota'] = 0;
+                $productAttr[0]['bar_code'] = $seckillInfo['bar_code'];
+                $productAttr[0]['weight'] = 0;
+                $productAttr[0]['volume'] = 0;
+                $productAttr[0]['brokerage'] = 0;
+                $productAttr[0]['brokerage_two'] = 0;
+                $productAttr[0]['check'] = 0;
+            }
+        }
+        $attrs['attr'] = $attr;
+        $attrs['value'] = $productAttr;
+        $this->assign('attr', $attrs);
+        $this->assign('id', $id);
+        return $this->fetch();
+    }
+
+    /**
+     * 秒杀属性保存页面
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function save_attr()
+    {
+        $data = Util::postMore([
+            ['attr', []],
+            ['ids', []],
+            ['id', 0],
+        ]);
+        if (!$data['id']) return Json::fail('数据不存在!');
+        if (!$data['ids']) return Json::fail('你没有选择任何规格!');
+        $productId = StoreSeckillModel::where('id', $data['id'])->value('product_id');
+        $attr = json_decode(StoreProductAttrResult::where('product_id', $productId)->where('type', 0)->value('result'), true)['attr'];
+        foreach ($data['attr'] as $k => $v) {
+            if (in_array($k, $data['ids'])) {
+                $v['detail'] = json_decode(htmlspecialchars_decode($v['detail']), true);
+                $detail[$k] = $v;
+            }
+        }
+        if (min(array_column($detail, 'quota')) == 0) return Json::fail('限购不能为0');
+        $price = min(array_column($detail, 'price'));
+        $otPrice = min(array_column($detail, 'ot_price'));
+        $quota = array_sum(array_column($detail, 'quota'));
+        $stock = array_sum(array_column($detail, 'stock'));
+        if (!$attr) {
+            $attr[0]['value'] = '默认';
+            $attr[0]['detailValue'] = '';
+            $attr[0]['attrHidden'] = '';
+            $attr[0]['detail'][0] = '默认';
+        }
+        StoreProductAttr::createProductAttr($attr, $detail, $data['id'], 1);
+        StoreSeckillModel::where('id', $data['id'])->update(['stock' => $stock, 'quota' => $quota, 'quota_show' => $quota, 'price' => $price, 'ot_price' => $otPrice]);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 生成属性
+     * @param int $id
+     */
+    public function is_format_attr($id = 0)
+    {
+        if (!$id) return Json::fail('商品不存在');
+        list($attr, $detail) = Util::postMore([
+            ['items', []],
+            ['attrs', []]
+        ], $this->request, true);
+        $product = StoreSeckillModel::get($id);
+        if (!$product) return Json::fail('商品不存在');
+        $attrFormat = attr_format($attr)[1];
+        if (count($detail)) {
+            foreach ($attrFormat as $k => $v) {
+                foreach ($detail as $kk => $vv) {
+                    if ($v['detail'] == $vv['detail']) {
+                        $attrFormat[$k]['price'] = $vv['price'];
+                        $attrFormat[$k]['sales'] = $vv['sales'];
+                        $attrFormat[$k]['pic'] = $vv['pic'];
+                        $attrFormat[$k]['check'] = false;
+                        break;
+                    } else {
+                        $attrFormat[$k]['price'] = '';
+                        $attrFormat[$k]['sales'] = '';
+                        $attrFormat[$k]['pic'] = $product['image'];
+                        $attrFormat[$k]['check'] = true;
+                    }
+                }
+            }
+        } else {
+            foreach ($attrFormat as $k => $v) {
+                $attrFormat[$k]['price'] = $product['price'];
+                $attrFormat[$k]['sales'] = $product['stock'];
+                $attrFormat[$k]['pic'] = $product['image'];
+                $attrFormat[$k]['check'] = false;
+            }
+        }
+        return Json::successful($attrFormat);
+    }
+
+    /**
+     * 添加 修改属性
+     * @param $id
+     */
+    public function set_attr($id)
+    {
+        if (!$id) return $this->failed('商品不存在!');
+        list($attr, $detail) = Util::postMore([
+            ['items', []],
+            ['attrs', []]
+        ], $this->request, true);
+        $res = StoreSeckillAttr::createProductAttr($attr, $detail, $id);
+        if ($res)
+            return $this->successful('编辑属性成功!');
+        else
+            return $this->failed(StoreSeckillAttr::getErrorInfo());
+    }
+
+    /**
+     * 清除属性
+     * @param $id
+     */
+    public function clear_attr($id)
+    {
+        if (!$id) return $this->failed('商品不存在!');
+        if (false !== StoreSeckillAttr::clearProductAttr($id) && false !== StoreSeckillAttrResult::clearResult($id))
+            return $this->successful('清空商品属性成功!');
+        else
+            return $this->failed(StoreSeckillAttr::getErrorInfo('清空商品属性失败!'));
+    }
+
+    /**
+     * 修改秒杀商品状态
+     * @param $status
+     * @param int $id
+     */
+    public function set_seckill_status($status, $id = 0)
+    {
+        if (!$id) return Json::fail('参数错误');
+        $res = StoreProductAttrValue::where('product_id', $id)->where('type', 1)->find();
+        if (!$res) return Json::fail('请先配置规格');
+        $res = StoreSeckillModel::edit(['status' => $status], $id);
+        if ($res) return Json::successful('修改成功');
+        else return Json::fail('修改失败');
+    }
+
+    /**
+     * 秒杀获取商品列表
+     * @return string
+     * @throws \Exception
+     */
+    public function productList()
+    {
+        $cate = StoreCategory::getTierList(null, 1);
+        $this->assign('cate', $cate);
+        return $this->fetch();
+    }
+
+    /**
+     * 获取秒杀商品规格
+     * @param $attr
+     * @param $id
+     * @param $type
+     * @return array
+     */
+    public function get_attr($attr, $id, $type)
+    {
+        $value = attr_format($attr)[1];
+        $valueNew = [];
+        $count = 0;
+        foreach ($value as $key => $item) {
+            $detail = $item['detail'];
+            sort($item['detail'], SORT_STRING);
+            $suk = implode(',', $item['detail']);
+            $sukValue = StoreProductAttrValue::where('product_id', $id)->where('type', $type)->where('suk', $suk)->column('bar_code,cost,price,ot_price,stock,image as pic,weight,volume,brokerage,brokerage_two,quota', 'suk');
+            if (count($sukValue)) {
+                foreach (array_values($detail) as $k => $v) {
+                    $valueNew[$count]['value' . ($k + 1)] = $v;
+                }
+                $valueNew[$count]['detail'] = json_encode($detail);
+                $valueNew[$count]['pic'] = $sukValue[$suk]['pic'] ?? '';
+                $valueNew[$count]['price'] = isset($sukValue[$suk]['price']) ? floatval($sukValue[$suk]['price']) : 0;
+                $valueNew[$count]['cost'] = isset($sukValue[$suk]['cost']) ? floatval($sukValue[$suk]['cost']) : 0;
+                $valueNew[$count]['ot_price'] = isset($sukValue[$suk]['ot_price']) ? floatval($sukValue[$suk]['ot_price']) : 0;
+                $valueNew[$count]['stock'] = isset($sukValue[$suk]['stock']) ? intval($sukValue[$suk]['stock']) : 0;
+                $valueNew[$count]['quota'] = isset($sukValue[$suk]['quota']) ? intval($sukValue[$suk]['quota']) : 0;
+                $valueNew[$count]['bar_code'] = $sukValue[$suk]['bar_code'] ?? '';
+                $valueNew[$count]['weight'] = $sukValue[$suk]['weight'] ?? 0;
+                $valueNew[$count]['volume'] = $sukValue[$suk]['volume'] ?? 0;
+                $valueNew[$count]['brokerage'] = $sukValue[$suk]['brokerage'] ?? 0;
+                $valueNew[$count]['brokerage_two'] = $sukValue[$suk]['brokerage_two'] ?? 0;
+                $valueNew[$count]['check'] = $type != 0 ? 1 : 0;
+                $count++;
+            }
+        }
+        return $valueNew;
+    }
+}

+ 78 - 0
app/admin/controller/ump/UserPoint.php

@@ -0,0 +1,78 @@
+<?php
+
+namespace app\admin\controller\ump;
+
+use app\admin\controller\AuthController;
+use crmeb\services\UtilService as Util;
+use app\admin\model\user\UserPoint AS UserPointModel;
+use think\facade\Route as Url;
+use crmeb\services\JsonService;
+
+/**
+ * 优惠券控制器
+ * Class StoreCategory
+ * @package app\admin\controller\system
+ */
+class UserPoint extends AuthController
+{
+
+    /**
+     * @return mixed
+     */
+    public function index()
+    {
+        $this->assign([
+//            'sum_point'=>UserBill::where(['category'=>'integral','type'=>'system_add'])->sum('number'),
+//            'count'=>UserBill::where(['category'=>'integral','type'=>'sign'])->group('uid')->count(),
+//            'song_point'=>UserBill::where(['category'=>'integral','type'=>'sign'])->group('uid')->sum('number'),
+            'is_layui' => true,
+            'year' => get_month(),
+        ]);
+        return $this->fetch();
+    }
+
+    /**
+     * @return mixed
+     */
+    public function create()
+    {
+        $this->assign(['title' => '添加优惠券', 'action' => Url::buildUrl('save'), 'rules' => $this->rules()->getContent()]);
+        return $this->fetch('public/common_form');
+    }
+
+    //异步获取积分列表
+    public function getponitlist()
+    {
+        $where = Util::getMore([
+            ['start_time', ''],
+            ['end_time', ''],
+            ['nickname', ''],
+            ['page', 1],
+            ['limit', 10],
+        ]);
+        return JsonService::successlayui(UserPointModel::getpointlist($where));
+    }
+
+    //导出Excel表格
+    public function export()
+    {
+        $where = Util::getMore([
+            ['start_time', ''],
+            ['end_time', ''],
+            ['nickname', ''],
+        ]);
+        UserPointModel::SaveExport($where);
+    }
+
+    //获取积分日志头部信息
+    public function getuserpointbadgelist()
+    {
+        $where = Util::getMore([
+            ['start_time', ''],
+            ['end_time', ''],
+            ['nickname', ''],
+        ]);
+        return JsonService::successful(UserPointModel::getUserpointBadgelist($where));
+    }
+
+}

+ 862 - 0
app/admin/controller/user/User.php

@@ -0,0 +1,862 @@
+<?php
+/**
+ *
+ * @author: xaboy<365615158@qq.com>
+ * @day: 2017/11/11
+ */
+
+namespace app\admin\controller\user;
+
+use app\admin\controller\AuthController;
+use crmeb\repositories\UserRepository;
+use crmeb\traits\CurdControllerTrait;
+use think\facade\Route as Url;
+use crmeb\basic\BaseModel;
+use app\models\user\UserLevel as Level;
+use app\admin\model\order\StoreOrder;
+use app\admin\model\wechat\WechatMessage;
+use app\admin\model\store\{StoreVisit, StoreCouponUser};
+use app\admin\model\system\{SystemUserLevel, SystemUserTask};
+use crmeb\services\{FormBuilder as Form, UtilService as Util, JsonService as Json};
+use app\admin\model\user\{User as UserModel, UserBill as UserBillAdmin, UserLevel, UserGroup, UserTaskFinish};
+/**
+ * 用户管理控制器
+ * Class User
+ * @package app\admin\controller\user
+ */
+class User extends AuthController
+{
+    use CurdControllerTrait;
+
+    /**
+     * 显示资源列表
+     *
+     * @return \think\Response
+     */
+    public function index()
+    {
+        $level = SystemUserLevel::where('is_del', 0)->where('is_show', 1)->order('grade asc')->field(['id', 'name'])->select();
+        $group = UserGroup::select();
+        $this->assign(compact('group'));
+        $this->assign(compact('level'));
+        $this->assign('count_user', UserModel::getcount());
+        return $this->fetch();
+    }
+
+    /**
+     * 设置分组
+     * @param int $uid
+     */
+    public function set_group($uid = 0)
+    {
+        if (!$uid) return $this->failed('缺少参数');
+        $userGroup = UserGroup::select();
+        $field[] = Form::select('group_id', '会员分组')->setOptions(function () use ($userGroup) {
+            $menus = [];
+            foreach ($userGroup as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['group_name']];
+            }
+            return $menus;
+        })->filterable(1);
+        $form = Form::make_post_form('设置分组', $field, Url::buildUrl('save_set_group', ['uid' => $uid]), 2);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    public function save_set_group($uid = 0)
+    {
+        if (!$uid) return Json::fail('缺少参数');
+        list($group_id) = Util::postMore([
+            ['group_id', 0],
+        ], $this->request, true);
+        $uids = explode(',',$uid);
+        $res = UserModel::whereIn('uid', $uids)->update(['group_id' => $group_id]);
+        if ($res) {
+            return Json::successful('设置成功');
+        } else {
+            return Json::successful('设置失败');
+        }
+    }
+
+    /**
+     * 赠送会员等级
+     * @param int $uid
+     * @return string|void
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     */
+    public function give_level($uid = 0)
+    {
+        if (!$uid) return $this->failed('缺少参数');
+        $level = Level::getUserLevel($uid);
+        //获取当前会员等级
+        if ($level === false)
+            $grade = 0;
+        else
+            $grade = Level::getUserLevelInfo($level, 'grade');
+        //查询高于当前会员的所有会员等级
+        $systemLevelList = SystemUserLevel::where('grade', '>', $grade)->where(['is_show' => 1, 'is_del' => 0])->field(['name', 'id'])->select();
+        $field[] = Form::select('level_id', '会员等级')->setOptions(function () use ($systemLevelList) {
+            $menus = [];
+            foreach ($systemLevelList as $menu) {
+                $menus[] = ['value' => $menu['id'], 'label' => $menu['name']];
+            }
+            return $menus;
+        })->filterable(1);
+        $form = Form::make_post_form('赠送会员', $field, Url::buildUrl('save_give_level', ['uid' => $uid]), 2);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    public function edit_other($uid)
+    {
+        if (!$uid) return $this->failed('数据不存在');
+        $user = UserModel::get($uid);
+        if (!$user) return Json::fail('数据不存在!');
+        $f = array();
+        $f[] = Form::radio('money_status', '修改余额', 1)->options([['value' => 1, 'label' => '增加'], ['value' => 2, 'label' => '减少']]);
+        $f[] = Form::number('money', '余额')->min(0);
+        $f[] = Form::radio('integration_status', '修改趣豆', 1)->options([['value' => 1, 'label' => '增加'], ['value' => 2, 'label' => '减少']]);
+        $f[] = Form::number('integration', '趣豆')->min(0);
+        $f[] = Form::radio('anticipate_status', '修改艺金券', 1)->options([['value' => 1, 'label' => '增加'], ['value' => 2, 'label' => '减少']]);
+        $f[] = Form::number('anticipate', '艺金券')->min(0);
+        $form = Form::make_post_form('修改其他', $f, Url::buildUrl('update_other', array('uid' => $uid)));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    public function update_other($uid = 0)
+    {
+        $data = Util::postMore([
+            ['money_status', 0],
+            ['money', 0],
+            ['integration_status', 0],
+            ['integration', 0],
+            ['anticipate_status', 0],
+            ['anticipate', 0],
+        ], $this->request);
+        if (!$uid) return $this->failed('数据不存在');
+        $user = UserModel::get($uid);
+        if (!$user) return Json::fail('数据不存在!');
+        BaseModel::beginTrans();
+        $res1 = false;
+        $res2 = false;
+        $edit = array();
+        if ($data['money_status'] && $data['money']) {//余额增加或者减少
+            if ($data['money_status'] == 1) {//增加
+                $edit['now_money'] = bcadd($user['now_money'], $data['money'], 2);
+                $res1 = UserBillAdmin::income('系统增加余额', $user['uid'], 'now_money', 'system_add', $data['money'], $this->adminId, $edit['now_money'], '系统增加了' . floatval($data['money']) . '余额');
+                try {
+                    UserRepository::adminAddMoney($user, $data['money']);
+                } catch (\Exception $e) {
+                    BaseModel::rollbackTrans();
+                    return Json::fail($e->getMessage());
+                }
+            } else if ($data['money_status'] == 2) {//减少
+                $edit['now_money'] = bcsub($user['now_money'], $data['money'], 2);
+                $res1 = UserBillAdmin::expend('系统减少余额', $user['uid'], 'now_money', 'system_sub', $data['money'], $this->adminId, $edit['now_money'], '系统扣除了' . floatval($data['money']) . '余额');
+                try {
+                    UserRepository::adminSubMoney($user, $data['money']);
+                } catch (\Exception $e) {
+                    BaseModel::rollbackTrans();
+                    return Json::fail($e->getMessage());
+                }
+            }
+        } else {
+            $res1 = true;
+        }
+        if ($data['integration_status'] && $data['integration']) {//趣豆增加或者减少
+            if ($data['integration_status'] == 1) {//增加
+                $edit['integral'] = bcadd($user['integral'], $data['integration'], 2);
+                $res2 = UserBillAdmin::income('系统增加趣豆', $user['uid'], 'integral', 'system_add', $data['integration'], $this->adminId, $edit['integral'], '系统增加了' . floatval($data['integration']) . '趣豆');
+                try {
+                    UserRepository::adminAddIntegral($user, $data['integration']);
+                } catch (\Exception $e) {
+                    BaseModel::rollbackTrans();
+                    return Json::fail($e->getMessage());
+                }
+            } else if ($data['integration_status'] == 2) {//减少
+                $edit['integral'] = bcsub($user['integral'], $data['integration'], 2);
+                $res2 = UserBillAdmin::expend('系统减少趣豆', $user['uid'], 'integral', 'system_sub', $data['integration'], $this->adminId, $edit['integral'], '系统扣除了' . floatval($data['integration']) . '趣豆');
+                try {
+                    UserRepository::adminSubIntegral($user, $data['integration']);
+                } catch (\Exception $e) {
+                    BaseModel::rollbackTrans();
+                    return Json::fail($e->getMessage());
+                }
+            }
+        } else {
+            $res2 = true;
+        }
+        if ($data['anticipate_status'] && $data['anticipate']) {//趣豆增加或者减少
+            if ($data['anticipate_status'] == 1) {//增加
+                $edit['anticipate'] = bcadd($user['anticipate'], $data['anticipate'], 2);
+                $res3 = UserBillAdmin::income('系统增加艺金券', $user['uid'], 'anticipate', 'add_anticipate', $data['anticipate'], $this->adminId, $edit['anticipate'], '系统增加了' . floatval($data['anticipate']) . '艺金券');
+                try {
+                    UserRepository::adminAddIntegral($user, $data['integration']);
+                } catch (\Exception $e) {
+                    BaseModel::rollbackTrans();
+                    return Json::fail($e->getMessage());
+                }
+            } else if ($data['anticipate_status'] == 2) {//减少
+                $edit['anticipate'] = bcsub($user['anticipate'], $data['anticipate'], 2);
+                $res3 = UserBillAdmin::expend('系统减少艺金券', $user['uid'], 'anticipate', 'reduce_anticipate', $data['anticipate'], $this->adminId, $edit['anticipate'], '系统扣除了' . floatval($data['anticipate']) . '艺金券');
+                try {
+                    UserRepository::adminSubIntegral($user, $data['anticipate']);
+                } catch (\Exception $e) {
+                    BaseModel::rollbackTrans();
+                    return Json::fail($e->getMessage());
+                }
+            }
+        } else {
+            $res3 = true;
+        }
+
+        if ($edit) $res4 = UserModel::edit($edit, $uid);
+        else $res4 = true;
+        if ($res1 && $res2 && $res3 && $res4) $res = true;
+        else $res = false;
+        BaseModel::checkTrans($res);
+        if ($res) return Json::successful('修改成功!');
+        else return Json::fail('修改失败');
+    }
+
+    /*
+     * 赠送会员等级
+     * @paran int $uid
+     * @return json
+     * */
+    public function save_give_level($uid = 0)
+    {
+        if (!$uid) return Json::fail('缺少参数');
+        list($level_id) = Util::postMore([
+            ['level_id', 0],
+        ], $this->request, true);
+        //查询当前选择的会员等级
+        $systemLevel = SystemUserLevel::where(['is_show' => 1, 'is_del' => 0, 'id' => $level_id])->find();
+        if (!$systemLevel) return Json::fail('您选择赠送的会员等级不存在!');
+        //检查是否拥有此会员等级
+        $level = UserLevel::where(['uid' => $uid, 'level_id' => $level_id, 'is_del' => 0])->field('valid_time,is_forever')->find();
+        if ($level) if (!$level['is_forever'] && time() < $level['valid_time']) return Json::fail('此用户已有该会员等级,无法再次赠送');
+        //设置会员过期时间
+        $add_valid_time = (int)$systemLevel->valid_date * 86400;
+        UserModel::commitTrans();
+        try {
+            //保存会员信息
+            $res = UserLevel::create([
+                'is_forever' => $systemLevel->is_forever,
+                'status' => 1,
+                'is_del' => 0,
+                'grade' => $systemLevel->grade,
+                'uid' => $uid,
+                'add_time' => time(),
+                'level_id' => $level_id,
+                'discount' => $systemLevel->discount,
+                'valid_time' => $systemLevel->discount ? $add_valid_time + time() : 0,
+                'mark' => '尊敬的用户【' . UserModel::where('uid', $uid)->value('nickname') . '】在' . date('Y-m-d H:i:s', time()) . '赠送会员等级成为' . $systemLevel['name'] . '会员',
+            ]);
+            //提取等级任务并记录完成情况
+            $levelIds = [$level_id];
+            $lowGradeLevelIds = SystemUserLevel::where('grade', '<', $systemLevel->grade)->where(['is_show' => 1, 'is_del' => 0])->column('id', 'id');
+            if (count($lowGradeLevelIds)) $levelIds = array_merge($levelIds, $lowGradeLevelIds);
+            $taskIds = SystemUserTask::where('level_id', 'in', $levelIds)->column('id', 'id');
+            $inserValue = [];
+            foreach ($taskIds as $id) {
+                $inserValue[] = ['uid' => $uid, 'task_id' => $id, 'status' => 1, 'add_time' => time()];
+            }
+            $res = $res && UserTaskFinish::insertAll($inserValue) && UserModel::where('uid', $uid)->update(['level' => $level_id]);
+            if ($res) {
+                UserModel::commitTrans();
+                return Json::successful('赠送成功');
+            } else {
+                UserModel::rollbackTrans();
+                return Json::successful('赠送失败');
+            }
+        } catch (\Exception $e) {
+            UserModel::rollbackTrans();
+            return Json::fail('赠送失败');
+        }
+    }
+
+    /*
+     * 清除会员等级
+     * @param int $uid
+     * @return json
+     * */
+    public function del_level($uid = 0)
+    {
+        if (!$uid) return Json::fail('缺少参数');
+        if (UserLevel::cleanUpLevel($uid))
+            return Json::successful('清除成功');
+        else
+            return Json::fail('清除失败');
+    }
+
+    /**
+     * 修改实名认证状态状态
+     *
+     * @return json
+     */
+
+
+    /**
+     * 修改user表状态
+     *
+     * @return json
+     */
+    public function set_status($status = '', $uid = 0, $is_echo = 0)
+    {
+        if ($is_echo == 0) {
+            if ($status == '' || $uid == 0) return Json::fail('参数错误');
+            UserModel::where(['uid' => $uid])->update(['status' => $status]);
+        } else {
+            $uids = Util::postMore([
+                ['uids', []]
+            ]);
+            UserModel::destrSyatus($uids['uids'], $status);
+        }
+        return Json::successful($status == 0 ? '禁用成功' : '解禁成功');
+    }
+
+    /**
+     * 获取user表
+     *
+     * @return json
+     */
+    public function get_user_list()
+    {
+        $where = Util::getMore([
+            ['page', 1],
+            ['limit', 20],
+            ['nickname', ''],
+            ['status', ''],
+            ['pay_count', ''],
+            ['is_promoter', ''],
+            ['order', ''],
+            ['data', ''],
+            ['user_type', ''],
+            ['country', ''],
+            ['province', ''],
+            ['city', ''],
+            ['user_time_type', ''],
+            ['user_time', ''],
+            ['sex', ''],
+            ['level', ''],
+            ['group_id', ''],
+            ['excel', 0],
+        ]);
+        return Json::successlayui(UserModel::getUserList($where));
+    }
+
+    /**
+     * 编辑模板消息
+     * @param $id
+     * @return mixed|\think\response\Json|void
+     */
+    public function edit($uid)
+    {
+        if (!$uid) return $this->failed('数据不存在');
+        $user = UserModel::get($uid);
+        if (!$user) return Json::fail('数据不存在!');
+        $f = array();
+        $f[] = Form::input('uid', '用户编号', $user->getData('uid'))->disabled(1);
+        $f[] = Form::input('real_name', '真实姓名', $user->getData('real_name'));
+        $f[] = Form::text('phone', '手机号', $user->getData('phone'));
+        $f[] = Form::date('birthday', '生日', $user->getData('birthday') ? date('Y-m-d', $user->getData('birthday')) : 0);
+        $f[] = Form::input('card_id', '身份证号', $user->getData('card_id'));
+        $f[] = Form::textarea('mark', '用户备注', $user->getData('mark'));
+        $f[] = Form::radio('is_promoter', '推广员', $user->getData('is_promoter'))->options([['value' => 1, 'label' => '开启'], ['value' => 0, 'label' => '关闭']]);
+        $f[] = Form::radio('is_agent', '代理', $user->getData('is_agent'))->options([['value' => 1, 'label' => '是'], ['value' => 0, 'label' => '否']]);
+        $st[] = ['is_promoter','=',1];
+        $st[] = ['uid','<>',$uid];
+        $f[] = Form::input('spread_time', '绑定推荐人时间', $user->getData('spread_time') ? date('Y-m-d-h:i:s', $user->getData('spread_time')) : 0)->disabled(1);
+        $f[] = Form::select('spread_uid', '绑定推荐人', $user->getData('spread_uid'))->options(UserModel::where([$st])->field('uid as value,nickname as label')->select()->toArray())->filterable(true);
+        $f[] = Form::radio('status', '状态', $user->getData('status'))->options([['value' => 1, 'label' => '开启'], ['value' => 0, 'label' => '锁定']]);
+        $form = Form::make_post_form('添加用户通知', $f, Url::buildUrl('update', array('uid' => $uid)), 5);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    public function update($uid)
+    {
+        $data = Util::postMore([
+            ['money_status', 0],
+            ['is_promoter', 1],
+            ['real_name', ''],
+            ['phone', 0],
+            ['card_id', ''],
+            ['birthday', ''],
+            ['mark', ''],
+            ['money', 0],
+            ['integration_status', 0],
+            ['integration', 0],
+            ['spread_uid', 0],
+            ['status', 0],
+            ['is_agent', 0],
+            ['spread_time', ''],
+        ]);
+        if (!$uid) return $this->failed('数据不存在');
+        $user = UserModel::get($uid);
+        if (!$user) return Json::fail('数据不存在!');
+        BaseModel::beginTrans();
+        $res1 = false;
+        $res2 = false;
+        $edit = array();
+        if ($data['money_status'] && $data['money']) {//余额增加或者减少
+            if ($data['money_status'] == 1) {//增加
+                $edit['now_money'] = bcadd($user['now_money'], $data['money'], 2);
+                $res1 = UserBillAdmin::income('系统增加余额', $user['uid'], 'now_money', 'system_add', $data['money'], $this->adminId, $edit['now_money'], '系统增加了' . floatval($data['money']) . '余额');
+                try {
+                    UserRepository::adminAddMoney($user, $data['money']);
+                } catch (\Exception $e) {
+                    BaseModel::rollbackTrans();
+                    return Json::fail($e->getMessage());
+                }
+            } else if ($data['money_status'] == 2) {//减少
+                $edit['now_money'] = bcsub($user['now_money'], $data['money'], 2);
+                $res1 = UserBillAdmin::expend('系统减少余额', $user['uid'], 'now_money', 'system_sub', $data['money'], $this->adminId, $edit['now_money'], '系统扣除了' . floatval($data['money']) . '余额');
+                try {
+                    UserRepository::adminSubMoney($user, $data['money']);
+                } catch (\Exception $e) {
+                    BaseModel::rollbackTrans();
+                    return Json::fail($e->getMessage());
+                }
+            }
+        } else {
+            $res1 = true;
+        }
+        if ($data['integration_status'] && $data['integration']) {//趣豆增加或者减少
+            if ($data['integration_status'] == 1) {//增加
+                $edit['integral'] = bcadd($user['integral'], $data['integration'], 2);
+                $res2 = UserBillAdmin::income('系统增加趣豆', $user['uid'], 'integral', 'system_add', $data['integration'], $this->adminId, $edit['integral'], '系统增加了' . floatval($data['integration']) . '趣豆');
+                try {
+                    UserRepository::adminAddIntegral($user, $data['integration']);
+                } catch (\Exception $e) {
+                    BaseModel::rollbackTrans();
+                    return Json::fail($e->getMessage());
+                }
+            } else if ($data['integration_status'] == 2) {//减少
+                $edit['integral'] = bcsub($user['integral'], $data['integration'], 2);
+                $res2 = UserBillAdmin::expend('系统减少趣豆', $user['uid'], 'integral', 'system_sub', $data['integration'], $this->adminId, $edit['integral'], '系统扣除了' . floatval($data['integration']) . '趣豆');
+                try {
+                    UserRepository::adminSubIntegral($user, $data['integration']);
+                } catch (\Exception $e) {
+                    BaseModel::rollbackTrans();
+                    return Json::fail($e->getMessage());
+                }
+            }
+        } else {
+            $res2 = true;
+        }
+        $edit['status'] = $data['status'];
+        $edit['real_name'] = $data['real_name'];
+        $edit['phone'] = $data['phone'];
+        $edit['card_id'] = $data['card_id'];
+        $edit['birthday'] = strtotime($data['birthday']);
+        $edit['mark'] = $data['mark'];
+        $edit['is_agent'] = $data['is_agent'];
+        if($data['is_promoter']==1){
+//            if($user['level']<3){
+//                return $this->failed('等级未达到店长!不可为推广员');
+//                die;
+//            }
+            $edit['is_promoter'] = $data['is_promoter'];
+        }else{
+            $edit['is_promoter'] = $data['is_promoter'];
+        }
+        $userlist=UserModel::where('uid','<>',$uid)->column('uid,spread_uid','uid');
+        $sp =$data['spread_uid'];
+        while ($sp) {
+            if ($sp == $uid) {
+                $data['spread_uid'] = 0;
+                return Json::fail('推荐人不合法');
+                break;
+            }
+            $sp = $userlist[$sp]['spread_uid'];
+            $edit['spread_uid'] = $data['spread_uid'];
+        }
+        if($user['spread_uid']!=$data['spread_uid']){
+            $edit['spread_time'] = time();
+        }
+        if ($edit) $res3 = UserModel::edit($edit, $uid);
+        else $res3 = true;
+        if ($res1 && $res2 && $res3) $res = true;
+        else $res = false;
+        BaseModel::checkTrans($res);
+        if ($res) return Json::successful('修改成功!');
+        else return Json::fail('修改失败');
+    }
+
+    /**
+     * 用户图表
+     * @return mixed
+     */
+    public function user_analysis()
+    {
+        $where = Util::getMore([
+            ['nickname', ''],
+            ['status', ''],
+            ['is_promoter', ''],
+            ['date', ''],
+            ['user_type', ''],
+            ['export', 0]
+        ], $this->request);
+        $user_count = UserModel::consume($where, '', true);
+        //头部信息
+        $header = [
+            [
+                'name' => '新增用户',
+                'class' => 'fa-line-chart',
+                'value' => $user_count,
+                'color' => 'red'
+            ],
+            [
+                'name' => '用户留存',
+                'class' => 'fa-area-chart',
+                'value' => $this->gethreaderValue(UserModel::consume($where, '', true), $where) . '%',
+                'color' => 'lazur'
+            ],
+            [
+                'name' => '新增用户总消费',
+                'class' => 'fa-bar-chart',
+                'value' => '¥' . UserModel::consume($where),
+                'color' => 'navy'
+            ],
+            [
+                'name' => '用户活跃度',
+                'class' => 'fa-pie-chart',
+                'value' => $this->gethreaderValue(UserModel::consume($where, '', true)) . '%',
+                'color' => 'yellow'
+            ],
+        ];
+        $name = ['新增用户', '用户消费'];
+        $dates = $this->get_user_index($where, $name);
+        $user_index = ['name' => json_encode($name), 'date' => json_encode($dates['time']), 'series' => json_encode($dates['series'])];
+        //用户浏览分析
+        $view = StoreVisit::getVisit($where['date'], ['', 'warning', 'info', 'danger']);
+        $view_v1 = WechatMessage::getViweList($where['date'], ['', 'warning', 'info', 'danger']);
+        $view = array_merge($view, $view_v1);
+        $view_v2 = [];
+        foreach ($view as $val) {
+            $view_v2['color'][] = '#' . rand(100000, 339899);
+            $view_v2['name'][] = $val['name'];
+            $view_v2['value'][] = $val['value'];
+        }
+        $view = $view_v2;
+        //消费会员排行用户分析
+        $user_null = UserModel::getUserSpend($where['date']);
+        //消费数据
+        $now_number = UserModel::getUserSpend($where['date'], true);
+        list($paren_number, $title) = UserModel::getPostNumber($where['date']);
+        if ($paren_number == 0) {
+            $rightTitle = [
+                'number' => $now_number > 0 ? $now_number : 0,
+                'icon' => 'fa-level-up',
+                'title' => $title
+            ];
+        } else {
+            $number = (float)bcsub($now_number, $paren_number, 4);
+            if ($now_number == 0) {
+                $icon = 'fa-level-down';
+            } else {
+                $icon = $now_number > $paren_number ? 'fa-level-up' : 'fa-level-down';
+            }
+            $rightTitle = ['number' => $number, 'icon' => $icon, 'title' => $title];
+        }
+        unset($title, $paren_number, $now_number);
+        list($paren_user_count, $title) = UserModel::getPostNumber($where['date'], true, 'add_time', '');
+        if ($paren_user_count == 0) {
+            $count = $user_count == 0 ? 0 : $user_count;
+            $icon = $user_count == 0 ? 'fa-level-down' : 'fa-level-up';
+        } else {
+            $count = (float)bcsub($user_count, $paren_user_count, 4);
+            $icon = $user_count < $paren_user_count ? 'fa-level-down' : 'fa-level-up';
+        }
+        $leftTitle = [
+            'count' => $count,
+            'icon' => $icon,
+            'title' => $title
+        ];
+        unset($count, $icon, $title);
+        $consume = [
+            'title' => '消费金额为¥' . UserModel::consume($where),
+            'series' => UserModel::consume($where, 'xiaofei'),
+            'rightTitle' => $rightTitle,
+            'leftTitle' => $leftTitle,
+        ];
+        $form = UserModel::consume($where, 'form');
+        $grouping = UserModel::consume($where, 'grouping');
+        $this->assign(compact('header', 'user_index', 'view', 'user_null', 'consume', 'form', 'grouping', 'where'));
+        return $this->fetch();
+    }
+
+    public function gethreaderValue($chart, $where = [])
+    {
+        if ($where) {
+            switch ($where['date']) {
+                case null:
+                case 'today':
+                case 'week':
+                case 'year':
+                    if ($where['date'] == null) {
+                        $where['date'] = 'month';
+                    }
+                    $sum_user = UserModel::whereTime('add_time', $where['date'])->count();
+                    if ($sum_user == 0) return 0;
+                    $counts = bcdiv($chart, $sum_user, 4) * 100;
+                    return $counts;
+                    break;
+                case 'quarter':
+                    $quarter = UserModel::getMonth('n');
+                    $quarter[0] = strtotime($quarter[0]);
+                    $quarter[1] = strtotime($quarter[1]);
+                    $sum_user = UserModel::where('add_time', 'between', $quarter)->count();
+                    if ($sum_user == 0) return 0;
+                    $counts = bcdiv($chart, $sum_user, 4) * 100;
+                    return $counts;
+                default:
+                    //自定义时间
+                    $quarter = explode('-', $where['date']);
+                    $quarter[0] = strtotime($quarter[0]);
+                    $quarter[1] = strtotime($quarter[1]);
+                    $sum_user = UserModel::where('add_time', 'between', $quarter)->count();
+                    if ($sum_user == 0) return 0;
+                    $counts = bcdiv($chart, $sum_user, 4) * 100;
+                    return $counts;
+                    break;
+            }
+        } else {
+            $num = UserModel::count();
+            $chart = $num != 0 ? bcdiv($chart, $num, 5) * 100 : 0;
+            return $chart;
+        }
+    }
+
+    public function get_user_index($where, $name)
+    {
+        switch ($where['date']) {
+            case null:
+                $days = date("t", strtotime(date('Y-m', time())));
+                $dates = [];
+                $series = [];
+                $times_list = [];
+                foreach ($name as $key => $val) {
+                    for ($i = 1; $i <= $days; $i++) {
+                        if (!in_array($i . '号', $times_list)) {
+                            array_push($times_list, $i . '号');
+                        }
+                        $time = $this->gettime(date("Y-m", time()) . '-' . $i);
+                        if ($key == 0) {
+                            $dates['data'][] = UserModel::where('add_time', 'between', $time)->count();
+                        } else if ($key == 1) {
+                            $dates['data'][] = UserModel::consume(true, $time);
+                        }
+                    }
+                    $dates['name'] = $val;
+                    $dates['type'] = 'line';
+                    $series[] = $dates;
+                    unset($dates);
+                }
+                return ['time' => $times_list, 'series' => $series];
+            case 'today':
+                $dates = [];
+                $series = [];
+                $times_list = [];
+                foreach ($name as $key => $val) {
+                    for ($i = 0; $i <= 24; $i++) {
+                        $strtitle = $i . '点';
+                        if (!in_array($strtitle, $times_list)) {
+                            array_push($times_list, $strtitle);
+                        }
+                        $time = $this->gettime(date("Y-m-d ", time()) . $i);
+                        if ($key == 0) {
+                            $dates['data'][] = UserModel::where('add_time', 'between', $time)->count();
+                        } else if ($key == 1) {
+                            $dates['data'][] = UserModel::consume(true, $time);
+                        }
+                    }
+                    $dates['name'] = $val;
+                    $dates['type'] = 'line';
+                    $series[] = $dates;
+                    unset($dates);
+                }
+                return ['time' => $times_list, 'series' => $series];
+            case "week":
+                $dates = [];
+                $series = [];
+                $times_list = [];
+                foreach ($name as $key => $val) {
+                    for ($i = 0; $i <= 6; $i++) {
+                        if (!in_array('星期' . ($i + 1), $times_list)) {
+                            array_push($times_list, '星期' . ($i + 1));
+                        }
+                        $time = UserModel::getMonth('h', $i);
+                        if ($key == 0) {
+                            $dates['data'][] = UserModel::where('add_time', 'between', [strtotime($time[0]), strtotime($time[1])])->count();
+                        } else if ($key == 1) {
+                            $dates['data'][] = UserModel::consume(true, [strtotime($time[0]), strtotime($time[1])]);
+                        }
+                    }
+                    $dates['name'] = $val;
+                    $dates['type'] = 'line';
+                    $series[] = $dates;
+                    unset($dates);
+                }
+                return ['time' => $times_list, 'series' => $series];
+            case 'year':
+                $dates = [];
+                $series = [];
+                $times_list = [];
+                $year = date('Y');
+                foreach ($name as $key => $val) {
+                    for ($i = 1; $i <= 12; $i++) {
+                        if (!in_array($i . '月', $times_list)) {
+                            array_push($times_list, $i . '月');
+                        }
+                        $t = strtotime($year . '-' . $i . '-01');
+                        $arr = explode('/', date('Y-m-01', $t) . '/' . date('Y-m-', $t) . date('t', $t));
+                        if ($key == 0) {
+                            $dates['data'][] = UserModel::where('add_time', 'between', [strtotime($arr[0]), strtotime($arr[1])])->count();
+                        } else if ($key == 1) {
+                            $dates['data'][] = UserModel::consume(true, [strtotime($arr[0]), strtotime($arr[1])]);
+                        }
+                    }
+                    $dates['name'] = $val;
+                    $dates['type'] = 'line';
+                    $series[] = $dates;
+                    unset($dates);
+                }
+                return ['time' => $times_list, 'series' => $series];
+            case 'quarter':
+                $dates = [];
+                $series = [];
+                $times_list = [];
+                foreach ($name as $key => $val) {
+                    for ($i = 1; $i <= 4; $i++) {
+                        $arr = $this->gettime('quarter', $i);
+                        if (!in_array(implode('--', $arr) . '季度', $times_list)) {
+                            array_push($times_list, implode('--', $arr) . '季度');
+                        }
+                        if ($key == 0) {
+                            $dates['data'][] = UserModel::where('add_time', 'between', [strtotime($arr[0]), strtotime($arr[1])])->count();
+                        } else if ($key == 1) {
+                            $dates['data'][] = UserModel::consume(true, [strtotime($arr[0]), strtotime($arr[1])]);
+                        }
+                    }
+                    $dates['name'] = $val;
+                    $dates['type'] = 'line';
+                    $series[] = $dates;
+                    unset($dates);
+                }
+                return ['time' => $times_list, 'series' => $series];
+            default:
+                $list = UserModel::consume($where, 'default');
+                $dates = [];
+                $series = [];
+                $times_list = [];
+                foreach ($name as $k => $v) {
+                    foreach ($list as $val) {
+                        $date = $val['add_time'];
+                        if (!in_array($date, $times_list)) {
+                            array_push($times_list, $date);
+                        }
+                        if ($k == 0) {
+                            $dates['data'][] = $val['num'];
+                        } else if ($k == 1) {
+                            $dates['data'][] = UserBillAdmin::where(['uid' => $val['uid'], 'type' => 'pay_product'])->sum('number');
+                        }
+                    }
+                    $dates['name'] = $v;
+                    $dates['type'] = 'line';
+                    $series[] = $dates;
+                    unset($dates);
+                }
+                return ['time' => $times_list, 'series' => $series];
+        }
+    }
+
+    public function gettime($time = '', $season = '')
+    {
+        if (!empty($time) && empty($season)) {
+            $timestamp0 = strtotime($time);
+            $timestamp24 = strtotime($time) + 86400;
+            return [$timestamp0, $timestamp24];
+        } else if (!empty($time) && !empty($season)) {
+            $firstday = date('Y-m-01', mktime(0, 0, 0, ($season - 1) * 3 + 1, 1, date('Y')));
+            $lastday = date('Y-m-t', mktime(0, 0, 0, $season * 3, 1, date('Y')));
+            return [$firstday, $lastday];
+        }
+    }
+
+    /**
+     * 会员等级首页
+     */
+    public function group()
+    {
+        return $this->fetch();
+    }
+
+    /**
+     * 会员详情
+     */
+    public function see($uid = '')
+    {
+        $this->assign([
+            'uid' => $uid,
+            'userinfo' => UserModel::getUserDetailed($uid),
+            'is_layui' => true,
+            'headerList' => UserModel::getHeaderList($uid),
+            'count' => UserModel::getCountInfo($uid),
+        ]);
+        return $this->fetch();
+    }
+
+    /*
+     * 获取某个用户的推广下线
+     * */
+    public function getSpreadList($uid, $page = 1, $limit = 20)
+    {
+        return Json::successful(UserModel::getSpreadList($uid, (int)$page, (int)$limit));
+    }
+
+    /**
+     * 获取某用户的订单列表
+     */
+    public function getOneorderList($uid, $page = 1, $limit = 20)
+    {
+        return Json::successful(StoreOrder::getOneorderList(compact('uid', 'page', 'limit')));
+    }
+
+    /**
+     * 获取某用户的趣豆列表
+     */
+    public function getOneIntegralList($uid, $page = 1, $limit = 20)
+    {
+        return Json::successful(UserBillAdmin::getOneIntegralList(compact('uid', 'page', 'limit')));
+    }
+
+    /**
+     * 获取某用户的趣豆列表
+     */
+    public function getOneSignList($uid, $page = 1, $limit = 20)
+    {
+        return Json::successful(UserBillAdmin::getOneSignList(compact('uid', 'page', 'limit')));
+    }
+
+    /**
+     * 获取某用户的持有优惠劵
+     */
+    public function getOneCouponsList($uid, $page = 1, $limit = 20)
+    {
+        return Json::successful(StoreCouponUser::getOneCouponsList(compact('uid', 'page', 'limit')));
+    }
+
+    /**
+     * 获取某用户的余额变动记录
+     */
+    public function getOneBalanceChangList($uid, $page = 1, $limit = 20)
+    {
+        return Json::successful(UserBillAdmin::getOneBalanceChangList(compact('uid', 'page', 'limit')));
+    }
+}

+ 111 - 0
app/admin/controller/user/UserAuth.php

@@ -0,0 +1,111 @@
+<?php
+
+namespace app\admin\controller\user;
+
+use app\admin\controller\AuthController;
+use think\facade\Route as Url;
+use crmeb\traits\CurdControllerTrait;
+use app\admin\model\user\User as UserModel;
+use app\admin\model\user\UserBill as UserBillAdmin;
+use app\admin\model\system\{SystemUserLevel,SystemUserTask};
+use crmeb\services\{UtilService,JsonService,FormBuilder as Form};
+/**
+ * 会员设置
+ * Class UserLevel
+ * @package app\admin\controller\user
+ */
+class UserAuth extends AuthController
+{
+    use CurdControllerTrait;
+
+    /*
+     * 审核展示
+     * */
+    public function index()
+    {
+        return $this->fetch();
+    }
+
+    /*
+     * 创建form表单
+     * */
+    public function create($uid =0)
+    {
+		if ($uid) $vipinfo = UserModel::get($uid);
+        $field[] = Form::input('off', '拒绝理由', isset($vipinfo) ? $vipinfo->off: '')->col(Form::col(24));
+        $form = Form::make_post_form('添加拒绝理由', $field, Url::buildUrl('save', ['uid' => $uid]), 2);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /*
+     * 审核/拒绝
+     * @param $uid 审核的用户uid
+     * @return json
+     * */
+    public function save($uid = 0)
+    {
+        $data = UtilService::postMore([
+            ['off', ''],
+        ]);
+        if (!$data['off']) return JsonService::fail('请输入拒绝理由');
+		if($data['off']){
+			// 查询是否已审核
+			$res1=UserModel::where(['uid' => $uid])->find();
+			if($res1['is_auth']==2||$res1['is_auth']==3){
+				 return JsonService::fail('该信息已审核!不可操作');
+			}
+			$res=UserModel::where(['uid' => $uid])->update(['off' =>$data['off'],'is_auth'=>"3"]);
+			if($res>0){
+				return JsonService::successful('审核成功');
+			}else{
+				 return JsonService::fail('该信息已审核!不可重复');
+			}
+		}
+    }
+	
+	/*
+	 * 审核通过
+	 * @param int $id
+	 * */
+	public function pass($uid = 0){
+		 if($uid){
+			// 查询是否已审核
+			$res1=UserModel::where(['uid' => $uid])->find();
+			if($res1['is_auth']==2||$res1['is_auth']==3){
+				 return JsonService::fail('该信息已审核!不可操作');
+			}
+			$res=UserModel::where(['uid' => $uid])->update(['is_auth' =>2,'f_integral'=>3000,'off'=>"", 'is_new' => 1]);
+			if($res>0){
+				// 添加积分充值记录
+				$res2=UserBillAdmin::income('实名认证赠送',$uid, 'integral', 'top_add', 3000, 0, 3000, '首次实名赠送(竞拍消费满30000释放)');
+				return JsonService::successful('审核成功');
+				
+			}else{
+				 return JsonService::fail('审核失败');
+			} 
+		 }else{
+			 return JsonService::fail('参数错误!'); 
+		 }
+		
+		
+		
+		
+		
+	}
+    /*
+     * 获取列表
+     * @param int page
+     * @param int limit
+     * */
+    public function get_system_user_list()
+    {
+       $where =UtilService::getMore([
+           ['page', 1],
+           ['limit', 20],
+		   ['is_auth','<>',0]
+       ]);
+        return JsonService::successlayui(UserModel::authlist($where));
+    }
+  
+}

+ 101 - 0
app/admin/controller/user/UserGroup.php

@@ -0,0 +1,101 @@
+<?php
+/**
+ *
+ * @author: wuhaotian<442384644@qq.com>
+ * @day: 2019/12/07
+ */
+
+namespace app\admin\controller\user;
+
+use app\admin\controller\AuthController;
+use app\admin\model\user\UserGroup as GroupModel;
+use crmeb\services\JsonService;
+use crmeb\services\UtilService;
+use crmeb\services\FormBuilder as Form;
+use think\facade\Route as Url;
+
+/**
+ * Class UserGroup
+ * @package app\admin\controller\user
+ */
+class UserGroup extends AuthController
+{
+    /**
+     * 会员分组页面
+     * @return string
+     */
+    public function index()
+    {
+        return $this->fetch();
+    }
+
+    /**
+     * 分组列表
+     */
+    public function groupList()
+    {
+        $where = UtilService::getMore([
+            ['page', 1],
+            ['limit', 20],
+        ]);
+        return JsonService::successlayui(GroupModel::getList($where));
+    }
+
+    /**
+     * 添加/修改分组页面
+     * @param int $id
+     * @return string
+     */
+    public function addGroup($id = 0)
+    {
+        $group = GroupModel::get($id);
+        $f = array();
+        if (!$group) {
+            $f[] = Form::input('group_name', '分组名称', '');
+        } else {
+            $f[] = Form::input('group_name', '分组名称', $group->getData('group_name'));
+        }
+        $form = Form::make_post_form('添加用户通知', $f, Url::buildUrl('saveGroup', array('id' => $id)));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 添加/修改
+     * @param int $id
+     */
+    public function saveGroup($id = 0)
+    {
+        $data = UtilService::postMore([
+            ['group_name', ''],
+        ]);
+        if ($id) {
+            if (GroupModel::where('id', $id)->update($data)) {
+                return JsonService::success('修改成功');
+            } else {
+                return JsonService::fail('修改失败或者您没有修改什么!');
+            }
+        } else {
+            if ($res = GroupModel::create($data)) {
+                return JsonService::success('保存成功', ['id' => $res->id]);
+            } else {
+                return JsonService::fail('保存失败!');
+            }
+        }
+    }
+
+    /**
+     * 删除
+     * @param $id
+     * @throws \Exception
+     */
+    public function delete($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        if (!GroupModel::be(['id' => $id])) return $this->failed('产品数据不存在');
+        if (!GroupModel::where('id', $id)->delete())
+            return JsonService::fail(GroupModel::getErrorInfo('恢复失败,请稍候再试!'));
+        else
+            return JsonService::successful('恢复门店成功!');
+    }
+}

+ 341 - 0
app/admin/controller/user/UserLevel.php

@@ -0,0 +1,341 @@
+<?php
+
+namespace app\admin\controller\user;
+
+use app\admin\controller\AuthController;
+use think\facade\Route as Url;
+use crmeb\traits\CurdControllerTrait;
+use app\admin\model\user\UserLevel as UserLevelModel;
+use app\admin\model\system\{SystemUserLevel,SystemUserTask};
+use crmeb\services\{UtilService,JsonService,FormBuilder as Form};
+
+/**
+ * 会员设置
+ * Class UserLevel
+ * @package app\admin\controller\user
+ */
+class UserLevel extends AuthController
+{
+    use CurdControllerTrait;
+
+    /*
+     * 等级展示
+     * */
+    public function index()
+    {
+        return $this->fetch();
+    }
+
+    /*
+     * 创建form表单
+     * */
+    public function create($id = 0)
+    {
+        if ($id) $vipinfo = SystemUserLevel::get($id);
+        $field[] = Form::input('name', '等级名称', isset($vipinfo) ? $vipinfo->name : '')->col(Form::col(24));
+        $field[] = Form::radio('is_forever', '是否为永久', isset($vipinfo) ? $vipinfo->is_forever : 0)->options([['label' => '永久', 'value' => 1], ['label' => '非永久', 'value' => 0]])->col(24);
+        //$field[]= Form::number('money','等级价格',isset($vipinfo) ? $vipinfo->money : 0)->min(0)->col(24);
+        //$field[]= Form::radio('is_pay','是否需要购买',isset($vipinfo) ? $vipinfo->is_pay : 0)->options([['label'=>'需要','value'=>1],['label'=>'免费','value'=>0]])->col(24);
+        $field[] = Form::number('valid_date', '有效时间(天)', isset($vipinfo) ? $vipinfo->valid_date : 0)->min(0)->col(12);
+        $field[] = Form::number('grade', '等级', isset($vipinfo) ? $vipinfo->grade : 0)->min(0)->col(12);
+        $field[] = Form::number('discount', "享受折扣\n(输入折扣数100代表原价,90代表9折)", isset($vipinfo) ? $vipinfo->discount : 100)->min(0)->col(8);
+        $field[] = Form::frameImageOne('icon', '图标', Url::buildUrl('admin/widget.images/index', array('fodder' => 'icon')), isset($vipinfo) ? $vipinfo->icon : '')->icon('image')->width('100%')->height('500px');
+        $field[] = Form::frameImageOne('image', '会员背景', Url::buildUrl('admin/widget.images/index', array('fodder' => 'image')), isset($vipinfo) ? $vipinfo->image : '')->icon('image')->width('100%')->height('500px');
+        $field[] = Form::radio('is_show', '是否显示', isset($vipinfo) ? $vipinfo->is_show : 0)->options([['label' => '显示', 'value' => 1], ['label' => '隐藏', 'value' => 0]])->col(8);
+        $field[] = Form::textarea('explain', '等级说明', isset($vipinfo) ? $vipinfo->explain : '');
+        $form = Form::make_post_form('添加等级设置', $field, Url::buildUrl('save', ['id' => $id]), 2);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /*
+     * 会员等级添加或者修改
+     * @param $id 修改的等级id
+     * @return json
+     * */
+    public function save($id = 0)
+    {
+        $data = UtilService::postMore([
+            ['name', ''],
+            ['is_forever', 0],
+            ['money', 0],
+            ['is_pay', 0],
+            ['valid_date', 0],
+            ['grade', 0],
+            ['discount', 0],
+            ['icon', ''],
+            ['image', ''],
+            ['is_show', ''],
+            ['explain', ''],
+        ]);
+        if (!$data['name']) return JsonService::fail('请输入等级名称');
+        if (!$data['grade']) return JsonService::fail('请输入等级');
+        if (!$data['explain']) return JsonService::fail('请输入等级说明');
+        if ($data['is_forever'] == 0 && !$data['valid_date']) return JsonService::fail('请输入有效时间(天)');
+        if ($data['is_pay']) return JsonService::fail('会员等级购买功能正在开发中,暂时关闭可购买功能!');
+        if ($data['is_pay'] && !$data['money']) return JsonService::fail('请输入购买金额');
+        if (!$data['icon']) return JsonService::fail('请上传等级图标');
+        if (!$data['image']) return JsonService::fail('请上传等级背景图标');
+        if (!$id && SystemUserLevel::be(['is_del' => 0, 'grade' => $data['grade']])) return JsonService::fail('已检测到您设置过的会员等级,此等级不可重复');
+        SystemUserLevel::beginTrans();
+        try {
+            //修改
+            if ($id) {
+                if (SystemUserLevel::edit($data, $id)) {
+                    SystemUserLevel::commitTrans();
+                    return JsonService::successful('修改成功');
+                } else {
+                    SystemUserLevel::rollbackTrans();
+                    return JsonService::fail('修改失败');
+                }
+            } else {
+                //新增
+                $data['add_time'] = time();
+                if (SystemUserLevel::create($data)) {
+                    SystemUserLevel::commitTrans();
+                    return JsonService::successful('添加成功');
+                } else {
+                    SystemUserLevel::rollbackTrans();
+                    return JsonService::fail('添加失败');
+                }
+            }
+        } catch (\Exception $e) {
+            SystemUserLevel::rollbackTrans();
+            return JsonService::fail($e->getMessage());
+        }
+    }
+
+    /*
+     * 获取系统设置的vip列表
+     * @param int page
+     * @param int limit
+     * */
+    public function get_system_vip_list()
+    {
+        $where = UtilService::getMore([
+            ['page', 0],
+            ['limit', 10],
+            ['title', ''],
+            ['is_show', ''],
+        ]);
+        return JsonService::successlayui(SystemUserLevel::getSytemList($where));
+    }
+
+    /*
+     * 删除会员等级
+     * @param int $id
+     * */
+    public function delete($id = 0)
+    {
+        if (SystemUserLevel::edit(['is_del' => 1], $id))
+            return JsonService::successful('删除成功');
+        else
+            return JsonService::fail('删除失败');
+    }
+
+    /**
+     * 设置单个产品上架|下架
+     *
+     * @return json
+     */
+    public function set_show($is_show = '', $id = '')
+    {
+        ($is_show == '' || $id == '') && Json::fail('缺少参数');
+        $res = SystemUserLevel::where(['id' => $id])->update(['is_show' => (int)$is_show]);
+        if ($res) {
+            return JsonService::successful($is_show == 1 ? '显示成功' : '隐藏成功');
+        } else {
+            return JsonService::fail($is_show == 1 ? '显示失败' : '隐藏失败');
+        }
+    }
+
+    /**
+     * 快速编辑
+     *
+     * @return json
+     */
+    public function set_value($field = '', $id = '', $value = '')
+    {
+        $field == '' || $id == '' || $value == '' && Json::fail('缺少参数');
+        if (SystemUserLevel::where(['id' => $id])->update([$field => $value]))
+            return JsonService::successful('保存成功');
+        else
+            return JsonService::fail('保存失败');
+    }
+
+
+    /*
+     * 等级任务列表
+     * @param int $vip_id 等级id
+     * @return json
+     * */
+    public function tash($level_id = 0)
+    {
+        $this->assign('level_id', $level_id);
+        return $this->fetch();
+    }
+
+    /**
+     * 快速编辑
+     *
+     * @return json
+     */
+    public function set_tash_value($field = '', $id = '', $value = '')
+    {
+        $field == '' || $id == '' || $value == '' && Json::fail('缺少参数');
+        if (SystemUserTask::where(['id' => $id])->update([$field => $value]))
+            return JsonService::successful('保存成功');
+        else
+            return JsonService::fail('保存失败');
+    }
+
+    /**
+     * 设置单个产品上架|下架
+     *
+     * @return json
+     */
+    public function set_tash_show($is_show = '', $id = '')
+    {
+        ($is_show == '' || $id == '') && Json::fail('缺少参数');
+        $res = SystemUserTask::where(['id' => $id])->update(['is_show' => (int)$is_show]);
+        if ($res) {
+            return JsonService::successful($is_show == 1 ? '显示成功' : '隐藏成功');
+        } else {
+            return JsonService::fail($is_show == 1 ? '显示失败' : '隐藏失败');
+        }
+    }
+
+    /**
+     * 设置单个产品上架|下架
+     *
+     * @return json
+     */
+    public function set_tash_must($is_must = '', $id = '')
+    {
+        ($is_must == '' || $id == '') && Json::fail('缺少参数');
+        $res = SystemUserTask::where(['id' => $id])->update(['is_must' => (int)$is_must]);
+        if ($res) {
+            return JsonService::successful('设置成功');
+        } else {
+            return JsonService::fail('设置失败');
+        }
+    }
+
+    /*
+     * 生成任务表单
+     * @param int $id 任务id
+     * @param int $vip_id 会员id
+     * @return html
+     * */
+    public function create_tash($id = 0, $level_id = 0)
+    {
+        if ($id) $tash = SystemUserTask::get($id);
+        $field[] = Form::select('task_type', '任务类型', isset($tash) ? $tash->task_type : '')->setOptions(function () {
+            $list = SystemUserTask::getTaskTypeAll();
+            $menus = [];
+            foreach ($list as $menu) {
+                $menus[] = ['value' => $menu['type'], 'label' => $menu['name'] . '----单位[' . $menu['unit'] . ']'];
+            }
+            return $menus;
+        })->filterable(1);
+        $field[] = Form::number('number', '限定数量', isset($tash) ? $tash->number : 0)->min(0)->col(24);
+        $field[] = Form::number('sort', '排序', isset($tash) ? $tash->sort : 0)->min(0)->col(24);
+        $field[] = Form::radio('is_show', '是否显示', isset($tash) ? $tash->is_show : 1)->options([['label' => '显示', 'value' => 1], ['label' => '隐藏', 'value' => 0]])->col(24);
+        $field[] = Form::radio('is_must', '是否务必达成', isset($tash) ? $tash->is_must : 1)->options([['label' => '务必达成', 'value' => 1], ['label' => '完成其一', 'value' => 0]])->col(24);
+        $field[] = Form::textarea('illustrate', '任务说明', isset($tash) ? $tash->illustrate : '');
+        $form = Form::make_post_form('添加任务', $field, Url::buildUrl('save_tash', ['id' => $id, 'level_id' => $level_id]), 2);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+
+    /*
+     * 保存或者修改任务
+     * @param int $id 任务id
+     * @param int $vip_id 会员id
+     * */
+    public function save_tash($id = 0, $level_id = 0)
+    {
+        if (!$level_id) return JsonService::fail('缺少参数');
+        $data = UtilService::postMore([
+            ['task_type', ''],
+            ['number', 0],
+            ['is_show', 0],
+            ['sort', 0],
+            ['is_must', 0],
+            ['illustrate', ''],
+        ]);
+        if (!$data['task_type']) return JsonService::fail('请选择任务类型');
+        if ($data['number'] < 1) return JsonService::fail('请输入限定数量,数量不能小于1');
+        $tash = SystemUserTask::getTaskType($data['task_type']);
+        if ($tash['max_number'] != 0 && $data['number'] > $tash['max_number']) return JsonService::fail('您设置的限定数量超出最大限制,最大限制为:' . $tash['max_number']);
+        $data['name'] = SystemUserTask::setTaskName($data['task_type'], $data['number']);
+        try {
+            if ($id) {
+                SystemUserTask::edit($data, $id);
+                return JsonService::successful('修改成功');
+            } else {
+                $data['level_id'] = $level_id;
+                $data['add_time'] = time();
+                $data['real_name'] = $tash['real_name'];
+                if (SystemUserTask::create($data))
+                    return JsonService::successful('添加成功');
+                else
+                    return JsonService::fail('添加失败');
+            }
+        } catch (\Exception $e) {
+            return JsonService::fail($e->getMessage());
+        }
+    }
+
+    /*
+     * 异步获取等级任务列表
+     * @param int $vip_id 会员id
+     * @param int $page 分页
+     * @param int $limit 显示条数
+     * @return json
+     * */
+    public function get_tash_list($level_id = 0)
+    {
+        list($page, $limit) = UtilService::getMore([
+            ['page', 1],
+            ['limit', 10],
+        ], $this->request, true);
+        return JsonService::successlayui(SystemUserTask::getTashList($level_id, (int)$page, (int)$limit));
+    }
+
+    /*
+     * 删除任务
+     * @param int 任务id
+     * */
+    public function delete_tash($id = 0)
+    {
+        if (!$id) return JsonService::fail('缺少差参数');
+        if (SystemUserTask::del($id))
+            return JsonService::successful('删除成功');
+        else
+            return JsonService::fail('删除失败');
+    }
+
+    /*
+     * 会员等级展示
+     *
+     * */
+    public function user_level_list()
+    {
+        $this->assign('level', SystemUserLevel::where('is_del', 0)->where('is_show', 1)->order('grade asc')->field(['id', 'name'])->select());
+        return $this->fetch();
+    }
+
+    public function get_user_vip_list()
+    {
+        $where = UtilService::getMore([
+            ['page', 1],
+            ['limit', 10],
+            ['nickname', ''],
+            ['level_id', ''],
+        ]);
+        return JsonService::successlayui(UserLevelModel::getUserVipList($where));
+    }
+
+}

+ 303 - 0
app/admin/controller/user/UserNotice.php

@@ -0,0 +1,303 @@
+<?php
+
+namespace app\admin\controller\user;
+
+use app\admin\controller\AuthController;
+use crmeb\services\{FormBuilder as Form, UtilService as Util, JsonService as Json};
+use crmeb\services\JsonService;
+use think\facade\Route as Url;
+use app\admin\model\user\UserNotice as UserNoticeModel;
+use app\admin\model\user\UserNoticeSee as UserNoticeSeeModel;
+use app\admin\model\wechat\WechatUser as UserModel;
+
+/**
+ * 用户通知
+ * Class UserNotice
+ * @package app\admin\controller\user
+ */
+class UserNotice extends AuthController
+{
+    /**
+     * 显示资源列表
+     *
+     * @return \think\Response
+     */
+    public function index()
+    {
+        if ($this->request->isAjax()) {
+            $where = Util::getMore([
+                ['page', 1],
+                ['limit', 20]
+            ]);
+            return Json::successlayui(UserNoticeModel::getList($where));
+        } else {
+            return $this->fetch();
+        }
+    }
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return \think\Response
+     */
+    public function create()
+    {
+        $f = array();
+        $f[] = Form::input('user', '发送人', '系统管理员');
+        $f[] = Form::input('title', '通知标题');
+        $f[] = Form::input('content', '通知内容')->type('textarea');
+        $f[] = Form::radio('type', '消息类型', 1)->options([['label' => '系统消息', 'value' => 1], ['label' => '用户通知', 'value' => 2]]);
+        $form = Form::make_post_form('添加用户通知', $f, Url::buildUrl('save'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存新建的资源
+     */
+    public function save()
+    {
+        $params = request()->post();
+        if (!$params["user"]) return Json::fail('请输入发送人!');
+        if (!$params["title"]) return Json::fail('请输入通知标题!');
+        if (!$params["content"]) return Json::fail('请输入通知内容!');
+        if ($params["type"] == 2) {
+            $uids = UserModel::order('uid desc')->column("uid", 'uid');
+            $params["uid"] = count($uids) > 0 ? "," . implode(",", $uids) . "," : "";
+        }
+        $params["add_time"] = time();
+        $params["send_time"] = 0;
+        UserNoticeModel::create($params);
+        return Json::successful('添加成功!');
+    }
+
+    /**
+     * 显示编辑资源表单页.
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function edit($id)
+    {
+        $notice = UserNoticeModel::get($id);
+        if (!$notice) return Json::fail('数据不存在!');
+        $f = array();
+        $f[] = Form::input('user', '发送人', $notice["user"]);
+        $f[] = Form::input('title', '通知标题', $notice["title"]);
+        $f[] = Form::input('content', '通知内容', $notice["content"])->type('textarea');
+        $f[] = Form::radio('type', '消息类型', $notice["type"])->options([['label' => '系统消息', 'value' => 1], ['label' => '用户通知', 'value' => 2]]);
+        $form = Form::make_post_form('编辑通知', $f, Url::buildUrl('update', ["id" => $id]), 2);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存新建的资源
+     * @param $id
+     */
+    public function update($id)
+    {
+        $params = request()->post();
+        if (!$params["user"]) return Json::fail('请输入发送人!');
+        if (!$params["title"]) return Json::fail('请输入通知标题!');
+        if (!$params["content"]) return Json::fail('请输入通知内容!');
+        UserNoticeModel::edit($params, $id);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function send($id)
+    {
+        UserNoticeModel::edit(array("is_send" => 1, "send_time" => time()), $id);
+        return Json::successful('发送成功!');
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function delete($id)
+    {
+        if (!UserNoticeModel::del($id))
+            return Json::fail(UserNoticeModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+
+    /**
+     * 查询发送信息的用户资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function user($id)
+    {
+        $notice = UserNoticeModel::get($id)->toArray();
+        $model = new UserModel;
+        $model = $model::alias('A');
+        $model = $model->field('A.*');
+        if ($notice["type"] == 2) {
+            if ($notice["uid"] != "") {
+                $uids = explode(",", $notice["uid"]);
+                array_splice($uids, 0, 1);
+                array_splice($uids, count($uids) - 1, 1);
+                $model = $model->where("A.uid", "in", $uids);
+            } else {
+                $model = $model->where("A.uid", $notice['uid']);
+            }
+            $model->order('A.uid desc');
+        } else {
+            $model = $model->join('UserNoticeSee B', 'A.uid = B.uid', 'RIGHT');
+            $model = $model->where("B.nid", $notice['id']);
+            $model->order('B.add_time desc');
+        }
+        $this->assign(UserModel::page($model, function ($item, $key) use ($notice) {
+            $item["is_see"] = UserNoticeSeeModel::where("uid", $item["uid"])->where("nid", $notice["id"])->count() > 0 ? 1 : 0;
+        }));
+        $this->assign(compact('notice'));
+        return $this->fetch();
+    }
+
+    /**
+     * 添加发送信息的用户
+     *
+     * @param $id
+     * @return string
+     */
+    public function user_create($id)
+    {
+        $where = Util::getMore([
+            ['nickname', ''],
+            ['data', ''],
+        ], $this->request);
+        $this->assign('where', $where);
+        $this->assign(UserModel::systemPage($where));
+        $this->assign(['title' => '添加发送用户', 'save' => Url::buildUrl('user_save', array('id' => $id))]);
+        return $this->fetch();
+    }
+
+    /**
+     * 保存新建的资源
+     * @param $id
+     */
+    public function user_save($id)
+    {
+        $notice = UserNoticeModel::get($id)->toArray();
+        if (!$notice) return Json::fail('通知信息不存在!');
+        if ($notice["type"] == 1) return Json::fail('系统通知不能管理用户!');
+
+        //查找当前选中的uid
+        $params = request()->post();
+        if (isset($params["search"])) {
+            $model = new UserModel;
+            if ($params['search']['nickname'] !== '') $model = $model->where('nickname', 'LIKE', "%" . $params['search']['nickname'] . "%");
+            if ($params['search']['data'] !== '') {
+                list($startTime, $endTime) = explode(' - ', $params['search']['data']);
+                $model = $model->where('add_time', '>', strtotime($startTime));
+                $model = $model->where('add_time', '<', strtotime($endTime));
+            }
+            $model = $model->order('uid desc');
+            $uids = $model->column("uid", 'uid');
+        } else {
+            $uids = $params["checked_menus"];
+        }
+        if (count($uids) <= 0) return Json::fail('请选择要添加的用户!');
+
+        //合并原来和现在的uid
+        if ($notice["uid"] != "") {
+            $now_uids = explode(",", $notice["uid"]);
+            array_splice($now_uids, 0, 1);
+            array_splice($now_uids, count($now_uids) - 1, 1);
+            $now_uids = array_merge($now_uids, $uids);
+        } else {
+            $now_uids = $uids;
+        }
+
+        //编辑合并之后的uid
+        $res_uids = UserModel::where("uid", "in", $now_uids)->order('uid desc')->column("uid", 'uid');
+        UserNoticeModel::edit(array("uid" => "," . implode(",", $res_uids) . ","), $notice["id"]);
+        return Json::successful('添加成功!');
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function user_delete($id, $uid)
+    {
+        $notice = UserNoticeModel::get($id)->toArray();
+        if (!$notice) return Json::fail('通知信息不存在!');
+        if ($notice["type"] == 1) return Json::fail('系统通知不能管理用户!');
+        if ($notice["uid"] != "") {
+            $res_uids = explode(",", $notice["uid"]);
+            array_splice($res_uids, 0, 1);
+            array_splice($res_uids, count($res_uids) - 1, 1);
+        }
+        array_splice($res_uids, array_search($uid, $res_uids), 1);
+        $value = count($res_uids) > 0 ? "," . implode(",", $res_uids) . "," : "";
+        UserNoticeModel::edit(array("uid" => $value), $notice["id"]);
+        return Json::successful('删除成功!');
+    }
+
+    /**
+     * 删除指定的资源
+     * @param $id
+     */
+    public function user_select_delete($id)
+    {
+        $params = request()->post();
+        if (count($params["checked_menus"]) <= 0) return Json::fail('删除数据不能为空!');
+        $notice = UserNoticeModel::get($id)->toArray();
+        if (!$notice) return Json::fail('通知信息不存在!');
+
+        $res_uids = explode(",", $notice["uid"]);
+        array_splice($res_uids, 0, 1);
+        array_splice($res_uids, count($res_uids) - 1, 1);
+        foreach ($params["checked_menus"] as $key => $value) {
+            array_splice($res_uids, array_search($value, $res_uids), 1);
+        }
+        $value = count($res_uids) > 0 ? "," . implode(",", $res_uids) . "," : "";
+        UserNoticeModel::edit(array("uid" => $value), $notice["id"]);
+        return Json::successful('删除成功!');
+    }
+
+    /**
+     * @param $id
+     * @return mixed
+     */
+    public function notice($id)
+    {
+        $where = Util::getMore([
+            ['title', ''],
+        ], $this->request);
+        $nickname = UserModel::where('uid', 'IN', $id)->column('nickname', 'uid');
+        $this->assign('where', $where);
+        $this->assign('uid', $id);
+        $this->assign('nickname', implode(',', $nickname));
+        $this->assign(UserNoticeModel::getUserList($where));
+        return $this->fetch();
+    }
+
+
+    /**
+     * 给指定用户发送站内信息
+     * @param $id
+     */
+    public function send_user($id = 0, $uid = '')
+    {
+        if (!$id || $uid == '') return Json::fail('参数错误');
+        $uids = UserNoticeModel::where(['id' => $id])->value('uid');
+        $uid = rtrim($uids, ',') . "," . $uid . ",";
+        UserNoticeModel::edit(array("send_time" => time(), 'uid' => $uid), $id);
+        return Json::successful('发送成功!');
+    }
+}

+ 42 - 0
app/admin/controller/wechat/Menus.php

@@ -0,0 +1,42 @@
+<?php
+namespace app\admin\controller\wechat;
+
+use app\admin\controller\AuthController;
+use app\models\system\Cache;
+use crmeb\services\WechatService;
+
+/**
+ * 微信菜单  控制器
+ * Class Menus
+ * @package app\admin\controller\wechat
+ */
+class Menus extends AuthController
+{
+
+    public function index()
+    {
+        $menus = Cache::where('key','wechat_menus')->value('result');
+        $menus = $menus ? : '[]';
+        $this->assign('menus',$menus);
+        return $this->fetch();
+    }
+
+    public function save()
+    {
+        $buttons = request()->post('button/a',[]);
+        if(!count($buttons)) return $this->failed('请添加至少一个按钮');
+        try{
+            WechatService::menuService()->add($buttons);
+            $count = Cache::where('key', 'wechat_menus')->count();
+            if($count){
+                $count = Cache::where('key', 'wechat_menus')->where('result', json_encode($buttons))->count();
+                if(!$count)
+                    Cache::where('key', 'wechat_menus')->update(['result'=>json_encode($buttons),'add_time'=>time()]);
+            }else
+                Cache::insert(['key'=>'wechat_menus','result'=>json_encode($buttons),'add_time'=>time()],true);
+            return $this->successful('修改成功!');
+        }catch (\Exception $e){
+            return $this->failed($e->getMessage());
+        }
+    }
+}

+ 195 - 0
app/admin/controller/wechat/Reply.php

@@ -0,0 +1,195 @@
+<?php
+
+namespace app\admin\controller\wechat;
+
+use app\admin\controller\AuthController;
+use app\admin\model\system\SystemAttachment;
+use app\admin\model\wechat\WechatReply;
+use crmeb\services\UtilService as Util;
+use crmeb\services\JsonService as Json;
+use crmeb\services\upload\Upload;
+
+/**
+ * 关键字管理  控制器
+ * Class Reply
+ * @package app\admin\controller\wechat
+ */
+class Reply extends AuthController
+{
+    /**关注回复
+     * @return mixed|void
+     */
+    public function index()
+    {
+        if (empty(input('key'))) return $this->failed('请输入参数key');
+        if (empty(input('title'))) return $this->failed('请输入参数title');
+        $key = input('key');
+        switch ($key) {
+            case 'subscribe':
+                $title = '编辑关注回复';
+                $type = 0;
+                break;
+            case 'default':
+                $title = '编辑关键字默认回复';
+                $type = 1;
+                break;
+            default:
+                $title = '编辑关键字回复';
+                $type = 1;
+                break;
+        }
+        $this->assign('replay_arr', WechatReply::getDataByKey($key));
+        $this->assign('key', $key);
+        $this->assign('type', $type);
+        $this->assign('title', $title);
+        return $this->fetch();
+    }
+
+    public function one_reply()
+    {
+        $where = Util::postMore([
+            ['key'],
+            ['add', 0],
+        ], $this->request);
+        if (!empty($where['key'])) $replay_arr = WechatReply::getDataByKey($where['key']);
+        $replay_arr['code'] = 200;
+        if (empty($replay_arr)) {
+            $replay_arr['code'] = 0;
+        }
+        if ($where['add'] && empty($where['key'])) {
+            $replay_arr['code'] = 0;
+        }
+        exit(json_encode($replay_arr));
+    }
+
+    public function save()
+    {
+        $data = Util::postMore([
+            'type',
+            'key',
+            ['status', 0],
+            ['data', []],
+        ]);
+        if (!isset($data['type']) && empty($data['type']))
+            return Json::fail('请选择回复类型');
+        if (!in_array($data['type'], WechatReply::$reply_type))
+            return Json::fail('回复类型有误!');
+        if (!isset($data['data']) || !is_array($data['data']))
+            return Json::fail('回复消息参数有误!');
+        $res = WechatReply::redact($data['data'], $data['key'], $data['type'], $data['status']);
+        if (!$res)
+            return Json::fail(WechatReply::getErrorInfo());
+        else
+            return Json::successful('保存成功!', $data);
+    }
+
+    public function upload_img()
+    {
+        $name = $this->request->post('file');
+        if (!$name) return Json::fail('请上传图片');
+        $upload = new Upload('local');
+        $info = $upload->to('wechat/image')->validate()->move($name);
+        if ($info === false) {
+            return Json::fail($upload->getError());
+        }
+        $res = $upload->getUploadInfo();
+        SystemAttachment::attachmentAdd($res['name'], $res['size'], $res['type'], $res['dir'], $res['thumb_path'], 0, 1, $res['time'], 2);
+        return Json::successful('上传成功', $res['dir']);
+    }
+
+    public function upload_file()
+    {
+        $name = $this->request->post('file');
+        if (!$name) return Json::fail('请上传声音');
+        $upload = new Upload('local');
+        $info = $upload->to('wechat/voice')->validate()->move($name);
+        if ($info === false) {
+            return Json::fail($upload->getError());
+        }
+        return Json::successful('上传成功', $info->filePath);
+    }
+
+    /**
+     * 关键字回复
+     * */
+    public function keyword()
+    {
+        $where = Util::getMore([
+            ['key', ''],
+            ['type', ''],
+        ]);
+        $this->assign('where', $where);
+        $this->assign(WechatReply::getKeyAll($where));
+        return $this->fetch();
+
+    }
+
+    /**
+     * 添加关键字
+     * */
+    public function add_keyword()
+    {
+        $key = input('key');
+        if (empty($key)) $key = '';
+        $this->assign('key', $key);
+        $this->assign('dis', 1);
+        $this->assign('replay_arr', []);
+        return $this->fetch();
+    }
+
+    /**
+     * 修改关键字
+     * */
+    public function info_keyword()
+    {
+        $key = input('key');
+        if (empty($key)) return $this->failed('参数错误,请重新修改');
+        $this->assign('replay_arr', WechatReply::getDataByKey($key));
+        $this->assign('key', $key);
+        $this->assign('dis', 2);
+        return $this->fetch('add_keyword');
+    }
+
+    /**
+     * 保存关键字
+     * */
+    public function save_keyword()
+    {
+        $data = Util::postMore([
+            'key',
+            'type',
+            ['status', 0],
+            ['data', []],
+        ]);
+        if (!isset($data['key']) && empty($data['key']))
+            return Json::fail('请输入关键字');
+        if (isset($data['key']) && !empty($data['key'])) {
+            if (trim($data['key']) == 'subscribe') return Json::fail('请重新输入关键字');
+            if (trim($data['key']) == 'default') return Json::fail('请重新输入关键字');
+        }
+        if (!isset($data['type']) && empty($data['type']))
+            return Json::fail('请选择回复类型');
+        if (!in_array($data['type'], WechatReply::$reply_type))
+            return Json::fail('回复类型有误!');
+        if (!isset($data['data']) || !is_array($data['data']))
+            return Json::fail('回复消息参数有误!');
+        $res = WechatReply::redact($data['data'], $data['key'], $data['type'], $data['status']);
+        if (!$res)
+            return Json::fail(WechatReply::getErrorInfo());
+        else
+            return Json::successful('保存成功!', $data);
+    }
+
+    /**
+     * 删除关键字
+     * */
+    public function delete($id)
+    {
+        if (!WechatReply::del($id))
+            return Json::fail(WechatReply::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+
+
+}

+ 168 - 0
app/admin/controller/wechat/StoreService.php

@@ -0,0 +1,168 @@
+<?php
+
+namespace app\admin\controller\wechat;
+
+use app\admin\controller\AuthController;
+use app\admin\model\system\SystemAttachment;
+use crmeb\services\{
+    CacheService,
+    FormBuilder as Form,
+    UtilService as Util,
+    JsonService as Json
+};
+use think\facade\Route as Url;
+use app\admin\model\wechat\{
+    StoreService as ServiceModel, StoreServiceLog as StoreServiceLog, WechatUser as UserModel
+};
+
+/**
+ * 客服管理
+ * Class StoreService
+ * @package app\admin\controller\store
+ */
+class StoreService extends AuthController
+{
+    /**
+     * 显示资源列表
+     *
+     * @return \think\Response
+     */
+    public function index()
+    {
+        $this->assign(ServiceModel::getList(0));
+        return $this->fetch();
+    }
+
+    /**
+     * 显示创建资源表单页.
+     *
+     * @return \think\Response
+     */
+    public function create()
+    {
+        $where = Util::getMore([
+            ['nickname', ''],
+            ['data', ''],
+            ['tagid_list', ''],
+            ['groupid', '-1'],
+            ['sex', ''],
+            ['export', ''],
+            ['stair', ''],
+            ['second', ''],
+            ['order_stair', ''],
+            ['order_second', ''],
+            ['subscribe', ''],
+            ['now_money', ''],
+            ['is_promoter', ''],
+        ], $this->request);
+        $this->assign('where', $where);
+        $this->assign(UserModel::systemPage($where));
+        $this->assign(['title' => '添加客服', 'save' => Url::buildUrl('save')]);
+        return $this->fetch();
+    }
+
+    /**
+     * 保存新建的资源
+     */
+    public function save()
+    {
+        $params = request()->post();
+        if (count($params["checked_menus"]) <= 0) return Json::fail('请选择要添加的用户!');
+        if (ServiceModel::where('mer_id', 0)->where(array("uid" => array("in", implode(',', $params["checked_menus"]))))->count()) return Json::fail('添加用户中存在已有的客服!');
+        foreach ($params["checked_menus"] as $key => $value) {
+            $now_user = UserModel::get($value);
+            $data[$key]["mer_id"] = 0;
+            $data[$key]["uid"] = $now_user["uid"];
+            $data[$key]["avatar"] = $now_user["headimgurl"];
+            $data[$key]["nickname"] = $now_user["nickname"];
+            $data[$key]["add_time"] = time();
+        }
+        ServiceModel::setAll($data);
+        return Json::successful('添加成功!');
+    }
+
+    /**
+     * 显示编辑资源表单页.
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function edit($id)
+    {
+        $service = ServiceModel::get($id);
+        if (!$service) return Json::fail('数据不存在!');
+        $f = array();
+        $f[] = Form::frameImageOne('avatar', '客服头像', Url::buildUrl('admin/widget.images/index', array('fodder' => 'avatar')), $service['avatar'])->icon('image')->width('100%')->height('500px');
+        $f[] = Form::input('nickname', '客服名称', $service["nickname"]);
+        $f[] = Form::radio('customer', '统计管理', $service['customer'])->options([['value' => 1, 'label' => '开启'], ['value' => 0, 'label' => '关闭']]);
+        $f[] = Form::radio('notify', '订单通知', $service['notify'])->options([['value' => 1, 'label' => '开启'], ['value' => 0, 'label' => '关闭']]);
+        $f[] = Form::radio('status', '客服状态', $service['status'])->options([['value' => 1, 'label' => '在线'], ['value' => 0, 'label' => '离线']]);
+        $form = Form::make_post_form('修改数据', $f, Url::buildUrl('update', compact('id')));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 保存新建的资源
+     *
+     * @param \think\Request $request
+     * @return \think\Response
+     */
+    public function update($id)
+    {
+        $params = request()->post();
+        if (empty($params["nickname"])) return Json::fail("客服名称不能为空!");
+        $data = array("avatar" => $params["avatar"]
+        , "nickname" => $params["nickname"]
+        , 'status' => $params['status']
+        , 'notify' => $params['notify']
+        , 'customer' => $params['customer']
+        );
+        ServiceModel::edit($data, $id);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 删除指定资源
+     *
+     * @param int $id
+     * @return \think\Response
+     */
+    public function delete($id)
+    {
+        if (!ServiceModel::del($id))
+            return Json::fail(ServiceModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+
+    /**
+     * 显示资源列表
+     *
+     * @return \think\Response
+     */
+    public function chat_user($id)
+    {
+        $now_service = ServiceModel::get($id);
+        if (!$now_service) return Json::fail('数据不存在!');
+        $list = ServiceModel::getChatUser($now_service->toArray(), 0);
+        $this->assign(compact('list', 'now_service'));
+        return $this->fetch();
+    }
+
+    /**
+     * @param int $uid
+     * @param int $to_uid
+     * @return string
+     */
+    public function chat_list()
+    {
+        $where = Util::getMore([['uid', 0], ['to_uid', 0], ['id', 0]]);
+        if ($where['uid'])
+            CacheService::set('admin_chat_list' . $this->adminId, $where);
+        $where = CacheService::get('admin_chat_list' . $this->adminId);
+        $this->assign(StoreServiceLog::getChatList($where, 0));
+        $this->assign('where', $where);
+        return $this->fetch();
+    }
+}

+ 34 - 0
app/admin/controller/wechat/WechatMessage.php

@@ -0,0 +1,34 @@
+<?php
+
+namespace app\admin\controller\wechat;
+
+use app\admin\controller\AuthController;
+use app\admin\model\wechat\WechatMessage as MessageModel;
+use crmeb\services\UtilService as Util;
+
+/**
+ * 用户扫码点击事件
+ * Class SystemMessage
+ * @package app\admin\controller\system
+ */
+class WechatMessage extends AuthController
+{
+    /**
+     * 显示操作记录
+     */
+    public function index()
+    {
+        $where = Util::getMore([
+            ['nickname', ''],
+            ['type', ''],
+            ['data', ''],
+        ], $this->request);
+        $this->assign('where', $where);
+        $this->assign('mold', MessageModel::$mold);
+        $this->assign(MessageModel::systemPage($where));
+        return $this->fetch();
+    }
+
+
+}
+

+ 279 - 0
app/admin/controller/wechat/WechatNewsCategory.php

@@ -0,0 +1,279 @@
+<?php
+
+namespace app\admin\controller\wechat;
+
+use app\admin\controller\AuthController;
+use app\admin\model\article\Article;
+use app\models\article\ArticleContent;
+use think\facade\Route as Url;
+use app\admin\model\article\Article as ArticleModel;
+use app\admin\model\wechat\{WechatReply, WechatUser, WechatNewsCategory as WechatNewsCategoryModel};
+use crmeb\services\{FormBuilder as Form, UtilService as Util, JsonService as Json, UtilService, WechatService};
+
+/**
+ * 图文信息
+ * Class WechatNewsCategory
+ * @package app\admin\controller\wechat
+ *
+ */
+class WechatNewsCategory extends AuthController
+{
+    public function select($callback = '_selectNews$eb')
+    {
+        $where = Util::getMore([
+            ['cate_name', ''],
+            ['type', 1]
+        ], $this->request);
+        $this->assign('where', $where);
+        $this->assign('callback', $callback);
+        if ($where['type'] == 1)
+            $list = WechatNewsCategoryModel::getSendAll($where);
+        else
+            $list = WechatNewsCategoryModel::getAll($where);
+        $newList = $list['list']->toArray();
+        $newList = $newList['data'];
+        $this->assign($list);
+        $this->assign('type',$where['type']);
+        $this->assign('newList', $newList);
+        return $this->fetch();
+    }
+
+    public function index()
+    {
+        $where = Util::getMore([
+            ['cate_name', ''],
+        ], $this->request);
+        $this->assign('where', $where);
+        $this->assign(WechatNewsCategoryModel::getAll($where));
+        return $this->fetch();
+    }
+
+    public function create()
+    {
+        $f = array();
+        $f[] = Form::input('cate_name', '分类名称')->autofocus(1);
+        $f[] = Form::select('new_id', '图文列表')->setOptions(function () {
+            $list = ArticleModel::getNews();
+            $options = [];
+            foreach ($list as $id => $roleName) {
+                $options[] = ['label' => $roleName, 'value' => $id];
+            }
+            return $options;
+        })->filterable(1)->multiple(1);
+        $form = Form::make_post_form('编辑菜单', $f, Url::buildUrl('save'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    public function save()
+    {
+        $data = Util::postMore([
+            'cate_name',
+            ['new_id', []],
+            ['sort', 0],
+            ['add_time', time()],
+            ['status', 1],]);
+        if (!$data['cate_name']) return Json::fail('请输入图文名称');
+        if (empty($data['new_id'])) return Json::fail('请选择图文列表');
+        $data['new_id'] = array_unique($data['new_id']);
+        if (count($data['new_id']) > 8) {
+            $data['new_id'] = array_slice($data['new_id'], 0, 8);
+        };
+        $data['new_id'] = implode(',', $data['new_id']);
+        WechatNewsCategoryModel::create($data);
+        return Json::successful('添加菜单成功!');
+    }
+
+    public function edit($id)
+    {
+        $menu = WechatNewsCategoryModel::get($id);
+        if (!$menu) return Json::fail('数据不存在!');
+        $arr_new_id = array_unique(explode(',', $menu->new_id));
+        foreach ($arr_new_id as $k => $v) {
+            $arr_new_id[$k] = intval($v);
+        }
+        $f = array();
+        $f[] = Form::input('cate_name', '分类名称', $menu['cate_name'])->autofocus(1);
+        $f[] = Form::select('new_id', '图文列表', $arr_new_id)->setOptions(function () {
+            $list = ArticleModel::getNews();
+            $options = [];
+            foreach ($list as $id => $roleName) {
+                $options[] = ['label' => $roleName, 'value' => $id];
+            }
+            return $options;
+        })->filterable(1)->multiple(1);
+        $form = Form::make_post_form('编辑图文', $f, Url::buildUrl('update', compact('id')));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    public function update($id)
+    {
+        $data = Util::postMore([
+            'cate_name',
+            ['new_id', []],
+            ['sort', 0],
+            ['status', 1],]);
+        if (!$data['cate_name']) return Json::fail('请输入图文名称');
+        if (empty($data['new_id'])) return Json::fail('请选择图文列表');
+        if (count($data['new_id']) > 8) {
+            $data['new_id'] = array_slice($data['new_id'], 0, 8);
+        };
+        $data['new_id'] = implode(',', $data['new_id']);;
+        if (!WechatNewsCategoryModel::get($id)) return Json::fail('编辑的记录不存在!');
+        WechatNewsCategoryModel::edit($data, $id);
+        return Json::successful('修改成功!');
+    }
+
+    public function delete($id)
+    {
+        if (!WechatNewsCategoryModel::del($id))
+            return Json::fail(WechatNewsCategoryModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+
+
+    /**
+     * 发送消息
+     * @param int $id
+     * @param string $wechat
+     * $wechat  不为空  发消息  /  空 群发消息
+     */
+    public function push($id = 0, $new_id = 0, $wechat = '')
+    {
+        if ((!$id) || (!$new_id)) return Json::fail('参数错误');
+        $list = WechatNewsCategoryModel::getWechatNewsItem($id, $new_id);
+        $wechatNews = [];
+        if ($list) {
+            if ($list['new'] && is_array($list['new'])) {
+                foreach ($list['new'] as $kk => $vv) {
+                    $wechatNews[$kk]['title'] = $vv['title'];
+                    $wechatNews[$kk]['image'] = $vv['image_input'];
+                    $wechatNews[$kk]['date'] = date('m月d日', time());
+                    $wechatNews[$kk]['description'] = $vv['synopsis'];
+                    $wechatNews[$kk]['id'] = $vv['id'];
+                }
+            }
+        }
+        if ($wechat != '') {//客服消息
+            $wechatNews = WechatReply::tidyNews($wechatNews);
+            $message = WechatService::newsMessage($wechatNews);
+            $errorLog = [];//发送失败的用户
+            $user = WechatUser::where('uid', 'IN', $wechat)->column('nickname,subscribe,openid', 'uid');
+            if ($user) {
+                foreach ($user as $v) {
+                    if ($v['subscribe'] && $v['openid']) {
+                        try {
+                            WechatService::staffService()->message($message)->to($v['openid'])->send();
+                        } catch (\Exception $e) {
+                            $errorLog[] = $v['nickname'] . '发送失败';
+                        }
+                    } else {
+                        $errorLog[] = $v['nickname'] . '没有关注发送失败(不是微信公众号用户)';
+                    }
+                }
+            } else return Json::fail('发送失败,参数不正确');
+            if (!count($errorLog)) return Json::successful('全部发送成功');
+            else return Json::successful(implode(',', $errorLog) . ',剩余的发送成功');
+        }
+    }
+
+    public function send_news($id = '')
+    {
+        if ($id == '') return $this->failed('参数错误');
+        $where = Util::getMore([
+            ['cate_name', ''],
+            ['type', 0]
+        ], $this->request);
+        $this->assign('where', $where);
+        $this->assign('wechat', $id);
+        $this->assign(WechatNewsCategoryModel::getSendAll($where));
+        return $this->fetch();
+    }
+
+    public function append()
+    {
+        $this->assign('list', [
+            [
+                'id' => 0,
+                'title' => '',
+                'author' => $this->adminInfo->real_name,
+                'content' => '',
+                'image_input' => '/system/module/wechat/news/images/image.png',
+                'synopsis' => '',
+            ]
+        ]);
+        $this->assign('id', 0);
+        $this->assign('author', $this->adminInfo->real_name);
+        return $this->fetch();
+    }
+
+    public function append_save()
+    {
+        $data = UtilService::postMore([
+            ['list', []],
+            ['id', 0]
+        ]);
+        $id = [];
+        $countList = count($data['list']);
+        if (!$countList) return Json::fail('请添加图文');
+        Article::beginTrans();
+        foreach ($data['list'] as $k => $v) {
+            if ($v['title'] == '') return Json::fail('标题不能为空');
+            if ($v['author'] == '') return Json::fail('作者不能为空');
+            if ($v['content'] == '') return Json::fail('正文不能为空');
+            if ($v['synopsis'] == '') return Json::fail('摘要不能为空');
+            $v['status'] = 1;
+            $v['add_time'] = time();
+            if ($v['id']) {
+                $idC = $v['id'];
+                unset($v['id']);
+                Article::edit($v, $idC);
+                ArticleContent::where('nid', $idC)->update(['content' => $v['content']]);
+                $data['list'][$k]['id'] = $idC;
+                $id[] = $idC;
+            } else {
+                unset($v['id']);
+                $res = Article::create($v)->toArray();
+                $id[] = $res['id'];
+                $data['list'][$k]['id'] = $res['id'];
+                ArticleContent::insert(['content' => $v['content'], 'nid' => $res['id']]);
+            }
+        }
+        $countId = count($id);
+        if ($countId != $countList) {
+            Article::checkTrans(false);
+            if ($data['id']) return Json::fail('修改失败');
+            else return Json::fail('添加失败');
+        } else {
+            Article::checkTrans(true);
+            $newsCategory['cate_name'] = $data['list'][0]['title'];
+            $newsCategory['new_id'] = implode(',', $id);
+            $newsCategory['sort'] = 0;
+            $newsCategory['add_time'] = time();
+            $newsCategory['status'] = 1;
+            if ($data['id']) {
+                WechatNewsCategoryModel::edit($newsCategory, $data['id']);
+                return Json::successful('修改成功');
+            } else {
+                WechatNewsCategoryModel::create($newsCategory);
+                return Json::successful('添加成功');
+            }
+        }
+    }
+
+    public function modify($id)
+    {
+        if (!strlen(trim($id)) || !$id) return $this->failed('参数错误');
+        $wechatNews = WechatNewsCategoryModel::get($id);
+        if (!$wechatNews) return $this->failed('参数错误');
+        $wechatNews = $wechatNews->toArray();
+        $list = Article::getArticleList($wechatNews['new_id']);
+        $this->assign('list', $list);
+        $this->assign('id', $id);
+        $this->assign('author', $this->adminInfo->real_name);
+        return $this->fetch('append');
+    }
+
+}

+ 135 - 0
app/admin/controller/wechat/WechatTemplate.php

@@ -0,0 +1,135 @@
+<?php
+
+namespace app\admin\controller\wechat;
+
+use app\admin\controller\AuthController;
+use crmeb\services\FormBuilder as Form;
+use crmeb\services\UtilService as Util;
+use crmeb\services\JsonService as Json;
+use crmeb\services\WechatTemplateService;
+use think\facade\Cache;
+use think\facade\Route as Url;
+use app\admin\model\wechat\WechatTemplate as WechatTemplateModel;
+
+/**
+ * 微信模板消息控制器
+ * Class WechatTemplate
+ * @package app\admin\controller\wechat
+ */
+class WechatTemplate extends AuthController
+{
+
+    protected $cacheTag = '_system_wechat';
+
+    public function index()
+    {
+        $where = Util::getMore([
+            ['name', ''],
+            ['status', '']
+        ], $this->request);
+        $this->assign('where', $where);
+        $this->assign(WechatTemplateModel::SystemPage($where));
+        $industry = Cache::tag($this->cacheTag)->remember('_wechat_industry', function () {
+            try {
+                $cache = WechatTemplateService::getIndustry();
+                if (!$cache) return [];
+                Cache::tag($this->cacheTag, ['_wechat_industry']);
+                return $cache->toArray();
+            } catch (\Exception $e) {
+                return $e->getMessage();
+            }
+
+        }, 0) ?: [];
+        !is_array($industry) && $industry = [];
+        $this->assign('industry', $industry);
+        return $this->fetch();
+    }
+
+    /**
+     * 添加模板消息
+     * @return mixed
+     */
+    public function create()
+    {
+        $f = array();
+        $f[] = Form::input('tempkey', '模板编号');
+        $f[] = Form::input('tempid', '模板ID');
+        $f[] = Form::input('name', '模板名');
+        $f[] = Form::input('content', '回复内容')->type('textarea');
+        $f[] = Form::radio('status', '状态', 1)->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]]);
+        $form = Form::make_post_form('添加模板消息', $f, Url::buildUrl('save'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    public function save()
+    {
+        $data = Util::postMore([
+            'tempkey',
+            'tempid',
+            'name',
+            'content',
+            ['status', 0]
+        ]);
+        if ($data['tempkey'] == '') return Json::fail('请输入模板编号');
+        if ($data['tempkey'] != '' && WechatTemplateModel::be($data['tempkey'], 'tempkey'))
+            return Json::fail('请输入模板编号已存在,请重新输入');
+        if ($data['tempid'] == '') return Json::fail('请输入模板ID');
+        if ($data['name'] == '') return Json::fail('请输入模板名');
+        if ($data['content'] == '') return Json::fail('请输入回复内容');
+        $data['add_time'] = time();
+        $data['type'] = 1;
+        WechatTemplateModel::create($data);
+        return Json::successful('添加模板消息成功!');
+    }
+
+    /**
+     * 编辑模板消息
+     * @param $id
+     * @return mixed|\think\response\Json|void
+     */
+    public function edit($id)
+    {
+        if (!$id) return $this->failed('数据不存在');
+        $product = WechatTemplateModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        $f = array();
+        $f[] = Form::input('tempkey', '模板编号', $product->getData('tempkey'))->disabled(1);
+        $f[] = Form::input('name', '模板名', $product->getData('name'))->disabled(1);
+        $f[] = Form::input('tempid', '模板ID', $product->getData('tempid'));
+        $f[] = Form::radio('status', '状态', $product->getData('status'))->options([['label' => '开启', 'value' => 1], ['label' => '关闭', 'value' => 0]]);
+        $form = Form::make_post_form('编辑模板消息', $f, Url::buildUrl('update', compact('id')));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    public function update($id)
+    {
+        $data = Util::postMore([
+            'tempid',
+            ['status', 0]
+        ]);
+        if ($data['tempid'] == '') return Json::fail('请输入模板ID');
+        if (!$id) return $this->failed('数据不存在');
+        $product = WechatTemplateModel::get($id);
+        if (!$product) return Json::fail('数据不存在!');
+        WechatTemplateModel::edit($data, $id);
+        return Json::successful('修改成功!');
+    }
+
+    /**
+     * 删除模板消息
+     * @param $id
+     * @return \think\response\Json
+     */
+    public function delete($id)
+    {
+        if (!$id) return Json::fail('数据不存在!');
+        if (!WechatTemplateModel::del($id))
+            return Json::fail(WechatTemplateModel::getErrorInfo('删除失败,请稍候再试!'));
+        else
+            return Json::successful('删除成功!');
+    }
+
+
+}

+ 390 - 0
app/admin/controller/wechat/WechatUser.php

@@ -0,0 +1,390 @@
+<?php
+
+namespace app\admin\controller\wechat;
+
+use app\admin\controller\AuthController;
+use app\admin\model\user\User;
+use app\models\user\UserBill;
+use think\Collection;
+use think\facade\Route as Url;
+use app\admin\model\wechat\WechatUser as UserModel;
+use crmeb\services\{FormBuilder as Form, JsonService, UtilService as Util, WechatService};
+
+/**
+ * 管理员操作记录表控制器
+ * Class WechatUser
+ * @package app\admin\controller\wechat
+ */
+class WechatUser extends AuthController
+{
+    /**
+     * 显示操作记录
+     */
+    public function index()
+    {
+        $where = Util::getMore([
+            ['nickname', ''],
+            ['data', ''],
+            ['tagid_list', ''],
+            ['groupid', '-1'],
+            ['sex', ''],
+            ['export', ''],
+            ['stair', ''],
+            ['second', ''],
+            ['order_stair', ''],
+            ['order_second', ''],
+            ['subscribe', ''],
+            ['now_money', ''],
+            ['is_promoter', ''],
+        ], $this->request);
+        $tagidList = explode(',', $where['tagid_list']);
+        foreach ($tagidList as $k => $v) {
+            if (!$v) {
+                unset($tagidList[$k]);
+            }
+        }
+        $tagidList = array_unique($tagidList);
+        $where['tagid_list'] = implode(',', $tagidList);
+        try {
+            $groupList = UserModel::getUserGroup();
+            $tagList = UserModel::getUserTag();
+        } catch (\Exception $e) {
+            $groupList = [];
+            $tagList = [];
+        }
+        $this->assign([
+            'where' => $where,
+            'groupList' => $groupList,
+            'tagList' => $tagList
+        ]);
+        $limitTimeList = [
+            'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
+            'week' => implode(' - ', [
+                date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
+                date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
+            ]),
+            'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
+            'quarter' => implode(' - ', [
+                date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
+                date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
+            ]),
+            'year' => implode(' - ', [
+                date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
+            ])
+        ];
+        $uidAll = UserModel::getAll($where);
+        $this->assign(compact('limitTimeList', 'uidAll'));
+        $this->assign(UserModel::systemPage($where));
+        return $this->fetch();
+    }
+
+    public function edit_user_tag($openid)
+    {
+        if (!$openid) return JsonService::fail('参数错误!');
+        $list = Collection::make(UserModel::getUserTag())->each(function ($item) {
+            return ['value' => $item['id'], 'label' => $item['name']];
+        });
+        $tagList = UserModel::where('openid', $openid)->value('tagid_list');
+
+        $tagList = explode(',', $tagList) ?: [];
+        $f = [Form::select('tag_id', '用户标签', $tagList)->setOptions($list->toArray())->multiple(1)];
+        $form = Form::make_post_form('标签名称', $f, Url::buildUrl('update_user_tag', compact('openid')));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    public function update_user_tag($openid)
+    {
+        if (!$openid) return JsonService::fail('参数错误!');
+        $tagId = request()->post('tag_id/a', []);
+        if (!$tagId) return JsonService::fail('请选择用户标签!');
+        $tagList = explode(',', UserModel::where('openid', $openid)->value('tagid_list')) ?: [];
+        UserModel::edit(['tagid_list' => $tagId], $openid, 'openid');
+        if (!$tagId[0]) unset($tagId[0]);
+        UserModel::edit(['tagid_list' => $tagId], $openid, 'openid');
+        try {
+            foreach ($tagList as $tag) {
+                if ($tag) WechatService::userTagService()->batchUntagUsers([$openid], $tag);
+            }
+            foreach ($tagId as $tag) {
+                WechatService::userTagService()->batchTagUsers([$openid], $tag);
+            }
+        } catch (\Exception $e) {
+            UserModel::rollbackTrans();
+            return JsonService::fail($e->getMessage());
+        }
+        UserModel::commitTrans();
+        return JsonService::successful('修改成功!');
+    }
+
+    public function edit_user_group($openid)
+    {
+        if (!$openid) return JsonService::fail('参数错误!');
+        $list = Collection::make(UserModel::getUserGroup())->each(function ($item) {
+            return ['value' => $item['id'], 'label' => $item['name']];
+        });
+        $groupId = UserModel::where('openid', $openid)->value('groupid');
+        $f = [Form::select('group_id', '用户分组', (string)$groupId)->setOptions($list->toArray())];
+        $form = Form::make_post_form('用户分组', $f, Url::buildUrl('update_user_group', compact('openid')));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    public function update_user_group($openid)
+    {
+        if (!$openid) return JsonService::fail('参数错误!');
+        $groupId = request()->post('group_id');
+//        if(!$groupId) return JsonService::fail('请选择用户分组!');
+        UserModel::beginTrans();
+        UserModel::edit(['groupid' => $groupId], $openid, 'openid');
+        try {
+            WechatService::userGroupService()->moveUser($openid, $groupId);
+        } catch (\Exception $e) {
+            UserModel::rollbackTrans();
+            return JsonService::fail($e->getMessage());
+        }
+        UserModel::commitTrans();
+        return JsonService::successful('修改成功!');
+    }
+
+    /**
+     * 用户标签列表
+     */
+    public function tag($refresh = 0)
+    {
+        $list = [];
+        if ($refresh == 1) {
+            UserModel::clearUserTag();
+            $this->redirect(Url::buildUrl('tag')->suffix(false)->build());
+        }
+        try {
+            $list = UserModel::getUserTag();
+        } catch (\Exception $e) {
+        }
+        $this->assign(compact('list'));
+        return $this->fetch();
+    }
+
+    /**
+     * 添加标签
+     * @return mixed
+     */
+    public function create_tag()
+    {
+        $f = [Form::input('name', '标签名称')];
+        $form = Form::make_post_form('标签名称', $f, Url::buildUrl('save_tag'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 添加
+     */
+    public function save_tag()
+    {
+        $tagName = request()->post('name');
+        if (!$tagName) return JsonService::fail('请输入标签名称!');
+        try {
+            WechatService::userTagService()->create($tagName);
+        } catch (\Exception $e) {
+            return JsonService::fail($e->getMessage());
+        }
+        UserModel::clearUserTag();
+        return JsonService::successful('添加标签成功!');
+    }
+
+    /**
+     * 修改标签
+     * @param $id
+     * @return mixed
+     */
+    public function edit_tag($id)
+    {
+        $f = [Form::input('name', '标签名称')];
+        $form = Form::make_post_form('标签名称', $f, Url::buildUrl('update_tag', ['id' => $id]));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 修改标签
+     * @param $id
+     */
+    public function update_tag($id)
+    {
+        $tagName = request()->post('name');
+        if (!$tagName) return JsonService::fail('请输入标签名称!');
+        try {
+            WechatService::userTagService()->update($id, $tagName);
+        } catch (\Exception $e) {
+            return JsonService::fail($e->getMessage());
+        }
+        UserModel::clearUserTag();
+        return JsonService::successful('修改标签成功!');
+    }
+
+    /**
+     * 删除标签
+     * @param $id
+     * @return \think\response\Json
+     */
+    public function delete_tag($id)
+    {
+        try {
+            WechatService::userTagService()->delete($id);
+        } catch (\Exception $e) {
+            return JsonService::fail($e->getMessage());
+        }
+        UserModel::clearUserTag();
+        return JsonService::successful('删除标签成功!');
+    }
+
+    /**
+     * 用户分组列表
+     */
+
+    public function group($refresh = 0)
+    {
+        $list = [];
+        try {
+            if ($refresh == 1) {
+                UserModel::clearUserGroup();
+                $this->redirect(Url::buildUrl('group')->suffix(false)->build());
+            }
+            $list = UserModel::getUserGroup();
+        } catch (\Exception $e) {
+        }
+        $this->assign(compact('list'));
+        return $this->fetch();
+    }
+
+    /**
+     * 添加分组
+     * @return mixed
+     */
+    public function create_group()
+    {
+        $f = [Form::input('name', '分组名称')];
+        $form = Form::make_post_form('标签名称', $f, Url::buildUrl('save_group'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 添加
+     */
+    public function save_group()
+    {
+        $tagName = request()->post('name');
+        if (!$tagName) return JsonService::fail('请输入分组名称!');
+        try {
+            WechatService::userGroupService()->create($tagName);
+        } catch (\Exception $e) {
+            return JsonService::fail($e->getMessage());
+        }
+        UserModel::clearUserGroup();
+        return JsonService::successful('添加分组成功!');
+    }
+
+    /**
+     * 修改分组
+     * @param $id
+     * @return mixed
+     */
+    public function edit_group($id)
+    {
+        $f = [Form::input('name', '分组名称')];
+        $form = Form::make_post_form('标签名称', $f, Url::buildUrl('update_group', compact('id')));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 修改分组
+     * @param $id
+     */
+    public function update_group($id)
+    {
+        $tagName = request()->post('name');
+        if (!$tagName) return JsonService::fail('请输入分组名称!');
+        try {
+            WechatService::userGroupService()->update($id, $tagName);
+        } catch (\Exception $e) {
+            return JsonService::fail($e->getMessage());
+        }
+        UserModel::clearUserGroup();
+        return JsonService::successful('修改分组成功!');
+    }
+
+    /**
+     * 删除分组
+     * @param $id
+     * @return \think\response\Json
+     */
+    public function delete_group($id)
+    {
+        try {
+            WechatService::userTagService()->delete($id);
+        } catch (\Exception $e) {
+            return JsonService::fail($e->getMessage());
+        }
+        UserModel::clearUserGroup();
+        return JsonService::successful('删除分组成功!');
+    }
+
+    public function synchro_tag($openid)
+    {
+        if (!$openid) return JsonService::fail('参数错误!');
+        $data = array();
+        if (UserModel::be($openid, 'openid')) {
+            try {
+                $tag = WechatService::userTagService()->userTags($openid)->toArray();
+            } catch (\Exception $e) {
+                return JsonService::fail($e->getMessage());
+            }
+            if ($tag['tagid_list']) $data['tagid_list'] = implode(',', $tag['tagid_list']);
+            else $data['tagid_list'] = '';
+            $res = UserModel::edit($data, $openid, 'openid');
+            if ($res) return JsonService::successful('同步成功');
+            else return JsonService::fail('同步失败!');
+        } else  return JsonService::fail('参数错误!');
+    }
+
+    /**
+     * 一级推荐人页面
+     * @return mixed
+     */
+    public function stair($uid = '')
+    {
+        if ($uid == '') return $this->failed('参数错误');
+        $list = User::alias('u')
+            ->where('u.spread_uid', $uid)
+            ->field('u.avatar,u.nickname,u.now_money,u.add_time,u.uid')
+            ->where('u.status', 1)
+            ->order('u.add_time DESC')
+            ->select()
+            ->toArray();
+        foreach ($list as $key => $value) $list[$key]['orderCount'] = StoreOrder::getOrderCount($value['uid']);
+        $this->assign('list', $list);
+        return $this->fetch();
+    }
+
+    /**
+     * 个人资金详情页面
+     * @return mixed
+     */
+    public function now_money($uid = '')
+    {
+        if ($uid == '') return $this->failed('参数错误');
+        $list = UserBill::where('uid', $uid)->where('category', 'now_money')
+            ->field('mark,pm,number,add_time')
+            ->where('status', 1)->order('add_time DESC')->select()->toArray();
+        foreach ($list as &$v) {
+            $v['add_time'] = date('Y-m-d H:i:s', $v['add_time']);
+        }
+        $this->assign('list', $list);
+        return $this->fetch();
+    }
+
+}
+

+ 7 - 0
app/admin/controller/wechat/index.php

@@ -0,0 +1,7 @@
+<?php
+/**
+ * Created by PhpStorm.
+ * User: Administrator
+ * Date: 2018/4/18 0018
+ * Time: 上午 10:44
+ */

+ 278 - 0
app/admin/controller/widget/Images.php

@@ -0,0 +1,278 @@
+<?php
+
+namespace app\admin\controller\widget;
+
+use app\admin\controller\AuthController;
+use think\facade\Route as Url;
+use app\admin\model\system\{
+    SystemAttachment as SystemAttachmentModel, SystemAttachmentCategory as Category
+};
+use crmeb\services\{JsonService as Json, JsonService, UtilService as Util, FormBuilder as Form};
+use crmeb\services\upload\Upload;
+
+/**
+ * TODO 附件控制器
+ * Class Images
+ * @package app\admin\controller\widget
+ */
+class Images extends AuthController
+{
+    /**
+     * 附件列表
+     * @return \think\response\Json
+     */
+    public function index()
+    {
+        $pid = request()->param('pid');
+        if ($pid === NULL) {
+            $pid = session('pid') ? session('pid') : 0;
+        }
+        session('pid', $pid);
+        $this->assign('pid', $pid);
+////       //TODO 分类标题
+//       $typearray = Category::getAll();
+//       $this->assign(compact('typearray'));
+//       $this->assign(SystemAttachmentModel::getAll($pid));
+        return $this->fetch('widget/images');
+    }
+
+    /**获取图片列表
+     *
+     */
+    public function get_image_list()
+    {
+        $where = Util::getMore([
+            ['page', 1],
+            ['limit', 18],
+            ['pid', 0]
+        ]);
+        return Json::successful(SystemAttachmentModel::getImageList($where));
+    }
+
+    /**获取分类
+     * @param string $name
+     */
+    public function get_image_cate($name = '')
+    {
+        return Json::successful(Category::getAll($name));
+    }
+
+    /**
+     * 图片管理上传图片
+     * @return \think\response\Json
+     */
+    public function upload()
+    {
+        $pid = $this->request->param('pid', session('pid'));
+        $upload_type = $this->request->get('upload_type', sys_config('upload_type', 1));
+        try {
+            $path = make_path('attach', 2, true);
+            $upload = new Upload((int)$upload_type, [
+                'accessKey' => sys_config('accessKey'),
+                'secretKey' => sys_config('secretKey'),
+                'uploadUrl' => sys_config('uploadUrl'),
+                'storageName' => sys_config('storage_name'),
+                'storageRegion' => sys_config('storage_region'),
+            ]);
+            $res = $upload->to($path)->validate()->move();
+            if ($res === false) {
+                return JsonService::fail('上传失败:' . $upload->getError());
+            } else {
+                $fileInfo = $upload->getUploadInfo();
+                if ($fileInfo) {
+                    SystemAttachmentModel::attachmentAdd($fileInfo['name'], $fileInfo['size'], $fileInfo['type'], $fileInfo['dir'], $fileInfo['thumb_path'], $pid, $upload_type, $fileInfo['time']);
+                }
+                return JsonService::successful('上传成功', ['src' => $res->filePath]);
+            }
+        } catch (\Exception $e) {
+            return JsonService::fail('上传失败:' . $e->getMessage());
+        }
+    }
+
+    /**
+     * ajax 提交删除
+     */
+    public function delete()
+    {
+        $request = app('request');
+        $post = $request->post();
+        if (empty($post['imageid']))
+            Json::fail('还没选择要删除的图片呢?');
+        foreach ($post['imageid'] as $v) {
+            if ($v) self::deleteimganddata($v);
+        }
+        Json::successful('删除成功');
+    }
+
+    /**删除图片和数据记录
+     * @param $att_id
+     */
+    public function deleteimganddata($att_id)
+    {
+
+        $attinfo = SystemAttachmentModel::get($att_id);
+        if ($attinfo) {
+            try {
+                $upload = new Upload((int)$attinfo['image_type'], [
+                    'accessKey' => sys_config('accessKey'),
+                    'secretKey' => sys_config('secretKey'),
+                    'uploadUrl' => sys_config('uploadUrl'),
+                    'storageName' => sys_config('storage_name'),
+                    'storageRegion' => sys_config('storage_region'),
+                ]);
+                if ($attinfo['image_type'] == 1) {
+                    if (strpos($attinfo['att_dir'], '/') == 0) {
+                        $attinfo['att_dir'] = substr($attinfo['att_dir'], 1);
+                    }
+                    $upload->delete($attinfo['att_dir']);
+                } else {
+                    $upload->delete($attinfo['name']);
+                }
+            } catch (\Throwable $e) {
+            }
+            SystemAttachmentModel::where('att_id', $att_id)->delete();
+        }
+    }
+
+    /**
+     * 移动图片分类显示
+     */
+    public function moveimg($imgaes)
+    {
+
+        $formbuider = [];
+        $formbuider[] = Form::hidden('imgaes', $imgaes);
+        $formbuider[] = Form::select('pid', '选择分类')->setOptions(function () {
+            $list = Category::getCateList();
+            $options = [['value' => 0, 'label' => '所有分类']];
+            foreach ($list as $id => $cateName) {
+                $options[] = ['label' => $cateName['html'] . $cateName['name'], 'value' => $cateName['id']];
+            }
+            return $options;
+        })->filterable(1);
+        $form = Form::make_post_form('编辑分类', $formbuider, Url::buildUrl('moveImgCecate'));
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 移动图片分类操作
+     */
+    public function moveImgCecate()
+    {
+        $data = Util::postMore([
+            'pid',
+            'imgaes'
+        ]);
+        if ($data['imgaes'] == '') return Json::fail('请选择图片');
+        if (!$data['pid']) return Json::fail('请选择分类');
+        $res = SystemAttachmentModel::where('att_id', 'in', $data['imgaes'])->update(['pid' => $data['pid']]);
+        if ($res)
+            Json::successful('移动成功');
+        else
+            Json::fail('移动失败!');
+    }
+
+    /**
+     * ajax 添加分类
+     */
+    public function addcate($id = 0)
+    {
+        $formbuider = [];
+        $formbuider[] = Form::select('pid', '上级分类', (string)$id)->setOptions(function () {
+            $list = Category::getCateList(0,1);
+            $options = [['value' => 0, 'label' => '所有分类']];
+            foreach ($list as $id => $cateName) {
+                $options[] = ['label' => $cateName['html'] . $cateName['name'], 'value' => $cateName['id']];
+            }
+            return $options;
+        })->filterable(1);
+        $formbuider[] = Form::input('name', '分类名称');
+        $jsContent = <<<SCRIPT
+parent.SuccessCateg();
+parent.layer.close(parent.layer.getFrameIndex(window.name));
+SCRIPT;
+        $form = Form::make_post_form('添加分类', $formbuider, Url::buildUrl('saveCate'), $jsContent);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 添加分类
+     */
+    public function saveCate()
+    {
+        $request = app('request');
+        $post = $request->post();
+        $data['pid'] = $post['pid'];
+        $data['name'] = $post['name'];
+        if (empty($post['name']))
+            Json::fail('分类名称不能为空!');
+        $res = Category::create($data);
+        if ($res)
+            Json::successful('添加成功');
+        else
+            Json::fail('添加失败!');
+
+    }
+
+    /**
+     * 编辑分类
+     */
+    public function editcate($id)
+    {
+        $Category = Category::get($id);
+        if (!$Category) return Json::fail('数据不存在!');
+        $formbuider = [];
+        $formbuider[] = Form::hidden('id', $id);
+        $formbuider[] = Form::select('pid', '上级分类', (string)$Category->getData('pid'))->setOptions(function () use ($id) {
+            $list = Category::getCateList();
+            $options = [['value' => 0, 'label' => '所有分类']];
+            foreach ($list as $id => $cateName) {
+                $options[] = ['label' => $cateName['html'] . $cateName['name'], 'value' => $cateName['id']];
+            }
+            return $options;
+        })->filterable(1);
+        $formbuider[] = Form::input('name', '分类名称', $Category->getData('name'));
+        $jsContent = <<<SCRIPT
+parent.SuccessCateg();
+parent.layer.close(parent.layer.getFrameIndex(window.name));
+SCRIPT;
+        $form = Form::make_post_form('编辑分类', $formbuider, Url::buildUrl('updateCate'), $jsContent);
+        $this->assign(compact('form'));
+        return $this->fetch('public/form-builder');
+    }
+
+    /**
+     * 更新分类
+     * @param $id
+     */
+    public function updateCate($id)
+    {
+        $data = Util::postMore([
+            'pid',
+            'name'
+        ]);
+        if ($data['pid'] == '') return Json::fail('请选择父类');
+        if (!$data['name']) return Json::fail('请输入分类名称');
+        Category::edit($data, $id);
+        return Json::successful('分类编辑成功!');
+    }
+
+    /**
+     * 删除分类
+     */
+    public function deletecate($id)
+    {
+        $chdcount = Category::where('pid', $id)->count();
+        if ($chdcount) return Json::fail('有子栏目不能删除');
+        $chdcount = SystemAttachmentModel::where('pid', $id)->count();
+        if ($chdcount) return Json::fail('栏目内有图片不能删除');
+        if (Category::del($id))
+            return Json::successful('删除成功!');
+        else
+            return Json::fail('删除失败');
+
+
+    }
+}

+ 75 - 0
app/admin/controller/widget/Video.php

@@ -0,0 +1,75 @@
+<?php
+/**
+ * Created by PhpStorm.
+ * User: wuhaotian
+ * Date: 2020-02-24
+ * Time: 17:57
+ */
+
+namespace app\admin\controller\widget;
+
+use app\admin\controller\AuthController;
+use crmeb\services\JsonService;
+use crmeb\services\upload\Upload;
+use think\facade\Config;
+
+class Video extends AuthController
+{
+
+
+    /**
+     * 上传类型
+     * @var int
+     */
+    protected $uploadInfo;
+
+    /**
+     * 获取配置信息
+     * Video constructor.
+     */
+    public function initialize()
+    {
+        parent::initialize();
+        $this->uploadInfo['accessKey'] = sys_config('accessKey');
+        $this->uploadInfo['secretKey'] = sys_config('secretKey');
+        $this->uploadInfo['uploadUrl'] = sys_config('uploadUrl');
+        $this->uploadInfo['storageName'] = sys_config('storage_name');
+        $this->uploadInfo['storageRegion'] = sys_config('storage_region');
+        $this->uploadInfo['uploadType'] = sys_config('upload_type');
+    }
+
+    /**
+     * 获取密钥签名
+     */
+    public function get_signature()
+    {
+        if ($this->uploadInfo['uploadType'] == 1) {
+            if (!$this->uploadInfo['accessKey'] || !$this->uploadInfo['secretKey']) {
+                return JsonService::fail('视频上传需要上传到云端,默认使用阿里云OSS上传请配置!');
+            } else {
+                $this->uploadInfo['uploadType'] = 3;
+            }
+        }
+        if ($this->uploadInfo['uploadType'] == 2) {
+            $upload = new Upload('Qiniu', $this->uploadInfo);
+            $res = $upload->getSystem();
+            $this->uploadInfo['uploadToken'] = $res['token'];
+            $this->uploadInfo['domain'] = $res['domain'];
+            $this->uploadInfo['uploadType'] = 'QINIU';
+        } elseif ($this->uploadInfo['uploadType'] == 3) {
+            $this->uploadInfo['uploadType'] = 'OSS';
+            if (($leng = strpos($this->uploadInfo['storageRegion'], 'aliyuncs.com')) !== false) {
+                $this->uploadInfo['storageRegion'] = substr($this->uploadInfo['storageRegion'], 0, $leng - 1);
+            }
+        } elseif ($this->uploadInfo['uploadType'] == 4) {
+            $this->uploadInfo['uploadType'] = 'COS';
+        }
+        return JsonService::successful($this->uploadInfo);
+    }
+
+    public function index($fodder = '')
+    {
+        $this->assign(compact('fodder'));
+        return $this->fetch();
+    }
+}

+ 53 - 0
app/admin/controller/widget/Widgets.php

@@ -0,0 +1,53 @@
+<?php
+
+namespace app\admin\controller\widget;
+
+use app\admin\controller\AuthController;
+
+/**
+ * 文件校验控制器
+ * Class SystemFile
+ * @package app\admin\controller\system
+ *
+ */
+class Widgets extends AuthController
+{
+
+    /**
+     * icon
+     * @return \think\response\Json
+     */
+    public function icon()
+    {
+        return $this->fetch('widget/icon');
+    }
+
+    /**
+     * 会员列页面
+     * @return \think\response\Json
+     */
+    public function userlist()
+    {
+        return $this->fetch('widget/icon');
+    }
+
+    /**
+     * 产品列表页
+     * @return \think\response\Json
+     */
+    public function productlist()
+    {
+        return $this->fetch('widget/icon');
+    }
+
+    /**
+     * 图文列表页
+     * @return \think\response\Json
+     */
+    public function newtlist()
+    {
+        return $this->fetch('widget/icon');
+    }
+
+
+}

Niektoré súbory nie sú zobrazené, pretože je v týchto rozdielových dátach zmenené mnoho súborov