Assets.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619
  1. <?php
  2. namespace Dcat\Admin\Layout;
  3. class Assets
  4. {
  5. /**
  6. * 别名.
  7. *
  8. * @var array
  9. */
  10. protected $alias = [
  11. '@nunito' => [
  12. 'css' => ['https://fonts.googleapis.com/css?family=Nunito:200,200i,300,300i,400,400i,600,600i,800,800i,900,900i'],
  13. ],
  14. '@montserrat' => [
  15. 'css' => ['https://fonts.googleapis.com/css?family=Montserrat:300,400,500,600'],
  16. ],
  17. '@dcat' => [
  18. 'js' => 'dcat-admin/dcat/js/dcat-app.js',
  19. 'css' => 'dcat-admin/dcat/css/dcat-app.css',
  20. ],
  21. '@vendors' => [
  22. 'js' => 'dcat-admin/vendors/js/vendors.min.js',
  23. 'css' => 'dcat-admin/vendors/css/vendors.min.css',
  24. ],
  25. '@bootstrap' => [
  26. 'css' => 'dcat-admin/css/bootstrap.css',
  27. ],
  28. '@bootstrap-extended' => [
  29. 'css' => 'dcat-admin/css/bootstrap-extended.css',
  30. ],
  31. '@default-colors' => [
  32. 'css' => 'dcat-admin/css/colors.css',
  33. ],
  34. '@menu' => [
  35. 'js' => 'dcat-admin/js/core/app-menu.js',
  36. ],
  37. '@app' => [
  38. 'js' => 'dcat-admin/js/core/app.js',
  39. ],
  40. '@components' => [
  41. 'css' => 'dcat-admin/css/components.css',
  42. ],
  43. '@palette-gradient' => [
  44. 'css' => 'dcat-admin/css/core/colors/palette-gradient.css',
  45. ],
  46. '@datatables' => [
  47. 'css' => 'dcat-admin/vendors/css/tables/datatable/datatables.min.css',
  48. ],
  49. '@data-list-view' => [
  50. 'css' => 'dcat-admin/css/pages/data-list-view.css',
  51. ],
  52. '@custom' => [
  53. 'css' => 'dcat-admin/css/custom-laravel.css',
  54. ],
  55. '@grid-extension' => [
  56. 'js' => 'dcat-admin/dcat/extra/grid-extend.js',
  57. ],
  58. '@resource-selector' => [
  59. 'js' => 'dcat-admin/dcat/extra/resource-selector.js',
  60. ],
  61. '@layer' => [
  62. 'js' => 'dcat-admin/dcat/plugins/layer/layer.js',
  63. ],
  64. '@pjax' => [
  65. 'js' => 'dcat-admin/dcat/plugins/jquery-pjax/jquery.pjax.min.js',
  66. ],
  67. '@toastr' => [
  68. 'js' => 'dcat-admin/vendors/js/extensions/toastr.min.js',
  69. 'css' => 'dcat-admin/vendors/css/extensions/toastr.css',
  70. ],
  71. '@jquery.nestable' => [
  72. 'js' => 'dcat-admin/dcat/plugins/nestable/jquery.nestable.min.js',
  73. 'css' => 'dcat-admin/dcat/plugins/nestable/nestable.css',
  74. ],
  75. '@validator' => [
  76. 'js' => 'dcat-admin/dcat/plugins/bootstrap-validator/validator.min.js',
  77. ],
  78. '@select2' => [
  79. 'js' => 'dcat-admin/vendors/js/forms/select/select2.full.min.js',
  80. 'css' => 'dcat-admin/vendors/css/forms/select/select2.min.css',
  81. ],
  82. '@bootstrap-datetimepicker' => [
  83. 'js' => 'dcat-admin/dcat/plugins/bootstrap-datetimepicker/bootstrap-datetimepicker.min.js',
  84. 'css' => 'dcat-admin/dcat/plugins/bootstrap-datetimepicker/bootstrap-datetimepicker.min.css',
  85. ],
  86. '@rwd-table' => [
  87. 'js' => 'dcat-admin/dcat/plugins/RWD-Table-Patterns/dist/js/rwd-table.min.js',
  88. 'css' => 'dcat-admin/dcat/plugins/RWD-Table-Patterns/dist/css/rwd-table.min.css',
  89. ],
  90. '@jstree' => [
  91. 'js' => 'dcat-admin/dcat/plugins/jstree-theme/jstree.min.js',
  92. 'css' => 'dcat-admin/dcat/plugins/jstree-theme/themes/proton/style.min.css',
  93. ],
  94. '@switchery' => [
  95. 'js' => 'dcat-admin/dcat/plugins/switchery/switchery.min.js',
  96. 'css' => 'dcat-admin/dcat/plugins/switchery/switchery.min.css',
  97. ],
  98. '@webuploader' => [
  99. 'js' => [
  100. 'dcat-admin/dcat/plugins/webuploader/webuploader.min.js',
  101. 'dcat-admin/dcat/extra/upload.js',
  102. ],
  103. 'css' => 'dcat-admin/dcat/plugins/webuploader/webuploader.min.css',
  104. ],
  105. '@chartjs' => [
  106. 'js' => 'dcat-admin/dcat/plugins/chart.js/chart.bundle.min.js',
  107. ],
  108. '@jquery.sparkline' => [
  109. 'js' => 'dcat-admin/dcat/plugins/jquery.sparkline/jquery.sparkline.min.js',
  110. ],
  111. '@jquery.bootstrap-duallistbox' => [
  112. 'js' => 'dcat-admin/dcat/plugins/bootstrap-duallistbox/dist/jquery.bootstrap-duallistbox.min.js',
  113. 'css' => 'dcat-admin/dcat/plugins/bootstrap-duallistbox/dist/jquery.bootstrap-duallistbox.min.css',
  114. ],
  115. '@number-input' => [
  116. 'js' => 'dcat-admin/dcat/plugins/number-input/bootstrap-number-input.js',
  117. ],
  118. '@ionslider' => [
  119. 'js' => [
  120. 'dcat-admin/dcat/plugins/ionslider/ion.rangeSlider.min.js',
  121. ],
  122. 'css' => [
  123. 'dcat-admin/dcat/plugins/ionslider/ion.rangeSlider.css',
  124. 'dcat-admin/dcat/plugins/ionslider/ion.rangeSlider.skinNice.css',
  125. ],
  126. ],
  127. '@editor-md' => [
  128. 'js' => [
  129. 'dcat-admin/dcat/plugins/editor-md/lib/raphael.min.js',
  130. 'dcat-admin/dcat/plugins/editor-md/lib/marked.min.js',
  131. 'dcat-admin/dcat/plugins/editor-md/lib/prettify.min.js',
  132. 'dcat-admin/dcat/plugins/editor-md/lib/underscore.min.js',
  133. 'dcat-admin/dcat/plugins/editor-md/lib/sequence-diagram.min.js',
  134. 'dcat-admin/dcat/plugins/editor-md/lib/flowchart.min.js',
  135. 'dcat-admin/dcat/plugins/editor-md/lib/jquery.flowchart.min.js',
  136. 'dcat-admin/dcat/plugins/editor-md/editormd.min.js',
  137. ],
  138. 'css' => [
  139. 'dcat-admin/dcat/plugins/editor-md/css/editormd.preview.min.css',
  140. 'dcat-admin/dcat/extra/markdown.css',
  141. ],
  142. ],
  143. '@jquery.inputmask' => [
  144. 'js' => 'dcat-admin/dcat/plugins/input-mask/jquery.inputmask.bundle.min.js',
  145. ],
  146. ];
  147. /**
  148. * js代码.
  149. *
  150. * @var array
  151. */
  152. protected $script = [];
  153. /**
  154. * css代码.
  155. *
  156. * @var array
  157. */
  158. protected $style = [];
  159. /**
  160. * css脚本路径.
  161. *
  162. * @var array
  163. */
  164. protected $css = [];
  165. /**
  166. * js脚本路径.
  167. *
  168. * @var array
  169. */
  170. protected $js = [];
  171. /**
  172. * 在head标签内加载的js脚本.
  173. *
  174. * @var array
  175. */
  176. protected $headerJs = [
  177. 'vendors' => '@vendors',
  178. 'dcat' => '@dcat',
  179. ];
  180. /**
  181. * 基础css.
  182. *
  183. * @var array
  184. */
  185. protected $baseCss = [
  186. 'vendors' => '@vendors',
  187. 'bootstrap' => '@bootstrap',
  188. 'bootstrap-extended' => '@bootstrap-extended',
  189. 'toastr' => '@toastr',
  190. 'components' => '@components',
  191. 'palette-gradient' => '@palette-gradient',
  192. 'colors' => '@default-colors',
  193. //'custom' => 'custom',
  194. 'datatables' => '@datatables',
  195. 'data-list-view' => '@data-list-view',
  196. 'dcat' => '@dcat',
  197. ];
  198. /**
  199. * 基础js.
  200. *
  201. * @var array
  202. */
  203. protected $baseJs = [
  204. 'menu' => '@menu',
  205. 'app' => '@app',
  206. 'toastr' => '@toastr',
  207. 'pjax' => '@pjax',
  208. 'validator' => '@validator',
  209. 'layer' => '@layer',
  210. ];
  211. /**
  212. * @var array
  213. */
  214. public $fonts = [
  215. '@nunito',
  216. '@montserrat',
  217. ];
  218. /**
  219. * @var bool
  220. */
  221. protected $isPjax = false;
  222. /**
  223. * @var bool
  224. */
  225. protected $usingFullPage = false;
  226. /**
  227. * @var array
  228. */
  229. protected $themeCssMap = [
  230. 'dark' => 'dark-layout',
  231. 'semi-dark' => 'semi-dark-layout',
  232. ];
  233. /**
  234. * Assets constructor.
  235. */
  236. public function __construct()
  237. {
  238. $this->isPjax = request()->pjax();
  239. }
  240. /**
  241. * 设置或获取别名.
  242. *
  243. * @param string|array $name
  244. * @param string|array $js
  245. * @param string|array $css
  246. *
  247. * @return void|array
  248. */
  249. public function alias($name, $js = null, $css = null)
  250. {
  251. if (is_array($name)) {
  252. foreach ($name as $key => $value) {
  253. $this->alias($key, $value['js'] ?? [], $value['css'] ?? []);
  254. }
  255. return;
  256. }
  257. if ($js === null && $css === null) {
  258. return $this->alias[$name] ?? [];
  259. }
  260. if (strpos($name, '@') !== 0) {
  261. $name = '@'.$name;
  262. }
  263. $this->alias[$name] = [
  264. 'js' => $js,
  265. 'css' => $css,
  266. ];
  267. }
  268. /**
  269. * 使用全页面(无菜单和导航栏).
  270. *
  271. * @param bool $value
  272. *
  273. * @return $this
  274. */
  275. public function full(bool $value = true)
  276. {
  277. $this->usingFullPage = $value;
  278. return $this;
  279. }
  280. /**
  281. * 根据别名设置需要载入的js和css脚本.
  282. *
  283. * @param string $alias
  284. * @param string $type
  285. */
  286. public function collect(string $alias, string $type = '')
  287. {
  288. if (strpos($alias, '@') !== 0) {
  289. $alias = '@'.$alias;
  290. }
  291. if ($type === 'js') {
  292. $this->js($this->alias[$alias]['js'] ?? null);
  293. return;
  294. } elseif ($type === 'css') {
  295. $this->css($this->alias[$alias]['css'] ?? null);
  296. return;
  297. }
  298. $this->js($this->alias[$alias]['js'] ?? null);
  299. $this->css($this->alias[$alias]['css'] ?? null);
  300. }
  301. /**
  302. * 设置需要载入的css脚本.
  303. *
  304. * @param string|array $css
  305. */
  306. public function css($css)
  307. {
  308. if (! $css) {
  309. return;
  310. }
  311. $this->css = array_merge(
  312. $this->css,
  313. (array) $css
  314. );
  315. }
  316. /**
  317. * 设置需要载入的基础css脚本.
  318. *
  319. * @param array $css
  320. */
  321. public function baseCss(array $css)
  322. {
  323. $this->baseCss = $css;
  324. }
  325. /**
  326. * 设置需要载入的js脚本.
  327. *
  328. * @param string|array $js
  329. */
  330. public function js($js)
  331. {
  332. if (! $js) {
  333. return;
  334. }
  335. $this->js = array_merge(
  336. $this->js,
  337. (array) $js
  338. );
  339. }
  340. /**
  341. * 获取脚本的真实路径
  342. *
  343. * @param string $path
  344. * @param string $type
  345. *
  346. * @return string|array|null
  347. */
  348. public function getRealPath($path, string $type = 'js')
  349. {
  350. if (empty($this->alias[$path])) {
  351. return admin_asset($path);
  352. }
  353. $paths = isset($this->alias[$path][$type]) ? (array) $this->alias[$path][$type] : null;
  354. if (! $paths) {
  355. return $paths;
  356. }
  357. foreach ($paths as &$value) {
  358. $value = admin_asset($value);
  359. }
  360. return $paths;
  361. }
  362. /**
  363. * 设置在head标签内加载的js.
  364. *
  365. * @param string|array $js
  366. */
  367. public function headerJs($js)
  368. {
  369. if (! $js) {
  370. return;
  371. }
  372. $this->headerJs = array_merge($this->headerJs, (array) $js);
  373. }
  374. /**
  375. * 设置基础js脚本.
  376. *
  377. * @param array $js
  378. */
  379. public function baseJs(array $js)
  380. {
  381. $this->baseJs = $js;
  382. }
  383. /**
  384. * 设置js代码.
  385. *
  386. * @param string|array $script
  387. */
  388. public function script($script)
  389. {
  390. if (! $script) {
  391. return;
  392. }
  393. $this->script = array_merge($this->script, (array) $script);
  394. }
  395. /**
  396. * 设置css代码.
  397. *
  398. * @param string $style
  399. */
  400. public function style($style)
  401. {
  402. if (! $style) {
  403. return;
  404. }
  405. $this->style = array_merge($this->style, (array) $style);
  406. }
  407. /**
  408. * 增加布局css文件.
  409. */
  410. protected function addLayoutCss()
  411. {
  412. if ($this->usingFullPage) {
  413. return;
  414. }
  415. if (config('admin.layout.main_layout_type') === 'horizontal') {
  416. $this->baseCss[] = 'dcat-admin/css/core/menu/menu-types/horizontal-menu.css';
  417. }
  418. $this->baseCss[] = 'dcat-admin/css/core/menu/menu-types/vertical-menu.css';
  419. }
  420. /**
  421. * 主题css文件.
  422. */
  423. protected function addThemeCss()
  424. {
  425. if (! $theme = config('admin.layout.theme')) {
  426. return;
  427. }
  428. $css = $this->themeCssMap[$theme] ?? $theme;
  429. if ($css === 'light') {
  430. return;
  431. }
  432. $this->baseCss[] = "dcat-admin/css/themes/{$css}.css";
  433. }
  434. /**
  435. * 字体css脚本路径.
  436. */
  437. protected function addFontCss()
  438. {
  439. $this->fonts && (
  440. $this->baseCss = array_merge(
  441. $this->baseCss,
  442. (array) $this->fonts
  443. )
  444. );
  445. }
  446. /**
  447. * 合并基础css脚本.
  448. */
  449. protected function mergeBaseCss()
  450. {
  451. if ($this->isPjax) {
  452. return;
  453. }
  454. $this->addLayoutCss();
  455. $this->addThemeCss();
  456. $this->addFontCss();
  457. $this->css = array_merge($this->baseCss, $this->css);
  458. }
  459. /**
  460. * @return string
  461. */
  462. public function renderCss()
  463. {
  464. $this->mergeBaseCss();
  465. $html = '';
  466. foreach (array_unique($this->css) as &$v) {
  467. if (! $paths = $this->getRealPath($v, 'css')) {
  468. continue;
  469. }
  470. foreach ((array) $paths as $path) {
  471. $html .= "<link rel=\"stylesheet\" href=\"{$path}\">";
  472. }
  473. }
  474. return $html;
  475. }
  476. /**
  477. * 合并基础js脚本.
  478. */
  479. protected function mergeBaseJs()
  480. {
  481. if ($this->isPjax) {
  482. return;
  483. }
  484. if ($this->usingFullPage) {
  485. unset($this->baseJs['menu']);
  486. }
  487. $this->js = array_merge($this->baseJs, $this->js);
  488. }
  489. /**
  490. * @return string
  491. */
  492. public function renderJs()
  493. {
  494. $this->mergeBaseJs();
  495. $html = '';
  496. foreach (array_unique($this->js) as &$v) {
  497. if (! $paths = $this->getRealPath($v, 'js')) {
  498. continue;
  499. }
  500. foreach ((array) $paths as $path) {
  501. $html .= "<script src=\"{$path}\"></script>";
  502. }
  503. }
  504. return $html;
  505. }
  506. /**
  507. * @return string
  508. */
  509. public function renderHeaderJs()
  510. {
  511. $html = '';
  512. foreach (array_unique($this->headerJs) as &$v) {
  513. if (! $paths = $this->getRealPath($v, 'js')) {
  514. continue;
  515. }
  516. foreach ((array) $paths as $path) {
  517. $html .= "<script src=\"{$path}\"></script>";
  518. }
  519. }
  520. return $html;
  521. }
  522. /**
  523. * @return string
  524. */
  525. public function renderScript()
  526. {
  527. $script = implode(';', array_unique($this->script));
  528. return <<<HTML
  529. <script data-exec-on-popstate>
  530. Dcat.ready(function () {
  531. try {
  532. {$script}
  533. } catch (e) {
  534. console.error(e)
  535. }
  536. });
  537. </script>
  538. HTML;
  539. }
  540. /**
  541. * @return string
  542. */
  543. public function renderStyle()
  544. {
  545. $style = implode('', array_unique($this->style));
  546. return "<style>$style</style>";
  547. }
  548. }