From 7f3db2ed48c81bb695672db064cc0931c05160d3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=A2=81=E6=9C=9D=E4=BC=9F?= Date: Wed, 13 Nov 2024 19:23:49 +0800 Subject: [PATCH] init --- .editorconfig | 19 + .env.example | 79 + .gitattributes | 11 + .gitignore | 20 + .php-cs-fixer.php | 69 + README.md | 1 + _ide_helper.php | 22257 ++++++++ .../Commands/AppVersionUpdateCommand.php | 48 + app/Foundation/PersonalAccessToken.php | 25 + app/Http/Controllers/Controller.php | 5 + .../CreateClientTokenMiddlewire.php | 21 + app/Models/Media.php | 29 + app/Models/User.php | 48 + app/Providers/AppServiceProvider.php | 30 + artisan | 15 + bootstrap/app.php | 67 + bootstrap/cache/.gitignore | 2 + bootstrap/providers.php | 6 + composer.json | 85 + composer.lock | 12347 +++++ config/app.php | 128 + config/auth.php | 104 + config/cache.php | 108 + config/database.php | 173 + config/eloquent-sortable.php | 6 + config/filesystems.php | 76 + config/logging.php | 139 + config/mail.php | 116 + config/media-library.php | 8 + config/permission.php | 186 + config/queue.php | 112 + config/sanctum.php | 83 + config/services.php | 42 + config/session.php | 217 + database/.gitignore | 1 + database/factories/UserFactory.php | 44 + .../0001_01_01_000000_create_users_table.php | 49 + .../0001_01_01_000001_create_cache_table.php | 35 + .../0001_01_01_000002_create_jobs_table.php | 57 + ...44_create_personal_access_tokens_table.php | 34 + .../2024_08_15_165944_create_media_table.php | 31 + database/seeders/DatabaseSeeder.php | 23 + package.json | 13 + packages/README.md | 1 + packages/bydauto/README.md | 1 + packages/bydauto/cluepackage-send.sh | 14 + packages/bydauto/composer.json | 9 + packages/bydauto/config/bydauto.php | 4 + ...024_11_13_160651_create_bydauto_tables.php | 39 + packages/bydauto/routes/api.php | 14 + .../src/Actions/TestdriveCreateAction.php | 23 + .../bydauto/src/BYDAutoServiceProvider.php | 40 + packages/bydauto/src/CheryClueApi.php | 71 + packages/bydauto/src/CheryResult.php | 26 + .../bydauto/src/Commands/BYDAutoCommand.php | 59 + .../src/Commands/BYDAutoNoticeCommand.php | 61 + .../src/Commands/CheryTransferCommand.php | 80 + .../bydauto/src/Commands/GeocodingCommand.php | 206 + .../src/Controllers/BYDAutoController.php | 67 + packages/bydauto/src/Foundation/AlipayAES.php | 83 + .../src/Foundation/AlipayEasySDKFactory.php | 33 + packages/bydauto/src/Foundation/DBLog.php | 15 + .../bydauto/src/Foundation/DataTransfer.php | 53 + .../bydauto/src/Foundation/Encryption.php | 31 + .../bydauto/src/Jobs/TestdrivePushJob.php | 37 + packages/bydauto/src/Models/Contact.php | 18 + packages/bydauto/src/Models/Dealer.php | 54 + packages/bydauto/src/Models/Testdrive.php | 37 + packages/bydauto/src/Models/Vehicle.php | 44 + .../Notifications/TestdirveNotification.php | 41 + .../src/Observers/TestdriveObserver.php | 25 + .../views/notice/salesleads-day.blade.php | 16 + .../bydauto/views/notice/salesleads.blade.php | 8 + phpunit.xml | 33 + public/.htaccess | 21 + public/favicon.ico | 0 public/index.php | 17 + public/robots.txt | 2 + public/static/1731484241.jpg | Bin 0 -> 241009 bytes .../static/libs/element-ui/CHANGELOG.en-US.md | 2085 + public/static/libs/element-ui/CHANGELOG.es.md | 2093 + .../static/libs/element-ui/CHANGELOG.fr-FR.md | 2085 + .../static/libs/element-ui/CHANGELOG.zh-CN.md | 2085 + public/static/libs/element-ui/LICENSE | 21 + public/static/libs/element-ui/README.md | 148 + public/static/libs/element-ui/lib/alert.js | 419 + public/static/libs/element-ui/lib/aside.js | 276 + .../libs/element-ui/lib/autocomplete.js | 952 + public/static/libs/element-ui/lib/avatar.js | 362 + public/static/libs/element-ui/lib/backtop.js | 401 + public/static/libs/element-ui/lib/badge.js | 333 + .../libs/element-ui/lib/breadcrumb-item.js | 321 + .../static/libs/element-ui/lib/breadcrumb.js | 292 + .../libs/element-ui/lib/button-group.js | 261 + public/static/libs/element-ui/lib/button.js | 356 + public/static/libs/element-ui/lib/calendar.js | 935 + public/static/libs/element-ui/lib/card.js | 296 + .../libs/element-ui/lib/carousel-item.js | 433 + public/static/libs/element-ui/lib/carousel.js | 706 + .../libs/element-ui/lib/cascader-panel.js | 1563 + public/static/libs/element-ui/lib/cascader.js | 1436 + .../libs/element-ui/lib/checkbox-button.js | 582 + .../libs/element-ui/lib/checkbox-group.js | 312 + public/static/libs/element-ui/lib/checkbox.js | 626 + public/static/libs/element-ui/lib/col.js | 176 + .../libs/element-ui/lib/collapse-item.js | 496 + public/static/libs/element-ui/lib/collapse.js | 328 + .../libs/element-ui/lib/color-picker.js | 1957 + .../static/libs/element-ui/lib/container.js | 287 + .../static/libs/element-ui/lib/date-picker.js | 6358 +++ .../libs/element-ui/lib/descriptions-item.js | 139 + .../libs/element-ui/lib/descriptions.js | 456 + public/static/libs/element-ui/lib/dialog.js | 597 + .../element-ui/lib/directives/mousewheel.js | 26 + .../element-ui/lib/directives/repeat-click.js | 33 + public/static/libs/element-ui/lib/divider.js | 312 + public/static/libs/element-ui/lib/drawer.js | 591 + .../libs/element-ui/lib/dropdown-item.js | 315 + .../libs/element-ui/lib/dropdown-menu.js | 350 + public/static/libs/element-ui/lib/dropdown.js | 642 + .../libs/element-ui/lib/element-ui.common.js | 43907 ++++++++++++++++ public/static/libs/element-ui/lib/empty.js | 729 + public/static/libs/element-ui/lib/footer.js | 276 + .../static/libs/element-ui/lib/form-item.js | 828 + public/static/libs/element-ui/lib/form.js | 465 + public/static/libs/element-ui/lib/header.js | 276 + public/static/libs/element-ui/lib/icon.js | 264 + public/static/libs/element-ui/lib/image.js | 1140 + public/static/libs/element-ui/lib/index.js | 1 + .../libs/element-ui/lib/infinite-scroll.js | 300 + .../libs/element-ui/lib/input-number.js | 751 + public/static/libs/element-ui/lib/input.js | 997 + public/static/libs/element-ui/lib/link.js | 329 + public/static/libs/element-ui/lib/loading.js | 630 + .../libs/element-ui/lib/locale/format.js | 56 + .../libs/element-ui/lib/locale/index.js | 63 + .../libs/element-ui/lib/locale/lang/af-ZA.js | 126 + .../libs/element-ui/lib/locale/lang/ar.js | 125 + .../libs/element-ui/lib/locale/lang/az.js | 126 + .../libs/element-ui/lib/locale/lang/bg.js | 126 + .../libs/element-ui/lib/locale/lang/bn.js | 126 + .../libs/element-ui/lib/locale/lang/ca.js | 125 + .../libs/element-ui/lib/locale/lang/cs-CZ.js | 128 + .../libs/element-ui/lib/locale/lang/da.js | 125 + .../libs/element-ui/lib/locale/lang/de.js | 127 + .../libs/element-ui/lib/locale/lang/ee.js | 126 + .../libs/element-ui/lib/locale/lang/el.js | 126 + .../libs/element-ui/lib/locale/lang/en.js | 126 + .../libs/element-ui/lib/locale/lang/eo.js | 126 + .../libs/element-ui/lib/locale/lang/es.js | 125 + .../libs/element-ui/lib/locale/lang/eu.js | 126 + .../libs/element-ui/lib/locale/lang/fa.js | 126 + .../libs/element-ui/lib/locale/lang/fi.js | 126 + .../libs/element-ui/lib/locale/lang/fr.js | 125 + .../libs/element-ui/lib/locale/lang/he.js | 126 + .../libs/element-ui/lib/locale/lang/hr.js | 126 + .../libs/element-ui/lib/locale/lang/hu.js | 125 + .../libs/element-ui/lib/locale/lang/hy-AM.js | 126 + .../libs/element-ui/lib/locale/lang/id.js | 126 + .../libs/element-ui/lib/locale/lang/is.js | 126 + .../libs/element-ui/lib/locale/lang/it.js | 125 + .../libs/element-ui/lib/locale/lang/ja.js | 126 + .../libs/element-ui/lib/locale/lang/kg.js | 126 + .../libs/element-ui/lib/locale/lang/km.js | 126 + .../libs/element-ui/lib/locale/lang/ko.js | 126 + .../libs/element-ui/lib/locale/lang/ku.js | 126 + .../libs/element-ui/lib/locale/lang/kz.js | 126 + .../libs/element-ui/lib/locale/lang/lt.js | 126 + .../libs/element-ui/lib/locale/lang/lv.js | 126 + .../libs/element-ui/lib/locale/lang/mn.js | 126 + .../libs/element-ui/lib/locale/lang/ms.js | 125 + .../libs/element-ui/lib/locale/lang/nb-NO.js | 125 + .../libs/element-ui/lib/locale/lang/nl.js | 126 + .../libs/element-ui/lib/locale/lang/pl.js | 126 + .../libs/element-ui/lib/locale/lang/pt-br.js | 126 + .../libs/element-ui/lib/locale/lang/pt.js | 126 + .../libs/element-ui/lib/locale/lang/ro.js | 126 + .../libs/element-ui/lib/locale/lang/ru-RU.js | 126 + .../libs/element-ui/lib/locale/lang/si.js | 126 + .../libs/element-ui/lib/locale/lang/sk.js | 128 + .../libs/element-ui/lib/locale/lang/sl.js | 126 + .../element-ui/lib/locale/lang/sr-Latn.js | 126 + .../libs/element-ui/lib/locale/lang/sr.js | 126 + .../libs/element-ui/lib/locale/lang/sv-SE.js | 126 + .../libs/element-ui/lib/locale/lang/sw.js | 126 + .../libs/element-ui/lib/locale/lang/ta.js | 125 + .../libs/element-ui/lib/locale/lang/th.js | 126 + .../libs/element-ui/lib/locale/lang/tk.js | 126 + .../libs/element-ui/lib/locale/lang/tr-TR.js | 126 + .../libs/element-ui/lib/locale/lang/ua.js | 126 + .../libs/element-ui/lib/locale/lang/ug-CN.js | 126 + .../libs/element-ui/lib/locale/lang/uz-UZ.js | 126 + .../libs/element-ui/lib/locale/lang/vi.js | 126 + .../libs/element-ui/lib/locale/lang/zh-CN.js | 126 + .../libs/element-ui/lib/locale/lang/zh-TW.js | 126 + public/static/libs/element-ui/lib/main.js | 263 + .../libs/element-ui/lib/menu-item-group.js | 307 + .../static/libs/element-ui/lib/menu-item.js | 490 + public/static/libs/element-ui/lib/menu.js | 864 + .../static/libs/element-ui/lib/message-box.js | 1191 + public/static/libs/element-ui/lib/message.js | 547 + .../libs/element-ui/lib/mixins/emitter.js | 36 + .../libs/element-ui/lib/mixins/focus.js | 15 + .../libs/element-ui/lib/mixins/locale.js | 17 + .../libs/element-ui/lib/mixins/migrating.js | 69 + .../libs/element-ui/lib/notification.js | 614 + .../libs/element-ui/lib/option-group.js | 343 + public/static/libs/element-ui/lib/option.js | 474 + .../static/libs/element-ui/lib/page-header.js | 318 + .../static/libs/element-ui/lib/pagination.js | 946 + .../static/libs/element-ui/lib/popconfirm.js | 456 + public/static/libs/element-ui/lib/popover.js | 616 + public/static/libs/element-ui/lib/progress.js | 592 + .../libs/element-ui/lib/radio-button.js | 462 + .../static/libs/element-ui/lib/radio-group.js | 390 + public/static/libs/element-ui/lib/radio.js | 496 + public/static/libs/element-ui/lib/rate.js | 669 + public/static/libs/element-ui/lib/result.js | 593 + public/static/libs/element-ui/lib/row.js | 148 + .../static/libs/element-ui/lib/scrollbar.js | 422 + public/static/libs/element-ui/lib/select.js | 2172 + .../libs/element-ui/lib/skeleton-item.js | 345 + public/static/libs/element-ui/lib/skeleton.js | 371 + public/static/libs/element-ui/lib/slider.js | 1201 + public/static/libs/element-ui/lib/spinner.js | 300 + .../static/libs/element-ui/lib/statistic.js | 532 + public/static/libs/element-ui/lib/step.js | 521 + public/static/libs/element-ui/lib/steps.js | 341 + public/static/libs/element-ui/lib/submenu.js | 700 + public/static/libs/element-ui/lib/switch.js | 553 + public/static/libs/element-ui/lib/tab-pane.js | 331 + .../libs/element-ui/lib/table-column.js | 951 + public/static/libs/element-ui/lib/table.js | 5008 ++ public/static/libs/element-ui/lib/tabs.js | 925 + public/static/libs/element-ui/lib/tag.js | 303 + .../libs/element-ui/lib/theme-chalk/alert.css | 1 + .../libs/element-ui/lib/theme-chalk/aside.css | 1 + .../lib/theme-chalk/autocomplete.css | 1 + .../element-ui/lib/theme-chalk/avatar.css | 1 + .../element-ui/lib/theme-chalk/backtop.css | 1 + .../libs/element-ui/lib/theme-chalk/badge.css | 1 + .../libs/element-ui/lib/theme-chalk/base.css | 1 + .../element-ui/lib/theme-chalk/breadcrumb.css | 1 + .../element-ui/lib/theme-chalk/button.css | 1 + .../element-ui/lib/theme-chalk/calendar.css | 1 + .../libs/element-ui/lib/theme-chalk/card.css | 1 + .../lib/theme-chalk/carousel-item.css | 1 + .../element-ui/lib/theme-chalk/carousel.css | 1 + .../lib/theme-chalk/cascader-panel.css | 1 + .../element-ui/lib/theme-chalk/cascader.css | 1 + .../element-ui/lib/theme-chalk/checkbox.css | 1 + .../libs/element-ui/lib/theme-chalk/col.css | 1 + .../element-ui/lib/theme-chalk/collapse.css | 1 + .../lib/theme-chalk/color-picker.css | 1 + .../element-ui/lib/theme-chalk/container.css | 1 + .../lib/theme-chalk/date-picker.css | 1 + .../lib/theme-chalk/descriptions-item.css | 1 + .../lib/theme-chalk/descriptions.css | 1 + .../element-ui/lib/theme-chalk/dialog.css | 1 + .../element-ui/lib/theme-chalk/display.css | 1 + .../element-ui/lib/theme-chalk/divider.css | 1 + .../element-ui/lib/theme-chalk/drawer.css | 1 + .../element-ui/lib/theme-chalk/dropdown.css | 1 + .../libs/element-ui/lib/theme-chalk/empty.css | 1 + .../lib/theme-chalk/fonts/element-icons.ttf | Bin 0 -> 55956 bytes .../lib/theme-chalk/fonts/element-icons.woff | Bin 0 -> 28200 bytes .../element-ui/lib/theme-chalk/footer.css | 1 + .../libs/element-ui/lib/theme-chalk/form.css | 1 + .../element-ui/lib/theme-chalk/header.css | 1 + .../libs/element-ui/lib/theme-chalk/icon.css | 1 + .../libs/element-ui/lib/theme-chalk/image.css | 1 + .../libs/element-ui/lib/theme-chalk/index.css | 1 + .../lib/theme-chalk/input-number.css | 1 + .../libs/element-ui/lib/theme-chalk/input.css | 1 + .../libs/element-ui/lib/theme-chalk/link.css | 1 + .../element-ui/lib/theme-chalk/loading.css | 1 + .../libs/element-ui/lib/theme-chalk/main.css | 1 + .../libs/element-ui/lib/theme-chalk/menu.css | 1 + .../lib/theme-chalk/message-box.css | 1 + .../element-ui/lib/theme-chalk/message.css | 1 + .../lib/theme-chalk/notification.css | 1 + .../lib/theme-chalk/option-group.css | 1 + .../element-ui/lib/theme-chalk/option.css | 1 + .../lib/theme-chalk/page-header.css | 1 + .../element-ui/lib/theme-chalk/pagination.css | 1 + .../element-ui/lib/theme-chalk/popconfirm.css | 1 + .../element-ui/lib/theme-chalk/popover.css | 1 + .../element-ui/lib/theme-chalk/popper.css | 1 + .../element-ui/lib/theme-chalk/progress.css | 1 + .../lib/theme-chalk/radio-button.css | 1 + .../lib/theme-chalk/radio-group.css | 1 + .../libs/element-ui/lib/theme-chalk/radio.css | 1 + .../libs/element-ui/lib/theme-chalk/rate.css | 1 + .../libs/element-ui/lib/theme-chalk/reset.css | 1 + .../element-ui/lib/theme-chalk/result.css | 1 + .../libs/element-ui/lib/theme-chalk/row.css | 1 + .../element-ui/lib/theme-chalk/scrollbar.css | 1 + .../lib/theme-chalk/select-dropdown.css | 1 + .../element-ui/lib/theme-chalk/select.css | 1 + .../lib/theme-chalk/skeleton-item.css | 1 + .../element-ui/lib/theme-chalk/skeleton.css | 1 + .../element-ui/lib/theme-chalk/slider.css | 1 + .../element-ui/lib/theme-chalk/spinner.css | 1 + .../element-ui/lib/theme-chalk/statistic.css | 1 + .../libs/element-ui/lib/theme-chalk/step.css | 1 + .../libs/element-ui/lib/theme-chalk/steps.css | 1 + .../element-ui/lib/theme-chalk/switch.css | 1 + .../lib/theme-chalk/table-column.css | 1 + .../libs/element-ui/lib/theme-chalk/table.css | 1 + .../libs/element-ui/lib/theme-chalk/tabs.css | 1 + .../libs/element-ui/lib/theme-chalk/tag.css | 1 + .../lib/theme-chalk/time-picker.css | 1 + .../lib/theme-chalk/time-select.css | 1 + .../lib/theme-chalk/timeline-item.css | 1 + .../element-ui/lib/theme-chalk/timeline.css | 1 + .../element-ui/lib/theme-chalk/tooltip.css | 1 + .../element-ui/lib/theme-chalk/transfer.css | 1 + .../libs/element-ui/lib/theme-chalk/tree.css | 1 + .../element-ui/lib/theme-chalk/upload.css | 1 + .../static/libs/element-ui/lib/time-picker.js | 2975 ++ .../static/libs/element-ui/lib/time-select.js | 1767 + .../libs/element-ui/lib/timeline-item.js | 370 + public/static/libs/element-ui/lib/timeline.js | 274 + public/static/libs/element-ui/lib/tooltip.js | 424 + public/static/libs/element-ui/lib/transfer.js | 1104 + .../lib/transitions/collapse-transition.js | 91 + public/static/libs/element-ui/lib/tree.js | 2265 + .../libs/element-ui/lib/umd/locale/af-ZA.js | 142 + .../libs/element-ui/lib/umd/locale/ar.js | 141 + .../libs/element-ui/lib/umd/locale/az.js | 141 + .../libs/element-ui/lib/umd/locale/bg.js | 142 + .../libs/element-ui/lib/umd/locale/bn.js | 141 + .../libs/element-ui/lib/umd/locale/ca.js | 141 + .../libs/element-ui/lib/umd/locale/cs-CZ.js | 144 + .../libs/element-ui/lib/umd/locale/da.js | 141 + .../libs/element-ui/lib/umd/locale/de.js | 143 + .../libs/element-ui/lib/umd/locale/ee.js | 142 + .../libs/element-ui/lib/umd/locale/el.js | 142 + .../libs/element-ui/lib/umd/locale/en.js | 142 + .../libs/element-ui/lib/umd/locale/eo.js | 142 + .../libs/element-ui/lib/umd/locale/es.js | 141 + .../libs/element-ui/lib/umd/locale/eu.js | 142 + .../libs/element-ui/lib/umd/locale/fa.js | 142 + .../libs/element-ui/lib/umd/locale/fi.js | 142 + .../libs/element-ui/lib/umd/locale/fr.js | 141 + .../libs/element-ui/lib/umd/locale/he.js | 142 + .../libs/element-ui/lib/umd/locale/hr.js | 142 + .../libs/element-ui/lib/umd/locale/hu.js | 141 + .../libs/element-ui/lib/umd/locale/hy-AM.js | 142 + .../libs/element-ui/lib/umd/locale/id.js | 142 + .../libs/element-ui/lib/umd/locale/is.js | 142 + .../libs/element-ui/lib/umd/locale/it.js | 141 + .../libs/element-ui/lib/umd/locale/ja.js | 142 + .../libs/element-ui/lib/umd/locale/kg.js | 142 + .../libs/element-ui/lib/umd/locale/km.js | 142 + .../libs/element-ui/lib/umd/locale/ko.js | 142 + .../libs/element-ui/lib/umd/locale/ku.js | 142 + .../libs/element-ui/lib/umd/locale/kz.js | 142 + .../libs/element-ui/lib/umd/locale/lt.js | 142 + .../libs/element-ui/lib/umd/locale/lv.js | 142 + .../libs/element-ui/lib/umd/locale/mn.js | 142 + .../libs/element-ui/lib/umd/locale/ms.js | 141 + .../libs/element-ui/lib/umd/locale/nb-NO.js | 141 + .../libs/element-ui/lib/umd/locale/nl.js | 142 + .../libs/element-ui/lib/umd/locale/pl.js | 142 + .../libs/element-ui/lib/umd/locale/pt-br.js | 142 + .../libs/element-ui/lib/umd/locale/pt.js | 142 + .../libs/element-ui/lib/umd/locale/ro.js | 142 + .../libs/element-ui/lib/umd/locale/ru-RU.js | 142 + .../libs/element-ui/lib/umd/locale/si.js | 142 + .../libs/element-ui/lib/umd/locale/sk.js | 144 + .../libs/element-ui/lib/umd/locale/sl.js | 142 + .../libs/element-ui/lib/umd/locale/sr-Latn.js | 142 + .../libs/element-ui/lib/umd/locale/sr.js | 142 + .../libs/element-ui/lib/umd/locale/sv-SE.js | 142 + .../libs/element-ui/lib/umd/locale/sw.js | 142 + .../libs/element-ui/lib/umd/locale/ta.js | 141 + .../libs/element-ui/lib/umd/locale/th.js | 142 + .../libs/element-ui/lib/umd/locale/tk.js | 142 + .../libs/element-ui/lib/umd/locale/tr-TR.js | 142 + .../libs/element-ui/lib/umd/locale/ua.js | 142 + .../libs/element-ui/lib/umd/locale/ug-CN.js | 142 + .../libs/element-ui/lib/umd/locale/uz-UZ.js | 142 + .../libs/element-ui/lib/umd/locale/vi.js | 142 + .../libs/element-ui/lib/umd/locale/zh-CN.js | 142 + .../libs/element-ui/lib/umd/locale/zh-TW.js | 142 + public/static/libs/element-ui/lib/upload.js | 1398 + .../libs/element-ui/lib/utils/after-leave.js | 35 + .../libs/element-ui/lib/utils/aria-dialog.js | 104 + .../libs/element-ui/lib/utils/aria-utils.js | 126 + .../libs/element-ui/lib/utils/clickoutside.js | 79 + .../libs/element-ui/lib/utils/date-util.js | 310 + .../static/libs/element-ui/lib/utils/date.js | 369 + .../static/libs/element-ui/lib/utils/dom.js | 234 + .../libs/element-ui/lib/utils/lodash.js | 9421 ++++ .../element-ui/lib/utils/menu/aria-menubar.js | 24 + .../lib/utils/menu/aria-menuitem.js | 62 + .../element-ui/lib/utils/menu/aria-submenu.js | 69 + .../static/libs/element-ui/lib/utils/merge.js | 21 + .../libs/element-ui/lib/utils/popper.js | 1261 + .../libs/element-ui/lib/utils/popup/index.js | 233 + .../lib/utils/popup/popup-manager.js | 205 + .../libs/element-ui/lib/utils/resize-event.js | 59 + .../element-ui/lib/utils/scroll-into-view.js | 38 + .../element-ui/lib/utils/scrollbar-width.js | 39 + .../libs/element-ui/lib/utils/shared.js | 12 + .../static/libs/element-ui/lib/utils/types.js | 52 + .../static/libs/element-ui/lib/utils/util.js | 272 + .../static/libs/element-ui/lib/utils/vdom.js | 13 + .../libs/element-ui/lib/utils/vue-popper.js | 202 + public/static/libs/element-ui/package.json | 151 + public/static/libs/element-ui/web-types.json | 4195 ++ .../libs/sweetalert2/sweetalert2.all.js | 4611 ++ .../libs/sweetalert2/sweetalert2.all.min.js | 6 + .../static/libs/sweetalert2/sweetalert2.css | 1085 + public/static/libs/sweetalert2/sweetalert2.js | 4610 ++ .../libs/sweetalert2/sweetalert2.min.css | 1 + .../libs/sweetalert2/sweetalert2.min.js | 5 + public/static/libs/vue/LICENSE | 21 + public/static/libs/vue/README.md | 118 + .../static/libs/vue/compiler-sfc/index.d.ts | 1 + public/static/libs/vue/compiler-sfc/index.js | 1 + public/static/libs/vue/compiler-sfc/index.mjs | 1 + .../static/libs/vue/compiler-sfc/package.json | 5 + public/static/libs/vue/dist/vue.common.dev.js | 11818 +++++ public/static/libs/vue/dist/vue.common.js | 5 + .../static/libs/vue/dist/vue.common.prod.js | 11 + .../static/libs/vue/dist/vue.esm.browser.js | 11731 +++++ .../libs/vue/dist/vue.esm.browser.min.js | 11 + public/static/libs/vue/dist/vue.esm.js | 11918 +++++ public/static/libs/vue/dist/vue.js | 11932 +++++ public/static/libs/vue/dist/vue.min.js | 11 + .../libs/vue/dist/vue.runtime.common.dev.js | 8736 +++ .../libs/vue/dist/vue.runtime.common.js | 5 + .../libs/vue/dist/vue.runtime.common.prod.js | 11 + .../static/libs/vue/dist/vue.runtime.esm.js | 8825 ++++ public/static/libs/vue/dist/vue.runtime.js | 8826 ++++ .../static/libs/vue/dist/vue.runtime.min.js | 11 + public/static/libs/vue/dist/vue.runtime.mjs | 76 + public/static/libs/vue/package.json | 136 + public/static/testdrive.html | 141 + resources/css/app.css | 0 resources/js/app.js | 1 + resources/js/bootstrap.js | 4 + resources/views/welcome.blade.php | 172 + routes/api.php | 8 + routes/console.php | 8 + routes/web.php | 5 + storage/app/.gitignore | 3 + storage/app/public/.gitignore | 2 + storage/framework/.gitignore | 9 + storage/framework/cache/.gitignore | 3 + storage/framework/cache/data/.gitignore | 2 + storage/framework/sessions/.gitignore | 2 + storage/framework/testing/.gitignore | 2 + storage/framework/views/.gitignore | 2 + storage/logs/.gitignore | 2 + tests/Feature/ExampleTest.php | 19 + tests/TestCase.php | 10 + tests/Unit/ExampleTest.php | 16 + vite.config.js | 11 + 461 files changed, 276684 insertions(+) create mode 100644 .editorconfig create mode 100644 .env.example create mode 100644 .gitattributes create mode 100644 .gitignore create mode 100644 .php-cs-fixer.php create mode 100644 README.md create mode 100644 _ide_helper.php create mode 100644 app/Console/Commands/AppVersionUpdateCommand.php create mode 100644 app/Foundation/PersonalAccessToken.php create mode 100644 app/Http/Controllers/Controller.php create mode 100644 app/Http/Middleware/CreateClientTokenMiddlewire.php create mode 100644 app/Models/Media.php create mode 100644 app/Models/User.php create mode 100644 app/Providers/AppServiceProvider.php create mode 100755 artisan create mode 100644 bootstrap/app.php create mode 100644 bootstrap/cache/.gitignore create mode 100644 bootstrap/providers.php create mode 100644 composer.json create mode 100644 composer.lock create mode 100644 config/app.php create mode 100644 config/auth.php create mode 100644 config/cache.php create mode 100644 config/database.php create mode 100644 config/eloquent-sortable.php create mode 100644 config/filesystems.php create mode 100644 config/logging.php create mode 100644 config/mail.php create mode 100644 config/media-library.php create mode 100644 config/permission.php create mode 100644 config/queue.php create mode 100644 config/sanctum.php create mode 100644 config/services.php create mode 100644 config/session.php create mode 100644 database/.gitignore create mode 100644 database/factories/UserFactory.php create mode 100644 database/migrations/0001_01_01_000000_create_users_table.php create mode 100644 database/migrations/0001_01_01_000001_create_cache_table.php create mode 100644 database/migrations/0001_01_01_000002_create_jobs_table.php create mode 100644 database/migrations/2024_08_15_165744_create_personal_access_tokens_table.php create mode 100644 database/migrations/2024_08_15_165944_create_media_table.php create mode 100644 database/seeders/DatabaseSeeder.php create mode 100644 package.json create mode 100644 packages/README.md create mode 100644 packages/bydauto/README.md create mode 100644 packages/bydauto/cluepackage-send.sh create mode 100644 packages/bydauto/composer.json create mode 100644 packages/bydauto/config/bydauto.php create mode 100644 packages/bydauto/migrations/2024_11_13_160651_create_bydauto_tables.php create mode 100644 packages/bydauto/routes/api.php create mode 100644 packages/bydauto/src/Actions/TestdriveCreateAction.php create mode 100644 packages/bydauto/src/BYDAutoServiceProvider.php create mode 100644 packages/bydauto/src/CheryClueApi.php create mode 100644 packages/bydauto/src/CheryResult.php create mode 100644 packages/bydauto/src/Commands/BYDAutoCommand.php create mode 100644 packages/bydauto/src/Commands/BYDAutoNoticeCommand.php create mode 100644 packages/bydauto/src/Commands/CheryTransferCommand.php create mode 100644 packages/bydauto/src/Commands/GeocodingCommand.php create mode 100644 packages/bydauto/src/Controllers/BYDAutoController.php create mode 100644 packages/bydauto/src/Foundation/AlipayAES.php create mode 100644 packages/bydauto/src/Foundation/AlipayEasySDKFactory.php create mode 100644 packages/bydauto/src/Foundation/DBLog.php create mode 100644 packages/bydauto/src/Foundation/DataTransfer.php create mode 100644 packages/bydauto/src/Foundation/Encryption.php create mode 100644 packages/bydauto/src/Jobs/TestdrivePushJob.php create mode 100644 packages/bydauto/src/Models/Contact.php create mode 100644 packages/bydauto/src/Models/Dealer.php create mode 100644 packages/bydauto/src/Models/Testdrive.php create mode 100644 packages/bydauto/src/Models/Vehicle.php create mode 100644 packages/bydauto/src/Notifications/TestdirveNotification.php create mode 100644 packages/bydauto/src/Observers/TestdriveObserver.php create mode 100644 packages/bydauto/views/notice/salesleads-day.blade.php create mode 100644 packages/bydauto/views/notice/salesleads.blade.php create mode 100644 phpunit.xml create mode 100644 public/.htaccess create mode 100644 public/favicon.ico create mode 100644 public/index.php create mode 100644 public/robots.txt create mode 100644 public/static/1731484241.jpg create mode 100644 public/static/libs/element-ui/CHANGELOG.en-US.md create mode 100644 public/static/libs/element-ui/CHANGELOG.es.md create mode 100644 public/static/libs/element-ui/CHANGELOG.fr-FR.md create mode 100644 public/static/libs/element-ui/CHANGELOG.zh-CN.md create mode 100644 public/static/libs/element-ui/LICENSE create mode 100644 public/static/libs/element-ui/README.md create mode 100644 public/static/libs/element-ui/lib/alert.js create mode 100644 public/static/libs/element-ui/lib/aside.js create mode 100644 public/static/libs/element-ui/lib/autocomplete.js create mode 100644 public/static/libs/element-ui/lib/avatar.js create mode 100644 public/static/libs/element-ui/lib/backtop.js create mode 100644 public/static/libs/element-ui/lib/badge.js create mode 100644 public/static/libs/element-ui/lib/breadcrumb-item.js create mode 100644 public/static/libs/element-ui/lib/breadcrumb.js create mode 100644 public/static/libs/element-ui/lib/button-group.js create mode 100644 public/static/libs/element-ui/lib/button.js create mode 100644 public/static/libs/element-ui/lib/calendar.js create mode 100644 public/static/libs/element-ui/lib/card.js create mode 100644 public/static/libs/element-ui/lib/carousel-item.js create mode 100644 public/static/libs/element-ui/lib/carousel.js create mode 100644 public/static/libs/element-ui/lib/cascader-panel.js create mode 100644 public/static/libs/element-ui/lib/cascader.js create mode 100644 public/static/libs/element-ui/lib/checkbox-button.js create mode 100644 public/static/libs/element-ui/lib/checkbox-group.js create mode 100644 public/static/libs/element-ui/lib/checkbox.js create mode 100644 public/static/libs/element-ui/lib/col.js create mode 100644 public/static/libs/element-ui/lib/collapse-item.js create mode 100644 public/static/libs/element-ui/lib/collapse.js create mode 100644 public/static/libs/element-ui/lib/color-picker.js create mode 100644 public/static/libs/element-ui/lib/container.js create mode 100644 public/static/libs/element-ui/lib/date-picker.js create mode 100644 public/static/libs/element-ui/lib/descriptions-item.js create mode 100644 public/static/libs/element-ui/lib/descriptions.js create mode 100644 public/static/libs/element-ui/lib/dialog.js create mode 100644 public/static/libs/element-ui/lib/directives/mousewheel.js create mode 100644 public/static/libs/element-ui/lib/directives/repeat-click.js create mode 100644 public/static/libs/element-ui/lib/divider.js create mode 100644 public/static/libs/element-ui/lib/drawer.js create mode 100644 public/static/libs/element-ui/lib/dropdown-item.js create mode 100644 public/static/libs/element-ui/lib/dropdown-menu.js create mode 100644 public/static/libs/element-ui/lib/dropdown.js create mode 100644 public/static/libs/element-ui/lib/element-ui.common.js create mode 100644 public/static/libs/element-ui/lib/empty.js create mode 100644 public/static/libs/element-ui/lib/footer.js create mode 100644 public/static/libs/element-ui/lib/form-item.js create mode 100644 public/static/libs/element-ui/lib/form.js create mode 100644 public/static/libs/element-ui/lib/header.js create mode 100644 public/static/libs/element-ui/lib/icon.js create mode 100644 public/static/libs/element-ui/lib/image.js create mode 100644 public/static/libs/element-ui/lib/index.js create mode 100644 public/static/libs/element-ui/lib/infinite-scroll.js create mode 100644 public/static/libs/element-ui/lib/input-number.js create mode 100644 public/static/libs/element-ui/lib/input.js create mode 100644 public/static/libs/element-ui/lib/link.js create mode 100644 public/static/libs/element-ui/lib/loading.js create mode 100644 public/static/libs/element-ui/lib/locale/format.js create mode 100644 public/static/libs/element-ui/lib/locale/index.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/af-ZA.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/ar.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/az.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/bg.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/bn.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/ca.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/cs-CZ.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/da.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/de.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/ee.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/el.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/en.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/eo.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/es.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/eu.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/fa.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/fi.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/fr.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/he.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/hr.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/hu.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/hy-AM.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/id.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/is.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/it.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/ja.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/kg.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/km.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/ko.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/ku.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/kz.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/lt.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/lv.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/mn.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/ms.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/nb-NO.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/nl.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/pl.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/pt-br.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/pt.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/ro.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/ru-RU.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/si.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/sk.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/sl.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/sr-Latn.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/sr.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/sv-SE.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/sw.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/ta.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/th.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/tk.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/tr-TR.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/ua.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/ug-CN.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/uz-UZ.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/vi.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/zh-CN.js create mode 100644 public/static/libs/element-ui/lib/locale/lang/zh-TW.js create mode 100644 public/static/libs/element-ui/lib/main.js create mode 100644 public/static/libs/element-ui/lib/menu-item-group.js create mode 100644 public/static/libs/element-ui/lib/menu-item.js create mode 100644 public/static/libs/element-ui/lib/menu.js create mode 100644 public/static/libs/element-ui/lib/message-box.js create mode 100644 public/static/libs/element-ui/lib/message.js create mode 100644 public/static/libs/element-ui/lib/mixins/emitter.js create mode 100644 public/static/libs/element-ui/lib/mixins/focus.js create mode 100644 public/static/libs/element-ui/lib/mixins/locale.js create mode 100644 public/static/libs/element-ui/lib/mixins/migrating.js create mode 100644 public/static/libs/element-ui/lib/notification.js create mode 100644 public/static/libs/element-ui/lib/option-group.js create mode 100644 public/static/libs/element-ui/lib/option.js create mode 100644 public/static/libs/element-ui/lib/page-header.js create mode 100644 public/static/libs/element-ui/lib/pagination.js create mode 100644 public/static/libs/element-ui/lib/popconfirm.js create mode 100644 public/static/libs/element-ui/lib/popover.js create mode 100644 public/static/libs/element-ui/lib/progress.js create mode 100644 public/static/libs/element-ui/lib/radio-button.js create mode 100644 public/static/libs/element-ui/lib/radio-group.js create mode 100644 public/static/libs/element-ui/lib/radio.js create mode 100644 public/static/libs/element-ui/lib/rate.js create mode 100644 public/static/libs/element-ui/lib/result.js create mode 100644 public/static/libs/element-ui/lib/row.js create mode 100644 public/static/libs/element-ui/lib/scrollbar.js create mode 100644 public/static/libs/element-ui/lib/select.js create mode 100644 public/static/libs/element-ui/lib/skeleton-item.js create mode 100644 public/static/libs/element-ui/lib/skeleton.js create mode 100644 public/static/libs/element-ui/lib/slider.js create mode 100644 public/static/libs/element-ui/lib/spinner.js create mode 100644 public/static/libs/element-ui/lib/statistic.js create mode 100644 public/static/libs/element-ui/lib/step.js create mode 100644 public/static/libs/element-ui/lib/steps.js create mode 100644 public/static/libs/element-ui/lib/submenu.js create mode 100644 public/static/libs/element-ui/lib/switch.js create mode 100644 public/static/libs/element-ui/lib/tab-pane.js create mode 100644 public/static/libs/element-ui/lib/table-column.js create mode 100644 public/static/libs/element-ui/lib/table.js create mode 100644 public/static/libs/element-ui/lib/tabs.js create mode 100644 public/static/libs/element-ui/lib/tag.js create mode 100644 public/static/libs/element-ui/lib/theme-chalk/alert.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/aside.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/autocomplete.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/avatar.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/backtop.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/badge.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/base.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/breadcrumb.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/button.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/calendar.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/card.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/carousel-item.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/carousel.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/cascader-panel.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/cascader.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/checkbox.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/col.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/collapse.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/color-picker.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/container.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/date-picker.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/descriptions-item.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/descriptions.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/dialog.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/display.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/divider.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/drawer.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/dropdown.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/empty.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/fonts/element-icons.ttf create mode 100644 public/static/libs/element-ui/lib/theme-chalk/fonts/element-icons.woff create mode 100644 public/static/libs/element-ui/lib/theme-chalk/footer.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/form.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/header.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/icon.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/image.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/index.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/input-number.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/input.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/link.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/loading.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/main.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/menu.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/message-box.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/message.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/notification.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/option-group.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/option.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/page-header.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/pagination.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/popconfirm.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/popover.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/popper.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/progress.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/radio-button.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/radio-group.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/radio.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/rate.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/reset.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/result.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/row.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/scrollbar.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/select-dropdown.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/select.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/skeleton-item.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/skeleton.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/slider.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/spinner.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/statistic.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/step.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/steps.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/switch.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/table-column.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/table.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/tabs.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/tag.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/time-picker.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/time-select.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/timeline-item.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/timeline.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/tooltip.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/transfer.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/tree.css create mode 100644 public/static/libs/element-ui/lib/theme-chalk/upload.css create mode 100644 public/static/libs/element-ui/lib/time-picker.js create mode 100644 public/static/libs/element-ui/lib/time-select.js create mode 100644 public/static/libs/element-ui/lib/timeline-item.js create mode 100644 public/static/libs/element-ui/lib/timeline.js create mode 100644 public/static/libs/element-ui/lib/tooltip.js create mode 100644 public/static/libs/element-ui/lib/transfer.js create mode 100644 public/static/libs/element-ui/lib/transitions/collapse-transition.js create mode 100644 public/static/libs/element-ui/lib/tree.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/af-ZA.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/ar.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/az.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/bg.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/bn.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/ca.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/cs-CZ.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/da.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/de.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/ee.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/el.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/en.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/eo.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/es.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/eu.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/fa.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/fi.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/fr.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/he.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/hr.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/hu.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/hy-AM.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/id.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/is.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/it.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/ja.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/kg.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/km.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/ko.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/ku.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/kz.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/lt.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/lv.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/mn.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/ms.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/nb-NO.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/nl.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/pl.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/pt-br.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/pt.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/ro.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/ru-RU.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/si.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/sk.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/sl.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/sr-Latn.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/sr.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/sv-SE.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/sw.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/ta.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/th.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/tk.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/tr-TR.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/ua.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/ug-CN.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/uz-UZ.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/vi.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/zh-CN.js create mode 100644 public/static/libs/element-ui/lib/umd/locale/zh-TW.js create mode 100644 public/static/libs/element-ui/lib/upload.js create mode 100644 public/static/libs/element-ui/lib/utils/after-leave.js create mode 100644 public/static/libs/element-ui/lib/utils/aria-dialog.js create mode 100644 public/static/libs/element-ui/lib/utils/aria-utils.js create mode 100644 public/static/libs/element-ui/lib/utils/clickoutside.js create mode 100644 public/static/libs/element-ui/lib/utils/date-util.js create mode 100644 public/static/libs/element-ui/lib/utils/date.js create mode 100644 public/static/libs/element-ui/lib/utils/dom.js create mode 100644 public/static/libs/element-ui/lib/utils/lodash.js create mode 100644 public/static/libs/element-ui/lib/utils/menu/aria-menubar.js create mode 100644 public/static/libs/element-ui/lib/utils/menu/aria-menuitem.js create mode 100644 public/static/libs/element-ui/lib/utils/menu/aria-submenu.js create mode 100644 public/static/libs/element-ui/lib/utils/merge.js create mode 100644 public/static/libs/element-ui/lib/utils/popper.js create mode 100644 public/static/libs/element-ui/lib/utils/popup/index.js create mode 100644 public/static/libs/element-ui/lib/utils/popup/popup-manager.js create mode 100644 public/static/libs/element-ui/lib/utils/resize-event.js create mode 100644 public/static/libs/element-ui/lib/utils/scroll-into-view.js create mode 100644 public/static/libs/element-ui/lib/utils/scrollbar-width.js create mode 100644 public/static/libs/element-ui/lib/utils/shared.js create mode 100644 public/static/libs/element-ui/lib/utils/types.js create mode 100644 public/static/libs/element-ui/lib/utils/util.js create mode 100644 public/static/libs/element-ui/lib/utils/vdom.js create mode 100644 public/static/libs/element-ui/lib/utils/vue-popper.js create mode 100644 public/static/libs/element-ui/package.json create mode 100644 public/static/libs/element-ui/web-types.json create mode 100644 public/static/libs/sweetalert2/sweetalert2.all.js create mode 100644 public/static/libs/sweetalert2/sweetalert2.all.min.js create mode 100644 public/static/libs/sweetalert2/sweetalert2.css create mode 100644 public/static/libs/sweetalert2/sweetalert2.js create mode 100644 public/static/libs/sweetalert2/sweetalert2.min.css create mode 100644 public/static/libs/sweetalert2/sweetalert2.min.js create mode 100644 public/static/libs/vue/LICENSE create mode 100644 public/static/libs/vue/README.md create mode 100644 public/static/libs/vue/compiler-sfc/index.d.ts create mode 100644 public/static/libs/vue/compiler-sfc/index.js create mode 100644 public/static/libs/vue/compiler-sfc/index.mjs create mode 100644 public/static/libs/vue/compiler-sfc/package.json create mode 100644 public/static/libs/vue/dist/vue.common.dev.js create mode 100644 public/static/libs/vue/dist/vue.common.js create mode 100644 public/static/libs/vue/dist/vue.common.prod.js create mode 100644 public/static/libs/vue/dist/vue.esm.browser.js create mode 100644 public/static/libs/vue/dist/vue.esm.browser.min.js create mode 100644 public/static/libs/vue/dist/vue.esm.js create mode 100644 public/static/libs/vue/dist/vue.js create mode 100644 public/static/libs/vue/dist/vue.min.js create mode 100644 public/static/libs/vue/dist/vue.runtime.common.dev.js create mode 100644 public/static/libs/vue/dist/vue.runtime.common.js create mode 100644 public/static/libs/vue/dist/vue.runtime.common.prod.js create mode 100644 public/static/libs/vue/dist/vue.runtime.esm.js create mode 100644 public/static/libs/vue/dist/vue.runtime.js create mode 100644 public/static/libs/vue/dist/vue.runtime.min.js create mode 100644 public/static/libs/vue/dist/vue.runtime.mjs create mode 100644 public/static/libs/vue/package.json create mode 100644 public/static/testdrive.html create mode 100644 resources/css/app.css create mode 100644 resources/js/app.js create mode 100644 resources/js/bootstrap.js create mode 100644 resources/views/welcome.blade.php create mode 100644 routes/api.php create mode 100644 routes/console.php create mode 100644 routes/web.php create mode 100644 storage/app/.gitignore create mode 100644 storage/app/public/.gitignore create mode 100644 storage/framework/.gitignore create mode 100644 storage/framework/cache/.gitignore create mode 100644 storage/framework/cache/data/.gitignore create mode 100644 storage/framework/sessions/.gitignore create mode 100644 storage/framework/testing/.gitignore create mode 100644 storage/framework/views/.gitignore create mode 100644 storage/logs/.gitignore create mode 100644 tests/Feature/ExampleTest.php create mode 100644 tests/TestCase.php create mode 100644 tests/Unit/ExampleTest.php create mode 100644 vite.config.js diff --git a/.editorconfig b/.editorconfig new file mode 100644 index 0000000..8a13ac4 --- /dev/null +++ b/.editorconfig @@ -0,0 +1,19 @@ +root = true + +[*] +charset = utf-8 +end_of_line = lf +indent_size = 4 +indent_style = space +insert_final_newline = true +trim_trailing_whitespace = true +max_line_length = 150 + +[*.md] +trim_trailing_whitespace = false + +[*.{yml,yaml}] +indent_size = 2 + +[docker-compose.yml] +indent_size = 4 diff --git a/.env.example b/.env.example new file mode 100644 index 0000000..f1d87da --- /dev/null +++ b/.env.example @@ -0,0 +1,79 @@ +APP_NAME=Laravel +APP_ENV=local +APP_KEY= +APP_DEBUG=true +APP_TIMEZONE=PRC +APP_URL=http://localhost +APP_VERSION=0.0.0 + +APP_LOCALE=en +APP_FALLBACK_LOCALE=en +APP_FAKER_LOCALE=en_US + +APP_MAINTENANCE_DRIVER=file +# APP_MAINTENANCE_STORE=database + +BCRYPT_ROUNDS=12 + +LOG_CHANNEL=stack +LOG_STACK=single +LOG_DEPRECATIONS_CHANNEL=null +LOG_LEVEL=debug + +DB_CONNECTION=sqlite +# DB_HOST=127.0.0.1 +# DB_PORT=3306 +# DB_DATABASE=laravel +# DB_USERNAME=root +# DB_PASSWORD= + +SESSION_DRIVER=database +SESSION_LIFETIME=120 +SESSION_ENCRYPT=false +SESSION_PATH=/ +SESSION_DOMAIN=null + +BROADCAST_CONNECTION=log +FILESYSTEM_DISK=local +QUEUE_CONNECTION=database + +CACHE_STORE=database +CACHE_PREFIX= + +MEMCACHED_HOST=127.0.0.1 + +REDIS_CLIENT=phpredis +REDIS_HOST=127.0.0.1 +REDIS_PASSWORD=null +REDIS_PORT=6379 + +MAIL_MAILER=log +MAIL_HOST=127.0.0.1 +MAIL_PORT=2525 +MAIL_USERNAME=null +MAIL_PASSWORD=null +MAIL_ENCRYPTION=null +MAIL_FROM_ADDRESS="hello@example.com" +MAIL_FROM_NAME="${APP_NAME}" + +AWS_ACCESS_KEY_ID= +AWS_SECRET_ACCESS_KEY= +AWS_DEFAULT_REGION=us-east-1 +AWS_BUCKET= +AWS_USE_PATH_STYLE_ENDPOINT=false + +VITE_APP_NAME="${APP_NAME}" + +# 支付宝开放平台 +ALIPAY_APP_ID= + +CHERY_SCRM_ENDPOINT= +CHERY_APP_ID= +CHERY_APP_SECRET= + +# 支付宝数字推广平台 token +ADOPS_BIZ_TOKEN= +# 支付宝数字推广平台 商家标识 +ADOPS_PRINCIPAL_TAG= + +BAIDU_LBS_AK= diff --git a/.gitattributes b/.gitattributes new file mode 100644 index 0000000..fcb21d3 --- /dev/null +++ b/.gitattributes @@ -0,0 +1,11 @@ +* text=auto eol=lf + +*.blade.php diff=html +*.css diff=css +*.html diff=html +*.md diff=markdown +*.php diff=php + +/.github export-ignore +CHANGELOG.md export-ignore +.styleci.yml export-ignore diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..46340a6 --- /dev/null +++ b/.gitignore @@ -0,0 +1,20 @@ +/.phpunit.cache +/node_modules +/public/build +/public/hot +/public/storage +/storage/*.key +/vendor +.env +.env.backup +.env.production +.phpactor.json +.phpunit.result.cache +Homestead.json +Homestead.yaml +auth.json +npm-debug.log +yarn-error.log +/.fleet +/.idea +/.vscode diff --git a/.php-cs-fixer.php b/.php-cs-fixer.php new file mode 100644 index 0000000..a516129 --- /dev/null +++ b/.php-cs-fixer.php @@ -0,0 +1,69 @@ +setRiskyAllowed(true) + ->setRules([ + '@PSR2' => true, + '@Symfony' => true, + '@DoctrineAnnotation' => true, + '@PhpCsFixer' => true, + 'array_syntax' => [ + 'syntax' => 'short' + ], + 'list_syntax' => [ + 'syntax' => 'short' + ], + 'concat_space' => [ + 'spacing' => 'one' + ], + 'blank_line_before_statement' => [ + 'statements' => [ + 'declare', + ], + ], + 'general_phpdoc_annotation_remove' => [ + 'annotations' => [ + 'author' + ], + ], + 'ordered_imports' => [ + 'imports_order' => [ + 'class', 'function', 'const', + ], + 'sort_algorithm' => 'alpha', + ], + 'single_line_comment_style' => [ + 'comment_types' => [], + ], + 'yoda_style' => [ + 'always_move_variable' => false, + 'equal' => false, + 'identical' => false, + ], + 'phpdoc_align' => [ + 'align' => 'left', + ], + 'multiline_whitespace_before_semicolons' => [ + 'strategy' => 'no_multi_line', + ], + 'constant_case' => [ + 'case' => 'lower', + ], + 'class_attributes_separation' => true, + 'combine_consecutive_unsets' => true, + 'declare_strict_types' => false, + 'linebreak_after_opening_tag' => true, + 'lowercase_static_reference' => true, + 'no_useless_else' => true, + 'no_unused_imports' => true, + 'not_operator_with_successor_space' => false, + 'not_operator_with_space' => false, + 'ordered_class_elements' => true, + 'php_unit_strict' => false, + 'phpdoc_separation' => false, + 'single_quote' => false, + 'standardize_not_equals' => true, + 'multiline_comment_opening_closing' => true, + ]) + ->setFinder(PhpCsFixer\Finder::create()->in(__DIR__ . '/app')->in(__DIR__ . '/packages')) + ->setUsingCache(false); diff --git a/README.md b/README.md new file mode 100644 index 0000000..576677b --- /dev/null +++ b/README.md @@ -0,0 +1 @@ +# BYDAuto web api diff --git a/_ide_helper.php b/_ide_helper.php new file mode 100644 index 0000000..c197dca --- /dev/null +++ b/_ide_helper.php @@ -0,0 +1,22257 @@ + + * @see https://github.com/barryvdh/laravel-ide-helper + */ + +namespace Illuminate\Support\Facades { + /** + * + * + * @see \Illuminate\Foundation\Application + */ class App { + /** + * Begin configuring a new Laravel application instance. + * + * @param string|null $basePath + * @return \Illuminate\Foundation\Configuration\ApplicationBuilder + * @static + */ public static function configure($basePath = null) + { + return \Illuminate\Foundation\Application::configure($basePath); + } + /** + * Infer the application's base directory from the environment. + * + * @return string + * @static + */ public static function inferBasePath() + { + return \Illuminate\Foundation\Application::inferBasePath(); + } + /** + * Get the version number of the application. + * + * @return string + * @static + */ public static function version() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->version(); + } + /** + * Run the given array of bootstrap classes. + * + * @param string[] $bootstrappers + * @return void + * @static + */ public static function bootstrapWith($bootstrappers) + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->bootstrapWith($bootstrappers); + } + /** + * Register a callback to run after loading the environment. + * + * @param \Closure $callback + * @return void + * @static + */ public static function afterLoadingEnvironment($callback) + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->afterLoadingEnvironment($callback); + } + /** + * Register a callback to run before a bootstrapper. + * + * @param string $bootstrapper + * @param \Closure $callback + * @return void + * @static + */ public static function beforeBootstrapping($bootstrapper, $callback) + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->beforeBootstrapping($bootstrapper, $callback); + } + /** + * Register a callback to run after a bootstrapper. + * + * @param string $bootstrapper + * @param \Closure $callback + * @return void + * @static + */ public static function afterBootstrapping($bootstrapper, $callback) + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->afterBootstrapping($bootstrapper, $callback); + } + /** + * Determine if the application has been bootstrapped before. + * + * @return bool + * @static + */ public static function hasBeenBootstrapped() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->hasBeenBootstrapped(); + } + /** + * Set the base path for the application. + * + * @param string $basePath + * @return \Illuminate\Foundation\Application + * @static + */ public static function setBasePath($basePath) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->setBasePath($basePath); + } + /** + * Get the path to the application "app" directory. + * + * @param string $path + * @return string + * @static + */ public static function path($path = '') + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->path($path); + } + /** + * Set the application directory. + * + * @param string $path + * @return \Illuminate\Foundation\Application + * @static + */ public static function useAppPath($path) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->useAppPath($path); + } + /** + * Get the base path of the Laravel installation. + * + * @param string $path + * @return string + * @static + */ public static function basePath($path = '') + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->basePath($path); + } + /** + * Get the path to the bootstrap directory. + * + * @param string $path + * @return string + * @static + */ public static function bootstrapPath($path = '') + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->bootstrapPath($path); + } + /** + * Get the path to the service provider list in the bootstrap directory. + * + * @return string + * @static + */ public static function getBootstrapProvidersPath() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->getBootstrapProvidersPath(); + } + /** + * Set the bootstrap file directory. + * + * @param string $path + * @return \Illuminate\Foundation\Application + * @static + */ public static function useBootstrapPath($path) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->useBootstrapPath($path); + } + /** + * Get the path to the application configuration files. + * + * @param string $path + * @return string + * @static + */ public static function configPath($path = '') + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->configPath($path); + } + /** + * Set the configuration directory. + * + * @param string $path + * @return \Illuminate\Foundation\Application + * @static + */ public static function useConfigPath($path) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->useConfigPath($path); + } + /** + * Get the path to the database directory. + * + * @param string $path + * @return string + * @static + */ public static function databasePath($path = '') + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->databasePath($path); + } + /** + * Set the database directory. + * + * @param string $path + * @return \Illuminate\Foundation\Application + * @static + */ public static function useDatabasePath($path) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->useDatabasePath($path); + } + /** + * Get the path to the language files. + * + * @param string $path + * @return string + * @static + */ public static function langPath($path = '') + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->langPath($path); + } + /** + * Set the language file directory. + * + * @param string $path + * @return \Illuminate\Foundation\Application + * @static + */ public static function useLangPath($path) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->useLangPath($path); + } + /** + * Get the path to the public / web directory. + * + * @param string $path + * @return string + * @static + */ public static function publicPath($path = '') + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->publicPath($path); + } + /** + * Set the public / web directory. + * + * @param string $path + * @return \Illuminate\Foundation\Application + * @static + */ public static function usePublicPath($path) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->usePublicPath($path); + } + /** + * Get the path to the storage directory. + * + * @param string $path + * @return string + * @static + */ public static function storagePath($path = '') + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->storagePath($path); + } + /** + * Set the storage directory. + * + * @param string $path + * @return \Illuminate\Foundation\Application + * @static + */ public static function useStoragePath($path) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->useStoragePath($path); + } + /** + * Get the path to the resources directory. + * + * @param string $path + * @return string + * @static + */ public static function resourcePath($path = '') + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->resourcePath($path); + } + /** + * Get the path to the views directory. + * + * This method returns the first configured path in the array of view paths. + * + * @param string $path + * @return string + * @static + */ public static function viewPath($path = '') + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->viewPath($path); + } + /** + * Join the given paths together. + * + * @param string $basePath + * @param string $path + * @return string + * @static + */ public static function joinPaths($basePath, $path = '') + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->joinPaths($basePath, $path); + } + /** + * Get the path to the environment file directory. + * + * @return string + * @static + */ public static function environmentPath() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->environmentPath(); + } + /** + * Set the directory for the environment file. + * + * @param string $path + * @return \Illuminate\Foundation\Application + * @static + */ public static function useEnvironmentPath($path) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->useEnvironmentPath($path); + } + /** + * Set the environment file to be loaded during bootstrapping. + * + * @param string $file + * @return \Illuminate\Foundation\Application + * @static + */ public static function loadEnvironmentFrom($file) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->loadEnvironmentFrom($file); + } + /** + * Get the environment file the application is using. + * + * @return string + * @static + */ public static function environmentFile() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->environmentFile(); + } + /** + * Get the fully qualified path to the environment file. + * + * @return string + * @static + */ public static function environmentFilePath() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->environmentFilePath(); + } + /** + * Get or check the current application environment. + * + * @param string|array $environments + * @return string|bool + * @static + */ public static function environment(...$environments) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->environment(...$environments); + } + /** + * Determine if the application is in the local environment. + * + * @return bool + * @static + */ public static function isLocal() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->isLocal(); + } + /** + * Determine if the application is in the production environment. + * + * @return bool + * @static + */ public static function isProduction() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->isProduction(); + } + /** + * Detect the application's current environment. + * + * @param \Closure $callback + * @return string + * @static + */ public static function detectEnvironment($callback) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->detectEnvironment($callback); + } + /** + * Determine if the application is running in the console. + * + * @return bool + * @static + */ public static function runningInConsole() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->runningInConsole(); + } + /** + * Determine if the application is running any of the given console commands. + * + * @param string|array $commands + * @return bool + * @static + */ public static function runningConsoleCommand(...$commands) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->runningConsoleCommand(...$commands); + } + /** + * Determine if the application is running unit tests. + * + * @return bool + * @static + */ public static function runningUnitTests() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->runningUnitTests(); + } + /** + * Determine if the application is running with debug mode enabled. + * + * @return bool + * @static + */ public static function hasDebugModeEnabled() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->hasDebugModeEnabled(); + } + /** + * Register a new registered listener. + * + * @param callable $callback + * @return void + * @static + */ public static function registered($callback) + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->registered($callback); + } + /** + * Register all of the configured providers. + * + * @return void + * @static + */ public static function registerConfiguredProviders() + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->registerConfiguredProviders(); + } + /** + * Register a service provider with the application. + * + * @param \Illuminate\Support\ServiceProvider|string $provider + * @param bool $force + * @return \Illuminate\Support\ServiceProvider + * @static + */ public static function register($provider, $force = false) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->register($provider, $force); + } + /** + * Get the registered service provider instance if it exists. + * + * @param \Illuminate\Support\ServiceProvider|string $provider + * @return \Illuminate\Support\ServiceProvider|null + * @static + */ public static function getProvider($provider) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->getProvider($provider); + } + /** + * Get the registered service provider instances if any exist. + * + * @param \Illuminate\Support\ServiceProvider|string $provider + * @return array + * @static + */ public static function getProviders($provider) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->getProviders($provider); + } + /** + * Resolve a service provider instance from the class name. + * + * @param string $provider + * @return \Illuminate\Support\ServiceProvider + * @static + */ public static function resolveProvider($provider) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->resolveProvider($provider); + } + /** + * Load and boot all of the remaining deferred providers. + * + * @return void + * @static + */ public static function loadDeferredProviders() + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->loadDeferredProviders(); + } + /** + * Load the provider for a deferred service. + * + * @param string $service + * @return void + * @static + */ public static function loadDeferredProvider($service) + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->loadDeferredProvider($service); + } + /** + * Register a deferred provider and service. + * + * @param string $provider + * @param string|null $service + * @return void + * @static + */ public static function registerDeferredProvider($provider, $service = null) + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->registerDeferredProvider($provider, $service); + } + /** + * Resolve the given type from the container. + * + * @param string $abstract + * @param array $parameters + * @return mixed + * @throws \Illuminate\Contracts\Container\BindingResolutionException + * @static + */ public static function make($abstract, $parameters = []) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->make($abstract, $parameters); + } + /** + * Determine if the given abstract type has been bound. + * + * @param string $abstract + * @return bool + * @static + */ public static function bound($abstract) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->bound($abstract); + } + /** + * Determine if the application has booted. + * + * @return bool + * @static + */ public static function isBooted() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->isBooted(); + } + /** + * Boot the application's service providers. + * + * @return void + * @static + */ public static function boot() + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->boot(); + } + /** + * Register a new boot listener. + * + * @param callable $callback + * @return void + * @static + */ public static function booting($callback) + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->booting($callback); + } + /** + * Register a new "booted" listener. + * + * @param callable $callback + * @return void + * @static + */ public static function booted($callback) + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->booted($callback); + } + /** + * {@inheritdoc} + * + * @return \Symfony\Component\HttpFoundation\Response + * @static + */ public static function handle($request, $type = 1, $catch = true) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->handle($request, $type, $catch); + } + /** + * Handle the incoming HTTP request and send the response to the browser. + * + * @param \Illuminate\Http\Request $request + * @return void + * @static + */ public static function handleRequest($request) + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->handleRequest($request); + } + /** + * Handle the incoming Artisan command. + * + * @param \Symfony\Component\Console\Input\InputInterface $input + * @return int + * @static + */ public static function handleCommand($input) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->handleCommand($input); + } + /** + * Determine if the framework's base configuration should be merged. + * + * @return bool + * @static + */ public static function shouldMergeFrameworkConfiguration() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->shouldMergeFrameworkConfiguration(); + } + /** + * Indicate that the framework's base configuration should not be merged. + * + * @return \Illuminate\Foundation\Application + * @static + */ public static function dontMergeFrameworkConfiguration() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->dontMergeFrameworkConfiguration(); + } + /** + * Determine if middleware has been disabled for the application. + * + * @return bool + * @static + */ public static function shouldSkipMiddleware() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->shouldSkipMiddleware(); + } + /** + * Get the path to the cached services.php file. + * + * @return string + * @static + */ public static function getCachedServicesPath() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->getCachedServicesPath(); + } + /** + * Get the path to the cached packages.php file. + * + * @return string + * @static + */ public static function getCachedPackagesPath() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->getCachedPackagesPath(); + } + /** + * Determine if the application configuration is cached. + * + * @return bool + * @static + */ public static function configurationIsCached() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->configurationIsCached(); + } + /** + * Get the path to the configuration cache file. + * + * @return string + * @static + */ public static function getCachedConfigPath() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->getCachedConfigPath(); + } + /** + * Determine if the application routes are cached. + * + * @return bool + * @static + */ public static function routesAreCached() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->routesAreCached(); + } + /** + * Get the path to the routes cache file. + * + * @return string + * @static + */ public static function getCachedRoutesPath() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->getCachedRoutesPath(); + } + /** + * Determine if the application events are cached. + * + * @return bool + * @static + */ public static function eventsAreCached() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->eventsAreCached(); + } + /** + * Get the path to the events cache file. + * + * @return string + * @static + */ public static function getCachedEventsPath() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->getCachedEventsPath(); + } + /** + * Add new prefix to list of absolute path prefixes. + * + * @param string $prefix + * @return \Illuminate\Foundation\Application + * @static + */ public static function addAbsoluteCachePathPrefix($prefix) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->addAbsoluteCachePathPrefix($prefix); + } + /** + * Get an instance of the maintenance mode manager implementation. + * + * @return \Illuminate\Contracts\Foundation\MaintenanceMode + * @static + */ public static function maintenanceMode() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->maintenanceMode(); + } + /** + * Determine if the application is currently down for maintenance. + * + * @return bool + * @static + */ public static function isDownForMaintenance() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->isDownForMaintenance(); + } + /** + * Throw an HttpException with the given data. + * + * @param int $code + * @param string $message + * @param array $headers + * @return \Illuminate\Foundation\never + * @throws \Symfony\Component\HttpKernel\Exception\HttpException + * @throws \Symfony\Component\HttpKernel\Exception\NotFoundHttpException + * @static + */ public static function abort($code, $message = '', $headers = []) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->abort($code, $message, $headers); + } + /** + * Register a terminating callback with the application. + * + * @param callable|string $callback + * @return \Illuminate\Foundation\Application + * @static + */ public static function terminating($callback) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->terminating($callback); + } + /** + * Terminate the application. + * + * @return void + * @static + */ public static function terminate() + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->terminate(); + } + /** + * Get the service providers that have been loaded. + * + * @return array + * @static + */ public static function getLoadedProviders() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->getLoadedProviders(); + } + /** + * Determine if the given service provider is loaded. + * + * @param string $provider + * @return bool + * @static + */ public static function providerIsLoaded($provider) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->providerIsLoaded($provider); + } + /** + * Get the application's deferred services. + * + * @return array + * @static + */ public static function getDeferredServices() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->getDeferredServices(); + } + /** + * Set the application's deferred services. + * + * @param array $services + * @return void + * @static + */ public static function setDeferredServices($services) + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->setDeferredServices($services); + } + /** + * Add an array of services to the application's deferred services. + * + * @param array $services + * @return void + * @static + */ public static function addDeferredServices($services) + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->addDeferredServices($services); + } + /** + * Determine if the given service is a deferred service. + * + * @param string $service + * @return bool + * @static + */ public static function isDeferredService($service) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->isDeferredService($service); + } + /** + * Configure the real-time facade namespace. + * + * @param string $namespace + * @return void + * @static + */ public static function provideFacades($namespace) + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->provideFacades($namespace); + } + /** + * Get the current application locale. + * + * @return string + * @static + */ public static function getLocale() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->getLocale(); + } + /** + * Get the current application locale. + * + * @return string + * @static + */ public static function currentLocale() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->currentLocale(); + } + /** + * Get the current application fallback locale. + * + * @return string + * @static + */ public static function getFallbackLocale() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->getFallbackLocale(); + } + /** + * Set the current application locale. + * + * @param string $locale + * @return void + * @static + */ public static function setLocale($locale) + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->setLocale($locale); + } + /** + * Set the current application fallback locale. + * + * @param string $fallbackLocale + * @return void + * @static + */ public static function setFallbackLocale($fallbackLocale) + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->setFallbackLocale($fallbackLocale); + } + /** + * Determine if the application locale is the given locale. + * + * @param string $locale + * @return bool + * @static + */ public static function isLocale($locale) + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->isLocale($locale); + } + /** + * Register the core class aliases in the container. + * + * @return void + * @static + */ public static function registerCoreContainerAliases() + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->registerCoreContainerAliases(); + } + /** + * Flush the container of all bindings and resolved instances. + * + * @return void + * @static + */ public static function flush() + { + /** @var \Illuminate\Foundation\Application $instance */ + $instance->flush(); + } + /** + * Get the application namespace. + * + * @return string + * @throws \RuntimeException + * @static + */ public static function getNamespace() + { + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->getNamespace(); + } + /** + * Define a contextual binding. + * + * @param array|string $concrete + * @return \Illuminate\Contracts\Container\ContextualBindingBuilder + * @static + */ public static function when($concrete) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->when($concrete); + } + /** + * Define a contextual binding based on an attribute. + * + * @param string $attribute + * @param \Closure $handler + * @return void + * @static + */ public static function whenHasAttribute($attribute, $handler) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->whenHasAttribute($attribute, $handler); + } + /** + * Returns true if the container can return an entry for the given identifier. + * + * Returns false otherwise. + * + * `has($id)` returning true does not mean that `get($id)` will not throw an exception. + * It does however mean that `get($id)` will not throw a `NotFoundExceptionInterface`. + * + * @return bool + * @param string $id Identifier of the entry to look for. + * @return bool + * @static + */ public static function has($id) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->has($id); + } + /** + * Determine if the given abstract type has been resolved. + * + * @param string $abstract + * @return bool + * @static + */ public static function resolved($abstract) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->resolved($abstract); + } + /** + * Determine if a given type is shared. + * + * @param string $abstract + * @return bool + * @static + */ public static function isShared($abstract) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->isShared($abstract); + } + /** + * Determine if a given string is an alias. + * + * @param string $name + * @return bool + * @static + */ public static function isAlias($name) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->isAlias($name); + } + /** + * Register a binding with the container. + * + * @param string $abstract + * @param \Closure|string|null $concrete + * @param bool $shared + * @return void + * @throws \TypeError + * @static + */ public static function bind($abstract, $concrete = null, $shared = false) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->bind($abstract, $concrete, $shared); + } + /** + * Determine if the container has a method binding. + * + * @param string $method + * @return bool + * @static + */ public static function hasMethodBinding($method) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->hasMethodBinding($method); + } + /** + * Bind a callback to resolve with Container::call. + * + * @param array|string $method + * @param \Closure $callback + * @return void + * @static + */ public static function bindMethod($method, $callback) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->bindMethod($method, $callback); + } + /** + * Get the method binding for the given method. + * + * @param string $method + * @param mixed $instance + * @return mixed + * @static + */ public static function callMethodBinding($method, $instance) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->callMethodBinding($method, $instance); + } + /** + * Add a contextual binding to the container. + * + * @param string $concrete + * @param string $abstract + * @param \Closure|string $implementation + * @return void + * @static + */ public static function addContextualBinding($concrete, $abstract, $implementation) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->addContextualBinding($concrete, $abstract, $implementation); + } + /** + * Register a binding if it hasn't already been registered. + * + * @param string $abstract + * @param \Closure|string|null $concrete + * @param bool $shared + * @return void + * @static + */ public static function bindIf($abstract, $concrete = null, $shared = false) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->bindIf($abstract, $concrete, $shared); + } + /** + * Register a shared binding in the container. + * + * @param string $abstract + * @param \Closure|string|null $concrete + * @return void + * @static + */ public static function singleton($abstract, $concrete = null) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->singleton($abstract, $concrete); + } + /** + * Register a shared binding if it hasn't already been registered. + * + * @param string $abstract + * @param \Closure|string|null $concrete + * @return void + * @static + */ public static function singletonIf($abstract, $concrete = null) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->singletonIf($abstract, $concrete); + } + /** + * Register a scoped binding in the container. + * + * @param string $abstract + * @param \Closure|string|null $concrete + * @return void + * @static + */ public static function scoped($abstract, $concrete = null) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->scoped($abstract, $concrete); + } + /** + * Register a scoped binding if it hasn't already been registered. + * + * @param string $abstract + * @param \Closure|string|null $concrete + * @return void + * @static + */ public static function scopedIf($abstract, $concrete = null) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->scopedIf($abstract, $concrete); + } + /** + * "Extend" an abstract type in the container. + * + * @param string $abstract + * @param \Closure $closure + * @return void + * @throws \InvalidArgumentException + * @static + */ public static function extend($abstract, $closure) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->extend($abstract, $closure); + } + /** + * Register an existing instance as shared in the container. + * + * @param string $abstract + * @param mixed $instance + * @return mixed + * @static + */ public static function instance($abstract, $instance) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->instance($abstract, $instance); + } + /** + * Assign a set of tags to a given binding. + * + * @param array|string $abstracts + * @param array|mixed $tags + * @return void + * @static + */ public static function tag($abstracts, $tags) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->tag($abstracts, $tags); + } + /** + * Resolve all of the bindings for a given tag. + * + * @param string $tag + * @return \Illuminate\Container\iterable + * @static + */ public static function tagged($tag) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->tagged($tag); + } + /** + * Alias a type to a different name. + * + * @param string $abstract + * @param string $alias + * @return void + * @throws \LogicException + * @static + */ public static function alias($abstract, $alias) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->alias($abstract, $alias); + } + /** + * Bind a new callback to an abstract's rebind event. + * + * @param string $abstract + * @param \Closure $callback + * @return mixed + * @static + */ public static function rebinding($abstract, $callback) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->rebinding($abstract, $callback); + } + /** + * Refresh an instance on the given target and method. + * + * @param string $abstract + * @param mixed $target + * @param string $method + * @return mixed + * @static + */ public static function refresh($abstract, $target, $method) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->refresh($abstract, $target, $method); + } + /** + * Wrap the given closure such that its dependencies will be injected when executed. + * + * @param \Closure $callback + * @param array $parameters + * @return \Closure + * @static + */ public static function wrap($callback, $parameters = []) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->wrap($callback, $parameters); + } + /** + * Call the given Closure / class@method and inject its dependencies. + * + * @param callable|string $callback + * @param array $parameters + * @param string|null $defaultMethod + * @return mixed + * @throws \InvalidArgumentException + * @static + */ public static function call($callback, $parameters = [], $defaultMethod = null) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->call($callback, $parameters, $defaultMethod); + } + /** + * Get a closure to resolve the given type from the container. + * + * @param string $abstract + * @return \Closure + * @static + */ public static function factory($abstract) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->factory($abstract); + } + /** + * An alias function name for make(). + * + * @param string|callable $abstract + * @param array $parameters + * @return mixed + * @throws \Illuminate\Contracts\Container\BindingResolutionException + * @static + */ public static function makeWith($abstract, $parameters = []) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->makeWith($abstract, $parameters); + } + /** + * Finds an entry of the container by its identifier and returns it. + * + * @return mixed + * @param string $id Identifier of the entry to look for. + * @throws NotFoundExceptionInterface No entry was found for **this** identifier. + * @throws ContainerExceptionInterface Error while retrieving the entry. + * @return mixed Entry. + * @static + */ public static function get($id) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->get($id); + } + /** + * Instantiate a concrete instance of the given type. + * + * @param \Closure|string $concrete + * @return mixed + * @throws \Illuminate\Contracts\Container\BindingResolutionException + * @throws \Illuminate\Contracts\Container\CircularDependencyException + * @static + */ public static function build($concrete) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->build($concrete); + } + /** + * Register a new before resolving callback for all types. + * + * @param \Closure|string $abstract + * @param \Closure|null $callback + * @return void + * @static + */ public static function beforeResolving($abstract, $callback = null) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->beforeResolving($abstract, $callback); + } + /** + * Register a new resolving callback. + * + * @param \Closure|string $abstract + * @param \Closure|null $callback + * @return void + * @static + */ public static function resolving($abstract, $callback = null) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->resolving($abstract, $callback); + } + /** + * Register a new after resolving callback for all types. + * + * @param \Closure|string $abstract + * @param \Closure|null $callback + * @return void + * @static + */ public static function afterResolving($abstract, $callback = null) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->afterResolving($abstract, $callback); + } + /** + * Register a new after resolving attribute callback for all types. + * + * @param string $attribute + * @param \Closure $callback + * @return void + * @static + */ public static function afterResolvingAttribute($attribute, $callback) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->afterResolvingAttribute($attribute, $callback); + } + /** + * Get the container's bindings. + * + * @return array + * @static + */ public static function getBindings() + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->getBindings(); + } + /** + * Get the alias for an abstract if available. + * + * @param string $abstract + * @return string + * @static + */ public static function getAlias($abstract) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->getAlias($abstract); + } + /** + * Remove all of the extender callbacks for a given type. + * + * @param string $abstract + * @return void + * @static + */ public static function forgetExtenders($abstract) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->forgetExtenders($abstract); + } + /** + * Remove a resolved instance from the instance cache. + * + * @param string $abstract + * @return void + * @static + */ public static function forgetInstance($abstract) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->forgetInstance($abstract); + } + /** + * Clear all of the instances from the container. + * + * @return void + * @static + */ public static function forgetInstances() + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->forgetInstances(); + } + /** + * Clear all of the scoped instances from the container. + * + * @return void + * @static + */ public static function forgetScopedInstances() + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->forgetScopedInstances(); + } + /** + * Get the globally available instance of the container. + * + * @return static + * @static + */ public static function getInstance() + { //Method inherited from \Illuminate\Container\Container + return \Illuminate\Foundation\Application::getInstance(); + } + /** + * Set the shared instance of the container. + * + * @param \Illuminate\Contracts\Container\Container|null $container + * @return \Illuminate\Contracts\Container\Container|static + * @static + */ public static function setInstance($container = null) + { //Method inherited from \Illuminate\Container\Container + return \Illuminate\Foundation\Application::setInstance($container); + } + /** + * Determine if a given offset exists. + * + * @param string $key + * @return bool + * @static + */ public static function offsetExists($key) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->offsetExists($key); + } + /** + * Get the value at a given offset. + * + * @param string $key + * @return mixed + * @static + */ public static function offsetGet($key) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + return $instance->offsetGet($key); + } + /** + * Set the value at a given offset. + * + * @param string $key + * @param mixed $value + * @return void + * @static + */ public static function offsetSet($key, $value) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->offsetSet($key, $value); + } + /** + * Unset the value at a given offset. + * + * @param string $key + * @return void + * @static + */ public static function offsetUnset($key) + { //Method inherited from \Illuminate\Container\Container + /** @var \Illuminate\Foundation\Application $instance */ + $instance->offsetUnset($key); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Foundation\Application::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Foundation\Application::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Foundation\Application::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Foundation\Application::flushMacros(); + } + } + /** + * + * + * @see \Illuminate\Foundation\Console\Kernel + */ class Artisan { + /** + * Re-route the Symfony command events to their Laravel counterparts. + * + * @internal + * @return \Illuminate\Foundation\Console\Kernel + * @static + */ public static function rerouteSymfonyCommandEvents() + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + return $instance->rerouteSymfonyCommandEvents(); + } + /** + * Run the console application. + * + * @param \Symfony\Component\Console\Input\InputInterface $input + * @param \Symfony\Component\Console\Output\OutputInterface|null $output + * @return int + * @static + */ public static function handle($input, $output = null) + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + return $instance->handle($input, $output); + } + /** + * Terminate the application. + * + * @param \Symfony\Component\Console\Input\InputInterface $input + * @param int $status + * @return void + * @static + */ public static function terminate($input, $status) + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + $instance->terminate($input, $status); + } + /** + * Register a callback to be invoked when the command lifecycle duration exceeds a given amount of time. + * + * @param \DateTimeInterface|\Carbon\CarbonInterval|float|int $threshold + * @param callable $handler + * @return void + * @static + */ public static function whenCommandLifecycleIsLongerThan($threshold, $handler) + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + $instance->whenCommandLifecycleIsLongerThan($threshold, $handler); + } + /** + * When the command being handled started. + * + * @return \Illuminate\Support\Carbon|null + * @static + */ public static function commandStartedAt() + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + return $instance->commandStartedAt(); + } + /** + * Resolve a console schedule instance. + * + * @return \Illuminate\Console\Scheduling\Schedule + * @static + */ public static function resolveConsoleSchedule() + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + return $instance->resolveConsoleSchedule(); + } + /** + * Register a Closure based command with the application. + * + * @param string $signature + * @param \Closure $callback + * @return \Illuminate\Foundation\Console\ClosureCommand + * @static + */ public static function command($signature, $callback) + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + return $instance->command($signature, $callback); + } + /** + * Register the given command with the console application. + * + * @param \Symfony\Component\Console\Command\Command $command + * @return void + * @static + */ public static function registerCommand($command) + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + $instance->registerCommand($command); + } + /** + * Run an Artisan console command by name. + * + * @param string $command + * @param array $parameters + * @param \Symfony\Component\Console\Output\OutputInterface|null $outputBuffer + * @return int + * @throws \Symfony\Component\Console\Exception\CommandNotFoundException + * @static + */ public static function call($command, $parameters = [], $outputBuffer = null) + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + return $instance->call($command, $parameters, $outputBuffer); + } + /** + * Queue the given console command. + * + * @param string $command + * @param array $parameters + * @return \Illuminate\Foundation\Bus\PendingDispatch + * @static + */ public static function queue($command, $parameters = []) + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + return $instance->queue($command, $parameters); + } + /** + * Get all of the commands registered with the console. + * + * @return array + * @static + */ public static function all() + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + return $instance->all(); + } + /** + * Get the output for the last run command. + * + * @return string + * @static + */ public static function output() + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + return $instance->output(); + } + /** + * Bootstrap the application for artisan commands. + * + * @return void + * @static + */ public static function bootstrap() + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + $instance->bootstrap(); + } + /** + * Bootstrap the application without booting service providers. + * + * @return void + * @static + */ public static function bootstrapWithoutBootingProviders() + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + $instance->bootstrapWithoutBootingProviders(); + } + /** + * Set the Artisan application instance. + * + * @param \Illuminate\Console\Application|null $artisan + * @return void + * @static + */ public static function setArtisan($artisan) + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + $instance->setArtisan($artisan); + } + /** + * Set the Artisan commands provided by the application. + * + * @param array $commands + * @return \Illuminate\Foundation\Console\Kernel + * @static + */ public static function addCommands($commands) + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + return $instance->addCommands($commands); + } + /** + * Set the paths that should have their Artisan commands automatically discovered. + * + * @param array $paths + * @return \Illuminate\Foundation\Console\Kernel + * @static + */ public static function addCommandPaths($paths) + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + return $instance->addCommandPaths($paths); + } + /** + * Set the paths that should have their Artisan "routes" automatically discovered. + * + * @param array $paths + * @return \Illuminate\Foundation\Console\Kernel + * @static + */ public static function addCommandRoutePaths($paths) + { + /** @var \Illuminate\Foundation\Console\Kernel $instance */ + return $instance->addCommandRoutePaths($paths); + } + } + /** + * + * + * @see \Illuminate\Auth\AuthManager + * @see \Illuminate\Auth\SessionGuard + */ class Auth { + /** + * Attempt to get the guard from the local cache. + * + * @param string|null $name + * @return \Illuminate\Contracts\Auth\Guard|\Illuminate\Contracts\Auth\StatefulGuard + * @static + */ public static function guard($name = null) + { + /** @var \Illuminate\Auth\AuthManager $instance */ + return $instance->guard($name); + } + /** + * Create a session based authentication guard. + * + * @param string $name + * @param array $config + * @return \Illuminate\Auth\SessionGuard + * @static + */ public static function createSessionDriver($name, $config) + { + /** @var \Illuminate\Auth\AuthManager $instance */ + return $instance->createSessionDriver($name, $config); + } + /** + * Create a token based authentication guard. + * + * @param string $name + * @param array $config + * @return \Illuminate\Auth\TokenGuard + * @static + */ public static function createTokenDriver($name, $config) + { + /** @var \Illuminate\Auth\AuthManager $instance */ + return $instance->createTokenDriver($name, $config); + } + /** + * Get the default authentication driver name. + * + * @return string + * @static + */ public static function getDefaultDriver() + { + /** @var \Illuminate\Auth\AuthManager $instance */ + return $instance->getDefaultDriver(); + } + /** + * Set the default guard driver the factory should serve. + * + * @param string $name + * @return void + * @static + */ public static function shouldUse($name) + { + /** @var \Illuminate\Auth\AuthManager $instance */ + $instance->shouldUse($name); + } + /** + * Set the default authentication driver name. + * + * @param string $name + * @return void + * @static + */ public static function setDefaultDriver($name) + { + /** @var \Illuminate\Auth\AuthManager $instance */ + $instance->setDefaultDriver($name); + } + /** + * Register a new callback based request guard. + * + * @param string $driver + * @param callable $callback + * @return \Illuminate\Auth\AuthManager + * @static + */ public static function viaRequest($driver, $callback) + { + /** @var \Illuminate\Auth\AuthManager $instance */ + return $instance->viaRequest($driver, $callback); + } + /** + * Get the user resolver callback. + * + * @return \Closure + * @static + */ public static function userResolver() + { + /** @var \Illuminate\Auth\AuthManager $instance */ + return $instance->userResolver(); + } + /** + * Set the callback to be used to resolve users. + * + * @param \Closure $userResolver + * @return \Illuminate\Auth\AuthManager + * @static + */ public static function resolveUsersUsing($userResolver) + { + /** @var \Illuminate\Auth\AuthManager $instance */ + return $instance->resolveUsersUsing($userResolver); + } + /** + * Register a custom driver creator Closure. + * + * @param string $driver + * @param \Closure $callback + * @return \Illuminate\Auth\AuthManager + * @static + */ public static function extend($driver, $callback) + { + /** @var \Illuminate\Auth\AuthManager $instance */ + return $instance->extend($driver, $callback); + } + /** + * Register a custom provider creator Closure. + * + * @param string $name + * @param \Closure $callback + * @return \Illuminate\Auth\AuthManager + * @static + */ public static function provider($name, $callback) + { + /** @var \Illuminate\Auth\AuthManager $instance */ + return $instance->provider($name, $callback); + } + /** + * Determines if any guards have already been resolved. + * + * @return bool + * @static + */ public static function hasResolvedGuards() + { + /** @var \Illuminate\Auth\AuthManager $instance */ + return $instance->hasResolvedGuards(); + } + /** + * Forget all of the resolved guard instances. + * + * @return \Illuminate\Auth\AuthManager + * @static + */ public static function forgetGuards() + { + /** @var \Illuminate\Auth\AuthManager $instance */ + return $instance->forgetGuards(); + } + /** + * Set the application instance used by the manager. + * + * @param \Illuminate\Contracts\Foundation\Application $app + * @return \Illuminate\Auth\AuthManager + * @static + */ public static function setApplication($app) + { + /** @var \Illuminate\Auth\AuthManager $instance */ + return $instance->setApplication($app); + } + /** + * Create the user provider implementation for the driver. + * + * @param string|null $provider + * @return \Illuminate\Contracts\Auth\UserProvider|null + * @throws \InvalidArgumentException + * @static + */ public static function createUserProvider($provider = null) + { + /** @var \Illuminate\Auth\AuthManager $instance */ + return $instance->createUserProvider($provider); + } + /** + * Get the default user provider name. + * + * @return string + * @static + */ public static function getDefaultUserProvider() + { + /** @var \Illuminate\Auth\AuthManager $instance */ + return $instance->getDefaultUserProvider(); + } + /** + * Get the currently authenticated user. + * + * @return \App\Models\User|null + * @static + */ public static function user() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->user(); + } + /** + * Get the ID for the currently authenticated user. + * + * @return int|string|null + * @static + */ public static function id() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->id(); + } + /** + * Log a user into the application without sessions or cookies. + * + * @param array $credentials + * @return bool + * @static + */ public static function once($credentials = []) + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->once($credentials); + } + /** + * Log the given user ID into the application without sessions or cookies. + * + * @param mixed $id + * @return \App\Models\User|false + * @static + */ public static function onceUsingId($id) + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->onceUsingId($id); + } + /** + * Validate a user's credentials. + * + * @param array $credentials + * @return bool + * @static + */ public static function validate($credentials = []) + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->validate($credentials); + } + /** + * Attempt to authenticate using HTTP Basic Auth. + * + * @param string $field + * @param array $extraConditions + * @return \Symfony\Component\HttpFoundation\Response|null + * @throws \Symfony\Component\HttpKernel\Exception\UnauthorizedHttpException + * @static + */ public static function basic($field = 'email', $extraConditions = []) + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->basic($field, $extraConditions); + } + /** + * Perform a stateless HTTP Basic login attempt. + * + * @param string $field + * @param array $extraConditions + * @return \Symfony\Component\HttpFoundation\Response|null + * @throws \Symfony\Component\HttpKernel\Exception\UnauthorizedHttpException + * @static + */ public static function onceBasic($field = 'email', $extraConditions = []) + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->onceBasic($field, $extraConditions); + } + /** + * Attempt to authenticate a user using the given credentials. + * + * @param array $credentials + * @param bool $remember + * @return bool + * @static + */ public static function attempt($credentials = [], $remember = false) + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->attempt($credentials, $remember); + } + /** + * Attempt to authenticate a user with credentials and additional callbacks. + * + * @param array $credentials + * @param array|callable|null $callbacks + * @param bool $remember + * @return bool + * @static + */ public static function attemptWhen($credentials = [], $callbacks = null, $remember = false) + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->attemptWhen($credentials, $callbacks, $remember); + } + /** + * Log the given user ID into the application. + * + * @param mixed $id + * @param bool $remember + * @return \App\Models\User|false + * @static + */ public static function loginUsingId($id, $remember = false) + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->loginUsingId($id, $remember); + } + /** + * Log a user into the application. + * + * @param \Illuminate\Contracts\Auth\Authenticatable $user + * @param bool $remember + * @return void + * @static + */ public static function login($user, $remember = false) + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + $instance->login($user, $remember); + } + /** + * Log the user out of the application. + * + * @return void + * @static + */ public static function logout() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + $instance->logout(); + } + /** + * Log the user out of the application on their current device only. + * + * This method does not cycle the "remember" token. + * + * @return void + * @static + */ public static function logoutCurrentDevice() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + $instance->logoutCurrentDevice(); + } + /** + * Invalidate other sessions for the current user. + * + * The application must be using the AuthenticateSession middleware. + * + * @param string $password + * @return \App\Models\User|null + * @throws \Illuminate\Auth\AuthenticationException + * @static + */ public static function logoutOtherDevices($password) + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->logoutOtherDevices($password); + } + /** + * Register an authentication attempt event listener. + * + * @param mixed $callback + * @return void + * @static + */ public static function attempting($callback) + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + $instance->attempting($callback); + } + /** + * Get the last user we attempted to authenticate. + * + * @return \App\Models\User + * @static + */ public static function getLastAttempted() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->getLastAttempted(); + } + /** + * Get a unique identifier for the auth session value. + * + * @return string + * @static + */ public static function getName() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->getName(); + } + /** + * Get the name of the cookie used to store the "recaller". + * + * @return string + * @static + */ public static function getRecallerName() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->getRecallerName(); + } + /** + * Determine if the user was authenticated via "remember me" cookie. + * + * @return bool + * @static + */ public static function viaRemember() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->viaRemember(); + } + /** + * Set the number of minutes the remember me cookie should be valid for. + * + * @param int $minutes + * @return \Illuminate\Auth\SessionGuard + * @static + */ public static function setRememberDuration($minutes) + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->setRememberDuration($minutes); + } + /** + * Get the cookie creator instance used by the guard. + * + * @return \Illuminate\Contracts\Cookie\QueueingFactory + * @throws \RuntimeException + * @static + */ public static function getCookieJar() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->getCookieJar(); + } + /** + * Set the cookie creator instance used by the guard. + * + * @param \Illuminate\Contracts\Cookie\QueueingFactory $cookie + * @return void + * @static + */ public static function setCookieJar($cookie) + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + $instance->setCookieJar($cookie); + } + /** + * Get the event dispatcher instance. + * + * @return \Illuminate\Contracts\Events\Dispatcher + * @static + */ public static function getDispatcher() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->getDispatcher(); + } + /** + * Set the event dispatcher instance. + * + * @param \Illuminate\Contracts\Events\Dispatcher $events + * @return void + * @static + */ public static function setDispatcher($events) + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + $instance->setDispatcher($events); + } + /** + * Get the session store used by the guard. + * + * @return \Illuminate\Contracts\Session\Session + * @static + */ public static function getSession() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->getSession(); + } + /** + * Return the currently cached user. + * + * @return \App\Models\User|null + * @static + */ public static function getUser() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->getUser(); + } + /** + * Set the current user. + * + * @param \Illuminate\Contracts\Auth\Authenticatable $user + * @return \Illuminate\Auth\SessionGuard + * @static + */ public static function setUser($user) + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->setUser($user); + } + /** + * Get the current request instance. + * + * @return \Symfony\Component\HttpFoundation\Request + * @static + */ public static function getRequest() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->getRequest(); + } + /** + * Set the current request instance. + * + * @param \Symfony\Component\HttpFoundation\Request $request + * @return \Illuminate\Auth\SessionGuard + * @static + */ public static function setRequest($request) + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->setRequest($request); + } + /** + * Get the timebox instance used by the guard. + * + * @return \Illuminate\Support\Timebox + * @static + */ public static function getTimebox() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->getTimebox(); + } + /** + * Determine if the current user is authenticated. If not, throw an exception. + * + * @return \App\Models\User + * @throws \Illuminate\Auth\AuthenticationException + * @static + */ public static function authenticate() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->authenticate(); + } + /** + * Determine if the guard has a user instance. + * + * @return bool + * @static + */ public static function hasUser() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->hasUser(); + } + /** + * Determine if the current user is authenticated. + * + * @return bool + * @static + */ public static function check() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->check(); + } + /** + * Determine if the current user is a guest. + * + * @return bool + * @static + */ public static function guest() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->guest(); + } + /** + * Forget the current user. + * + * @return \Illuminate\Auth\SessionGuard + * @static + */ public static function forgetUser() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->forgetUser(); + } + /** + * Get the user provider used by the guard. + * + * @return \Illuminate\Contracts\Auth\UserProvider + * @static + */ public static function getProvider() + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + return $instance->getProvider(); + } + /** + * Set the user provider used by the guard. + * + * @param \Illuminate\Contracts\Auth\UserProvider $provider + * @return void + * @static + */ public static function setProvider($provider) + { + /** @var \Illuminate\Auth\SessionGuard $instance */ + $instance->setProvider($provider); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Auth\SessionGuard::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Auth\SessionGuard::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Auth\SessionGuard::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Auth\SessionGuard::flushMacros(); + } + } + /** + * + * + * @see \Illuminate\View\Compilers\BladeCompiler + */ class Blade { + /** + * Compile the view at the given path. + * + * @param string|null $path + * @return void + * @static + */ public static function compile($path = null) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->compile($path); + } + /** + * Get the path currently being compiled. + * + * @return string + * @static + */ public static function getPath() + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + return $instance->getPath(); + } + /** + * Set the path currently being compiled. + * + * @param string $path + * @return void + * @static + */ public static function setPath($path) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->setPath($path); + } + /** + * Compile the given Blade template contents. + * + * @param string $value + * @return string + * @static + */ public static function compileString($value) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + return $instance->compileString($value); + } + /** + * Evaluate and render a Blade string to HTML. + * + * @param string $string + * @param array $data + * @param bool $deleteCachedView + * @return string + * @static + */ public static function render($string, $data = [], $deleteCachedView = false) + { + return \Illuminate\View\Compilers\BladeCompiler::render($string, $data, $deleteCachedView); + } + /** + * Render a component instance to HTML. + * + * @param \Illuminate\View\Component $component + * @return string + * @static + */ public static function renderComponent($component) + { + return \Illuminate\View\Compilers\BladeCompiler::renderComponent($component); + } + /** + * Strip the parentheses from the given expression. + * + * @param string $expression + * @return string + * @static + */ public static function stripParentheses($expression) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + return $instance->stripParentheses($expression); + } + /** + * Register a custom Blade compiler. + * + * @param callable $compiler + * @return void + * @static + */ public static function extend($compiler) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->extend($compiler); + } + /** + * Get the extensions used by the compiler. + * + * @return array + * @static + */ public static function getExtensions() + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + return $instance->getExtensions(); + } + /** + * Register an "if" statement directive. + * + * @param string $name + * @param callable $callback + * @return void + * @static + */ public static function if($name, $callback) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->if($name, $callback); + } + /** + * Check the result of a condition. + * + * @param string $name + * @param mixed $parameters + * @return bool + * @static + */ public static function check($name, ...$parameters) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + return $instance->check($name, ...$parameters); + } + /** + * Register a class-based component alias directive. + * + * @param string $class + * @param string|null $alias + * @param string $prefix + * @return void + * @static + */ public static function component($class, $alias = null, $prefix = '') + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->component($class, $alias, $prefix); + } + /** + * Register an array of class-based components. + * + * @param array $components + * @param string $prefix + * @return void + * @static + */ public static function components($components, $prefix = '') + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->components($components, $prefix); + } + /** + * Get the registered class component aliases. + * + * @return array + * @static + */ public static function getClassComponentAliases() + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + return $instance->getClassComponentAliases(); + } + /** + * Register a new anonymous component path. + * + * @param string $path + * @param string|null $prefix + * @return void + * @static + */ public static function anonymousComponentPath($path, $prefix = null) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->anonymousComponentPath($path, $prefix); + } + /** + * Register an anonymous component namespace. + * + * @param string $directory + * @param string|null $prefix + * @return void + * @static + */ public static function anonymousComponentNamespace($directory, $prefix = null) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->anonymousComponentNamespace($directory, $prefix); + } + /** + * Register a class-based component namespace. + * + * @param string $namespace + * @param string $prefix + * @return void + * @static + */ public static function componentNamespace($namespace, $prefix) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->componentNamespace($namespace, $prefix); + } + /** + * Get the registered anonymous component paths. + * + * @return array + * @static + */ public static function getAnonymousComponentPaths() + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + return $instance->getAnonymousComponentPaths(); + } + /** + * Get the registered anonymous component namespaces. + * + * @return array + * @static + */ public static function getAnonymousComponentNamespaces() + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + return $instance->getAnonymousComponentNamespaces(); + } + /** + * Get the registered class component namespaces. + * + * @return array + * @static + */ public static function getClassComponentNamespaces() + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + return $instance->getClassComponentNamespaces(); + } + /** + * Register a component alias directive. + * + * @param string $path + * @param string|null $alias + * @return void + * @static + */ public static function aliasComponent($path, $alias = null) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->aliasComponent($path, $alias); + } + /** + * Register an include alias directive. + * + * @param string $path + * @param string|null $alias + * @return void + * @static + */ public static function include($path, $alias = null) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->include($path, $alias); + } + /** + * Register an include alias directive. + * + * @param string $path + * @param string|null $alias + * @return void + * @static + */ public static function aliasInclude($path, $alias = null) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->aliasInclude($path, $alias); + } + /** + * Register a handler for custom directives. + * + * @param string $name + * @param callable $handler + * @return void + * @throws \InvalidArgumentException + * @static + */ public static function directive($name, $handler) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->directive($name, $handler); + } + /** + * Get the list of custom directives. + * + * @return array + * @static + */ public static function getCustomDirectives() + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + return $instance->getCustomDirectives(); + } + /** + * Indicate that the following callable should be used to prepare strings for compilation. + * + * @param callable $callback + * @return \Illuminate\View\Compilers\BladeCompiler + * @static + */ public static function prepareStringsForCompilationUsing($callback) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + return $instance->prepareStringsForCompilationUsing($callback); + } + /** + * Register a new precompiler. + * + * @param callable $precompiler + * @return void + * @static + */ public static function precompiler($precompiler) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->precompiler($precompiler); + } + /** + * Set the echo format to be used by the compiler. + * + * @param string $format + * @return void + * @static + */ public static function setEchoFormat($format) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->setEchoFormat($format); + } + /** + * Set the "echo" format to double encode entities. + * + * @return void + * @static + */ public static function withDoubleEncoding() + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->withDoubleEncoding(); + } + /** + * Set the "echo" format to not double encode entities. + * + * @return void + * @static + */ public static function withoutDoubleEncoding() + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->withoutDoubleEncoding(); + } + /** + * Indicate that component tags should not be compiled. + * + * @return void + * @static + */ public static function withoutComponentTags() + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->withoutComponentTags(); + } + /** + * Get the path to the compiled version of a view. + * + * @param string $path + * @return string + * @static + */ public static function getCompiledPath($path) + { //Method inherited from \Illuminate\View\Compilers\Compiler + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + return $instance->getCompiledPath($path); + } + /** + * Determine if the view at the given path is expired. + * + * @param string $path + * @return bool + * @throws \ErrorException + * @static + */ public static function isExpired($path) + { //Method inherited from \Illuminate\View\Compilers\Compiler + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + return $instance->isExpired($path); + } + /** + * Get a new component hash for a component name. + * + * @param string $component + * @return string + * @static + */ public static function newComponentHash($component) + { + return \Illuminate\View\Compilers\BladeCompiler::newComponentHash($component); + } + /** + * Compile a class component opening. + * + * @param string $component + * @param string $alias + * @param string $data + * @param string $hash + * @return string + * @static + */ public static function compileClassComponentOpening($component, $alias, $data, $hash) + { + return \Illuminate\View\Compilers\BladeCompiler::compileClassComponentOpening($component, $alias, $data, $hash); + } + /** + * Compile the end-component statements into valid PHP. + * + * @return string + * @static + */ public static function compileEndComponentClass() + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + return $instance->compileEndComponentClass(); + } + /** + * Sanitize the given component attribute value. + * + * @param mixed $value + * @return mixed + * @static + */ public static function sanitizeComponentAttribute($value) + { + return \Illuminate\View\Compilers\BladeCompiler::sanitizeComponentAttribute($value); + } + /** + * Compile an end-once block into valid PHP. + * + * @return string + * @static + */ public static function compileEndOnce() + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + return $instance->compileEndOnce(); + } + /** + * Add a handler to be executed before echoing a given class. + * + * @param string|callable $class + * @param callable|null $handler + * @return void + * @static + */ public static function stringable($class, $handler = null) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + $instance->stringable($class, $handler); + } + /** + * Compile Blade echos into valid PHP. + * + * @param string $value + * @return string + * @static + */ public static function compileEchos($value) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + return $instance->compileEchos($value); + } + /** + * Apply the echo handler for the value if it exists. + * + * @param string $value + * @return string + * @static + */ public static function applyEchoHandler($value) + { + /** @var \Illuminate\View\Compilers\BladeCompiler $instance */ + return $instance->applyEchoHandler($value); + } + } + /** + * + * + * @method static mixed auth(\Illuminate\Http\Request $request) + * @method static mixed validAuthenticationResponse(\Illuminate\Http\Request $request, mixed $result) + * @method static void broadcast(array $channels, string $event, array $payload = []) + * @method static array|null resolveAuthenticatedUser(\Illuminate\Http\Request $request) + * @method static void resolveAuthenticatedUserUsing(\Closure $callback) + * @method static \Illuminate\Broadcasting\Broadcasters\Broadcaster channel(\Illuminate\Contracts\Broadcasting\HasBroadcastChannel|string $channel, callable|string $callback, array $options = []) + * @method static \Illuminate\Support\Collection getChannels() + * @see \Illuminate\Broadcasting\BroadcastManager + * @see \Illuminate\Broadcasting\Broadcasters\Broadcaster + */ class Broadcast { + /** + * Register the routes for handling broadcast channel authentication and sockets. + * + * @param array|null $attributes + * @return void + * @static + */ public static function routes($attributes = null) + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + $instance->routes($attributes); + } + /** + * Register the routes for handling broadcast user authentication. + * + * @param array|null $attributes + * @return void + * @static + */ public static function userRoutes($attributes = null) + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + $instance->userRoutes($attributes); + } + /** + * Register the routes for handling broadcast authentication and sockets. + * + * Alias of "routes" method. + * + * @param array|null $attributes + * @return void + * @static + */ public static function channelRoutes($attributes = null) + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + $instance->channelRoutes($attributes); + } + /** + * Get the socket ID for the given request. + * + * @param \Illuminate\Http\Request|null $request + * @return string|null + * @static + */ public static function socket($request = null) + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + return $instance->socket($request); + } + /** + * Begin sending an anonymous broadcast to the given channels. + * + * @static + */ public static function on($channels) + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + return $instance->on($channels); + } + /** + * Begin sending an anonymous broadcast to the given private channels. + * + * @static + */ public static function private($channel) + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + return $instance->private($channel); + } + /** + * Begin sending an anonymous broadcast to the given presence channels. + * + * @static + */ public static function presence($channel) + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + return $instance->presence($channel); + } + /** + * Begin broadcasting an event. + * + * @param mixed|null $event + * @return \Illuminate\Broadcasting\PendingBroadcast + * @static + */ public static function event($event = null) + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + return $instance->event($event); + } + /** + * Queue the given event for broadcast. + * + * @param mixed $event + * @return void + * @static + */ public static function queue($event) + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + $instance->queue($event); + } + /** + * Get a driver instance. + * + * @param string|null $driver + * @return mixed + * @static + */ public static function connection($driver = null) + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + return $instance->connection($driver); + } + /** + * Get a driver instance. + * + * @param string|null $name + * @return mixed + * @static + */ public static function driver($name = null) + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + return $instance->driver($name); + } + /** + * Get a Pusher instance for the given configuration. + * + * @param array $config + * @return \Pusher\Pusher + * @static + */ public static function pusher($config) + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + return $instance->pusher($config); + } + /** + * Get an Ably instance for the given configuration. + * + * @param array $config + * @return \Ably\AblyRest + * @static + */ public static function ably($config) + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + return $instance->ably($config); + } + /** + * Get the default driver name. + * + * @return string + * @static + */ public static function getDefaultDriver() + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + return $instance->getDefaultDriver(); + } + /** + * Set the default driver name. + * + * @param string $name + * @return void + * @static + */ public static function setDefaultDriver($name) + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + $instance->setDefaultDriver($name); + } + /** + * Disconnect the given disk and remove from local cache. + * + * @param string|null $name + * @return void + * @static + */ public static function purge($name = null) + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + $instance->purge($name); + } + /** + * Register a custom driver creator Closure. + * + * @param string $driver + * @param \Closure $callback + * @return \Illuminate\Broadcasting\BroadcastManager + * @static + */ public static function extend($driver, $callback) + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + return $instance->extend($driver, $callback); + } + /** + * Get the application instance used by the manager. + * + * @return \Illuminate\Contracts\Foundation\Application + * @static + */ public static function getApplication() + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + return $instance->getApplication(); + } + /** + * Set the application instance used by the manager. + * + * @param \Illuminate\Contracts\Foundation\Application $app + * @return \Illuminate\Broadcasting\BroadcastManager + * @static + */ public static function setApplication($app) + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + return $instance->setApplication($app); + } + /** + * Forget all of the resolved driver instances. + * + * @return \Illuminate\Broadcasting\BroadcastManager + * @static + */ public static function forgetDrivers() + { + /** @var \Illuminate\Broadcasting\BroadcastManager $instance */ + return $instance->forgetDrivers(); + } + } + /** + * + * + * @see \Illuminate\Bus\Dispatcher + * @see \Illuminate\Support\Testing\Fakes\BusFake + */ class Bus { + /** + * Dispatch a command to its appropriate handler. + * + * @param mixed $command + * @return mixed + * @static + */ public static function dispatch($command) + { + /** @var \Illuminate\Bus\Dispatcher $instance */ + return $instance->dispatch($command); + } + /** + * Dispatch a command to its appropriate handler in the current process. + * + * Queueable jobs will be dispatched to the "sync" queue. + * + * @param mixed $command + * @param mixed $handler + * @return mixed + * @static + */ public static function dispatchSync($command, $handler = null) + { + /** @var \Illuminate\Bus\Dispatcher $instance */ + return $instance->dispatchSync($command, $handler); + } + /** + * Dispatch a command to its appropriate handler in the current process without using the synchronous queue. + * + * @param mixed $command + * @param mixed $handler + * @return mixed + * @static + */ public static function dispatchNow($command, $handler = null) + { + /** @var \Illuminate\Bus\Dispatcher $instance */ + return $instance->dispatchNow($command, $handler); + } + /** + * Attempt to find the batch with the given ID. + * + * @param string $batchId + * @return \Illuminate\Bus\Batch|null + * @static + */ public static function findBatch($batchId) + { + /** @var \Illuminate\Bus\Dispatcher $instance */ + return $instance->findBatch($batchId); + } + /** + * Create a new batch of queueable jobs. + * + * @param \Illuminate\Support\Collection|array|mixed $jobs + * @return \Illuminate\Bus\PendingBatch + * @static + */ public static function batch($jobs) + { + /** @var \Illuminate\Bus\Dispatcher $instance */ + return $instance->batch($jobs); + } + /** + * Create a new chain of queueable jobs. + * + * @param \Illuminate\Support\Collection|array $jobs + * @return \Illuminate\Foundation\Bus\PendingChain + * @static + */ public static function chain($jobs) + { + /** @var \Illuminate\Bus\Dispatcher $instance */ + return $instance->chain($jobs); + } + /** + * Determine if the given command has a handler. + * + * @param mixed $command + * @return bool + * @static + */ public static function hasCommandHandler($command) + { + /** @var \Illuminate\Bus\Dispatcher $instance */ + return $instance->hasCommandHandler($command); + } + /** + * Retrieve the handler for a command. + * + * @param mixed $command + * @return bool|mixed + * @static + */ public static function getCommandHandler($command) + { + /** @var \Illuminate\Bus\Dispatcher $instance */ + return $instance->getCommandHandler($command); + } + /** + * Dispatch a command to its appropriate handler behind a queue. + * + * @param mixed $command + * @return mixed + * @throws \RuntimeException + * @static + */ public static function dispatchToQueue($command) + { + /** @var \Illuminate\Bus\Dispatcher $instance */ + return $instance->dispatchToQueue($command); + } + /** + * Dispatch a command to its appropriate handler after the current process. + * + * @param mixed $command + * @param mixed $handler + * @return void + * @static + */ public static function dispatchAfterResponse($command, $handler = null) + { + /** @var \Illuminate\Bus\Dispatcher $instance */ + $instance->dispatchAfterResponse($command, $handler); + } + /** + * Set the pipes through which commands should be piped before dispatching. + * + * @param array $pipes + * @return \Illuminate\Bus\Dispatcher + * @static + */ public static function pipeThrough($pipes) + { + /** @var \Illuminate\Bus\Dispatcher $instance */ + return $instance->pipeThrough($pipes); + } + /** + * Map a command to a handler. + * + * @param array $map + * @return \Illuminate\Bus\Dispatcher + * @static + */ public static function map($map) + { + /** @var \Illuminate\Bus\Dispatcher $instance */ + return $instance->map($map); + } + /** + * Specify the jobs that should be dispatched instead of faked. + * + * @param array|string $jobsToDispatch + * @return \Illuminate\Support\Testing\Fakes\BusFake + * @static + */ public static function except($jobsToDispatch) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + return $instance->except($jobsToDispatch); + } + /** + * Assert if a job was dispatched based on a truth-test callback. + * + * @param string|\Closure $command + * @param callable|int|null $callback + * @return void + * @static + */ public static function assertDispatched($command, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + $instance->assertDispatched($command, $callback); + } + /** + * Assert if a job was pushed a number of times. + * + * @param string|\Closure $command + * @param int $times + * @return void + * @static + */ public static function assertDispatchedTimes($command, $times = 1) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + $instance->assertDispatchedTimes($command, $times); + } + /** + * Determine if a job was dispatched based on a truth-test callback. + * + * @param string|\Closure $command + * @param callable|null $callback + * @return void + * @static + */ public static function assertNotDispatched($command, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + $instance->assertNotDispatched($command, $callback); + } + /** + * Assert that no jobs were dispatched. + * + * @return void + * @static + */ public static function assertNothingDispatched() + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + $instance->assertNothingDispatched(); + } + /** + * Assert if a job was explicitly dispatched synchronously based on a truth-test callback. + * + * @param string|\Closure $command + * @param callable|int|null $callback + * @return void + * @static + */ public static function assertDispatchedSync($command, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + $instance->assertDispatchedSync($command, $callback); + } + /** + * Assert if a job was pushed synchronously a number of times. + * + * @param string|\Closure $command + * @param int $times + * @return void + * @static + */ public static function assertDispatchedSyncTimes($command, $times = 1) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + $instance->assertDispatchedSyncTimes($command, $times); + } + /** + * Determine if a job was dispatched based on a truth-test callback. + * + * @param string|\Closure $command + * @param callable|null $callback + * @return void + * @static + */ public static function assertNotDispatchedSync($command, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + $instance->assertNotDispatchedSync($command, $callback); + } + /** + * Assert if a job was dispatched after the response was sent based on a truth-test callback. + * + * @param string|\Closure $command + * @param callable|int|null $callback + * @return void + * @static + */ public static function assertDispatchedAfterResponse($command, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + $instance->assertDispatchedAfterResponse($command, $callback); + } + /** + * Assert if a job was pushed after the response was sent a number of times. + * + * @param string|\Closure $command + * @param int $times + * @return void + * @static + */ public static function assertDispatchedAfterResponseTimes($command, $times = 1) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + $instance->assertDispatchedAfterResponseTimes($command, $times); + } + /** + * Determine if a job was dispatched based on a truth-test callback. + * + * @param string|\Closure $command + * @param callable|null $callback + * @return void + * @static + */ public static function assertNotDispatchedAfterResponse($command, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + $instance->assertNotDispatchedAfterResponse($command, $callback); + } + /** + * Assert if a chain of jobs was dispatched. + * + * @param array $expectedChain + * @return void + * @static + */ public static function assertChained($expectedChain) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + $instance->assertChained($expectedChain); + } + /** + * Assert if a job was dispatched with an empty chain based on a truth-test callback. + * + * @param string|\Closure $command + * @param callable|null $callback + * @return void + * @static + */ public static function assertDispatchedWithoutChain($command, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + $instance->assertDispatchedWithoutChain($command, $callback); + } + /** + * Create a new assertion about a chained batch. + * + * @param \Closure $callback + * @return \Illuminate\Support\Testing\Fakes\ChainedBatchTruthTest + * @static + */ public static function chainedBatch($callback) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + return $instance->chainedBatch($callback); + } + /** + * Assert if a batch was dispatched based on a truth-test callback. + * + * @param callable $callback + * @return void + * @static + */ public static function assertBatched($callback) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + $instance->assertBatched($callback); + } + /** + * Assert the number of batches that have been dispatched. + * + * @param int $count + * @return void + * @static + */ public static function assertBatchCount($count) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + $instance->assertBatchCount($count); + } + /** + * Assert that no batched jobs were dispatched. + * + * @return void + * @static + */ public static function assertNothingBatched() + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + $instance->assertNothingBatched(); + } + /** + * Get all of the jobs matching a truth-test callback. + * + * @param string $command + * @param callable|null $callback + * @return \Illuminate\Support\Collection + * @static + */ public static function dispatched($command, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + return $instance->dispatched($command, $callback); + } + /** + * Get all of the jobs dispatched synchronously matching a truth-test callback. + * + * @param string $command + * @param callable|null $callback + * @return \Illuminate\Support\Collection + * @static + */ public static function dispatchedSync($command, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + return $instance->dispatchedSync($command, $callback); + } + /** + * Get all of the jobs dispatched after the response was sent matching a truth-test callback. + * + * @param string $command + * @param callable|null $callback + * @return \Illuminate\Support\Collection + * @static + */ public static function dispatchedAfterResponse($command, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + return $instance->dispatchedAfterResponse($command, $callback); + } + /** + * Get all of the pending batches matching a truth-test callback. + * + * @param callable $callback + * @return \Illuminate\Support\Collection + * @static + */ public static function batched($callback) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + return $instance->batched($callback); + } + /** + * Determine if there are any stored commands for a given class. + * + * @param string $command + * @return bool + * @static + */ public static function hasDispatched($command) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + return $instance->hasDispatched($command); + } + /** + * Determine if there are any stored commands for a given class. + * + * @param string $command + * @return bool + * @static + */ public static function hasDispatchedSync($command) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + return $instance->hasDispatchedSync($command); + } + /** + * Determine if there are any stored commands for a given class. + * + * @param string $command + * @return bool + * @static + */ public static function hasDispatchedAfterResponse($command) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + return $instance->hasDispatchedAfterResponse($command); + } + /** + * Dispatch an empty job batch for testing. + * + * @param string $name + * @return \Illuminate\Bus\Batch + * @static + */ public static function dispatchFakeBatch($name = '') + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + return $instance->dispatchFakeBatch($name); + } + /** + * Record the fake pending batch dispatch. + * + * @param \Illuminate\Bus\PendingBatch $pendingBatch + * @return \Illuminate\Bus\Batch + * @static + */ public static function recordPendingBatch($pendingBatch) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + return $instance->recordPendingBatch($pendingBatch); + } + /** + * Specify if commands should be serialized and restored when being batched. + * + * @param bool $serializeAndRestore + * @return \Illuminate\Support\Testing\Fakes\BusFake + * @static + */ public static function serializeAndRestore($serializeAndRestore = true) + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + return $instance->serializeAndRestore($serializeAndRestore); + } + /** + * Get the batches that have been dispatched. + * + * @return array + * @static + */ public static function dispatchedBatches() + { + /** @var \Illuminate\Support\Testing\Fakes\BusFake $instance */ + return $instance->dispatchedBatches(); + } + } + /** + * + * + * @see \Illuminate\Cache\CacheManager + * @see \Illuminate\Cache\Repository + */ class Cache { + /** + * Get a cache store instance by name, wrapped in a repository. + * + * @param string|null $name + * @return \Illuminate\Contracts\Cache\Repository + * @static + */ public static function store($name = null) + { + /** @var \Illuminate\Cache\CacheManager $instance */ + return $instance->store($name); + } + /** + * Get a cache driver instance. + * + * @param string|null $driver + * @return \Illuminate\Contracts\Cache\Repository + * @static + */ public static function driver($driver = null) + { + /** @var \Illuminate\Cache\CacheManager $instance */ + return $instance->driver($driver); + } + /** + * Resolve the given store. + * + * @param string $name + * @return \Illuminate\Contracts\Cache\Repository + * @throws \InvalidArgumentException + * @static + */ public static function resolve($name) + { + /** @var \Illuminate\Cache\CacheManager $instance */ + return $instance->resolve($name); + } + /** + * Create a new cache repository with the given implementation. + * + * @param \Illuminate\Contracts\Cache\Store $store + * @param array $config + * @return \Illuminate\Cache\Repository + * @static + */ public static function repository($store, $config = []) + { + /** @var \Illuminate\Cache\CacheManager $instance */ + return $instance->repository($store, $config); + } + /** + * Re-set the event dispatcher on all resolved cache repositories. + * + * @return void + * @static + */ public static function refreshEventDispatcher() + { + /** @var \Illuminate\Cache\CacheManager $instance */ + $instance->refreshEventDispatcher(); + } + /** + * Get the default cache driver name. + * + * @return string + * @static + */ public static function getDefaultDriver() + { + /** @var \Illuminate\Cache\CacheManager $instance */ + return $instance->getDefaultDriver(); + } + /** + * Set the default cache driver name. + * + * @param string $name + * @return void + * @static + */ public static function setDefaultDriver($name) + { + /** @var \Illuminate\Cache\CacheManager $instance */ + $instance->setDefaultDriver($name); + } + /** + * Unset the given driver instances. + * + * @param array|string|null $name + * @return \Illuminate\Cache\CacheManager + * @static + */ public static function forgetDriver($name = null) + { + /** @var \Illuminate\Cache\CacheManager $instance */ + return $instance->forgetDriver($name); + } + /** + * Disconnect the given driver and remove from local cache. + * + * @param string|null $name + * @return void + * @static + */ public static function purge($name = null) + { + /** @var \Illuminate\Cache\CacheManager $instance */ + $instance->purge($name); + } + /** + * Register a custom driver creator Closure. + * + * @param string $driver + * @param \Closure $callback + * @return \Illuminate\Cache\CacheManager + * @static + */ public static function extend($driver, $callback) + { + /** @var \Illuminate\Cache\CacheManager $instance */ + return $instance->extend($driver, $callback); + } + /** + * Set the application instance used by the manager. + * + * @param \Illuminate\Contracts\Foundation\Application $app + * @return \Illuminate\Cache\CacheManager + * @static + */ public static function setApplication($app) + { + /** @var \Illuminate\Cache\CacheManager $instance */ + return $instance->setApplication($app); + } + /** + * Determine if an item exists in the cache. + * + * @param array|string $key + * @return bool + * @static + */ public static function has($key) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->has($key); + } + /** + * Determine if an item doesn't exist in the cache. + * + * @param string $key + * @return bool + * @static + */ public static function missing($key) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->missing($key); + } + /** + * Retrieve an item from the cache by key. + * + * @template TCacheValue + * @param array|string $key + * @param \Illuminate\Cache\TCacheValue|\Illuminate\Cache\(\Closure(): TCacheValue) $default + * @return \Illuminate\Cache\(TCacheValue is null ? mixed : TCacheValue) + * @static + */ public static function get($key, $default = null) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->get($key, $default); + } + /** + * Retrieve multiple items from the cache by key. + * + * Items not found in the cache will have a null value. + * + * @param array $keys + * @return array + * @static + */ public static function many($keys) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->many($keys); + } + /** + * Obtains multiple cache items by their unique keys. + * + * @return \Illuminate\Cache\iterable + * @param \Psr\SimpleCache\iterable $keys A list of keys that can be obtained in a single operation. + * @param mixed $default Default value to return for keys that do not exist. + * @return \Psr\SimpleCache\iterable A list of key => value pairs. Cache keys that do not exist or are stale will have $default as value. + * @throws \Psr\SimpleCache\InvalidArgumentException + * MUST be thrown if $keys is neither an array nor a Traversable, + * or if any of the $keys are not a legal value. + * @static + */ public static function getMultiple($keys, $default = null) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->getMultiple($keys, $default); + } + /** + * Retrieve an item from the cache and delete it. + * + * @template TCacheValue + * @param array|string $key + * @param \Illuminate\Cache\TCacheValue|\Illuminate\Cache\(\Closure(): TCacheValue) $default + * @return \Illuminate\Cache\(TCacheValue is null ? mixed : TCacheValue) + * @static + */ public static function pull($key, $default = null) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->pull($key, $default); + } + /** + * Store an item in the cache. + * + * @param array|string $key + * @param mixed $value + * @param \DateTimeInterface|\DateInterval|int|null $ttl + * @return bool + * @static + */ public static function put($key, $value, $ttl = null) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->put($key, $value, $ttl); + } + /** + * Persists data in the cache, uniquely referenced by a key with an optional expiration TTL time. + * + * @return bool + * @param string $key The key of the item to store. + * @param mixed $value The value of the item to store, must be serializable. + * @param null|int|\DateInterval $ttl Optional. The TTL value of this item. If no value is sent and + * the driver supports TTL then the library may set a default value + * for it or let the driver take care of that. + * @return bool True on success and false on failure. + * @throws \Psr\SimpleCache\InvalidArgumentException + * MUST be thrown if the $key string is not a legal value. + * @static + */ public static function set($key, $value, $ttl = null) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->set($key, $value, $ttl); + } + /** + * Store multiple items in the cache for a given number of seconds. + * + * @param array $values + * @param \DateTimeInterface|\DateInterval|int|null $ttl + * @return bool + * @static + */ public static function putMany($values, $ttl = null) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->putMany($values, $ttl); + } + /** + * Persists a set of key => value pairs in the cache, with an optional TTL. + * + * @return bool + * @param \Psr\SimpleCache\iterable $values A list of key => value pairs for a multiple-set operation. + * @param null|int|\DateInterval $ttl Optional. The TTL value of this item. If no value is sent and + * the driver supports TTL then the library may set a default value + * for it or let the driver take care of that. + * @return bool True on success and false on failure. + * @throws \Psr\SimpleCache\InvalidArgumentException + * MUST be thrown if $values is neither an array nor a Traversable, + * or if any of the $values are not a legal value. + * @static + */ public static function setMultiple($values, $ttl = null) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->setMultiple($values, $ttl); + } + /** + * Store an item in the cache if the key does not exist. + * + * @param string $key + * @param mixed $value + * @param \DateTimeInterface|\DateInterval|int|null $ttl + * @return bool + * @static + */ public static function add($key, $value, $ttl = null) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->add($key, $value, $ttl); + } + /** + * Increment the value of an item in the cache. + * + * @param string $key + * @param mixed $value + * @return int|bool + * @static + */ public static function increment($key, $value = 1) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->increment($key, $value); + } + /** + * Decrement the value of an item in the cache. + * + * @param string $key + * @param mixed $value + * @return int|bool + * @static + */ public static function decrement($key, $value = 1) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->decrement($key, $value); + } + /** + * Store an item in the cache indefinitely. + * + * @param string $key + * @param mixed $value + * @return bool + * @static + */ public static function forever($key, $value) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->forever($key, $value); + } + /** + * Get an item from the cache, or execute the given Closure and store the result. + * + * @template TCacheValue + * @param string $key + * @param \Closure|\DateTimeInterface|\DateInterval|int|null $ttl + * @param \Closure(): TCacheValue $callback + * @return \Illuminate\Cache\TCacheValue + * @static + */ public static function remember($key, $ttl, $callback) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->remember($key, $ttl, $callback); + } + /** + * Get an item from the cache, or execute the given Closure and store the result forever. + * + * @template TCacheValue + * @param string $key + * @param \Closure(): TCacheValue $callback + * @return \Illuminate\Cache\TCacheValue + * @static + */ public static function sear($key, $callback) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->sear($key, $callback); + } + /** + * Get an item from the cache, or execute the given Closure and store the result forever. + * + * @template TCacheValue + * @param string $key + * @param \Closure(): TCacheValue $callback + * @return \Illuminate\Cache\TCacheValue + * @static + */ public static function rememberForever($key, $callback) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->rememberForever($key, $callback); + } + /** + * Remove an item from the cache. + * + * @param string $key + * @return bool + * @static + */ public static function forget($key) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->forget($key); + } + /** + * Delete an item from the cache by its unique key. + * + * @return bool + * @param string $key The unique cache key of the item to delete. + * @return bool True if the item was successfully removed. False if there was an error. + * @throws \Psr\SimpleCache\InvalidArgumentException + * MUST be thrown if the $key string is not a legal value. + * @static + */ public static function delete($key) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->delete($key); + } + /** + * Deletes multiple cache items in a single operation. + * + * @return bool + * @param \Psr\SimpleCache\iterable $keys A list of string-based keys to be deleted. + * @return bool True if the items were successfully removed. False if there was an error. + * @throws \Psr\SimpleCache\InvalidArgumentException + * MUST be thrown if $keys is neither an array nor a Traversable, + * or if any of the $keys are not a legal value. + * @static + */ public static function deleteMultiple($keys) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->deleteMultiple($keys); + } + /** + * Wipes clean the entire cache's keys. + * + * @return bool + * @return bool True on success and false on failure. + * @static + */ public static function clear() + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->clear(); + } + /** + * Begin executing a new tags operation if the store supports it. + * + * @param array|mixed $names + * @return \Illuminate\Cache\TaggedCache + * @throws \BadMethodCallException + * @static + */ public static function tags($names) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->tags($names); + } + /** + * Determine if the current store supports tags. + * + * @return bool + * @static + */ public static function supportsTags() + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->supportsTags(); + } + /** + * Get the default cache time. + * + * @return int|null + * @static + */ public static function getDefaultCacheTime() + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->getDefaultCacheTime(); + } + /** + * Set the default cache time in seconds. + * + * @param int|null $seconds + * @return \Illuminate\Cache\Repository + * @static + */ public static function setDefaultCacheTime($seconds) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->setDefaultCacheTime($seconds); + } + /** + * Get the cache store implementation. + * + * @return \Illuminate\Contracts\Cache\Store + * @static + */ public static function getStore() + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->getStore(); + } + /** + * Set the cache store implementation. + * + * @param \Illuminate\Contracts\Cache\Store $store + * @return static + * @static + */ public static function setStore($store) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->setStore($store); + } + /** + * Get the event dispatcher instance. + * + * @return \Illuminate\Contracts\Events\Dispatcher|null + * @static + */ public static function getEventDispatcher() + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->getEventDispatcher(); + } + /** + * Set the event dispatcher instance. + * + * @param \Illuminate\Contracts\Events\Dispatcher $events + * @return void + * @static + */ public static function setEventDispatcher($events) + { + /** @var \Illuminate\Cache\Repository $instance */ + $instance->setEventDispatcher($events); + } + /** + * Determine if a cached value exists. + * + * @param string $key + * @return bool + * @static + */ public static function offsetExists($key) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->offsetExists($key); + } + /** + * Retrieve an item from the cache by key. + * + * @param string $key + * @return mixed + * @static + */ public static function offsetGet($key) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->offsetGet($key); + } + /** + * Store an item in the cache for the default time. + * + * @param string $key + * @param mixed $value + * @return void + * @static + */ public static function offsetSet($key, $value) + { + /** @var \Illuminate\Cache\Repository $instance */ + $instance->offsetSet($key, $value); + } + /** + * Remove an item from the cache. + * + * @param string $key + * @return void + * @static + */ public static function offsetUnset($key) + { + /** @var \Illuminate\Cache\Repository $instance */ + $instance->offsetUnset($key); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Cache\Repository::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Cache\Repository::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Cache\Repository::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Cache\Repository::flushMacros(); + } + /** + * Dynamically handle calls to the class. + * + * @param string $method + * @param array $parameters + * @return mixed + * @throws \BadMethodCallException + * @static + */ public static function macroCall($method, $parameters) + { + /** @var \Illuminate\Cache\Repository $instance */ + return $instance->macroCall($method, $parameters); + } + /** + * Get a lock instance. + * + * @param string $name + * @param int $seconds + * @param string|null $owner + * @return \Illuminate\Contracts\Cache\Lock + * @static + */ public static function lock($name, $seconds = 0, $owner = null) + { + /** @var \Illuminate\Cache\DatabaseStore $instance */ + return $instance->lock($name, $seconds, $owner); + } + /** + * Restore a lock instance using the owner identifier. + * + * @param string $name + * @param string $owner + * @return \Illuminate\Contracts\Cache\Lock + * @static + */ public static function restoreLock($name, $owner) + { + /** @var \Illuminate\Cache\DatabaseStore $instance */ + return $instance->restoreLock($name, $owner); + } + /** + * Remove an item from the cache if it is expired. + * + * @param string $key + * @return bool + * @static + */ public static function forgetIfExpired($key) + { + /** @var \Illuminate\Cache\DatabaseStore $instance */ + return $instance->forgetIfExpired($key); + } + /** + * Remove all items from the cache. + * + * @return bool + * @static + */ public static function flush() + { + /** @var \Illuminate\Cache\DatabaseStore $instance */ + return $instance->flush(); + } + /** + * Get the underlying database connection. + * + * @return \Illuminate\Database\SQLiteConnection + * @static + */ public static function getConnection() + { + /** @var \Illuminate\Cache\DatabaseStore $instance */ + return $instance->getConnection(); + } + /** + * Specify the name of the connection that should be used to manage locks. + * + * @param \Illuminate\Database\ConnectionInterface $connection + * @return \Illuminate\Cache\DatabaseStore + * @static + */ public static function setLockConnection($connection) + { + /** @var \Illuminate\Cache\DatabaseStore $instance */ + return $instance->setLockConnection($connection); + } + /** + * Get the cache key prefix. + * + * @return string + * @static + */ public static function getPrefix() + { + /** @var \Illuminate\Cache\DatabaseStore $instance */ + return $instance->getPrefix(); + } + /** + * Set the cache key prefix. + * + * @param string $prefix + * @return void + * @static + */ public static function setPrefix($prefix) + { + /** @var \Illuminate\Cache\DatabaseStore $instance */ + $instance->setPrefix($prefix); + } + } + /** + * + * + * @see \Illuminate\Config\Repository + */ class Config { + /** + * Determine if the given configuration value exists. + * + * @param string $key + * @return bool + * @static + */ public static function has($key) + { + /** @var \Illuminate\Config\Repository $instance */ + return $instance->has($key); + } + /** + * Get the specified configuration value. + * + * @param array|string $key + * @param mixed $default + * @return mixed + * @static + */ public static function get($key, $default = null) + { + /** @var \Illuminate\Config\Repository $instance */ + return $instance->get($key, $default); + } + /** + * Get many configuration values. + * + * @param array $keys + * @return array + * @static + */ public static function getMany($keys) + { + /** @var \Illuminate\Config\Repository $instance */ + return $instance->getMany($keys); + } + /** + * Get the specified string configuration value. + * + * @param string $key + * @param \Illuminate\Config\(\Closure():(string|\Illuminate\Config\null))|string|null $default + * @return string + * @static + */ public static function string($key, $default = null) + { + /** @var \Illuminate\Config\Repository $instance */ + return $instance->string($key, $default); + } + /** + * Get the specified integer configuration value. + * + * @param string $key + * @param \Illuminate\Config\(\Closure():(int|\Illuminate\Config\null))|int|null $default + * @return int + * @static + */ public static function integer($key, $default = null) + { + /** @var \Illuminate\Config\Repository $instance */ + return $instance->integer($key, $default); + } + /** + * Get the specified float configuration value. + * + * @param string $key + * @param \Illuminate\Config\(\Closure():(float|\Illuminate\Config\null))|float|null $default + * @return float + * @static + */ public static function float($key, $default = null) + { + /** @var \Illuminate\Config\Repository $instance */ + return $instance->float($key, $default); + } + /** + * Get the specified boolean configuration value. + * + * @param string $key + * @param \Illuminate\Config\(\Closure():(bool|\Illuminate\Config\null))|bool|null $default + * @return bool + * @static + */ public static function boolean($key, $default = null) + { + /** @var \Illuminate\Config\Repository $instance */ + return $instance->boolean($key, $default); + } + /** + * Get the specified array configuration value. + * + * @param string $key + * @param \Illuminate\Config\(\Closure():(array|\Illuminate\Config\null))|\Illuminate\Config\array|null $default + * @return array + * @static + */ public static function array($key, $default = null) + { + /** @var \Illuminate\Config\Repository $instance */ + return $instance->array($key, $default); + } + /** + * Set a given configuration value. + * + * @param array|string $key + * @param mixed $value + * @return void + * @static + */ public static function set($key, $value = null) + { + /** @var \Illuminate\Config\Repository $instance */ + $instance->set($key, $value); + } + /** + * Prepend a value onto an array configuration value. + * + * @param string $key + * @param mixed $value + * @return void + * @static + */ public static function prepend($key, $value) + { + /** @var \Illuminate\Config\Repository $instance */ + $instance->prepend($key, $value); + } + /** + * Push a value onto an array configuration value. + * + * @param string $key + * @param mixed $value + * @return void + * @static + */ public static function push($key, $value) + { + /** @var \Illuminate\Config\Repository $instance */ + $instance->push($key, $value); + } + /** + * Get all of the configuration items for the application. + * + * @return array + * @static + */ public static function all() + { + /** @var \Illuminate\Config\Repository $instance */ + return $instance->all(); + } + /** + * Determine if the given configuration option exists. + * + * @param string $key + * @return bool + * @static + */ public static function offsetExists($key) + { + /** @var \Illuminate\Config\Repository $instance */ + return $instance->offsetExists($key); + } + /** + * Get a configuration option. + * + * @param string $key + * @return mixed + * @static + */ public static function offsetGet($key) + { + /** @var \Illuminate\Config\Repository $instance */ + return $instance->offsetGet($key); + } + /** + * Set a configuration option. + * + * @param string $key + * @param mixed $value + * @return void + * @static + */ public static function offsetSet($key, $value) + { + /** @var \Illuminate\Config\Repository $instance */ + $instance->offsetSet($key, $value); + } + /** + * Unset a configuration option. + * + * @param string $key + * @return void + * @static + */ public static function offsetUnset($key) + { + /** @var \Illuminate\Config\Repository $instance */ + $instance->offsetUnset($key); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Config\Repository::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Config\Repository::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Config\Repository::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Config\Repository::flushMacros(); + } + } + /** + * + * + * @see \Illuminate\Log\Context\Repository + */ class Context { + /** + * Determine if the given key exists. + * + * @param string $key + * @return bool + * @static + */ public static function has($key) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->has($key); + } + /** + * Determine if the given key exists within the hidden context data. + * + * @param string $key + * @return bool + * @static + */ public static function hasHidden($key) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->hasHidden($key); + } + /** + * Retrieve all the context data. + * + * @return array + * @static + */ public static function all() + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->all(); + } + /** + * Retrieve all the hidden context data. + * + * @return array + * @static + */ public static function allHidden() + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->allHidden(); + } + /** + * Retrieve the given key's value. + * + * @param string $key + * @param mixed $default + * @return mixed + * @static + */ public static function get($key, $default = null) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->get($key, $default); + } + /** + * Retrieve the given key's hidden value. + * + * @param string $key + * @param mixed $default + * @return mixed + * @static + */ public static function getHidden($key, $default = null) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->getHidden($key, $default); + } + /** + * Retrieve the given key's value and then forget it. + * + * @param string $key + * @param mixed $default + * @return mixed + * @static + */ public static function pull($key, $default = null) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->pull($key, $default); + } + /** + * Retrieve the given key's hidden value and then forget it. + * + * @param string $key + * @param mixed $default + * @return mixed + * @static + */ public static function pullHidden($key, $default = null) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->pullHidden($key, $default); + } + /** + * Retrieve only the values of the given keys. + * + * @param array $keys + * @return array + * @static + */ public static function only($keys) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->only($keys); + } + /** + * Retrieve only the hidden values of the given keys. + * + * @param array $keys + * @return array + * @static + */ public static function onlyHidden($keys) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->onlyHidden($keys); + } + /** + * Add a context value. + * + * @param string|array $key + * @param mixed $value + * @return \Illuminate\Log\Context\Repository + * @static + */ public static function add($key, $value = null) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->add($key, $value); + } + /** + * Add a hidden context value. + * + * @param string|array $key + * @param mixed $value + * @return \Illuminate\Log\Context\Repository + * @static + */ public static function addHidden($key, $value = null) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->addHidden($key, $value); + } + /** + * Forget the given context key. + * + * @param string|array $key + * @return \Illuminate\Log\Context\Repository + * @static + */ public static function forget($key) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->forget($key); + } + /** + * Forget the given hidden context key. + * + * @param string|array $key + * @return \Illuminate\Log\Context\Repository + * @static + */ public static function forgetHidden($key) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->forgetHidden($key); + } + /** + * Add a context value if it does not exist yet. + * + * @param string $key + * @param mixed $value + * @return \Illuminate\Log\Context\Repository + * @static + */ public static function addIf($key, $value) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->addIf($key, $value); + } + /** + * Add a hidden context value if it does not exist yet. + * + * @param string $key + * @param mixed $value + * @return \Illuminate\Log\Context\Repository + * @static + */ public static function addHiddenIf($key, $value) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->addHiddenIf($key, $value); + } + /** + * Push the given values onto the key's stack. + * + * @param string $key + * @param mixed $values + * @return \Illuminate\Log\Context\Repository + * @throws \RuntimeException + * @static + */ public static function push($key, ...$values) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->push($key, ...$values); + } + /** + * Push the given hidden values onto the key's stack. + * + * @param string $key + * @param mixed $values + * @return \Illuminate\Log\Context\Repository + * @throws \RuntimeException + * @static + */ public static function pushHidden($key, ...$values) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->pushHidden($key, ...$values); + } + /** + * Determine if the given value is in the given stack. + * + * @param string $key + * @param mixed $value + * @param bool $strict + * @return bool + * @throws \RuntimeException + * @static + */ public static function stackContains($key, $value, $strict = false) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->stackContains($key, $value, $strict); + } + /** + * Determine if the given value is in the given hidden stack. + * + * @param string $key + * @param mixed $value + * @param bool $strict + * @return bool + * @throws \RuntimeException + * @static + */ public static function hiddenStackContains($key, $value, $strict = false) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->hiddenStackContains($key, $value, $strict); + } + /** + * Determine if the repository is empty. + * + * @return bool + * @static + */ public static function isEmpty() + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->isEmpty(); + } + /** + * Execute the given callback when context is about to be dehydrated. + * + * @param callable $callback + * @return \Illuminate\Log\Context\Repository + * @static + */ public static function dehydrating($callback) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->dehydrating($callback); + } + /** + * Execute the given callback when context has been hydrated. + * + * @param callable $callback + * @return \Illuminate\Log\Context\Repository + * @static + */ public static function hydrated($callback) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->hydrated($callback); + } + /** + * Handle unserialize exceptions using the given callback. + * + * @param callable|null $callback + * @return static + * @static + */ public static function handleUnserializeExceptionsUsing($callback) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->handleUnserializeExceptionsUsing($callback); + } + /** + * Flush all context data. + * + * @return \Illuminate\Log\Context\Repository + * @static + */ public static function flush() + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->flush(); + } + /** + * Dehydrate the context data. + * + * @internal + * @return \Illuminate\Log\Context\?array + * @static + */ public static function dehydrate() + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->dehydrate(); + } + /** + * Hydrate the context instance. + * + * @internal + * @param \Illuminate\Log\Context\?array $context + * @return \Illuminate\Log\Context\Repository + * @throws \RuntimeException + * @static + */ public static function hydrate($context) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->hydrate($context); + } + /** + * Apply the callback if the given "value" is (or resolves to) truthy. + * + * @template TWhenParameter + * @template TWhenReturnType + * @param \Illuminate\Log\Context\(\Closure($this): TWhenParameter)|TWhenParameter|null $value + * @param \Illuminate\Log\Context\(callable($this, TWhenParameter): TWhenReturnType)|null $callback + * @param \Illuminate\Log\Context\(callable($this, TWhenParameter): TWhenReturnType)|null $default + * @return $this|\Illuminate\Log\Context\TWhenReturnType + * @static + */ public static function when($value = null, $callback = null, $default = null) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->when($value, $callback, $default); + } + /** + * Apply the callback if the given "value" is (or resolves to) falsy. + * + * @template TUnlessParameter + * @template TUnlessReturnType + * @param \Illuminate\Log\Context\(\Closure($this): TUnlessParameter)|TUnlessParameter|null $value + * @param \Illuminate\Log\Context\(callable($this, TUnlessParameter): TUnlessReturnType)|null $callback + * @param \Illuminate\Log\Context\(callable($this, TUnlessParameter): TUnlessReturnType)|null $default + * @return $this|\Illuminate\Log\Context\TUnlessReturnType + * @static + */ public static function unless($value = null, $callback = null, $default = null) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->unless($value, $callback, $default); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Log\Context\Repository::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Log\Context\Repository::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Log\Context\Repository::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Log\Context\Repository::flushMacros(); + } + /** + * Restore the model from the model identifier instance. + * + * @param \Illuminate\Contracts\Database\ModelIdentifier $value + * @return \Illuminate\Database\Eloquent\Model + * @static + */ public static function restoreModel($value) + { + /** @var \Illuminate\Log\Context\Repository $instance */ + return $instance->restoreModel($value); + } + } + /** + * + * + * @see \Illuminate\Cookie\CookieJar + */ class Cookie { + /** + * Create a new cookie instance. + * + * @param string $name + * @param string $value + * @param int $minutes + * @param string|null $path + * @param string|null $domain + * @param bool|null $secure + * @param bool $httpOnly + * @param bool $raw + * @param string|null $sameSite + * @return \Symfony\Component\HttpFoundation\Cookie + * @static + */ public static function make($name, $value, $minutes = 0, $path = null, $domain = null, $secure = null, $httpOnly = true, $raw = false, $sameSite = null) + { + /** @var \Illuminate\Cookie\CookieJar $instance */ + return $instance->make($name, $value, $minutes, $path, $domain, $secure, $httpOnly, $raw, $sameSite); + } + /** + * Create a cookie that lasts "forever" (400 days). + * + * @param string $name + * @param string $value + * @param string|null $path + * @param string|null $domain + * @param bool|null $secure + * @param bool $httpOnly + * @param bool $raw + * @param string|null $sameSite + * @return \Symfony\Component\HttpFoundation\Cookie + * @static + */ public static function forever($name, $value, $path = null, $domain = null, $secure = null, $httpOnly = true, $raw = false, $sameSite = null) + { + /** @var \Illuminate\Cookie\CookieJar $instance */ + return $instance->forever($name, $value, $path, $domain, $secure, $httpOnly, $raw, $sameSite); + } + /** + * Expire the given cookie. + * + * @param string $name + * @param string|null $path + * @param string|null $domain + * @return \Symfony\Component\HttpFoundation\Cookie + * @static + */ public static function forget($name, $path = null, $domain = null) + { + /** @var \Illuminate\Cookie\CookieJar $instance */ + return $instance->forget($name, $path, $domain); + } + /** + * Determine if a cookie has been queued. + * + * @param string $key + * @param string|null $path + * @return bool + * @static + */ public static function hasQueued($key, $path = null) + { + /** @var \Illuminate\Cookie\CookieJar $instance */ + return $instance->hasQueued($key, $path); + } + /** + * Get a queued cookie instance. + * + * @param string $key + * @param mixed $default + * @param string|null $path + * @return \Symfony\Component\HttpFoundation\Cookie|null + * @static + */ public static function queued($key, $default = null, $path = null) + { + /** @var \Illuminate\Cookie\CookieJar $instance */ + return $instance->queued($key, $default, $path); + } + /** + * Queue a cookie to send with the next response. + * + * @param mixed $parameters + * @return void + * @static + */ public static function queue(...$parameters) + { + /** @var \Illuminate\Cookie\CookieJar $instance */ + $instance->queue(...$parameters); + } + /** + * Queue a cookie to expire with the next response. + * + * @param string $name + * @param string|null $path + * @param string|null $domain + * @return void + * @static + */ public static function expire($name, $path = null, $domain = null) + { + /** @var \Illuminate\Cookie\CookieJar $instance */ + $instance->expire($name, $path, $domain); + } + /** + * Remove a cookie from the queue. + * + * @param string $name + * @param string|null $path + * @return void + * @static + */ public static function unqueue($name, $path = null) + { + /** @var \Illuminate\Cookie\CookieJar $instance */ + $instance->unqueue($name, $path); + } + /** + * Set the default path and domain for the jar. + * + * @param string $path + * @param string|null $domain + * @param bool|null $secure + * @param string|null $sameSite + * @return \Illuminate\Cookie\CookieJar + * @static + */ public static function setDefaultPathAndDomain($path, $domain, $secure = false, $sameSite = null) + { + /** @var \Illuminate\Cookie\CookieJar $instance */ + return $instance->setDefaultPathAndDomain($path, $domain, $secure, $sameSite); + } + /** + * Get the cookies which have been queued for the next request. + * + * @return \Symfony\Component\HttpFoundation\Cookie[] + * @static + */ public static function getQueuedCookies() + { + /** @var \Illuminate\Cookie\CookieJar $instance */ + return $instance->getQueuedCookies(); + } + /** + * Flush the cookies which have been queued for the next request. + * + * @return \Illuminate\Cookie\CookieJar + * @static + */ public static function flushQueuedCookies() + { + /** @var \Illuminate\Cookie\CookieJar $instance */ + return $instance->flushQueuedCookies(); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Cookie\CookieJar::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Cookie\CookieJar::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Cookie\CookieJar::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Cookie\CookieJar::flushMacros(); + } + } + /** + * + * + * @see https://carbon.nesbot.com/docs/ + * @see https://github.com/briannesbitt/Carbon/blob/master/src/Carbon/Factory.php + * @method static \Illuminate\Support\Carbon create($year = 0, $month = 1, $day = 1, $hour = 0, $minute = 0, $second = 0, $tz = null) + * @method static \Illuminate\Support\Carbon createFromDate($year = null, $month = null, $day = null, $tz = null) + * @method static \Illuminate\Support\Carbon|false createFromFormat($format, $time, $tz = null) + * @method static \Illuminate\Support\Carbon createFromTime($hour = 0, $minute = 0, $second = 0, $tz = null) + * @method static \Illuminate\Support\Carbon createFromTimeString($time, $tz = null) + * @method static \Illuminate\Support\Carbon createFromTimestamp($timestamp, $tz = null) + * @method static \Illuminate\Support\Carbon createFromTimestampMs($timestamp, $tz = null) + * @method static \Illuminate\Support\Carbon createFromTimestampUTC($timestamp) + * @method static \Illuminate\Support\Carbon createMidnightDate($year = null, $month = null, $day = null, $tz = null) + * @method static \Illuminate\Support\Carbon|false createSafe($year = null, $month = null, $day = null, $hour = null, $minute = null, $second = null, $tz = null) + * @method static void disableHumanDiffOption($humanDiffOption) + * @method static void enableHumanDiffOption($humanDiffOption) + * @method static mixed executeWithLocale($locale, $func) + * @method static \Illuminate\Support\Carbon fromSerialized($value) + * @method static array getAvailableLocales() + * @method static array getDays() + * @method static int getHumanDiffOptions() + * @method static array getIsoUnits() + * @method static array getLastErrors() + * @method static string getLocale() + * @method static int getMidDayAt() + * @method static \Illuminate\Support\Carbon|null getTestNow() + * @method static \Symfony\Component\Translation\TranslatorInterface getTranslator() + * @method static int getWeekEndsAt() + * @method static int getWeekStartsAt() + * @method static array getWeekendDays() + * @method static bool hasFormat($date, $format) + * @method static bool hasMacro($name) + * @method static bool hasRelativeKeywords($time) + * @method static bool hasTestNow() + * @method static \Illuminate\Support\Carbon instance($date) + * @method static bool isImmutable() + * @method static bool isModifiableUnit($unit) + * @method static bool isMutable() + * @method static bool isStrictModeEnabled() + * @method static bool localeHasDiffOneDayWords($locale) + * @method static bool localeHasDiffSyntax($locale) + * @method static bool localeHasDiffTwoDayWords($locale) + * @method static bool localeHasPeriodSyntax($locale) + * @method static bool localeHasShortUnits($locale) + * @method static void macro($name, $macro) + * @method static \Illuminate\Support\Carbon|null make($var) + * @method static \Illuminate\Support\Carbon maxValue() + * @method static \Illuminate\Support\Carbon minValue() + * @method static void mixin($mixin) + * @method static \Illuminate\Support\Carbon now($tz = null) + * @method static \Illuminate\Support\Carbon parse($time = null, $tz = null) + * @method static string pluralUnit(string $unit) + * @method static void resetMonthsOverflow() + * @method static void resetToStringFormat() + * @method static void resetYearsOverflow() + * @method static void serializeUsing($callback) + * @method static void setHumanDiffOptions($humanDiffOptions) + * @method static bool setLocale($locale) + * @method static void setMidDayAt($hour) + * @method static void setTestNow($testNow = null) + * @method static void setToStringFormat($format) + * @method static void setTranslator(\Symfony\Component\Translation\TranslatorInterface $translator) + * @method static void setUtf8($utf8) + * @method static void setWeekEndsAt($day) + * @method static void setWeekStartsAt($day) + * @method static void setWeekendDays($days) + * @method static bool shouldOverflowMonths() + * @method static bool shouldOverflowYears() + * @method static string singularUnit(string $unit) + * @method static \Illuminate\Support\Carbon today($tz = null) + * @method static \Illuminate\Support\Carbon tomorrow($tz = null) + * @method static void useMonthsOverflow($monthsOverflow = true) + * @method static void useStrictMode($strictModeEnabled = true) + * @method static void useYearsOverflow($yearsOverflow = true) + * @method static \Illuminate\Support\Carbon yesterday($tz = null) + * @see \Illuminate\Support\DateFactory + */ class Date { + /** + * Use the given handler when generating dates (class name, callable, or factory). + * + * @param mixed $handler + * @return mixed + * @throws \InvalidArgumentException + * @static + */ public static function use($handler) + { + return \Illuminate\Support\DateFactory::use($handler); + } + /** + * Use the default date class when generating dates. + * + * @return void + * @static + */ public static function useDefault() + { + \Illuminate\Support\DateFactory::useDefault(); + } + /** + * Execute the given callable on each date creation. + * + * @param callable $callable + * @return void + * @static + */ public static function useCallable($callable) + { + \Illuminate\Support\DateFactory::useCallable($callable); + } + /** + * Use the given date type (class) when generating dates. + * + * @param string $dateClass + * @return void + * @static + */ public static function useClass($dateClass) + { + \Illuminate\Support\DateFactory::useClass($dateClass); + } + /** + * Use the given Carbon factory when generating dates. + * + * @param object $factory + * @return void + * @static + */ public static function useFactory($factory) + { + \Illuminate\Support\DateFactory::useFactory($factory); + } + } + /** + * + * + * @see \Illuminate\Database\DatabaseManager + */ class DB { + /** + * Get a database connection instance. + * + * @param string|null $name + * @return \Illuminate\Database\Connection + * @static + */ public static function connection($name = null) + { + /** @var \Illuminate\Database\DatabaseManager $instance */ + return $instance->connection($name); + } + /** + * Get a database connection instance from the given configuration. + * + * @param string $name + * @param array $config + * @param bool $force + * @return \Illuminate\Database\SQLiteConnection + * @static + */ public static function connectUsing($name, $config, $force = false) + { + /** @var \Illuminate\Database\DatabaseManager $instance */ + return $instance->connectUsing($name, $config, $force); + } + /** + * Disconnect from the given database and remove from local cache. + * + * @param string|null $name + * @return void + * @static + */ public static function purge($name = null) + { + /** @var \Illuminate\Database\DatabaseManager $instance */ + $instance->purge($name); + } + /** + * Disconnect from the given database. + * + * @param string|null $name + * @return void + * @static + */ public static function disconnect($name = null) + { + /** @var \Illuminate\Database\DatabaseManager $instance */ + $instance->disconnect($name); + } + /** + * Reconnect to the given database. + * + * @param string|null $name + * @return \Illuminate\Database\Connection + * @static + */ public static function reconnect($name = null) + { + /** @var \Illuminate\Database\DatabaseManager $instance */ + return $instance->reconnect($name); + } + /** + * Set the default database connection for the callback execution. + * + * @param string $name + * @param callable $callback + * @return mixed + * @static + */ public static function usingConnection($name, $callback) + { + /** @var \Illuminate\Database\DatabaseManager $instance */ + return $instance->usingConnection($name, $callback); + } + /** + * Get the default connection name. + * + * @return string + * @static + */ public static function getDefaultConnection() + { + /** @var \Illuminate\Database\DatabaseManager $instance */ + return $instance->getDefaultConnection(); + } + /** + * Set the default connection name. + * + * @param string $name + * @return void + * @static + */ public static function setDefaultConnection($name) + { + /** @var \Illuminate\Database\DatabaseManager $instance */ + $instance->setDefaultConnection($name); + } + /** + * Get all of the supported drivers. + * + * @return string[] + * @static + */ public static function supportedDrivers() + { + /** @var \Illuminate\Database\DatabaseManager $instance */ + return $instance->supportedDrivers(); + } + /** + * Get all of the drivers that are actually available. + * + * @return string[] + * @static + */ public static function availableDrivers() + { + /** @var \Illuminate\Database\DatabaseManager $instance */ + return $instance->availableDrivers(); + } + /** + * Register an extension connection resolver. + * + * @param string $name + * @param callable $resolver + * @return void + * @static + */ public static function extend($name, $resolver) + { + /** @var \Illuminate\Database\DatabaseManager $instance */ + $instance->extend($name, $resolver); + } + /** + * Remove an extension connection resolver. + * + * @param string $name + * @return void + * @static + */ public static function forgetExtension($name) + { + /** @var \Illuminate\Database\DatabaseManager $instance */ + $instance->forgetExtension($name); + } + /** + * Return all of the created connections. + * + * @return array + * @static + */ public static function getConnections() + { + /** @var \Illuminate\Database\DatabaseManager $instance */ + return $instance->getConnections(); + } + /** + * Set the database reconnector callback. + * + * @param callable $reconnector + * @return void + * @static + */ public static function setReconnector($reconnector) + { + /** @var \Illuminate\Database\DatabaseManager $instance */ + $instance->setReconnector($reconnector); + } + /** + * Set the application instance used by the manager. + * + * @param \Illuminate\Contracts\Foundation\Application $app + * @return \Illuminate\Database\DatabaseManager + * @static + */ public static function setApplication($app) + { + /** @var \Illuminate\Database\DatabaseManager $instance */ + return $instance->setApplication($app); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Database\DatabaseManager::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Database\DatabaseManager::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Database\DatabaseManager::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Database\DatabaseManager::flushMacros(); + } + /** + * Dynamically handle calls to the class. + * + * @param string $method + * @param array $parameters + * @return mixed + * @throws \BadMethodCallException + * @static + */ public static function macroCall($method, $parameters) + { + /** @var \Illuminate\Database\DatabaseManager $instance */ + return $instance->macroCall($method, $parameters); + } + /** + * Get a human-readable name for the given connection driver. + * + * @return string + * @static + */ public static function getDriverTitle() + { + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getDriverTitle(); + } + /** + * Get a schema builder instance for the connection. + * + * @return \Illuminate\Database\Schema\SQLiteBuilder + * @static + */ public static function getSchemaBuilder() + { + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getSchemaBuilder(); + } + /** + * Get the schema state for the connection. + * + * @param \Illuminate\Filesystem\Filesystem|null $files + * @param callable|null $processFactory + * @throws \RuntimeException + * @static + */ public static function getSchemaState($files = null, $processFactory = null) + { + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getSchemaState($files, $processFactory); + } + /** + * Set the query grammar to the default implementation. + * + * @return void + * @static + */ public static function useDefaultQueryGrammar() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->useDefaultQueryGrammar(); + } + /** + * Set the schema grammar to the default implementation. + * + * @return void + * @static + */ public static function useDefaultSchemaGrammar() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->useDefaultSchemaGrammar(); + } + /** + * Set the query post processor to the default implementation. + * + * @return void + * @static + */ public static function useDefaultPostProcessor() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->useDefaultPostProcessor(); + } + /** + * Begin a fluent query against a database table. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Contracts\Database\Query\Expression|string $table + * @param string|null $as + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function table($table, $as = null) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->table($table, $as); + } + /** + * Get a new query builder instance. + * + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function query() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->query(); + } + /** + * Run a select statement and return a single result. + * + * @param string $query + * @param array $bindings + * @param bool $useReadPdo + * @return mixed + * @static + */ public static function selectOne($query, $bindings = [], $useReadPdo = true) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->selectOne($query, $bindings, $useReadPdo); + } + /** + * Run a select statement and return the first column of the first row. + * + * @param string $query + * @param array $bindings + * @param bool $useReadPdo + * @return mixed + * @throws \Illuminate\Database\MultipleColumnsSelectedException + * @static + */ public static function scalar($query, $bindings = [], $useReadPdo = true) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->scalar($query, $bindings, $useReadPdo); + } + /** + * Run a select statement against the database. + * + * @param string $query + * @param array $bindings + * @return array + * @static + */ public static function selectFromWriteConnection($query, $bindings = []) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->selectFromWriteConnection($query, $bindings); + } + /** + * Run a select statement against the database. + * + * @param string $query + * @param array $bindings + * @param bool $useReadPdo + * @return array + * @static + */ public static function select($query, $bindings = [], $useReadPdo = true) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->select($query, $bindings, $useReadPdo); + } + /** + * Run a select statement against the database and returns all of the result sets. + * + * @param string $query + * @param array $bindings + * @param bool $useReadPdo + * @return array + * @static + */ public static function selectResultSets($query, $bindings = [], $useReadPdo = true) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->selectResultSets($query, $bindings, $useReadPdo); + } + /** + * Run a select statement against the database and returns a generator. + * + * @param string $query + * @param array $bindings + * @param bool $useReadPdo + * @return \Generator + * @static + */ public static function cursor($query, $bindings = [], $useReadPdo = true) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->cursor($query, $bindings, $useReadPdo); + } + /** + * Run an insert statement against the database. + * + * @param string $query + * @param array $bindings + * @return bool + * @static + */ public static function insert($query, $bindings = []) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->insert($query, $bindings); + } + /** + * Run an update statement against the database. + * + * @param string $query + * @param array $bindings + * @return int + * @static + */ public static function update($query, $bindings = []) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->update($query, $bindings); + } + /** + * Run a delete statement against the database. + * + * @param string $query + * @param array $bindings + * @return int + * @static + */ public static function delete($query, $bindings = []) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->delete($query, $bindings); + } + /** + * Execute an SQL statement and return the boolean result. + * + * @param string $query + * @param array $bindings + * @return bool + * @static + */ public static function statement($query, $bindings = []) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->statement($query, $bindings); + } + /** + * Run an SQL statement and get the number of rows affected. + * + * @param string $query + * @param array $bindings + * @return int + * @static + */ public static function affectingStatement($query, $bindings = []) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->affectingStatement($query, $bindings); + } + /** + * Run a raw, unprepared query against the PDO connection. + * + * @param string $query + * @return bool + * @static + */ public static function unprepared($query) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->unprepared($query); + } + /** + * Get the number of open connections for the database. + * + * @return int|null + * @static + */ public static function threadCount() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->threadCount(); + } + /** + * Execute the given callback in "dry run" mode. + * + * @param \Closure $callback + * @return array + * @static + */ public static function pretend($callback) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->pretend($callback); + } + /** + * Execute the given callback without "pretending". + * + * @param \Closure $callback + * @return mixed + * @static + */ public static function withoutPretending($callback) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->withoutPretending($callback); + } + /** + * Bind values to their parameters in the given statement. + * + * @param \PDOStatement $statement + * @param array $bindings + * @return void + * @static + */ public static function bindValues($statement, $bindings) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->bindValues($statement, $bindings); + } + /** + * Prepare the query bindings for execution. + * + * @param array $bindings + * @return array + * @static + */ public static function prepareBindings($bindings) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->prepareBindings($bindings); + } + /** + * Log a query in the connection's query log. + * + * @param string $query + * @param array $bindings + * @param float|null $time + * @return void + * @static + */ public static function logQuery($query, $bindings, $time = null) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->logQuery($query, $bindings, $time); + } + /** + * Register a callback to be invoked when the connection queries for longer than a given amount of time. + * + * @param \DateTimeInterface|\Carbon\CarbonInterval|float|int $threshold + * @param callable $handler + * @return void + * @static + */ public static function whenQueryingForLongerThan($threshold, $handler) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->whenQueryingForLongerThan($threshold, $handler); + } + /** + * Allow all the query duration handlers to run again, even if they have already run. + * + * @return void + * @static + */ public static function allowQueryDurationHandlersToRunAgain() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->allowQueryDurationHandlersToRunAgain(); + } + /** + * Get the duration of all run queries in milliseconds. + * + * @return float + * @static + */ public static function totalQueryDuration() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->totalQueryDuration(); + } + /** + * Reset the duration of all run queries. + * + * @return void + * @static + */ public static function resetTotalQueryDuration() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->resetTotalQueryDuration(); + } + /** + * Reconnect to the database if a PDO connection is missing. + * + * @return void + * @static + */ public static function reconnectIfMissingConnection() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->reconnectIfMissingConnection(); + } + /** + * Register a hook to be run just before a database transaction is started. + * + * @param \Closure $callback + * @return \Illuminate\Database\SQLiteConnection + * @static + */ public static function beforeStartingTransaction($callback) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->beforeStartingTransaction($callback); + } + /** + * Register a hook to be run just before a database query is executed. + * + * @param \Closure $callback + * @return \Illuminate\Database\SQLiteConnection + * @static + */ public static function beforeExecuting($callback) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->beforeExecuting($callback); + } + /** + * Register a database query listener with the connection. + * + * @param \Closure $callback + * @return void + * @static + */ public static function listen($callback) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->listen($callback); + } + /** + * Get a new raw query expression. + * + * @param mixed $value + * @return \Illuminate\Contracts\Database\Query\Expression + * @static + */ public static function raw($value) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->raw($value); + } + /** + * Escape a value for safe SQL embedding. + * + * @param string|float|int|bool|null $value + * @param bool $binary + * @return string + * @static + */ public static function escape($value, $binary = false) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->escape($value, $binary); + } + /** + * Determine if the database connection has modified any database records. + * + * @return bool + * @static + */ public static function hasModifiedRecords() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->hasModifiedRecords(); + } + /** + * Indicate if any records have been modified. + * + * @param bool $value + * @return void + * @static + */ public static function recordsHaveBeenModified($value = true) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->recordsHaveBeenModified($value); + } + /** + * Set the record modification state. + * + * @param bool $value + * @return \Illuminate\Database\SQLiteConnection + * @static + */ public static function setRecordModificationState($value) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->setRecordModificationState($value); + } + /** + * Reset the record modification state. + * + * @return void + * @static + */ public static function forgetRecordModificationState() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->forgetRecordModificationState(); + } + /** + * Indicate that the connection should use the write PDO connection for reads. + * + * @param bool $value + * @return \Illuminate\Database\SQLiteConnection + * @static + */ public static function useWriteConnectionWhenReading($value = true) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->useWriteConnectionWhenReading($value); + } + /** + * Get the current PDO connection. + * + * @return \PDO + * @static + */ public static function getPdo() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getPdo(); + } + /** + * Get the current PDO connection parameter without executing any reconnect logic. + * + * @return \PDO|\Closure|null + * @static + */ public static function getRawPdo() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getRawPdo(); + } + /** + * Get the current PDO connection used for reading. + * + * @return \PDO + * @static + */ public static function getReadPdo() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getReadPdo(); + } + /** + * Get the current read PDO connection parameter without executing any reconnect logic. + * + * @return \PDO|\Closure|null + * @static + */ public static function getRawReadPdo() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getRawReadPdo(); + } + /** + * Set the PDO connection. + * + * @param \PDO|\Closure|null $pdo + * @return \Illuminate\Database\SQLiteConnection + * @static + */ public static function setPdo($pdo) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->setPdo($pdo); + } + /** + * Set the PDO connection used for reading. + * + * @param \PDO|\Closure|null $pdo + * @return \Illuminate\Database\SQLiteConnection + * @static + */ public static function setReadPdo($pdo) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->setReadPdo($pdo); + } + /** + * Get the database connection name. + * + * @return string|null + * @static + */ public static function getName() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getName(); + } + /** + * Get the database connection full name. + * + * @return string|null + * @static + */ public static function getNameWithReadWriteType() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getNameWithReadWriteType(); + } + /** + * Get an option from the configuration options. + * + * @param string|null $option + * @return mixed + * @static + */ public static function getConfig($option = null) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getConfig($option); + } + /** + * Get the PDO driver name. + * + * @return string + * @static + */ public static function getDriverName() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getDriverName(); + } + /** + * Get the query grammar used by the connection. + * + * @return \Illuminate\Database\Query\Grammars\Grammar + * @static + */ public static function getQueryGrammar() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getQueryGrammar(); + } + /** + * Set the query grammar used by the connection. + * + * @param \Illuminate\Database\Query\Grammars\Grammar $grammar + * @return \Illuminate\Database\SQLiteConnection + * @static + */ public static function setQueryGrammar($grammar) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->setQueryGrammar($grammar); + } + /** + * Get the schema grammar used by the connection. + * + * @return \Illuminate\Database\Schema\Grammars\Grammar + * @static + */ public static function getSchemaGrammar() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getSchemaGrammar(); + } + /** + * Set the schema grammar used by the connection. + * + * @param \Illuminate\Database\Schema\Grammars\Grammar $grammar + * @return \Illuminate\Database\SQLiteConnection + * @static + */ public static function setSchemaGrammar($grammar) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->setSchemaGrammar($grammar); + } + /** + * Get the query post processor used by the connection. + * + * @return \Illuminate\Database\Query\Processors\Processor + * @static + */ public static function getPostProcessor() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getPostProcessor(); + } + /** + * Set the query post processor used by the connection. + * + * @param \Illuminate\Database\Query\Processors\Processor $processor + * @return \Illuminate\Database\SQLiteConnection + * @static + */ public static function setPostProcessor($processor) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->setPostProcessor($processor); + } + /** + * Get the event dispatcher used by the connection. + * + * @return \Illuminate\Contracts\Events\Dispatcher + * @static + */ public static function getEventDispatcher() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getEventDispatcher(); + } + /** + * Set the event dispatcher instance on the connection. + * + * @param \Illuminate\Contracts\Events\Dispatcher $events + * @return \Illuminate\Database\SQLiteConnection + * @static + */ public static function setEventDispatcher($events) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->setEventDispatcher($events); + } + /** + * Unset the event dispatcher for this connection. + * + * @return void + * @static + */ public static function unsetEventDispatcher() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->unsetEventDispatcher(); + } + /** + * Set the transaction manager instance on the connection. + * + * @param \Illuminate\Database\DatabaseTransactionsManager $manager + * @return \Illuminate\Database\SQLiteConnection + * @static + */ public static function setTransactionManager($manager) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->setTransactionManager($manager); + } + /** + * Unset the transaction manager for this connection. + * + * @return void + * @static + */ public static function unsetTransactionManager() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->unsetTransactionManager(); + } + /** + * Determine if the connection is in a "dry run". + * + * @return bool + * @static + */ public static function pretending() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->pretending(); + } + /** + * Get the connection query log. + * + * @return array + * @static + */ public static function getQueryLog() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getQueryLog(); + } + /** + * Get the connection query log with embedded bindings. + * + * @return array + * @static + */ public static function getRawQueryLog() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getRawQueryLog(); + } + /** + * Clear the query log. + * + * @return void + * @static + */ public static function flushQueryLog() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->flushQueryLog(); + } + /** + * Enable the query log on the connection. + * + * @return void + * @static + */ public static function enableQueryLog() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->enableQueryLog(); + } + /** + * Disable the query log on the connection. + * + * @return void + * @static + */ public static function disableQueryLog() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->disableQueryLog(); + } + /** + * Determine whether we're logging queries. + * + * @return bool + * @static + */ public static function logging() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->logging(); + } + /** + * Get the name of the connected database. + * + * @return string + * @static + */ public static function getDatabaseName() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getDatabaseName(); + } + /** + * Set the name of the connected database. + * + * @param string $database + * @return \Illuminate\Database\SQLiteConnection + * @static + */ public static function setDatabaseName($database) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->setDatabaseName($database); + } + /** + * Set the read / write type of the connection. + * + * @param string|null $readWriteType + * @return \Illuminate\Database\SQLiteConnection + * @static + */ public static function setReadWriteType($readWriteType) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->setReadWriteType($readWriteType); + } + /** + * Get the table prefix for the connection. + * + * @return string + * @static + */ public static function getTablePrefix() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getTablePrefix(); + } + /** + * Set the table prefix in use by the connection. + * + * @param string $prefix + * @return \Illuminate\Database\SQLiteConnection + * @static + */ public static function setTablePrefix($prefix) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->setTablePrefix($prefix); + } + /** + * Set the table prefix and return the grammar. + * + * @param \Illuminate\Database\Grammar $grammar + * @return \Illuminate\Database\Grammar + * @static + */ public static function withTablePrefix($grammar) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->withTablePrefix($grammar); + } + /** + * Get the server version for the connection. + * + * @return string + * @static + */ public static function getServerVersion() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->getServerVersion(); + } + /** + * Register a connection resolver. + * + * @param string $driver + * @param \Closure $callback + * @return void + * @static + */ public static function resolverFor($driver, $callback) + { //Method inherited from \Illuminate\Database\Connection + \Illuminate\Database\SQLiteConnection::resolverFor($driver, $callback); + } + /** + * Get the connection resolver for the given driver. + * + * @param string $driver + * @return mixed + * @static + */ public static function getResolver($driver) + { //Method inherited from \Illuminate\Database\Connection + return \Illuminate\Database\SQLiteConnection::getResolver($driver); + } + /** + * Execute a Closure within a transaction. + * + * @param \Closure $callback + * @param int $attempts + * @return mixed + * @throws \Throwable + * @static + */ public static function transaction($callback, $attempts = 1) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->transaction($callback, $attempts); + } + /** + * Start a new database transaction. + * + * @return void + * @throws \Throwable + * @static + */ public static function beginTransaction() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->beginTransaction(); + } + /** + * Commit the active database transaction. + * + * @return void + * @throws \Throwable + * @static + */ public static function commit() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->commit(); + } + /** + * Rollback the active database transaction. + * + * @param int|null $toLevel + * @return void + * @throws \Throwable + * @static + */ public static function rollBack($toLevel = null) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->rollBack($toLevel); + } + /** + * Get the number of active transactions. + * + * @return int + * @static + */ public static function transactionLevel() + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + return $instance->transactionLevel(); + } + /** + * Execute the callback after a transaction commits. + * + * @param callable $callback + * @return void + * @throws \RuntimeException + * @static + */ public static function afterCommit($callback) + { //Method inherited from \Illuminate\Database\Connection + /** @var \Illuminate\Database\SQLiteConnection $instance */ + $instance->afterCommit($callback); + } + } + /** + * + * + * @see \Illuminate\Events\Dispatcher + * @see \Illuminate\Support\Testing\Fakes\EventFake + */ class Event { + /** + * Register an event listener with the dispatcher. + * + * @param \Closure|string|array $events + * @param \Closure|string|array|null $listener + * @return void + * @static + */ public static function listen($events, $listener = null) + { + /** @var \Illuminate\Events\Dispatcher $instance */ + $instance->listen($events, $listener); + } + /** + * Determine if a given event has listeners. + * + * @param string $eventName + * @return bool + * @static + */ public static function hasListeners($eventName) + { + /** @var \Illuminate\Events\Dispatcher $instance */ + return $instance->hasListeners($eventName); + } + /** + * Determine if the given event has any wildcard listeners. + * + * @param string $eventName + * @return bool + * @static + */ public static function hasWildcardListeners($eventName) + { + /** @var \Illuminate\Events\Dispatcher $instance */ + return $instance->hasWildcardListeners($eventName); + } + /** + * Register an event and payload to be fired later. + * + * @param string $event + * @param object|array $payload + * @return void + * @static + */ public static function push($event, $payload = []) + { + /** @var \Illuminate\Events\Dispatcher $instance */ + $instance->push($event, $payload); + } + /** + * Flush a set of pushed events. + * + * @param string $event + * @return void + * @static + */ public static function flush($event) + { + /** @var \Illuminate\Events\Dispatcher $instance */ + $instance->flush($event); + } + /** + * Register an event subscriber with the dispatcher. + * + * @param object|string $subscriber + * @return void + * @static + */ public static function subscribe($subscriber) + { + /** @var \Illuminate\Events\Dispatcher $instance */ + $instance->subscribe($subscriber); + } + /** + * Fire an event until the first non-null response is returned. + * + * @param string|object $event + * @param mixed $payload + * @return mixed + * @static + */ public static function until($event, $payload = []) + { + /** @var \Illuminate\Events\Dispatcher $instance */ + return $instance->until($event, $payload); + } + /** + * Fire an event and call the listeners. + * + * @param string|object $event + * @param mixed $payload + * @param bool $halt + * @return array|null + * @static + */ public static function dispatch($event, $payload = [], $halt = false) + { + /** @var \Illuminate\Events\Dispatcher $instance */ + return $instance->dispatch($event, $payload, $halt); + } + /** + * Get all of the listeners for a given event name. + * + * @param string $eventName + * @return array + * @static + */ public static function getListeners($eventName) + { + /** @var \Illuminate\Events\Dispatcher $instance */ + return $instance->getListeners($eventName); + } + /** + * Register an event listener with the dispatcher. + * + * @param \Closure|string|array $listener + * @param bool $wildcard + * @return \Closure + * @static + */ public static function makeListener($listener, $wildcard = false) + { + /** @var \Illuminate\Events\Dispatcher $instance */ + return $instance->makeListener($listener, $wildcard); + } + /** + * Create a class based listener using the IoC container. + * + * @param string $listener + * @param bool $wildcard + * @return \Closure + * @static + */ public static function createClassListener($listener, $wildcard = false) + { + /** @var \Illuminate\Events\Dispatcher $instance */ + return $instance->createClassListener($listener, $wildcard); + } + /** + * Remove a set of listeners from the dispatcher. + * + * @param string $event + * @return void + * @static + */ public static function forget($event) + { + /** @var \Illuminate\Events\Dispatcher $instance */ + $instance->forget($event); + } + /** + * Forget all of the pushed listeners. + * + * @return void + * @static + */ public static function forgetPushed() + { + /** @var \Illuminate\Events\Dispatcher $instance */ + $instance->forgetPushed(); + } + /** + * Set the queue resolver implementation. + * + * @param callable $resolver + * @return \Illuminate\Events\Dispatcher + * @static + */ public static function setQueueResolver($resolver) + { + /** @var \Illuminate\Events\Dispatcher $instance */ + return $instance->setQueueResolver($resolver); + } + /** + * Set the database transaction manager resolver implementation. + * + * @param callable $resolver + * @return \Illuminate\Events\Dispatcher + * @static + */ public static function setTransactionManagerResolver($resolver) + { + /** @var \Illuminate\Events\Dispatcher $instance */ + return $instance->setTransactionManagerResolver($resolver); + } + /** + * Gets the raw, unprepared listeners. + * + * @return array + * @static + */ public static function getRawListeners() + { + /** @var \Illuminate\Events\Dispatcher $instance */ + return $instance->getRawListeners(); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Events\Dispatcher::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Events\Dispatcher::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Events\Dispatcher::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Events\Dispatcher::flushMacros(); + } + /** + * Specify the events that should be dispatched instead of faked. + * + * @param array|string $eventsToDispatch + * @return \Illuminate\Support\Testing\Fakes\EventFake + * @static + */ public static function except($eventsToDispatch) + { + /** @var \Illuminate\Support\Testing\Fakes\EventFake $instance */ + return $instance->except($eventsToDispatch); + } + /** + * Assert if an event has a listener attached to it. + * + * @param string $expectedEvent + * @param string|array $expectedListener + * @return void + * @static + */ public static function assertListening($expectedEvent, $expectedListener) + { + /** @var \Illuminate\Support\Testing\Fakes\EventFake $instance */ + $instance->assertListening($expectedEvent, $expectedListener); + } + /** + * Assert if an event was dispatched based on a truth-test callback. + * + * @param string|\Closure $event + * @param callable|int|null $callback + * @return void + * @static + */ public static function assertDispatched($event, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\EventFake $instance */ + $instance->assertDispatched($event, $callback); + } + /** + * Assert if an event was dispatched a number of times. + * + * @param string $event + * @param int $times + * @return void + * @static + */ public static function assertDispatchedTimes($event, $times = 1) + { + /** @var \Illuminate\Support\Testing\Fakes\EventFake $instance */ + $instance->assertDispatchedTimes($event, $times); + } + /** + * Determine if an event was dispatched based on a truth-test callback. + * + * @param string|\Closure $event + * @param callable|null $callback + * @return void + * @static + */ public static function assertNotDispatched($event, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\EventFake $instance */ + $instance->assertNotDispatched($event, $callback); + } + /** + * Assert that no events were dispatched. + * + * @return void + * @static + */ public static function assertNothingDispatched() + { + /** @var \Illuminate\Support\Testing\Fakes\EventFake $instance */ + $instance->assertNothingDispatched(); + } + /** + * Get all of the events matching a truth-test callback. + * + * @param string $event + * @param callable|null $callback + * @return \Illuminate\Support\Collection + * @static + */ public static function dispatched($event, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\EventFake $instance */ + return $instance->dispatched($event, $callback); + } + /** + * Determine if the given event has been dispatched. + * + * @param string $event + * @return bool + * @static + */ public static function hasDispatched($event) + { + /** @var \Illuminate\Support\Testing\Fakes\EventFake $instance */ + return $instance->hasDispatched($event); + } + /** + * Get the events that have been dispatched. + * + * @return array + * @static + */ public static function dispatchedEvents() + { + /** @var \Illuminate\Support\Testing\Fakes\EventFake $instance */ + return $instance->dispatchedEvents(); + } + } + /** + * + * + * @see \Illuminate\Filesystem\Filesystem + */ class File { + /** + * Determine if a file or directory exists. + * + * @param string $path + * @return bool + * @static + */ public static function exists($path) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->exists($path); + } + /** + * Determine if a file or directory is missing. + * + * @param string $path + * @return bool + * @static + */ public static function missing($path) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->missing($path); + } + /** + * Get the contents of a file. + * + * @param string $path + * @param bool $lock + * @return string + * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException + * @static + */ public static function get($path, $lock = false) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->get($path, $lock); + } + /** + * Get the contents of a file as decoded JSON. + * + * @param string $path + * @param int $flags + * @param bool $lock + * @return array + * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException + * @static + */ public static function json($path, $flags = 0, $lock = false) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->json($path, $flags, $lock); + } + /** + * Get contents of a file with shared access. + * + * @param string $path + * @return string + * @static + */ public static function sharedGet($path) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->sharedGet($path); + } + /** + * Get the returned value of a file. + * + * @param string $path + * @param array $data + * @return mixed + * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException + * @static + */ public static function getRequire($path, $data = []) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->getRequire($path, $data); + } + /** + * Require the given file once. + * + * @param string $path + * @param array $data + * @return mixed + * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException + * @static + */ public static function requireOnce($path, $data = []) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->requireOnce($path, $data); + } + /** + * Get the contents of a file one line at a time. + * + * @param string $path + * @return \Illuminate\Support\LazyCollection + * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException + * @static + */ public static function lines($path) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->lines($path); + } + /** + * Get the hash of the file at the given path. + * + * @param string $path + * @param string $algorithm + * @return string + * @static + */ public static function hash($path, $algorithm = 'md5') + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->hash($path, $algorithm); + } + /** + * Write the contents of a file. + * + * @param string $path + * @param string $contents + * @param bool $lock + * @return int|bool + * @static + */ public static function put($path, $contents, $lock = false) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->put($path, $contents, $lock); + } + /** + * Write the contents of a file, replacing it atomically if it already exists. + * + * @param string $path + * @param string $content + * @param int|null $mode + * @return void + * @static + */ public static function replace($path, $content, $mode = null) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + $instance->replace($path, $content, $mode); + } + /** + * Replace a given string within a given file. + * + * @param array|string $search + * @param array|string $replace + * @param string $path + * @return void + * @static + */ public static function replaceInFile($search, $replace, $path) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + $instance->replaceInFile($search, $replace, $path); + } + /** + * Prepend to a file. + * + * @param string $path + * @param string $data + * @return int + * @static + */ public static function prepend($path, $data) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->prepend($path, $data); + } + /** + * Append to a file. + * + * @param string $path + * @param string $data + * @param bool $lock + * @return int + * @static + */ public static function append($path, $data, $lock = false) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->append($path, $data, $lock); + } + /** + * Get or set UNIX mode of a file or directory. + * + * @param string $path + * @param int|null $mode + * @return mixed + * @static + */ public static function chmod($path, $mode = null) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->chmod($path, $mode); + } + /** + * Delete the file at a given path. + * + * @param string|array $paths + * @return bool + * @static + */ public static function delete($paths) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->delete($paths); + } + /** + * Move a file to a new location. + * + * @param string $path + * @param string $target + * @return bool + * @static + */ public static function move($path, $target) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->move($path, $target); + } + /** + * Copy a file to a new location. + * + * @param string $path + * @param string $target + * @return bool + * @static + */ public static function copy($path, $target) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->copy($path, $target); + } + /** + * Create a symlink to the target file or directory. On Windows, a hard link is created if the target is a file. + * + * @param string $target + * @param string $link + * @return bool|null + * @static + */ public static function link($target, $link) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->link($target, $link); + } + /** + * Create a relative symlink to the target file or directory. + * + * @param string $target + * @param string $link + * @return void + * @throws \RuntimeException + * @static + */ public static function relativeLink($target, $link) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + $instance->relativeLink($target, $link); + } + /** + * Extract the file name from a file path. + * + * @param string $path + * @return string + * @static + */ public static function name($path) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->name($path); + } + /** + * Extract the trailing name component from a file path. + * + * @param string $path + * @return string + * @static + */ public static function basename($path) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->basename($path); + } + /** + * Extract the parent directory from a file path. + * + * @param string $path + * @return string + * @static + */ public static function dirname($path) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->dirname($path); + } + /** + * Extract the file extension from a file path. + * + * @param string $path + * @return string + * @static + */ public static function extension($path) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->extension($path); + } + /** + * Guess the file extension from the mime-type of a given file. + * + * @param string $path + * @return string|null + * @throws \RuntimeException + * @static + */ public static function guessExtension($path) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->guessExtension($path); + } + /** + * Get the file type of a given file. + * + * @param string $path + * @return string + * @static + */ public static function type($path) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->type($path); + } + /** + * Get the mime-type of a given file. + * + * @param string $path + * @return string|false + * @static + */ public static function mimeType($path) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->mimeType($path); + } + /** + * Get the file size of a given file. + * + * @param string $path + * @return int + * @static + */ public static function size($path) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->size($path); + } + /** + * Get the file's last modification time. + * + * @param string $path + * @return int + * @static + */ public static function lastModified($path) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->lastModified($path); + } + /** + * Determine if the given path is a directory. + * + * @param string $directory + * @return bool + * @static + */ public static function isDirectory($directory) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->isDirectory($directory); + } + /** + * Determine if the given path is a directory that does not contain any other files or directories. + * + * @param string $directory + * @param bool $ignoreDotFiles + * @return bool + * @static + */ public static function isEmptyDirectory($directory, $ignoreDotFiles = false) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->isEmptyDirectory($directory, $ignoreDotFiles); + } + /** + * Determine if the given path is readable. + * + * @param string $path + * @return bool + * @static + */ public static function isReadable($path) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->isReadable($path); + } + /** + * Determine if the given path is writable. + * + * @param string $path + * @return bool + * @static + */ public static function isWritable($path) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->isWritable($path); + } + /** + * Determine if two files are the same by comparing their hashes. + * + * @param string $firstFile + * @param string $secondFile + * @return bool + * @static + */ public static function hasSameHash($firstFile, $secondFile) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->hasSameHash($firstFile, $secondFile); + } + /** + * Determine if the given path is a file. + * + * @param string $file + * @return bool + * @static + */ public static function isFile($file) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->isFile($file); + } + /** + * Find path names matching a given pattern. + * + * @param string $pattern + * @param int $flags + * @return array + * @static + */ public static function glob($pattern, $flags = 0) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->glob($pattern, $flags); + } + /** + * Get an array of all files in a directory. + * + * @param string $directory + * @param bool $hidden + * @return \Symfony\Component\Finder\SplFileInfo[] + * @static + */ public static function files($directory, $hidden = false) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->files($directory, $hidden); + } + /** + * Get all of the files from the given directory (recursive). + * + * @param string $directory + * @param bool $hidden + * @return \Symfony\Component\Finder\SplFileInfo[] + * @static + */ public static function allFiles($directory, $hidden = false) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->allFiles($directory, $hidden); + } + /** + * Get all of the directories within a given directory. + * + * @param string $directory + * @return array + * @static + */ public static function directories($directory) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->directories($directory); + } + /** + * Ensure a directory exists. + * + * @param string $path + * @param int $mode + * @param bool $recursive + * @return void + * @static + */ public static function ensureDirectoryExists($path, $mode = 493, $recursive = true) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + $instance->ensureDirectoryExists($path, $mode, $recursive); + } + /** + * Create a directory. + * + * @param string $path + * @param int $mode + * @param bool $recursive + * @param bool $force + * @return bool + * @static + */ public static function makeDirectory($path, $mode = 493, $recursive = false, $force = false) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->makeDirectory($path, $mode, $recursive, $force); + } + /** + * Move a directory. + * + * @param string $from + * @param string $to + * @param bool $overwrite + * @return bool + * @static + */ public static function moveDirectory($from, $to, $overwrite = false) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->moveDirectory($from, $to, $overwrite); + } + /** + * Copy a directory from one location to another. + * + * @param string $directory + * @param string $destination + * @param int|null $options + * @return bool + * @static + */ public static function copyDirectory($directory, $destination, $options = null) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->copyDirectory($directory, $destination, $options); + } + /** + * Recursively delete a directory. + * + * The directory itself may be optionally preserved. + * + * @param string $directory + * @param bool $preserve + * @return bool + * @static + */ public static function deleteDirectory($directory, $preserve = false) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->deleteDirectory($directory, $preserve); + } + /** + * Remove all of the directories within a given directory. + * + * @param string $directory + * @return bool + * @static + */ public static function deleteDirectories($directory) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->deleteDirectories($directory); + } + /** + * Empty the specified directory of all files and folders. + * + * @param string $directory + * @return bool + * @static + */ public static function cleanDirectory($directory) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->cleanDirectory($directory); + } + /** + * Apply the callback if the given "value" is (or resolves to) truthy. + * + * @template TWhenParameter + * @template TWhenReturnType + * @param \Illuminate\Filesystem\(\Closure($this): TWhenParameter)|TWhenParameter|null $value + * @param \Illuminate\Filesystem\(callable($this, TWhenParameter): TWhenReturnType)|null $callback + * @param \Illuminate\Filesystem\(callable($this, TWhenParameter): TWhenReturnType)|null $default + * @return $this|\Illuminate\Filesystem\TWhenReturnType + * @static + */ public static function when($value = null, $callback = null, $default = null) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->when($value, $callback, $default); + } + /** + * Apply the callback if the given "value" is (or resolves to) falsy. + * + * @template TUnlessParameter + * @template TUnlessReturnType + * @param \Illuminate\Filesystem\(\Closure($this): TUnlessParameter)|TUnlessParameter|null $value + * @param \Illuminate\Filesystem\(callable($this, TUnlessParameter): TUnlessReturnType)|null $callback + * @param \Illuminate\Filesystem\(callable($this, TUnlessParameter): TUnlessReturnType)|null $default + * @return $this|\Illuminate\Filesystem\TUnlessReturnType + * @static + */ public static function unless($value = null, $callback = null, $default = null) + { + /** @var \Illuminate\Filesystem\Filesystem $instance */ + return $instance->unless($value, $callback, $default); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Filesystem\Filesystem::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Filesystem\Filesystem::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Filesystem\Filesystem::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Filesystem\Filesystem::flushMacros(); + } + } + /** + * + * + * @see \Illuminate\Auth\Access\Gate + */ class Gate { + /** + * Determine if a given ability has been defined. + * + * @param string|array $ability + * @return bool + * @static + */ public static function has($ability) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->has($ability); + } + /** + * Perform an on-demand authorization check. Throw an authorization exception if the condition or callback is false. + * + * @param \Illuminate\Auth\Access\Response|\Closure|bool $condition + * @param string|null $message + * @param string|null $code + * @return \Illuminate\Auth\Access\Response + * @throws \Illuminate\Auth\Access\AuthorizationException + * @static + */ public static function allowIf($condition, $message = null, $code = null) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->allowIf($condition, $message, $code); + } + /** + * Perform an on-demand authorization check. Throw an authorization exception if the condition or callback is true. + * + * @param \Illuminate\Auth\Access\Response|\Closure|bool $condition + * @param string|null $message + * @param string|null $code + * @return \Illuminate\Auth\Access\Response + * @throws \Illuminate\Auth\Access\AuthorizationException + * @static + */ public static function denyIf($condition, $message = null, $code = null) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->denyIf($condition, $message, $code); + } + /** + * Define a new ability. + * + * @param string $ability + * @param callable|array|string $callback + * @return \Illuminate\Auth\Access\Gate + * @throws \InvalidArgumentException + * @static + */ public static function define($ability, $callback) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->define($ability, $callback); + } + /** + * Define abilities for a resource. + * + * @param string $name + * @param string $class + * @param array|null $abilities + * @return \Illuminate\Auth\Access\Gate + * @static + */ public static function resource($name, $class, $abilities = null) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->resource($name, $class, $abilities); + } + /** + * Define a policy class for a given class type. + * + * @param string $class + * @param string $policy + * @return \Illuminate\Auth\Access\Gate + * @static + */ public static function policy($class, $policy) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->policy($class, $policy); + } + /** + * Register a callback to run before all Gate checks. + * + * @param callable $callback + * @return \Illuminate\Auth\Access\Gate + * @static + */ public static function before($callback) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->before($callback); + } + /** + * Register a callback to run after all Gate checks. + * + * @param callable $callback + * @return \Illuminate\Auth\Access\Gate + * @static + */ public static function after($callback) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->after($callback); + } + /** + * Determine if all of the given abilities should be granted for the current user. + * + * @param \Illuminate\Auth\Access\iterable|string $ability + * @param array|mixed $arguments + * @return bool + * @static + */ public static function allows($ability, $arguments = []) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->allows($ability, $arguments); + } + /** + * Determine if any of the given abilities should be denied for the current user. + * + * @param \Illuminate\Auth\Access\iterable|string $ability + * @param array|mixed $arguments + * @return bool + * @static + */ public static function denies($ability, $arguments = []) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->denies($ability, $arguments); + } + /** + * Determine if all of the given abilities should be granted for the current user. + * + * @param \Illuminate\Auth\Access\iterable|string $abilities + * @param array|mixed $arguments + * @return bool + * @static + */ public static function check($abilities, $arguments = []) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->check($abilities, $arguments); + } + /** + * Determine if any one of the given abilities should be granted for the current user. + * + * @param \Illuminate\Auth\Access\iterable|string $abilities + * @param array|mixed $arguments + * @return bool + * @static + */ public static function any($abilities, $arguments = []) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->any($abilities, $arguments); + } + /** + * Determine if all of the given abilities should be denied for the current user. + * + * @param \Illuminate\Auth\Access\iterable|string $abilities + * @param array|mixed $arguments + * @return bool + * @static + */ public static function none($abilities, $arguments = []) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->none($abilities, $arguments); + } + /** + * Determine if the given ability should be granted for the current user. + * + * @param string $ability + * @param array|mixed $arguments + * @return \Illuminate\Auth\Access\Response + * @throws \Illuminate\Auth\Access\AuthorizationException + * @static + */ public static function authorize($ability, $arguments = []) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->authorize($ability, $arguments); + } + /** + * Inspect the user for the given ability. + * + * @param string $ability + * @param array|mixed $arguments + * @return \Illuminate\Auth\Access\Response + * @static + */ public static function inspect($ability, $arguments = []) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->inspect($ability, $arguments); + } + /** + * Get the raw result from the authorization callback. + * + * @param string $ability + * @param array|mixed $arguments + * @return mixed + * @throws \Illuminate\Auth\Access\AuthorizationException + * @static + */ public static function raw($ability, $arguments = []) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->raw($ability, $arguments); + } + /** + * Get a policy instance for a given class. + * + * @param object|string $class + * @return mixed + * @static + */ public static function getPolicyFor($class) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->getPolicyFor($class); + } + /** + * Specify a callback to be used to guess policy names. + * + * @param callable $callback + * @return \Illuminate\Auth\Access\Gate + * @static + */ public static function guessPolicyNamesUsing($callback) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->guessPolicyNamesUsing($callback); + } + /** + * Build a policy class instance of the given type. + * + * @param object|string $class + * @return mixed + * @throws \Illuminate\Contracts\Container\BindingResolutionException + * @static + */ public static function resolvePolicy($class) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->resolvePolicy($class); + } + /** + * Get a gate instance for the given user. + * + * @param \Illuminate\Contracts\Auth\Authenticatable|mixed $user + * @return static + * @static + */ public static function forUser($user) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->forUser($user); + } + /** + * Get all of the defined abilities. + * + * @return array + * @static + */ public static function abilities() + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->abilities(); + } + /** + * Get all of the defined policies. + * + * @return array + * @static + */ public static function policies() + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->policies(); + } + /** + * Set the default denial response for gates and policies. + * + * @param \Illuminate\Auth\Access\Response $response + * @return \Illuminate\Auth\Access\Gate + * @static + */ public static function defaultDenialResponse($response) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->defaultDenialResponse($response); + } + /** + * Set the container instance used by the gate. + * + * @param \Illuminate\Contracts\Container\Container $container + * @return \Illuminate\Auth\Access\Gate + * @static + */ public static function setContainer($container) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->setContainer($container); + } + /** + * Deny with a HTTP status code. + * + * @param int $status + * @param string|null $message + * @param int|null $code + * @return \Illuminate\Auth\Access\Response + * @static + */ public static function denyWithStatus($status, $message = null, $code = null) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->denyWithStatus($status, $message, $code); + } + /** + * Deny with a 404 HTTP status code. + * + * @param string|null $message + * @param int|null $code + * @return \Illuminate\Auth\Access\Response + * @static + */ public static function denyAsNotFound($message = null, $code = null) + { + /** @var \Illuminate\Auth\Access\Gate $instance */ + return $instance->denyAsNotFound($message, $code); + } + } + /** + * + * + * @see \Illuminate\Hashing\HashManager + * @see \Illuminate\Hashing\AbstractHasher + */ class Hash { + /** + * Create an instance of the Bcrypt hash Driver. + * + * @return \Illuminate\Hashing\BcryptHasher + * @static + */ public static function createBcryptDriver() + { + /** @var \Illuminate\Hashing\HashManager $instance */ + return $instance->createBcryptDriver(); + } + /** + * Create an instance of the Argon2i hash Driver. + * + * @return \Illuminate\Hashing\ArgonHasher + * @static + */ public static function createArgonDriver() + { + /** @var \Illuminate\Hashing\HashManager $instance */ + return $instance->createArgonDriver(); + } + /** + * Create an instance of the Argon2id hash Driver. + * + * @return \Illuminate\Hashing\Argon2IdHasher + * @static + */ public static function createArgon2idDriver() + { + /** @var \Illuminate\Hashing\HashManager $instance */ + return $instance->createArgon2idDriver(); + } + /** + * Get information about the given hashed value. + * + * @param string $hashedValue + * @return array + * @static + */ public static function info($hashedValue) + { + /** @var \Illuminate\Hashing\HashManager $instance */ + return $instance->info($hashedValue); + } + /** + * Hash the given value. + * + * @param string $value + * @param array $options + * @return string + * @static + */ public static function make($value, $options = []) + { + /** @var \Illuminate\Hashing\HashManager $instance */ + return $instance->make($value, $options); + } + /** + * Check the given plain value against a hash. + * + * @param string $value + * @param string $hashedValue + * @param array $options + * @return bool + * @static + */ public static function check($value, $hashedValue, $options = []) + { + /** @var \Illuminate\Hashing\HashManager $instance */ + return $instance->check($value, $hashedValue, $options); + } + /** + * Check if the given hash has been hashed using the given options. + * + * @param string $hashedValue + * @param array $options + * @return bool + * @static + */ public static function needsRehash($hashedValue, $options = []) + { + /** @var \Illuminate\Hashing\HashManager $instance */ + return $instance->needsRehash($hashedValue, $options); + } + /** + * Determine if a given string is already hashed. + * + * @param string $value + * @return bool + * @static + */ public static function isHashed($value) + { + /** @var \Illuminate\Hashing\HashManager $instance */ + return $instance->isHashed($value); + } + /** + * Get the default driver name. + * + * @return string + * @static + */ public static function getDefaultDriver() + { + /** @var \Illuminate\Hashing\HashManager $instance */ + return $instance->getDefaultDriver(); + } + /** + * Verifies that the configuration is less than or equal to what is configured. + * + * @param array $value + * @return bool + * @internal + * @static + */ public static function verifyConfiguration($value) + { + /** @var \Illuminate\Hashing\HashManager $instance */ + return $instance->verifyConfiguration($value); + } + /** + * Get a driver instance. + * + * @param string|null $driver + * @return mixed + * @throws \InvalidArgumentException + * @static + */ public static function driver($driver = null) + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Hashing\HashManager $instance */ + return $instance->driver($driver); + } + /** + * Register a custom driver creator Closure. + * + * @param string $driver + * @param \Closure $callback + * @return \Illuminate\Hashing\HashManager + * @static + */ public static function extend($driver, $callback) + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Hashing\HashManager $instance */ + return $instance->extend($driver, $callback); + } + /** + * Get all of the created "drivers". + * + * @return array + * @static + */ public static function getDrivers() + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Hashing\HashManager $instance */ + return $instance->getDrivers(); + } + /** + * Get the container instance used by the manager. + * + * @return \Illuminate\Contracts\Container\Container + * @static + */ public static function getContainer() + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Hashing\HashManager $instance */ + return $instance->getContainer(); + } + /** + * Set the container instance used by the manager. + * + * @param \Illuminate\Contracts\Container\Container $container + * @return \Illuminate\Hashing\HashManager + * @static + */ public static function setContainer($container) + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Hashing\HashManager $instance */ + return $instance->setContainer($container); + } + /** + * Forget all of the resolved driver instances. + * + * @return \Illuminate\Hashing\HashManager + * @static + */ public static function forgetDrivers() + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Hashing\HashManager $instance */ + return $instance->forgetDrivers(); + } + } + /** + * + * + * @method static \Illuminate\Http\Client\PendingRequest baseUrl(string $url) + * @method static \Illuminate\Http\Client\PendingRequest withBody(\Psr\Http\Message\StreamInterface|string $content, string $contentType = 'application/json') + * @method static \Illuminate\Http\Client\PendingRequest asJson() + * @method static \Illuminate\Http\Client\PendingRequest asForm() + * @method static \Illuminate\Http\Client\PendingRequest attach(string|array $name, string|resource $contents = '', string|null $filename = null, array $headers = []) + * @method static \Illuminate\Http\Client\PendingRequest asMultipart() + * @method static \Illuminate\Http\Client\PendingRequest bodyFormat(string $format) + * @method static \Illuminate\Http\Client\PendingRequest withQueryParameters(array $parameters) + * @method static \Illuminate\Http\Client\PendingRequest contentType(string $contentType) + * @method static \Illuminate\Http\Client\PendingRequest acceptJson() + * @method static \Illuminate\Http\Client\PendingRequest accept(string $contentType) + * @method static \Illuminate\Http\Client\PendingRequest withHeaders(array $headers) + * @method static \Illuminate\Http\Client\PendingRequest withHeader(string $name, mixed $value) + * @method static \Illuminate\Http\Client\PendingRequest replaceHeaders(array $headers) + * @method static \Illuminate\Http\Client\PendingRequest withBasicAuth(string $username, string $password) + * @method static \Illuminate\Http\Client\PendingRequest withDigestAuth(string $username, string $password) + * @method static \Illuminate\Http\Client\PendingRequest withToken(string $token, string $type = 'Bearer') + * @method static \Illuminate\Http\Client\PendingRequest withUserAgent(string|bool $userAgent) + * @method static \Illuminate\Http\Client\PendingRequest withUrlParameters(array $parameters = []) + * @method static \Illuminate\Http\Client\PendingRequest withCookies(array $cookies, string $domain) + * @method static \Illuminate\Http\Client\PendingRequest maxRedirects(int $max) + * @method static \Illuminate\Http\Client\PendingRequest withoutRedirecting() + * @method static \Illuminate\Http\Client\PendingRequest withoutVerifying() + * @method static \Illuminate\Http\Client\PendingRequest sink(string|resource $to) + * @method static \Illuminate\Http\Client\PendingRequest timeout(int $seconds) + * @method static \Illuminate\Http\Client\PendingRequest connectTimeout(int $seconds) + * @method static \Illuminate\Http\Client\PendingRequest retry(array|int $times, \Closure|int $sleepMilliseconds = 0, callable|null $when = null, bool $throw = true) + * @method static \Illuminate\Http\Client\PendingRequest withOptions(array $options) + * @method static \Illuminate\Http\Client\PendingRequest withMiddleware(callable $middleware) + * @method static \Illuminate\Http\Client\PendingRequest withRequestMiddleware(callable $middleware) + * @method static \Illuminate\Http\Client\PendingRequest withResponseMiddleware(callable $middleware) + * @method static \Illuminate\Http\Client\PendingRequest beforeSending(callable $callback) + * @method static \Illuminate\Http\Client\PendingRequest throw(callable|null $callback = null) + * @method static \Illuminate\Http\Client\PendingRequest throwIf(callable|bool $condition) + * @method static \Illuminate\Http\Client\PendingRequest throwUnless(bool $condition) + * @method static \Illuminate\Http\Client\PendingRequest dump() + * @method static \Illuminate\Http\Client\PendingRequest dd() + * @method static \Illuminate\Http\Client\Response get(string $url, array|string|null $query = null) + * @method static \Illuminate\Http\Client\Response head(string $url, array|string|null $query = null) + * @method static \Illuminate\Http\Client\Response post(string $url, array $data = []) + * @method static \Illuminate\Http\Client\Response patch(string $url, array $data = []) + * @method static \Illuminate\Http\Client\Response put(string $url, array $data = []) + * @method static \Illuminate\Http\Client\Response delete(string $url, array $data = []) + * @method static array pool(callable $callback) + * @method static \Illuminate\Http\Client\Response send(string $method, string $url, array $options = []) + * @method static \GuzzleHttp\Client buildClient() + * @method static \GuzzleHttp\Client createClient(\GuzzleHttp\HandlerStack $handlerStack) + * @method static \GuzzleHttp\HandlerStack buildHandlerStack() + * @method static \GuzzleHttp\HandlerStack pushHandlers(\GuzzleHttp\HandlerStack $handlerStack) + * @method static \Closure buildBeforeSendingHandler() + * @method static \Closure buildRecorderHandler() + * @method static \Closure buildStubHandler() + * @method static \GuzzleHttp\Psr7\RequestInterface runBeforeSendingCallbacks(\GuzzleHttp\Psr7\RequestInterface $request, array $options) + * @method static array mergeOptions(array ...$options) + * @method static \Illuminate\Http\Client\PendingRequest stub(callable $callback) + * @method static \Illuminate\Http\Client\PendingRequest async(bool $async = true) + * @method static \GuzzleHttp\Promise\PromiseInterface|null getPromise() + * @method static \Illuminate\Http\Client\PendingRequest setClient(\GuzzleHttp\Client $client) + * @method static \Illuminate\Http\Client\PendingRequest setHandler(callable $handler) + * @method static array getOptions() + * @method static \Illuminate\Http\Client\PendingRequest|mixed when(\Closure|mixed|null $value = null, callable|null $callback = null, callable|null $default = null) + * @method static \Illuminate\Http\Client\PendingRequest|mixed unless(\Closure|mixed|null $value = null, callable|null $callback = null, callable|null $default = null) + * @see \Illuminate\Http\Client\Factory + */ class Http { + /** + * Add middleware to apply to every request. + * + * @param callable $middleware + * @return \Illuminate\Http\Client\Factory + * @static + */ public static function globalMiddleware($middleware) + { + /** @var \Illuminate\Http\Client\Factory $instance */ + return $instance->globalMiddleware($middleware); + } + /** + * Add request middleware to apply to every request. + * + * @param callable $middleware + * @return \Illuminate\Http\Client\Factory + * @static + */ public static function globalRequestMiddleware($middleware) + { + /** @var \Illuminate\Http\Client\Factory $instance */ + return $instance->globalRequestMiddleware($middleware); + } + /** + * Add response middleware to apply to every request. + * + * @param callable $middleware + * @return \Illuminate\Http\Client\Factory + * @static + */ public static function globalResponseMiddleware($middleware) + { + /** @var \Illuminate\Http\Client\Factory $instance */ + return $instance->globalResponseMiddleware($middleware); + } + /** + * Set the options to apply to every request. + * + * @param \Closure|array $options + * @return \Illuminate\Http\Client\Factory + * @static + */ public static function globalOptions($options) + { + /** @var \Illuminate\Http\Client\Factory $instance */ + return $instance->globalOptions($options); + } + /** + * Create a new response instance for use during stubbing. + * + * @param array|string|null $body + * @param int $status + * @param array $headers + * @return \GuzzleHttp\Promise\PromiseInterface + * @static + */ public static function response($body = null, $status = 200, $headers = []) + { + return \Illuminate\Http\Client\Factory::response($body, $status, $headers); + } + /** + * Get an invokable object that returns a sequence of responses in order for use during stubbing. + * + * @param array $responses + * @return \Illuminate\Http\Client\ResponseSequence + * @static + */ public static function sequence($responses = []) + { + /** @var \Illuminate\Http\Client\Factory $instance */ + return $instance->sequence($responses); + } + /** + * Register a stub callable that will intercept requests and be able to return stub responses. + * + * @param callable|array|null $callback + * @return \Illuminate\Http\Client\Factory + * @static + */ public static function fake($callback = null) + { + /** @var \Illuminate\Http\Client\Factory $instance */ + return $instance->fake($callback); + } + /** + * Register a response sequence for the given URL pattern. + * + * @param string $url + * @return \Illuminate\Http\Client\ResponseSequence + * @static + */ public static function fakeSequence($url = '*') + { + /** @var \Illuminate\Http\Client\Factory $instance */ + return $instance->fakeSequence($url); + } + /** + * Stub the given URL using the given callback. + * + * @param string $url + * @param \Illuminate\Http\Client\Response|\GuzzleHttp\Promise\PromiseInterface|callable $callback + * @return \Illuminate\Http\Client\Factory + * @static + */ public static function stubUrl($url, $callback) + { + /** @var \Illuminate\Http\Client\Factory $instance */ + return $instance->stubUrl($url, $callback); + } + /** + * Indicate that an exception should be thrown if any request is not faked. + * + * @param bool $prevent + * @return \Illuminate\Http\Client\Factory + * @static + */ public static function preventStrayRequests($prevent = true) + { + /** @var \Illuminate\Http\Client\Factory $instance */ + return $instance->preventStrayRequests($prevent); + } + /** + * Indicate that an exception should not be thrown if any request is not faked. + * + * @return \Illuminate\Http\Client\Factory + * @static + */ public static function allowStrayRequests() + { + /** @var \Illuminate\Http\Client\Factory $instance */ + return $instance->allowStrayRequests(); + } + /** + * Record a request response pair. + * + * @param \Illuminate\Http\Client\Request $request + * @param \Illuminate\Http\Client\Response $response + * @return void + * @static + */ public static function recordRequestResponsePair($request, $response) + { + /** @var \Illuminate\Http\Client\Factory $instance */ + $instance->recordRequestResponsePair($request, $response); + } + /** + * Assert that a request / response pair was recorded matching a given truth test. + * + * @param callable $callback + * @return void + * @static + */ public static function assertSent($callback) + { + /** @var \Illuminate\Http\Client\Factory $instance */ + $instance->assertSent($callback); + } + /** + * Assert that the given request was sent in the given order. + * + * @param array $callbacks + * @return void + * @static + */ public static function assertSentInOrder($callbacks) + { + /** @var \Illuminate\Http\Client\Factory $instance */ + $instance->assertSentInOrder($callbacks); + } + /** + * Assert that a request / response pair was not recorded matching a given truth test. + * + * @param callable $callback + * @return void + * @static + */ public static function assertNotSent($callback) + { + /** @var \Illuminate\Http\Client\Factory $instance */ + $instance->assertNotSent($callback); + } + /** + * Assert that no request / response pair was recorded. + * + * @return void + * @static + */ public static function assertNothingSent() + { + /** @var \Illuminate\Http\Client\Factory $instance */ + $instance->assertNothingSent(); + } + /** + * Assert how many requests have been recorded. + * + * @param int $count + * @return void + * @static + */ public static function assertSentCount($count) + { + /** @var \Illuminate\Http\Client\Factory $instance */ + $instance->assertSentCount($count); + } + /** + * Assert that every created response sequence is empty. + * + * @return void + * @static + */ public static function assertSequencesAreEmpty() + { + /** @var \Illuminate\Http\Client\Factory $instance */ + $instance->assertSequencesAreEmpty(); + } + /** + * Get a collection of the request / response pairs matching the given truth test. + * + * @param callable $callback + * @return \Illuminate\Support\Collection + * @static + */ public static function recorded($callback = null) + { + /** @var \Illuminate\Http\Client\Factory $instance */ + return $instance->recorded($callback); + } + /** + * Create a new pending request instance for this factory. + * + * @return \Illuminate\Http\Client\PendingRequest + * @static + */ public static function createPendingRequest() + { + /** @var \Illuminate\Http\Client\Factory $instance */ + return $instance->createPendingRequest(); + } + /** + * Get the current event dispatcher implementation. + * + * @return \Illuminate\Contracts\Events\Dispatcher|null + * @static + */ public static function getDispatcher() + { + /** @var \Illuminate\Http\Client\Factory $instance */ + return $instance->getDispatcher(); + } + /** + * Get the array of global middleware. + * + * @return array + * @static + */ public static function getGlobalMiddleware() + { + /** @var \Illuminate\Http\Client\Factory $instance */ + return $instance->getGlobalMiddleware(); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Http\Client\Factory::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Http\Client\Factory::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Http\Client\Factory::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Http\Client\Factory::flushMacros(); + } + /** + * Dynamically handle calls to the class. + * + * @param string $method + * @param array $parameters + * @return mixed + * @throws \BadMethodCallException + * @static + */ public static function macroCall($method, $parameters) + { + /** @var \Illuminate\Http\Client\Factory $instance */ + return $instance->macroCall($method, $parameters); + } + } + /** + * + * + * @see \Illuminate\Translation\Translator + */ class Lang { + /** + * Determine if a translation exists for a given locale. + * + * @param string $key + * @param string|null $locale + * @return bool + * @static + */ public static function hasForLocale($key, $locale = null) + { + /** @var \Illuminate\Translation\Translator $instance */ + return $instance->hasForLocale($key, $locale); + } + /** + * Determine if a translation exists. + * + * @param string $key + * @param string|null $locale + * @param bool $fallback + * @return bool + * @static + */ public static function has($key, $locale = null, $fallback = true) + { + /** @var \Illuminate\Translation\Translator $instance */ + return $instance->has($key, $locale, $fallback); + } + /** + * Get the translation for the given key. + * + * @param string $key + * @param array $replace + * @param string|null $locale + * @param bool $fallback + * @return string|array + * @static + */ public static function get($key, $replace = [], $locale = null, $fallback = true) + { + /** @var \Illuminate\Translation\Translator $instance */ + return $instance->get($key, $replace, $locale, $fallback); + } + /** + * Get a translation according to an integer value. + * + * @param string $key + * @param \Countable|int|float|array $number + * @param array $replace + * @param string|null $locale + * @return string + * @static + */ public static function choice($key, $number, $replace = [], $locale = null) + { + /** @var \Illuminate\Translation\Translator $instance */ + return $instance->choice($key, $number, $replace, $locale); + } + /** + * Add translation lines to the given locale. + * + * @param array $lines + * @param string $locale + * @param string $namespace + * @return void + * @static + */ public static function addLines($lines, $locale, $namespace = '*') + { + /** @var \Illuminate\Translation\Translator $instance */ + $instance->addLines($lines, $locale, $namespace); + } + /** + * Load the specified language group. + * + * @param string $namespace + * @param string $group + * @param string $locale + * @return void + * @static + */ public static function load($namespace, $group, $locale) + { + /** @var \Illuminate\Translation\Translator $instance */ + $instance->load($namespace, $group, $locale); + } + /** + * Register a callback that is responsible for handling missing translation keys. + * + * @param callable|null $callback + * @return static + * @static + */ public static function handleMissingKeysUsing($callback) + { + /** @var \Illuminate\Translation\Translator $instance */ + return $instance->handleMissingKeysUsing($callback); + } + /** + * Add a new namespace to the loader. + * + * @param string $namespace + * @param string $hint + * @return void + * @static + */ public static function addNamespace($namespace, $hint) + { + /** @var \Illuminate\Translation\Translator $instance */ + $instance->addNamespace($namespace, $hint); + } + /** + * Add a new JSON path to the loader. + * + * @param string $path + * @return void + * @static + */ public static function addJsonPath($path) + { + /** @var \Illuminate\Translation\Translator $instance */ + $instance->addJsonPath($path); + } + /** + * Parse a key into namespace, group, and item. + * + * @param string $key + * @return array + * @static + */ public static function parseKey($key) + { + /** @var \Illuminate\Translation\Translator $instance */ + return $instance->parseKey($key); + } + /** + * Specify a callback that should be invoked to determined the applicable locale array. + * + * @param callable $callback + * @return void + * @static + */ public static function determineLocalesUsing($callback) + { + /** @var \Illuminate\Translation\Translator $instance */ + $instance->determineLocalesUsing($callback); + } + /** + * Get the message selector instance. + * + * @return \Illuminate\Translation\MessageSelector + * @static + */ public static function getSelector() + { + /** @var \Illuminate\Translation\Translator $instance */ + return $instance->getSelector(); + } + /** + * Set the message selector instance. + * + * @param \Illuminate\Translation\MessageSelector $selector + * @return void + * @static + */ public static function setSelector($selector) + { + /** @var \Illuminate\Translation\Translator $instance */ + $instance->setSelector($selector); + } + /** + * Get the language line loader implementation. + * + * @return \Illuminate\Contracts\Translation\Loader + * @static + */ public static function getLoader() + { + /** @var \Illuminate\Translation\Translator $instance */ + return $instance->getLoader(); + } + /** + * Get the default locale being used. + * + * @return string + * @static + */ public static function locale() + { + /** @var \Illuminate\Translation\Translator $instance */ + return $instance->locale(); + } + /** + * Get the default locale being used. + * + * @return string + * @static + */ public static function getLocale() + { + /** @var \Illuminate\Translation\Translator $instance */ + return $instance->getLocale(); + } + /** + * Set the default locale. + * + * @param string $locale + * @return void + * @throws \InvalidArgumentException + * @static + */ public static function setLocale($locale) + { + /** @var \Illuminate\Translation\Translator $instance */ + $instance->setLocale($locale); + } + /** + * Get the fallback locale being used. + * + * @return string + * @static + */ public static function getFallback() + { + /** @var \Illuminate\Translation\Translator $instance */ + return $instance->getFallback(); + } + /** + * Set the fallback locale being used. + * + * @param string $fallback + * @return void + * @static + */ public static function setFallback($fallback) + { + /** @var \Illuminate\Translation\Translator $instance */ + $instance->setFallback($fallback); + } + /** + * Set the loaded translation groups. + * + * @param array $loaded + * @return void + * @static + */ public static function setLoaded($loaded) + { + /** @var \Illuminate\Translation\Translator $instance */ + $instance->setLoaded($loaded); + } + /** + * Add a handler to be executed in order to format a given class to a string during translation replacements. + * + * @param callable|string $class + * @param callable|null $handler + * @return void + * @static + */ public static function stringable($class, $handler = null) + { + /** @var \Illuminate\Translation\Translator $instance */ + $instance->stringable($class, $handler); + } + /** + * Set the parsed value of a key. + * + * @param string $key + * @param array $parsed + * @return void + * @static + */ public static function setParsedKey($key, $parsed) + { //Method inherited from \Illuminate\Support\NamespacedItemResolver + /** @var \Illuminate\Translation\Translator $instance */ + $instance->setParsedKey($key, $parsed); + } + /** + * Flush the cache of parsed keys. + * + * @return void + * @static + */ public static function flushParsedKeys() + { //Method inherited from \Illuminate\Support\NamespacedItemResolver + /** @var \Illuminate\Translation\Translator $instance */ + $instance->flushParsedKeys(); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Translation\Translator::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Translation\Translator::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Translation\Translator::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Translation\Translator::flushMacros(); + } + } + /** + * + * + * @method static void write(string $level, \Illuminate\Contracts\Support\Arrayable|\Illuminate\Contracts\Support\Jsonable|\Illuminate\Support\Stringable|array|string $message, array $context = []) + * @method static \Illuminate\Log\Logger withContext(array $context = []) + * @method static void listen(\Closure $callback) + * @method static \Psr\Log\LoggerInterface getLogger() + * @method static \Illuminate\Contracts\Events\Dispatcher getEventDispatcher() + * @method static void setEventDispatcher(\Illuminate\Contracts\Events\Dispatcher $dispatcher) + * @method static \Illuminate\Log\Logger|mixed when(\Closure|mixed|null $value = null, callable|null $callback = null, callable|null $default = null) + * @method static \Illuminate\Log\Logger|mixed unless(\Closure|mixed|null $value = null, callable|null $callback = null, callable|null $default = null) + * @see \Illuminate\Log\LogManager + */ class Log { + /** + * Build an on-demand log channel. + * + * @param array $config + * @return \Psr\Log\LoggerInterface + * @static + */ public static function build($config) + { + /** @var \Illuminate\Log\LogManager $instance */ + return $instance->build($config); + } + /** + * Create a new, on-demand aggregate logger instance. + * + * @param array $channels + * @param string|null $channel + * @return \Psr\Log\LoggerInterface + * @static + */ public static function stack($channels, $channel = null) + { + /** @var \Illuminate\Log\LogManager $instance */ + return $instance->stack($channels, $channel); + } + /** + * Get a log channel instance. + * + * @param string|null $channel + * @return \Psr\Log\LoggerInterface + * @static + */ public static function channel($channel = null) + { + /** @var \Illuminate\Log\LogManager $instance */ + return $instance->channel($channel); + } + /** + * Get a log driver instance. + * + * @param string|null $driver + * @return \Psr\Log\LoggerInterface + * @static + */ public static function driver($driver = null) + { + /** @var \Illuminate\Log\LogManager $instance */ + return $instance->driver($driver); + } + /** + * Share context across channels and stacks. + * + * @param array $context + * @return \Illuminate\Log\LogManager + * @static + */ public static function shareContext($context) + { + /** @var \Illuminate\Log\LogManager $instance */ + return $instance->shareContext($context); + } + /** + * The context shared across channels and stacks. + * + * @return array + * @static + */ public static function sharedContext() + { + /** @var \Illuminate\Log\LogManager $instance */ + return $instance->sharedContext(); + } + /** + * Flush the log context on all currently resolved channels. + * + * @return \Illuminate\Log\LogManager + * @static + */ public static function withoutContext() + { + /** @var \Illuminate\Log\LogManager $instance */ + return $instance->withoutContext(); + } + /** + * Flush the shared context. + * + * @return \Illuminate\Log\LogManager + * @static + */ public static function flushSharedContext() + { + /** @var \Illuminate\Log\LogManager $instance */ + return $instance->flushSharedContext(); + } + /** + * Get the default log driver name. + * + * @return string|null + * @static + */ public static function getDefaultDriver() + { + /** @var \Illuminate\Log\LogManager $instance */ + return $instance->getDefaultDriver(); + } + /** + * Set the default log driver name. + * + * @param string $name + * @return void + * @static + */ public static function setDefaultDriver($name) + { + /** @var \Illuminate\Log\LogManager $instance */ + $instance->setDefaultDriver($name); + } + /** + * Register a custom driver creator Closure. + * + * @param string $driver + * @param \Closure $callback + * @return \Illuminate\Log\LogManager + * @static + */ public static function extend($driver, $callback) + { + /** @var \Illuminate\Log\LogManager $instance */ + return $instance->extend($driver, $callback); + } + /** + * Unset the given channel instance. + * + * @param string|null $driver + * @return void + * @static + */ public static function forgetChannel($driver = null) + { + /** @var \Illuminate\Log\LogManager $instance */ + $instance->forgetChannel($driver); + } + /** + * Get all of the resolved log channels. + * + * @return array + * @static + */ public static function getChannels() + { + /** @var \Illuminate\Log\LogManager $instance */ + return $instance->getChannels(); + } + /** + * System is unusable. + * + * @param string|\Stringable $message + * @param array $context + * @return void + * @static + */ public static function emergency($message, $context = []) + { + /** @var \Illuminate\Log\LogManager $instance */ + $instance->emergency($message, $context); + } + /** + * Action must be taken immediately. + * + * Example: Entire website down, database unavailable, etc. This should + * trigger the SMS alerts and wake you up. + * + * @param string|\Stringable $message + * @param array $context + * @return void + * @static + */ public static function alert($message, $context = []) + { + /** @var \Illuminate\Log\LogManager $instance */ + $instance->alert($message, $context); + } + /** + * Critical conditions. + * + * Example: Application component unavailable, unexpected exception. + * + * @param string|\Stringable $message + * @param array $context + * @return void + * @static + */ public static function critical($message, $context = []) + { + /** @var \Illuminate\Log\LogManager $instance */ + $instance->critical($message, $context); + } + /** + * Runtime errors that do not require immediate action but should typically + * be logged and monitored. + * + * @param string|\Stringable $message + * @param array $context + * @return void + * @static + */ public static function error($message, $context = []) + { + /** @var \Illuminate\Log\LogManager $instance */ + $instance->error($message, $context); + } + /** + * Exceptional occurrences that are not errors. + * + * Example: Use of deprecated APIs, poor use of an API, undesirable things + * that are not necessarily wrong. + * + * @param string|\Stringable $message + * @param array $context + * @return void + * @static + */ public static function warning($message, $context = []) + { + /** @var \Illuminate\Log\LogManager $instance */ + $instance->warning($message, $context); + } + /** + * Normal but significant events. + * + * @param string|\Stringable $message + * @param array $context + * @return void + * @static + */ public static function notice($message, $context = []) + { + /** @var \Illuminate\Log\LogManager $instance */ + $instance->notice($message, $context); + } + /** + * Interesting events. + * + * Example: User logs in, SQL logs. + * + * @param string|\Stringable $message + * @param array $context + * @return void + * @static + */ public static function info($message, $context = []) + { + /** @var \Illuminate\Log\LogManager $instance */ + $instance->info($message, $context); + } + /** + * Detailed debug information. + * + * @param string|\Stringable $message + * @param array $context + * @return void + * @static + */ public static function debug($message, $context = []) + { + /** @var \Illuminate\Log\LogManager $instance */ + $instance->debug($message, $context); + } + /** + * Logs with an arbitrary level. + * + * @param mixed $level + * @param string|\Stringable $message + * @param array $context + * @return void + * @static + */ public static function log($level, $message, $context = []) + { + /** @var \Illuminate\Log\LogManager $instance */ + $instance->log($level, $message, $context); + } + /** + * Set the application instance used by the manager. + * + * @param \Illuminate\Contracts\Foundation\Application $app + * @return \Illuminate\Log\LogManager + * @static + */ public static function setApplication($app) + { + /** @var \Illuminate\Log\LogManager $instance */ + return $instance->setApplication($app); + } + } + /** + * + * + * @method static void alwaysFrom(string $address, string|null $name = null) + * @method static void alwaysReplyTo(string $address, string|null $name = null) + * @method static void alwaysReturnPath(string $address) + * @method static void alwaysTo(string $address, string|null $name = null) + * @method static \Illuminate\Mail\SentMessage|null html(string $html, mixed $callback) + * @method static \Illuminate\Mail\SentMessage|null plain(string $view, array $data, mixed $callback) + * @method static string render(string|array $view, array $data = []) + * @method static mixed onQueue(string $queue, \Illuminate\Contracts\Mail\Mailable $view) + * @method static mixed queueOn(string $queue, \Illuminate\Contracts\Mail\Mailable $view) + * @method static mixed laterOn(string $queue, \DateTimeInterface|\DateInterval|int $delay, \Illuminate\Contracts\Mail\Mailable $view) + * @method static \Symfony\Component\Mailer\Transport\TransportInterface getSymfonyTransport() + * @method static \Illuminate\Contracts\View\Factory getViewFactory() + * @method static void setSymfonyTransport(\Symfony\Component\Mailer\Transport\TransportInterface $transport) + * @method static \Illuminate\Mail\Mailer setQueue(\Illuminate\Contracts\Queue\Factory $queue) + * @method static void macro(string $name, object|callable $macro, object|callable $macro = null) + * @method static void mixin(object $mixin, bool $replace = true) + * @method static bool hasMacro(string $name) + * @method static void flushMacros() + * @see \Illuminate\Mail\MailManager + * @see \Illuminate\Support\Testing\Fakes\MailFake + */ class Mail { + /** + * Get a mailer instance by name. + * + * @param string|null $name + * @return \Illuminate\Contracts\Mail\Mailer + * @static + */ public static function mailer($name = null) + { + /** @var \Illuminate\Mail\MailManager $instance */ + return $instance->mailer($name); + } + /** + * Get a mailer driver instance. + * + * @param string|null $driver + * @return \Illuminate\Mail\Mailer + * @static + */ public static function driver($driver = null) + { + /** @var \Illuminate\Mail\MailManager $instance */ + return $instance->driver($driver); + } + /** + * Create a new transport instance. + * + * @param array $config + * @return \Symfony\Component\Mailer\Transport\TransportInterface + * @throws \InvalidArgumentException + * @static + */ public static function createSymfonyTransport($config) + { + /** @var \Illuminate\Mail\MailManager $instance */ + return $instance->createSymfonyTransport($config); + } + /** + * Get the default mail driver name. + * + * @return string + * @static + */ public static function getDefaultDriver() + { + /** @var \Illuminate\Mail\MailManager $instance */ + return $instance->getDefaultDriver(); + } + /** + * Set the default mail driver name. + * + * @param string $name + * @return void + * @static + */ public static function setDefaultDriver($name) + { + /** @var \Illuminate\Mail\MailManager $instance */ + $instance->setDefaultDriver($name); + } + /** + * Disconnect the given mailer and remove from local cache. + * + * @param string|null $name + * @return void + * @static + */ public static function purge($name = null) + { + /** @var \Illuminate\Mail\MailManager $instance */ + $instance->purge($name); + } + /** + * Register a custom transport creator Closure. + * + * @param string $driver + * @param \Closure $callback + * @return \Illuminate\Mail\MailManager + * @static + */ public static function extend($driver, $callback) + { + /** @var \Illuminate\Mail\MailManager $instance */ + return $instance->extend($driver, $callback); + } + /** + * Get the application instance used by the manager. + * + * @return \Illuminate\Contracts\Foundation\Application + * @static + */ public static function getApplication() + { + /** @var \Illuminate\Mail\MailManager $instance */ + return $instance->getApplication(); + } + /** + * Set the application instance used by the manager. + * + * @param \Illuminate\Contracts\Foundation\Application $app + * @return \Illuminate\Mail\MailManager + * @static + */ public static function setApplication($app) + { + /** @var \Illuminate\Mail\MailManager $instance */ + return $instance->setApplication($app); + } + /** + * Forget all of the resolved mailer instances. + * + * @return \Illuminate\Mail\MailManager + * @static + */ public static function forgetMailers() + { + /** @var \Illuminate\Mail\MailManager $instance */ + return $instance->forgetMailers(); + } + /** + * Assert if a mailable was sent based on a truth-test callback. + * + * @param string|\Closure $mailable + * @param callable|array|string|int|null $callback + * @return void + * @static + */ public static function assertSent($mailable, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + $instance->assertSent($mailable, $callback); + } + /** + * Determine if a mailable was not sent or queued to be sent based on a truth-test callback. + * + * @param string|\Closure $mailable + * @param callable|null $callback + * @return void + * @static + */ public static function assertNotOutgoing($mailable, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + $instance->assertNotOutgoing($mailable, $callback); + } + /** + * Determine if a mailable was not sent based on a truth-test callback. + * + * @param string|\Closure $mailable + * @param callable|array|string|null $callback + * @return void + * @static + */ public static function assertNotSent($mailable, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + $instance->assertNotSent($mailable, $callback); + } + /** + * Assert that no mailables were sent or queued to be sent. + * + * @return void + * @static + */ public static function assertNothingOutgoing() + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + $instance->assertNothingOutgoing(); + } + /** + * Assert that no mailables were sent. + * + * @return void + * @static + */ public static function assertNothingSent() + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + $instance->assertNothingSent(); + } + /** + * Assert if a mailable was queued based on a truth-test callback. + * + * @param string|\Closure $mailable + * @param callable|array|string|int|null $callback + * @return void + * @static + */ public static function assertQueued($mailable, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + $instance->assertQueued($mailable, $callback); + } + /** + * Determine if a mailable was not queued based on a truth-test callback. + * + * @param string|\Closure $mailable + * @param callable|array|string|null $callback + * @return void + * @static + */ public static function assertNotQueued($mailable, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + $instance->assertNotQueued($mailable, $callback); + } + /** + * Assert that no mailables were queued. + * + * @return void + * @static + */ public static function assertNothingQueued() + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + $instance->assertNothingQueued(); + } + /** + * Assert the total number of mailables that were sent. + * + * @param int $count + * @return void + * @static + */ public static function assertSentCount($count) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + $instance->assertSentCount($count); + } + /** + * Assert the total number of mailables that were queued. + * + * @param int $count + * @return void + * @static + */ public static function assertQueuedCount($count) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + $instance->assertQueuedCount($count); + } + /** + * Assert the total number of mailables that were sent or queued. + * + * @param int $count + * @return void + * @static + */ public static function assertOutgoingCount($count) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + $instance->assertOutgoingCount($count); + } + /** + * Get all of the mailables matching a truth-test callback. + * + * @param string|\Closure $mailable + * @param callable|null $callback + * @return \Illuminate\Support\Collection + * @static + */ public static function sent($mailable, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + return $instance->sent($mailable, $callback); + } + /** + * Determine if the given mailable has been sent. + * + * @param string $mailable + * @return bool + * @static + */ public static function hasSent($mailable) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + return $instance->hasSent($mailable); + } + /** + * Get all of the queued mailables matching a truth-test callback. + * + * @param string|\Closure $mailable + * @param callable|null $callback + * @return \Illuminate\Support\Collection + * @static + */ public static function queued($mailable, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + return $instance->queued($mailable, $callback); + } + /** + * Determine if the given mailable has been queued. + * + * @param string $mailable + * @return bool + * @static + */ public static function hasQueued($mailable) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + return $instance->hasQueued($mailable); + } + /** + * Begin the process of mailing a mailable class instance. + * + * @param mixed $users + * @return \Illuminate\Mail\PendingMail + * @static + */ public static function to($users) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + return $instance->to($users); + } + /** + * Begin the process of mailing a mailable class instance. + * + * @param mixed $users + * @return \Illuminate\Mail\PendingMail + * @static + */ public static function cc($users) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + return $instance->cc($users); + } + /** + * Begin the process of mailing a mailable class instance. + * + * @param mixed $users + * @return \Illuminate\Mail\PendingMail + * @static + */ public static function bcc($users) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + return $instance->bcc($users); + } + /** + * Send a new message with only a raw text part. + * + * @param string $text + * @param \Closure|string $callback + * @return void + * @static + */ public static function raw($text, $callback) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + $instance->raw($text, $callback); + } + /** + * Send a new message using a view. + * + * @param \Illuminate\Contracts\Mail\Mailable|string|array $view + * @param array $data + * @param \Closure|string|null $callback + * @return mixed|void + * @static + */ public static function send($view, $data = [], $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + return $instance->send($view, $data, $callback); + } + /** + * Send a new message synchronously using a view. + * + * @param \Illuminate\Contracts\Mail\Mailable|string|array $mailable + * @param array $data + * @param \Closure|string|null $callback + * @return void + * @static + */ public static function sendNow($mailable, $data = [], $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + $instance->sendNow($mailable, $data, $callback); + } + /** + * Queue a new message for sending. + * + * @param \Illuminate\Contracts\Mail\Mailable|string|array $view + * @param string|null $queue + * @return mixed + * @static + */ public static function queue($view, $queue = null) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + return $instance->queue($view, $queue); + } + /** + * Queue a new e-mail message for sending after (n) seconds. + * + * @param \DateTimeInterface|\DateInterval|int $delay + * @param \Illuminate\Contracts\Mail\Mailable|string|array $view + * @param string|null $queue + * @return mixed + * @static + */ public static function later($delay, $view, $queue = null) + { + /** @var \Illuminate\Support\Testing\Fakes\MailFake $instance */ + return $instance->later($delay, $view, $queue); + } + } + /** + * + * + * @see \Illuminate\Notifications\ChannelManager + * @see \Illuminate\Support\Testing\Fakes\NotificationFake + */ class Notification { + /** + * Send the given notification to the given notifiable entities. + * + * @param \Illuminate\Support\Collection|array|mixed $notifiables + * @param mixed $notification + * @return void + * @static + */ public static function send($notifiables, $notification) + { + /** @var \Illuminate\Notifications\ChannelManager $instance */ + $instance->send($notifiables, $notification); + } + /** + * Send the given notification immediately. + * + * @param \Illuminate\Support\Collection|array|mixed $notifiables + * @param mixed $notification + * @param array|null $channels + * @return void + * @static + */ public static function sendNow($notifiables, $notification, $channels = null) + { + /** @var \Illuminate\Notifications\ChannelManager $instance */ + $instance->sendNow($notifiables, $notification, $channels); + } + /** + * Get a channel instance. + * + * @param string|null $name + * @return mixed + * @static + */ public static function channel($name = null) + { + /** @var \Illuminate\Notifications\ChannelManager $instance */ + return $instance->channel($name); + } + /** + * Get the default channel driver name. + * + * @return string + * @static + */ public static function getDefaultDriver() + { + /** @var \Illuminate\Notifications\ChannelManager $instance */ + return $instance->getDefaultDriver(); + } + /** + * Get the default channel driver name. + * + * @return string + * @static + */ public static function deliversVia() + { + /** @var \Illuminate\Notifications\ChannelManager $instance */ + return $instance->deliversVia(); + } + /** + * Set the default channel driver name. + * + * @param string $channel + * @return void + * @static + */ public static function deliverVia($channel) + { + /** @var \Illuminate\Notifications\ChannelManager $instance */ + $instance->deliverVia($channel); + } + /** + * Set the locale of notifications. + * + * @param string $locale + * @return \Illuminate\Notifications\ChannelManager + * @static + */ public static function locale($locale) + { + /** @var \Illuminate\Notifications\ChannelManager $instance */ + return $instance->locale($locale); + } + /** + * Get a driver instance. + * + * @param string|null $driver + * @return mixed + * @throws \InvalidArgumentException + * @static + */ public static function driver($driver = null) + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Notifications\ChannelManager $instance */ + return $instance->driver($driver); + } + /** + * Register a custom driver creator Closure. + * + * @param string $driver + * @param \Closure $callback + * @return \Illuminate\Notifications\ChannelManager + * @static + */ public static function extend($driver, $callback) + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Notifications\ChannelManager $instance */ + return $instance->extend($driver, $callback); + } + /** + * Get all of the created "drivers". + * + * @return array + * @static + */ public static function getDrivers() + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Notifications\ChannelManager $instance */ + return $instance->getDrivers(); + } + /** + * Get the container instance used by the manager. + * + * @return \Illuminate\Contracts\Container\Container + * @static + */ public static function getContainer() + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Notifications\ChannelManager $instance */ + return $instance->getContainer(); + } + /** + * Set the container instance used by the manager. + * + * @param \Illuminate\Contracts\Container\Container $container + * @return \Illuminate\Notifications\ChannelManager + * @static + */ public static function setContainer($container) + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Notifications\ChannelManager $instance */ + return $instance->setContainer($container); + } + /** + * Forget all of the resolved driver instances. + * + * @return \Illuminate\Notifications\ChannelManager + * @static + */ public static function forgetDrivers() + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Notifications\ChannelManager $instance */ + return $instance->forgetDrivers(); + } + /** + * Assert if a notification was sent on-demand based on a truth-test callback. + * + * @param string|\Closure $notification + * @param callable|null $callback + * @return void + * @throws \Exception + * @static + */ public static function assertSentOnDemand($notification, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\NotificationFake $instance */ + $instance->assertSentOnDemand($notification, $callback); + } + /** + * Assert if a notification was sent based on a truth-test callback. + * + * @param mixed $notifiable + * @param string|\Closure $notification + * @param callable|null $callback + * @return void + * @throws \Exception + * @static + */ public static function assertSentTo($notifiable, $notification, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\NotificationFake $instance */ + $instance->assertSentTo($notifiable, $notification, $callback); + } + /** + * Assert if a notification was sent on-demand a number of times. + * + * @param string $notification + * @param int $times + * @return void + * @static + */ public static function assertSentOnDemandTimes($notification, $times = 1) + { + /** @var \Illuminate\Support\Testing\Fakes\NotificationFake $instance */ + $instance->assertSentOnDemandTimes($notification, $times); + } + /** + * Assert if a notification was sent a number of times. + * + * @param mixed $notifiable + * @param string $notification + * @param int $times + * @return void + * @static + */ public static function assertSentToTimes($notifiable, $notification, $times = 1) + { + /** @var \Illuminate\Support\Testing\Fakes\NotificationFake $instance */ + $instance->assertSentToTimes($notifiable, $notification, $times); + } + /** + * Determine if a notification was sent based on a truth-test callback. + * + * @param mixed $notifiable + * @param string|\Closure $notification + * @param callable|null $callback + * @return void + * @throws \Exception + * @static + */ public static function assertNotSentTo($notifiable, $notification, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\NotificationFake $instance */ + $instance->assertNotSentTo($notifiable, $notification, $callback); + } + /** + * Assert that no notifications were sent. + * + * @return void + * @static + */ public static function assertNothingSent() + { + /** @var \Illuminate\Support\Testing\Fakes\NotificationFake $instance */ + $instance->assertNothingSent(); + } + /** + * Assert that no notifications were sent to the given notifiable. + * + * @param mixed $notifiable + * @return void + * @throws \Exception + * @static + */ public static function assertNothingSentTo($notifiable) + { + /** @var \Illuminate\Support\Testing\Fakes\NotificationFake $instance */ + $instance->assertNothingSentTo($notifiable); + } + /** + * Assert the total amount of times a notification was sent. + * + * @param string $notification + * @param int $expectedCount + * @return void + * @static + */ public static function assertSentTimes($notification, $expectedCount) + { + /** @var \Illuminate\Support\Testing\Fakes\NotificationFake $instance */ + $instance->assertSentTimes($notification, $expectedCount); + } + /** + * Assert the total count of notification that were sent. + * + * @param int $expectedCount + * @return void + * @static + */ public static function assertCount($expectedCount) + { + /** @var \Illuminate\Support\Testing\Fakes\NotificationFake $instance */ + $instance->assertCount($expectedCount); + } + /** + * Get all of the notifications matching a truth-test callback. + * + * @param mixed $notifiable + * @param string $notification + * @param callable|null $callback + * @return \Illuminate\Support\Collection + * @static + */ public static function sent($notifiable, $notification, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\NotificationFake $instance */ + return $instance->sent($notifiable, $notification, $callback); + } + /** + * Determine if there are more notifications left to inspect. + * + * @param mixed $notifiable + * @param string $notification + * @return bool + * @static + */ public static function hasSent($notifiable, $notification) + { + /** @var \Illuminate\Support\Testing\Fakes\NotificationFake $instance */ + return $instance->hasSent($notifiable, $notification); + } + /** + * Specify if notification should be serialized and restored when being "pushed" to the queue. + * + * @param bool $serializeAndRestore + * @return \Illuminate\Support\Testing\Fakes\NotificationFake + * @static + */ public static function serializeAndRestore($serializeAndRestore = true) + { + /** @var \Illuminate\Support\Testing\Fakes\NotificationFake $instance */ + return $instance->serializeAndRestore($serializeAndRestore); + } + /** + * Get the notifications that have been sent. + * + * @return array + * @static + */ public static function sentNotifications() + { + /** @var \Illuminate\Support\Testing\Fakes\NotificationFake $instance */ + return $instance->sentNotifications(); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Support\Testing\Fakes\NotificationFake::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Support\Testing\Fakes\NotificationFake::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Support\Testing\Fakes\NotificationFake::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Support\Testing\Fakes\NotificationFake::flushMacros(); + } + } + /** + * + * + * @method static string sendResetLink(array $credentials, \Closure|null $callback = null) + * @method static mixed reset(array $credentials, \Closure $callback) + * @method static \Illuminate\Contracts\Auth\CanResetPassword|null getUser(array $credentials) + * @method static string createToken(\Illuminate\Contracts\Auth\CanResetPassword $user) + * @method static void deleteToken(\Illuminate\Contracts\Auth\CanResetPassword $user) + * @method static bool tokenExists(\Illuminate\Contracts\Auth\CanResetPassword $user, string $token) + * @method static \Illuminate\Auth\Passwords\TokenRepositoryInterface getRepository() + * @see \Illuminate\Auth\Passwords\PasswordBrokerManager + * @see \Illuminate\Auth\Passwords\PasswordBroker + */ class Password { + /** + * Attempt to get the broker from the local cache. + * + * @param string|null $name + * @return \Illuminate\Contracts\Auth\PasswordBroker + * @static + */ public static function broker($name = null) + { + /** @var \Illuminate\Auth\Passwords\PasswordBrokerManager $instance */ + return $instance->broker($name); + } + /** + * Get the default password broker name. + * + * @return string + * @static + */ public static function getDefaultDriver() + { + /** @var \Illuminate\Auth\Passwords\PasswordBrokerManager $instance */ + return $instance->getDefaultDriver(); + } + /** + * Set the default password broker name. + * + * @param string $name + * @return void + * @static + */ public static function setDefaultDriver($name) + { + /** @var \Illuminate\Auth\Passwords\PasswordBrokerManager $instance */ + $instance->setDefaultDriver($name); + } + } + /** + * + * + * @method static \Illuminate\Process\PendingProcess command(array|string $command) + * @method static \Illuminate\Process\PendingProcess path(string $path) + * @method static \Illuminate\Process\PendingProcess timeout(int $timeout) + * @method static \Illuminate\Process\PendingProcess idleTimeout(int $timeout) + * @method static \Illuminate\Process\PendingProcess forever() + * @method static \Illuminate\Process\PendingProcess env(array $environment) + * @method static \Illuminate\Process\PendingProcess input(\Traversable|resource|string|int|float|bool|null $input) + * @method static \Illuminate\Process\PendingProcess quietly() + * @method static \Illuminate\Process\PendingProcess tty(bool $tty = true) + * @method static \Illuminate\Process\PendingProcess options(array $options) + * @method static \Illuminate\Contracts\Process\ProcessResult run(array|string|null $command = null, callable|null $output = null) + * @method static \Illuminate\Process\InvokedProcess start(array|string|null $command = null, callable|null $output = null) + * @method static \Illuminate\Process\PendingProcess withFakeHandlers(array $fakeHandlers) + * @method static \Illuminate\Process\PendingProcess|mixed when(\Closure|mixed|null $value = null, callable|null $callback = null, callable|null $default = null) + * @method static \Illuminate\Process\PendingProcess|mixed unless(\Closure|mixed|null $value = null, callable|null $callback = null, callable|null $default = null) + * @see \Illuminate\Process\PendingProcess + * @see \Illuminate\Process\Factory + */ class Process { + /** + * Create a new fake process response for testing purposes. + * + * @param array|string $output + * @param array|string $errorOutput + * @param int $exitCode + * @return \Illuminate\Process\FakeProcessResult + * @static + */ public static function result($output = '', $errorOutput = '', $exitCode = 0) + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->result($output, $errorOutput, $exitCode); + } + /** + * Begin describing a fake process lifecycle. + * + * @return \Illuminate\Process\FakeProcessDescription + * @static + */ public static function describe() + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->describe(); + } + /** + * Begin describing a fake process sequence. + * + * @param array $processes + * @return \Illuminate\Process\FakeProcessSequence + * @static + */ public static function sequence($processes = []) + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->sequence($processes); + } + /** + * Indicate that the process factory should fake processes. + * + * @param \Closure|array|null $callback + * @return \Illuminate\Process\Factory + * @static + */ public static function fake($callback = null) + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->fake($callback); + } + /** + * Determine if the process factory has fake process handlers and is recording processes. + * + * @return bool + * @static + */ public static function isRecording() + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->isRecording(); + } + /** + * Record the given process if processes should be recorded. + * + * @param \Illuminate\Process\PendingProcess $process + * @param \Illuminate\Contracts\Process\ProcessResult $result + * @return \Illuminate\Process\Factory + * @static + */ public static function recordIfRecording($process, $result) + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->recordIfRecording($process, $result); + } + /** + * Record the given process. + * + * @param \Illuminate\Process\PendingProcess $process + * @param \Illuminate\Contracts\Process\ProcessResult $result + * @return \Illuminate\Process\Factory + * @static + */ public static function record($process, $result) + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->record($process, $result); + } + /** + * Indicate that an exception should be thrown if any process is not faked. + * + * @param bool $prevent + * @return \Illuminate\Process\Factory + * @static + */ public static function preventStrayProcesses($prevent = true) + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->preventStrayProcesses($prevent); + } + /** + * Determine if stray processes are being prevented. + * + * @return bool + * @static + */ public static function preventingStrayProcesses() + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->preventingStrayProcesses(); + } + /** + * Assert that a process was recorded matching a given truth test. + * + * @param \Closure|string $callback + * @return \Illuminate\Process\Factory + * @static + */ public static function assertRan($callback) + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->assertRan($callback); + } + /** + * Assert that a process was recorded a given number of times matching a given truth test. + * + * @param \Closure|string $callback + * @param int $times + * @return \Illuminate\Process\Factory + * @static + */ public static function assertRanTimes($callback, $times = 1) + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->assertRanTimes($callback, $times); + } + /** + * Assert that a process was not recorded matching a given truth test. + * + * @param \Closure|string $callback + * @return \Illuminate\Process\Factory + * @static + */ public static function assertNotRan($callback) + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->assertNotRan($callback); + } + /** + * Assert that a process was not recorded matching a given truth test. + * + * @param \Closure|string $callback + * @return \Illuminate\Process\Factory + * @static + */ public static function assertDidntRun($callback) + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->assertDidntRun($callback); + } + /** + * Assert that no processes were recorded. + * + * @return \Illuminate\Process\Factory + * @static + */ public static function assertNothingRan() + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->assertNothingRan(); + } + /** + * Start defining a pool of processes. + * + * @param callable $callback + * @return \Illuminate\Process\Pool + * @static + */ public static function pool($callback) + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->pool($callback); + } + /** + * Start defining a series of piped processes. + * + * @param callable|array $callback + * @return \Illuminate\Contracts\Process\ProcessResult + * @static + */ public static function pipe($callback, $output = null) + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->pipe($callback, $output); + } + /** + * Run a pool of processes and wait for them to finish executing. + * + * @param callable $callback + * @param callable|null $output + * @return \Illuminate\Process\ProcessPoolResults + * @static + */ public static function concurrently($callback, $output = null) + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->concurrently($callback, $output); + } + /** + * Create a new pending process associated with this factory. + * + * @return \Illuminate\Process\PendingProcess + * @static + */ public static function newPendingProcess() + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->newPendingProcess(); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Process\Factory::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Process\Factory::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Process\Factory::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Process\Factory::flushMacros(); + } + /** + * Dynamically handle calls to the class. + * + * @param string $method + * @param array $parameters + * @return mixed + * @throws \BadMethodCallException + * @static + */ public static function macroCall($method, $parameters) + { + /** @var \Illuminate\Process\Factory $instance */ + return $instance->macroCall($method, $parameters); + } + } + /** + * + * + * @see \Illuminate\Queue\QueueManager + * @see \Illuminate\Queue\Queue + * @see \Illuminate\Support\Testing\Fakes\QueueFake + */ class Queue { + /** + * Register an event listener for the before job event. + * + * @param mixed $callback + * @return void + * @static + */ public static function before($callback) + { + /** @var \Illuminate\Queue\QueueManager $instance */ + $instance->before($callback); + } + /** + * Register an event listener for the after job event. + * + * @param mixed $callback + * @return void + * @static + */ public static function after($callback) + { + /** @var \Illuminate\Queue\QueueManager $instance */ + $instance->after($callback); + } + /** + * Register an event listener for the exception occurred job event. + * + * @param mixed $callback + * @return void + * @static + */ public static function exceptionOccurred($callback) + { + /** @var \Illuminate\Queue\QueueManager $instance */ + $instance->exceptionOccurred($callback); + } + /** + * Register an event listener for the daemon queue loop. + * + * @param mixed $callback + * @return void + * @static + */ public static function looping($callback) + { + /** @var \Illuminate\Queue\QueueManager $instance */ + $instance->looping($callback); + } + /** + * Register an event listener for the failed job event. + * + * @param mixed $callback + * @return void + * @static + */ public static function failing($callback) + { + /** @var \Illuminate\Queue\QueueManager $instance */ + $instance->failing($callback); + } + /** + * Register an event listener for the daemon queue stopping. + * + * @param mixed $callback + * @return void + * @static + */ public static function stopping($callback) + { + /** @var \Illuminate\Queue\QueueManager $instance */ + $instance->stopping($callback); + } + /** + * Determine if the driver is connected. + * + * @param string|null $name + * @return bool + * @static + */ public static function connected($name = null) + { + /** @var \Illuminate\Queue\QueueManager $instance */ + return $instance->connected($name); + } + /** + * Resolve a queue connection instance. + * + * @param string|null $name + * @return \Illuminate\Contracts\Queue\Queue + * @static + */ public static function connection($name = null) + { + /** @var \Illuminate\Queue\QueueManager $instance */ + return $instance->connection($name); + } + /** + * Add a queue connection resolver. + * + * @param string $driver + * @param \Closure $resolver + * @return void + * @static + */ public static function extend($driver, $resolver) + { + /** @var \Illuminate\Queue\QueueManager $instance */ + $instance->extend($driver, $resolver); + } + /** + * Add a queue connection resolver. + * + * @param string $driver + * @param \Closure $resolver + * @return void + * @static + */ public static function addConnector($driver, $resolver) + { + /** @var \Illuminate\Queue\QueueManager $instance */ + $instance->addConnector($driver, $resolver); + } + /** + * Get the name of the default queue connection. + * + * @return string + * @static + */ public static function getDefaultDriver() + { + /** @var \Illuminate\Queue\QueueManager $instance */ + return $instance->getDefaultDriver(); + } + /** + * Set the name of the default queue connection. + * + * @param string $name + * @return void + * @static + */ public static function setDefaultDriver($name) + { + /** @var \Illuminate\Queue\QueueManager $instance */ + $instance->setDefaultDriver($name); + } + /** + * Get the full name for the given connection. + * + * @param string|null $connection + * @return string + * @static + */ public static function getName($connection = null) + { + /** @var \Illuminate\Queue\QueueManager $instance */ + return $instance->getName($connection); + } + /** + * Get the application instance used by the manager. + * + * @return \Illuminate\Contracts\Foundation\Application + * @static + */ public static function getApplication() + { + /** @var \Illuminate\Queue\QueueManager $instance */ + return $instance->getApplication(); + } + /** + * Set the application instance used by the manager. + * + * @param \Illuminate\Contracts\Foundation\Application $app + * @return \Illuminate\Queue\QueueManager + * @static + */ public static function setApplication($app) + { + /** @var \Illuminate\Queue\QueueManager $instance */ + return $instance->setApplication($app); + } + /** + * Specify the jobs that should be queued instead of faked. + * + * @param array|string $jobsToBeQueued + * @return \Illuminate\Support\Testing\Fakes\QueueFake + * @static + */ public static function except($jobsToBeQueued) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + return $instance->except($jobsToBeQueued); + } + /** + * Assert if a job was pushed based on a truth-test callback. + * + * @param string|\Closure $job + * @param callable|int|null $callback + * @return void + * @static + */ public static function assertPushed($job, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + $instance->assertPushed($job, $callback); + } + /** + * Assert if a job was pushed based on a truth-test callback. + * + * @param string $queue + * @param string|\Closure $job + * @param callable|null $callback + * @return void + * @static + */ public static function assertPushedOn($queue, $job, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + $instance->assertPushedOn($queue, $job, $callback); + } + /** + * Assert if a job was pushed with chained jobs based on a truth-test callback. + * + * @param string $job + * @param array $expectedChain + * @param callable|null $callback + * @return void + * @static + */ public static function assertPushedWithChain($job, $expectedChain = [], $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + $instance->assertPushedWithChain($job, $expectedChain, $callback); + } + /** + * Assert if a job was pushed with an empty chain based on a truth-test callback. + * + * @param string $job + * @param callable|null $callback + * @return void + * @static + */ public static function assertPushedWithoutChain($job, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + $instance->assertPushedWithoutChain($job, $callback); + } + /** + * Assert if a closure was pushed based on a truth-test callback. + * + * @param callable|int|null $callback + * @return void + * @static + */ public static function assertClosurePushed($callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + $instance->assertClosurePushed($callback); + } + /** + * Assert that a closure was not pushed based on a truth-test callback. + * + * @param callable|null $callback + * @return void + * @static + */ public static function assertClosureNotPushed($callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + $instance->assertClosureNotPushed($callback); + } + /** + * Determine if a job was pushed based on a truth-test callback. + * + * @param string|\Closure $job + * @param callable|null $callback + * @return void + * @static + */ public static function assertNotPushed($job, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + $instance->assertNotPushed($job, $callback); + } + /** + * Assert the total count of jobs that were pushed. + * + * @param int $expectedCount + * @return void + * @static + */ public static function assertCount($expectedCount) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + $instance->assertCount($expectedCount); + } + /** + * Assert that no jobs were pushed. + * + * @return void + * @static + */ public static function assertNothingPushed() + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + $instance->assertNothingPushed(); + } + /** + * Get all of the jobs matching a truth-test callback. + * + * @param string $job + * @param callable|null $callback + * @return \Illuminate\Support\Collection + * @static + */ public static function pushed($job, $callback = null) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + return $instance->pushed($job, $callback); + } + /** + * Determine if there are any stored jobs for a given class. + * + * @param string $job + * @return bool + * @static + */ public static function hasPushed($job) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + return $instance->hasPushed($job); + } + /** + * Get the size of the queue. + * + * @param string|null $queue + * @return int + * @static + */ public static function size($queue = null) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + return $instance->size($queue); + } + /** + * Push a new job onto the queue. + * + * @param string|object $job + * @param mixed $data + * @param string|null $queue + * @return mixed + * @static + */ public static function push($job, $data = '', $queue = null) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + return $instance->push($job, $data, $queue); + } + /** + * Determine if a job should be faked or actually dispatched. + * + * @param object $job + * @return bool + * @static + */ public static function shouldFakeJob($job) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + return $instance->shouldFakeJob($job); + } + /** + * Push a raw payload onto the queue. + * + * @param string $payload + * @param string|null $queue + * @param array $options + * @return mixed + * @static + */ public static function pushRaw($payload, $queue = null, $options = []) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + return $instance->pushRaw($payload, $queue, $options); + } + /** + * Push a new job onto the queue after (n) seconds. + * + * @param \DateTimeInterface|\DateInterval|int $delay + * @param string|object $job + * @param mixed $data + * @param string|null $queue + * @return mixed + * @static + */ public static function later($delay, $job, $data = '', $queue = null) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + return $instance->later($delay, $job, $data, $queue); + } + /** + * Push a new job onto the queue. + * + * @param string $queue + * @param string|object $job + * @param mixed $data + * @return mixed + * @static + */ public static function pushOn($queue, $job, $data = '') + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + return $instance->pushOn($queue, $job, $data); + } + /** + * Push a new job onto a specific queue after (n) seconds. + * + * @param string $queue + * @param \DateTimeInterface|\DateInterval|int $delay + * @param string|object $job + * @param mixed $data + * @return mixed + * @static + */ public static function laterOn($queue, $delay, $job, $data = '') + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + return $instance->laterOn($queue, $delay, $job, $data); + } + /** + * Pop the next job off of the queue. + * + * @param string|null $queue + * @return \Illuminate\Contracts\Queue\Job|null + * @static + */ public static function pop($queue = null) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + return $instance->pop($queue); + } + /** + * Push an array of jobs onto the queue. + * + * @param array $jobs + * @param mixed $data + * @param string|null $queue + * @return mixed + * @static + */ public static function bulk($jobs, $data = '', $queue = null) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + return $instance->bulk($jobs, $data, $queue); + } + /** + * Get the jobs that have been pushed. + * + * @return array + * @static + */ public static function pushedJobs() + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + return $instance->pushedJobs(); + } + /** + * Specify if jobs should be serialized and restored when being "pushed" to the queue. + * + * @param bool $serializeAndRestore + * @return \Illuminate\Support\Testing\Fakes\QueueFake + * @static + */ public static function serializeAndRestore($serializeAndRestore = true) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + return $instance->serializeAndRestore($serializeAndRestore); + } + /** + * Get the connection name for the queue. + * + * @return string + * @static + */ public static function getConnectionName() + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + return $instance->getConnectionName(); + } + /** + * Set the connection name for the queue. + * + * @param string $name + * @return \Illuminate\Support\Testing\Fakes\QueueFake + * @static + */ public static function setConnectionName($name) + { + /** @var \Illuminate\Support\Testing\Fakes\QueueFake $instance */ + return $instance->setConnectionName($name); + } + /** + * Release a reserved job back onto the queue after (n) seconds. + * + * @param string $queue + * @param \Illuminate\Queue\Jobs\DatabaseJobRecord $job + * @param int $delay + * @return mixed + * @static + */ public static function release($queue, $job, $delay) + { + /** @var \Illuminate\Queue\DatabaseQueue $instance */ + return $instance->release($queue, $job, $delay); + } + /** + * Delete a reserved job from the queue. + * + * @param string $queue + * @param string $id + * @return void + * @throws \Throwable + * @static + */ public static function deleteReserved($queue, $id) + { + /** @var \Illuminate\Queue\DatabaseQueue $instance */ + $instance->deleteReserved($queue, $id); + } + /** + * Delete a reserved job from the reserved queue and release it. + * + * @param string $queue + * @param \Illuminate\Queue\Jobs\DatabaseJob $job + * @param int $delay + * @return void + * @static + */ public static function deleteAndRelease($queue, $job, $delay) + { + /** @var \Illuminate\Queue\DatabaseQueue $instance */ + $instance->deleteAndRelease($queue, $job, $delay); + } + /** + * Delete all of the jobs from the queue. + * + * @param string $queue + * @return int + * @static + */ public static function clear($queue) + { + /** @var \Illuminate\Queue\DatabaseQueue $instance */ + return $instance->clear($queue); + } + /** + * Get the queue or return the default. + * + * @param string|null $queue + * @return string + * @static + */ public static function getQueue($queue) + { + /** @var \Illuminate\Queue\DatabaseQueue $instance */ + return $instance->getQueue($queue); + } + /** + * Get the underlying database instance. + * + * @return \Illuminate\Database\Connection + * @static + */ public static function getDatabase() + { + /** @var \Illuminate\Queue\DatabaseQueue $instance */ + return $instance->getDatabase(); + } + /** + * Get the maximum number of attempts for an object-based queue handler. + * + * @param mixed $job + * @return mixed + * @static + */ public static function getJobTries($job) + { //Method inherited from \Illuminate\Queue\Queue + /** @var \Illuminate\Queue\DatabaseQueue $instance */ + return $instance->getJobTries($job); + } + /** + * Get the backoff for an object-based queue handler. + * + * @param mixed $job + * @return mixed + * @static + */ public static function getJobBackoff($job) + { //Method inherited from \Illuminate\Queue\Queue + /** @var \Illuminate\Queue\DatabaseQueue $instance */ + return $instance->getJobBackoff($job); + } + /** + * Get the expiration timestamp for an object-based queue handler. + * + * @param mixed $job + * @return mixed + * @static + */ public static function getJobExpiration($job) + { //Method inherited from \Illuminate\Queue\Queue + /** @var \Illuminate\Queue\DatabaseQueue $instance */ + return $instance->getJobExpiration($job); + } + /** + * Register a callback to be executed when creating job payloads. + * + * @param callable|null $callback + * @return void + * @static + */ public static function createPayloadUsing($callback) + { //Method inherited from \Illuminate\Queue\Queue + \Illuminate\Queue\DatabaseQueue::createPayloadUsing($callback); + } + /** + * Get the container instance being used by the connection. + * + * @return \Illuminate\Container\Container + * @static + */ public static function getContainer() + { //Method inherited from \Illuminate\Queue\Queue + /** @var \Illuminate\Queue\DatabaseQueue $instance */ + return $instance->getContainer(); + } + /** + * Set the IoC container instance. + * + * @param \Illuminate\Container\Container $container + * @return void + * @static + */ public static function setContainer($container) + { //Method inherited from \Illuminate\Queue\Queue + /** @var \Illuminate\Queue\DatabaseQueue $instance */ + $instance->setContainer($container); + } + } + /** + * + * + * @see \Illuminate\Cache\RateLimiter + */ class RateLimiter { + /** + * Register a named limiter configuration. + * + * @param string $name + * @param \Closure $callback + * @return \Illuminate\Cache\RateLimiter + * @static + */ public static function for($name, $callback) + { + /** @var \Illuminate\Cache\RateLimiter $instance */ + return $instance->for($name, $callback); + } + /** + * Get the given named rate limiter. + * + * @param string $name + * @return \Closure|null + * @static + */ public static function limiter($name) + { + /** @var \Illuminate\Cache\RateLimiter $instance */ + return $instance->limiter($name); + } + /** + * Attempts to execute a callback if it's not limited. + * + * @param string $key + * @param int $maxAttempts + * @param \Closure $callback + * @param int $decaySeconds + * @return mixed + * @static + */ public static function attempt($key, $maxAttempts, $callback, $decaySeconds = 60) + { + /** @var \Illuminate\Cache\RateLimiter $instance */ + return $instance->attempt($key, $maxAttempts, $callback, $decaySeconds); + } + /** + * Determine if the given key has been "accessed" too many times. + * + * @param string $key + * @param int $maxAttempts + * @return bool + * @static + */ public static function tooManyAttempts($key, $maxAttempts) + { + /** @var \Illuminate\Cache\RateLimiter $instance */ + return $instance->tooManyAttempts($key, $maxAttempts); + } + /** + * Increment (by 1) the counter for a given key for a given decay time. + * + * @param string $key + * @param int $decaySeconds + * @return int + * @static + */ public static function hit($key, $decaySeconds = 60) + { + /** @var \Illuminate\Cache\RateLimiter $instance */ + return $instance->hit($key, $decaySeconds); + } + /** + * Increment the counter for a given key for a given decay time by a given amount. + * + * @param string $key + * @param int $decaySeconds + * @param int $amount + * @return int + * @static + */ public static function increment($key, $decaySeconds = 60, $amount = 1) + { + /** @var \Illuminate\Cache\RateLimiter $instance */ + return $instance->increment($key, $decaySeconds, $amount); + } + /** + * Decrement the counter for a given key for a given decay time by a given amount. + * + * @param string $key + * @param int $decaySeconds + * @param int $amount + * @return int + * @static + */ public static function decrement($key, $decaySeconds = 60, $amount = 1) + { + /** @var \Illuminate\Cache\RateLimiter $instance */ + return $instance->decrement($key, $decaySeconds, $amount); + } + /** + * Get the number of attempts for the given key. + * + * @param string $key + * @return mixed + * @static + */ public static function attempts($key) + { + /** @var \Illuminate\Cache\RateLimiter $instance */ + return $instance->attempts($key); + } + /** + * Reset the number of attempts for the given key. + * + * @param string $key + * @return mixed + * @static + */ public static function resetAttempts($key) + { + /** @var \Illuminate\Cache\RateLimiter $instance */ + return $instance->resetAttempts($key); + } + /** + * Get the number of retries left for the given key. + * + * @param string $key + * @param int $maxAttempts + * @return int + * @static + */ public static function remaining($key, $maxAttempts) + { + /** @var \Illuminate\Cache\RateLimiter $instance */ + return $instance->remaining($key, $maxAttempts); + } + /** + * Get the number of retries left for the given key. + * + * @param string $key + * @param int $maxAttempts + * @return int + * @static + */ public static function retriesLeft($key, $maxAttempts) + { + /** @var \Illuminate\Cache\RateLimiter $instance */ + return $instance->retriesLeft($key, $maxAttempts); + } + /** + * Clear the hits and lockout timer for the given key. + * + * @param string $key + * @return void + * @static + */ public static function clear($key) + { + /** @var \Illuminate\Cache\RateLimiter $instance */ + $instance->clear($key); + } + /** + * Get the number of seconds until the "key" is accessible again. + * + * @param string $key + * @return int + * @static + */ public static function availableIn($key) + { + /** @var \Illuminate\Cache\RateLimiter $instance */ + return $instance->availableIn($key); + } + /** + * Clean the rate limiter key from unicode characters. + * + * @param string $key + * @return string + * @static + */ public static function cleanRateLimiterKey($key) + { + /** @var \Illuminate\Cache\RateLimiter $instance */ + return $instance->cleanRateLimiterKey($key); + } + } + /** + * + * + * @see \Illuminate\Routing\Redirector + */ class Redirect { + /** + * Create a new redirect response to the previous location. + * + * @param int $status + * @param array $headers + * @param mixed $fallback + * @return \Illuminate\Http\RedirectResponse + * @static + */ public static function back($status = 302, $headers = [], $fallback = false) + { + /** @var \Illuminate\Routing\Redirector $instance */ + return $instance->back($status, $headers, $fallback); + } + /** + * Create a new redirect response to the current URI. + * + * @param int $status + * @param array $headers + * @return \Illuminate\Http\RedirectResponse + * @static + */ public static function refresh($status = 302, $headers = []) + { + /** @var \Illuminate\Routing\Redirector $instance */ + return $instance->refresh($status, $headers); + } + /** + * Create a new redirect response, while putting the current URL in the session. + * + * @param string $path + * @param int $status + * @param array $headers + * @param bool|null $secure + * @return \Illuminate\Http\RedirectResponse + * @static + */ public static function guest($path, $status = 302, $headers = [], $secure = null) + { + /** @var \Illuminate\Routing\Redirector $instance */ + return $instance->guest($path, $status, $headers, $secure); + } + /** + * Create a new redirect response to the previously intended location. + * + * @param mixed $default + * @param int $status + * @param array $headers + * @param bool|null $secure + * @return \Illuminate\Http\RedirectResponse + * @static + */ public static function intended($default = '/', $status = 302, $headers = [], $secure = null) + { + /** @var \Illuminate\Routing\Redirector $instance */ + return $instance->intended($default, $status, $headers, $secure); + } + /** + * Create a new redirect response to the given path. + * + * @param string $path + * @param int $status + * @param array $headers + * @param bool|null $secure + * @return \Illuminate\Http\RedirectResponse + * @static + */ public static function to($path, $status = 302, $headers = [], $secure = null) + { + /** @var \Illuminate\Routing\Redirector $instance */ + return $instance->to($path, $status, $headers, $secure); + } + /** + * Create a new redirect response to an external URL (no validation). + * + * @param string $path + * @param int $status + * @param array $headers + * @return \Illuminate\Http\RedirectResponse + * @static + */ public static function away($path, $status = 302, $headers = []) + { + /** @var \Illuminate\Routing\Redirector $instance */ + return $instance->away($path, $status, $headers); + } + /** + * Create a new redirect response to the given HTTPS path. + * + * @param string $path + * @param int $status + * @param array $headers + * @return \Illuminate\Http\RedirectResponse + * @static + */ public static function secure($path, $status = 302, $headers = []) + { + /** @var \Illuminate\Routing\Redirector $instance */ + return $instance->secure($path, $status, $headers); + } + /** + * Create a new redirect response to a named route. + * + * @param string $route + * @param mixed $parameters + * @param int $status + * @param array $headers + * @return \Illuminate\Http\RedirectResponse + * @static + */ public static function route($route, $parameters = [], $status = 302, $headers = []) + { + /** @var \Illuminate\Routing\Redirector $instance */ + return $instance->route($route, $parameters, $status, $headers); + } + /** + * Create a new redirect response to a signed named route. + * + * @param string $route + * @param mixed $parameters + * @param \DateTimeInterface|\DateInterval|int|null $expiration + * @param int $status + * @param array $headers + * @return \Illuminate\Http\RedirectResponse + * @static + */ public static function signedRoute($route, $parameters = [], $expiration = null, $status = 302, $headers = []) + { + /** @var \Illuminate\Routing\Redirector $instance */ + return $instance->signedRoute($route, $parameters, $expiration, $status, $headers); + } + /** + * Create a new redirect response to a signed named route. + * + * @param string $route + * @param \DateTimeInterface|\DateInterval|int|null $expiration + * @param mixed $parameters + * @param int $status + * @param array $headers + * @return \Illuminate\Http\RedirectResponse + * @static + */ public static function temporarySignedRoute($route, $expiration, $parameters = [], $status = 302, $headers = []) + { + /** @var \Illuminate\Routing\Redirector $instance */ + return $instance->temporarySignedRoute($route, $expiration, $parameters, $status, $headers); + } + /** + * Create a new redirect response to a controller action. + * + * @param string|array $action + * @param mixed $parameters + * @param int $status + * @param array $headers + * @return \Illuminate\Http\RedirectResponse + * @static + */ public static function action($action, $parameters = [], $status = 302, $headers = []) + { + /** @var \Illuminate\Routing\Redirector $instance */ + return $instance->action($action, $parameters, $status, $headers); + } + /** + * Get the URL generator instance. + * + * @return \Illuminate\Routing\UrlGenerator + * @static + */ public static function getUrlGenerator() + { + /** @var \Illuminate\Routing\Redirector $instance */ + return $instance->getUrlGenerator(); + } + /** + * Set the active session store. + * + * @param \Illuminate\Session\Store $session + * @return void + * @static + */ public static function setSession($session) + { + /** @var \Illuminate\Routing\Redirector $instance */ + $instance->setSession($session); + } + /** + * Get the "intended" URL from the session. + * + * @return string|null + * @static + */ public static function getIntendedUrl() + { + /** @var \Illuminate\Routing\Redirector $instance */ + return $instance->getIntendedUrl(); + } + /** + * Set the "intended" URL in the session. + * + * @param string $url + * @return \Illuminate\Routing\Redirector + * @static + */ public static function setIntendedUrl($url) + { + /** @var \Illuminate\Routing\Redirector $instance */ + return $instance->setIntendedUrl($url); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Routing\Redirector::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Routing\Redirector::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Routing\Redirector::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Routing\Redirector::flushMacros(); + } + } + /** + * + * + * @see \Illuminate\Http\Request + */ class Request { + /** + * Create a new Illuminate HTTP request from server variables. + * + * @return static + * @static + */ public static function capture() + { + return \Illuminate\Http\Request::capture(); + } + /** + * Return the Request instance. + * + * @return \Illuminate\Http\Request + * @static + */ public static function instance() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->instance(); + } + /** + * Get the request method. + * + * @return string + * @static + */ public static function method() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->method(); + } + /** + * Get the root URL for the application. + * + * @return string + * @static + */ public static function root() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->root(); + } + /** + * Get the URL (no query string) for the request. + * + * @return string + * @static + */ public static function url() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->url(); + } + /** + * Get the full URL for the request. + * + * @return string + * @static + */ public static function fullUrl() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->fullUrl(); + } + /** + * Get the full URL for the request with the added query string parameters. + * + * @param array $query + * @return string + * @static + */ public static function fullUrlWithQuery($query) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->fullUrlWithQuery($query); + } + /** + * Get the full URL for the request without the given query string parameters. + * + * @param array|string $keys + * @return string + * @static + */ public static function fullUrlWithoutQuery($keys) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->fullUrlWithoutQuery($keys); + } + /** + * Get the current path info for the request. + * + * @return string + * @static + */ public static function path() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->path(); + } + /** + * Get the current decoded path info for the request. + * + * @return string + * @static + */ public static function decodedPath() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->decodedPath(); + } + /** + * Get a segment from the URI (1 based index). + * + * @param int $index + * @param string|null $default + * @return string|null + * @static + */ public static function segment($index, $default = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->segment($index, $default); + } + /** + * Get all of the segments for the request path. + * + * @return array + * @static + */ public static function segments() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->segments(); + } + /** + * Determine if the current request URI matches a pattern. + * + * @param mixed $patterns + * @return bool + * @static + */ public static function is(...$patterns) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->is(...$patterns); + } + /** + * Determine if the route name matches a given pattern. + * + * @param mixed $patterns + * @return bool + * @static + */ public static function routeIs(...$patterns) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->routeIs(...$patterns); + } + /** + * Determine if the current request URL and query string match a pattern. + * + * @param mixed $patterns + * @return bool + * @static + */ public static function fullUrlIs(...$patterns) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->fullUrlIs(...$patterns); + } + /** + * Get the host name. + * + * @return string + * @static + */ public static function host() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->host(); + } + /** + * Get the HTTP host being requested. + * + * @return string + * @static + */ public static function httpHost() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->httpHost(); + } + /** + * Get the scheme and HTTP host. + * + * @return string + * @static + */ public static function schemeAndHttpHost() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->schemeAndHttpHost(); + } + /** + * Determine if the request is the result of an AJAX call. + * + * @return bool + * @static + */ public static function ajax() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->ajax(); + } + /** + * Determine if the request is the result of a PJAX call. + * + * @return bool + * @static + */ public static function pjax() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->pjax(); + } + /** + * Determine if the request is the result of a prefetch call. + * + * @return bool + * @static + */ public static function prefetch() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->prefetch(); + } + /** + * Determine if the request is over HTTPS. + * + * @return bool + * @static + */ public static function secure() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->secure(); + } + /** + * Get the client IP address. + * + * @return string|null + * @static + */ public static function ip() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->ip(); + } + /** + * Get the client IP addresses. + * + * @return array + * @static + */ public static function ips() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->ips(); + } + /** + * Get the client user agent. + * + * @return string|null + * @static + */ public static function userAgent() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->userAgent(); + } + /** + * Merge new input into the current request's input array. + * + * @param array $input + * @return \Illuminate\Http\Request + * @static + */ public static function merge($input) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->merge($input); + } + /** + * Merge new input into the request's input, but only when that key is missing from the request. + * + * @param array $input + * @return \Illuminate\Http\Request + * @static + */ public static function mergeIfMissing($input) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->mergeIfMissing($input); + } + /** + * Replace the input values for the current request. + * + * @param array $input + * @return \Illuminate\Http\Request + * @static + */ public static function replace($input) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->replace($input); + } + /** + * This method belongs to Symfony HttpFoundation and is not usually needed when using Laravel. + * + * Instead, you may use the "input" method. + * + * @param string $key + * @param mixed $default + * @return mixed + * @static + */ public static function get($key, $default = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->get($key, $default); + } + /** + * Get the JSON payload for the request. + * + * @param string|null $key + * @param mixed $default + * @return \Symfony\Component\HttpFoundation\InputBag|mixed + * @static + */ public static function json($key = null, $default = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->json($key, $default); + } + /** + * Create a new request instance from the given Laravel request. + * + * @param \Illuminate\Http\Request $from + * @param \Illuminate\Http\Request|null $to + * @return static + * @static + */ public static function createFrom($from, $to = null) + { + return \Illuminate\Http\Request::createFrom($from, $to); + } + /** + * Create an Illuminate request from a Symfony instance. + * + * @param \Symfony\Component\HttpFoundation\Request $request + * @return static + * @static + */ public static function createFromBase($request) + { + return \Illuminate\Http\Request::createFromBase($request); + } + /** + * Clones a request and overrides some of its parameters. + * + * @return static + * @param array|null $query The GET parameters + * @param array|null $request The POST parameters + * @param array|null $attributes The request attributes (parameters parsed from the PATH_INFO, ...) + * @param array|null $cookies The COOKIE parameters + * @param array|null $files The FILES parameters + * @param array|null $server The SERVER parameters + * @static + */ public static function duplicate($query = null, $request = null, $attributes = null, $cookies = null, $files = null, $server = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->duplicate($query, $request, $attributes, $cookies, $files, $server); + } + /** + * Whether the request contains a Session object. + * + * This method does not give any information about the state of the session object, + * like whether the session is started or not. It is just a way to check if this Request + * is associated with a Session instance. + * + * @param bool $skipIfUninitialized When true, ignores factories injected by `setSessionFactory` + * @static + */ public static function hasSession($skipIfUninitialized = false) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->hasSession($skipIfUninitialized); + } + /** + * Gets the Session. + * + * @throws SessionNotFoundException When session is not set properly + * @static + */ public static function getSession() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->getSession(); + } + /** + * Get the session associated with the request. + * + * @return \Illuminate\Contracts\Session\Session + * @throws \RuntimeException + * @static + */ public static function session() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->session(); + } + /** + * Set the session instance on the request. + * + * @param \Illuminate\Contracts\Session\Session $session + * @return void + * @static + */ public static function setLaravelSession($session) + { + /** @var \Illuminate\Http\Request $instance */ + $instance->setLaravelSession($session); + } + /** + * Set the locale for the request instance. + * + * @param string $locale + * @return void + * @static + */ public static function setRequestLocale($locale) + { + /** @var \Illuminate\Http\Request $instance */ + $instance->setRequestLocale($locale); + } + /** + * Set the default locale for the request instance. + * + * @param string $locale + * @return void + * @static + */ public static function setDefaultRequestLocale($locale) + { + /** @var \Illuminate\Http\Request $instance */ + $instance->setDefaultRequestLocale($locale); + } + /** + * Get the user making the request. + * + * @param string|null $guard + * @return mixed + * @static + */ public static function user($guard = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->user($guard); + } + /** + * Get the route handling the request. + * + * @param string|null $param + * @param mixed $default + * @return \Illuminate\Routing\Route|object|string|null + * @static + */ public static function route($param = null, $default = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->route($param, $default); + } + /** + * Get a unique fingerprint for the request / route / IP address. + * + * @return string + * @throws \RuntimeException + * @static + */ public static function fingerprint() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->fingerprint(); + } + /** + * Set the JSON payload for the request. + * + * @param \Symfony\Component\HttpFoundation\InputBag $json + * @return \Illuminate\Http\Request + * @static + */ public static function setJson($json) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->setJson($json); + } + /** + * Get the user resolver callback. + * + * @return \Closure + * @static + */ public static function getUserResolver() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->getUserResolver(); + } + /** + * Set the user resolver callback. + * + * @param \Closure $callback + * @return \Illuminate\Http\Request + * @static + */ public static function setUserResolver($callback) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->setUserResolver($callback); + } + /** + * Get the route resolver callback. + * + * @return \Closure + * @static + */ public static function getRouteResolver() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->getRouteResolver(); + } + /** + * Set the route resolver callback. + * + * @param \Closure $callback + * @return \Illuminate\Http\Request + * @static + */ public static function setRouteResolver($callback) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->setRouteResolver($callback); + } + /** + * Get all of the input and files for the request. + * + * @return array + * @static + */ public static function toArray() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->toArray(); + } + /** + * Determine if the given offset exists. + * + * @param string $offset + * @return bool + * @static + */ public static function offsetExists($offset) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->offsetExists($offset); + } + /** + * Get the value at the given offset. + * + * @param string $offset + * @return mixed + * @static + */ public static function offsetGet($offset) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->offsetGet($offset); + } + /** + * Set the value at the given offset. + * + * @param string $offset + * @param mixed $value + * @return void + * @static + */ public static function offsetSet($offset, $value) + { + /** @var \Illuminate\Http\Request $instance */ + $instance->offsetSet($offset, $value); + } + /** + * Remove the value at the given offset. + * + * @param string $offset + * @return void + * @static + */ public static function offsetUnset($offset) + { + /** @var \Illuminate\Http\Request $instance */ + $instance->offsetUnset($offset); + } + /** + * Sets the parameters for this request. + * + * This method also re-initializes all properties. + * + * @param array $query The GET parameters + * @param array $request The POST parameters + * @param array $attributes The request attributes (parameters parsed from the PATH_INFO, ...) + * @param array $cookies The COOKIE parameters + * @param array $files The FILES parameters + * @param array $server The SERVER parameters + * @param string|resource|null $content The raw body data + * @static + */ public static function initialize($query = [], $request = [], $attributes = [], $cookies = [], $files = [], $server = [], $content = null) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->initialize($query, $request, $attributes, $cookies, $files, $server, $content); + } + /** + * Creates a new request with values from PHP's super globals. + * + * @static + */ public static function createFromGlobals() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + return \Illuminate\Http\Request::createFromGlobals(); + } + /** + * Creates a Request based on a given URI and configuration. + * + * The information contained in the URI always take precedence + * over the other information (server and parameters). + * + * @param string $uri The URI + * @param string $method The HTTP method + * @param array $parameters The query (GET) or request (POST) parameters + * @param array $cookies The request cookies ($_COOKIE) + * @param array $files The request files ($_FILES) + * @param array $server The server parameters ($_SERVER) + * @param string|resource|null $content The raw body data + * @static + */ public static function create($uri, $method = 'GET', $parameters = [], $cookies = [], $files = [], $server = [], $content = null) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + return \Illuminate\Http\Request::create($uri, $method, $parameters, $cookies, $files, $server, $content); + } + /** + * Sets a callable able to create a Request instance. + * + * This is mainly useful when you need to override the Request class + * to keep BC with an existing system. It should not be used for any + * other purpose. + * + * @static + */ public static function setFactory($callable) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + return \Illuminate\Http\Request::setFactory($callable); + } + /** + * Overrides the PHP global variables according to this request instance. + * + * It overrides $_GET, $_POST, $_REQUEST, $_SERVER, $_COOKIE. + * $_FILES is never overridden, see rfc1867 + * + * @static + */ public static function overrideGlobals() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->overrideGlobals(); + } + /** + * Sets a list of trusted proxies. + * + * You should only list the reverse proxies that you manage directly. + * + * @param array $proxies A list of trusted proxies, the string 'REMOTE_ADDR' will be replaced with $_SERVER['REMOTE_ADDR'] + * @param int $trustedHeaderSet A bit field of Request::HEADER_*, to set which headers to trust from your proxies + * @static + */ public static function setTrustedProxies($proxies, $trustedHeaderSet) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + return \Illuminate\Http\Request::setTrustedProxies($proxies, $trustedHeaderSet); + } + /** + * Gets the list of trusted proxies. + * + * @return string[] + * @static + */ public static function getTrustedProxies() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + return \Illuminate\Http\Request::getTrustedProxies(); + } + /** + * Gets the set of trusted headers from trusted proxies. + * + * @return int A bit field of Request::HEADER_* that defines which headers are trusted from your proxies + * @static + */ public static function getTrustedHeaderSet() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + return \Illuminate\Http\Request::getTrustedHeaderSet(); + } + /** + * Sets a list of trusted host patterns. + * + * You should only list the hosts you manage using regexs. + * + * @param array $hostPatterns A list of trusted host patterns + * @static + */ public static function setTrustedHosts($hostPatterns) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + return \Illuminate\Http\Request::setTrustedHosts($hostPatterns); + } + /** + * Gets the list of trusted host patterns. + * + * @return string[] + * @static + */ public static function getTrustedHosts() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + return \Illuminate\Http\Request::getTrustedHosts(); + } + /** + * Normalizes a query string. + * + * It builds a normalized query string, where keys/value pairs are alphabetized, + * have consistent escaping and unneeded delimiters are removed. + * + * @static + */ public static function normalizeQueryString($qs) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + return \Illuminate\Http\Request::normalizeQueryString($qs); + } + /** + * Enables support for the _method request parameter to determine the intended HTTP method. + * + * Be warned that enabling this feature might lead to CSRF issues in your code. + * Check that you are using CSRF tokens when required. + * If the HTTP method parameter override is enabled, an html-form with method "POST" can be altered + * and used to send a "PUT" or "DELETE" request via the _method request parameter. + * If these methods are not protected against CSRF, this presents a possible vulnerability. + * + * The HTTP method can only be overridden when the real HTTP method is POST. + * + * @static + */ public static function enableHttpMethodParameterOverride() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + return \Illuminate\Http\Request::enableHttpMethodParameterOverride(); + } + /** + * Checks whether support for the _method request parameter is enabled. + * + * @static + */ public static function getHttpMethodParameterOverride() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + return \Illuminate\Http\Request::getHttpMethodParameterOverride(); + } + /** + * Whether the request contains a Session which was started in one of the + * previous requests. + * + * @static + */ public static function hasPreviousSession() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->hasPreviousSession(); + } + /** + * + * + * @static + */ public static function setSession($session) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->setSession($session); + } + /** + * + * + * @internal + * @param \Symfony\Component\HttpFoundation\callable(): SessionInterface $factory + * @static + */ public static function setSessionFactory($factory) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->setSessionFactory($factory); + } + /** + * Returns the client IP addresses. + * + * In the returned array the most trusted IP address is first, and the + * least trusted one last. The "real" client IP address is the last one, + * but this is also the least trusted one. Trusted proxies are stripped. + * + * Use this method carefully; you should use getClientIp() instead. + * + * @see getClientIp() + * @static + */ public static function getClientIps() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getClientIps(); + } + /** + * Returns the client IP address. + * + * This method can read the client IP address from the "X-Forwarded-For" header + * when trusted proxies were set via "setTrustedProxies()". The "X-Forwarded-For" + * header value is a comma+space separated list of IP addresses, the left-most + * being the original client, and each successive proxy that passed the request + * adding the IP address where it received the request from. + * + * If your reverse proxy uses a different header name than "X-Forwarded-For", + * ("Client-Ip" for instance), configure it via the $trustedHeaderSet + * argument of the Request::setTrustedProxies() method instead. + * + * @see getClientIps() + * @see https://wikipedia.org/wiki/X-Forwarded-For + * @static + */ public static function getClientIp() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getClientIp(); + } + /** + * Returns current script name. + * + * @static + */ public static function getScriptName() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getScriptName(); + } + /** + * Returns the path being requested relative to the executed script. + * + * The path info always starts with a /. + * + * Suppose this request is instantiated from /mysite on localhost: + * + * * http://localhost/mysite returns an empty string + * * http://localhost/mysite/about returns '/about' + * * http://localhost/mysite/enco%20ded returns '/enco%20ded' + * * http://localhost/mysite/about?var=1 returns '/about' + * + * @return string The raw path (i.e. not urldecoded) + * @static + */ public static function getPathInfo() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getPathInfo(); + } + /** + * Returns the root path from which this request is executed. + * + * Suppose that an index.php file instantiates this request object: + * + * * http://localhost/index.php returns an empty string + * * http://localhost/index.php/page returns an empty string + * * http://localhost/web/index.php returns '/web' + * * http://localhost/we%20b/index.php returns '/we%20b' + * + * @return string The raw path (i.e. not urldecoded) + * @static + */ public static function getBasePath() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getBasePath(); + } + /** + * Returns the root URL from which this request is executed. + * + * The base URL never ends with a /. + * + * This is similar to getBasePath(), except that it also includes the + * script filename (e.g. index.php) if one exists. + * + * @return string The raw URL (i.e. not urldecoded) + * @static + */ public static function getBaseUrl() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getBaseUrl(); + } + /** + * Gets the request's scheme. + * + * @static + */ public static function getScheme() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getScheme(); + } + /** + * Returns the port on which the request is made. + * + * This method can read the client port from the "X-Forwarded-Port" header + * when trusted proxies were set via "setTrustedProxies()". + * + * The "X-Forwarded-Port" header must contain the client port. + * + * @return int|string|null Can be a string if fetched from the server bag + * @static + */ public static function getPort() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getPort(); + } + /** + * Returns the user. + * + * @static + */ public static function getUser() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getUser(); + } + /** + * Returns the password. + * + * @static + */ public static function getPassword() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getPassword(); + } + /** + * Gets the user info. + * + * @return string|null A user name if any and, optionally, scheme-specific information about how to gain authorization to access the server + * @static + */ public static function getUserInfo() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getUserInfo(); + } + /** + * Returns the HTTP host being requested. + * + * The port name will be appended to the host if it's non-standard. + * + * @static + */ public static function getHttpHost() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getHttpHost(); + } + /** + * Returns the requested URI (path and query string). + * + * @return string The raw URI (i.e. not URI decoded) + * @static + */ public static function getRequestUri() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getRequestUri(); + } + /** + * Gets the scheme and HTTP host. + * + * If the URL was called with basic authentication, the user + * and the password are not added to the generated string. + * + * @static + */ public static function getSchemeAndHttpHost() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getSchemeAndHttpHost(); + } + /** + * Generates a normalized URI (URL) for the Request. + * + * @see getQueryString() + * @static + */ public static function getUri() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getUri(); + } + /** + * Generates a normalized URI for the given path. + * + * @param string $path A path to use instead of the current one + * @static + */ public static function getUriForPath($path) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getUriForPath($path); + } + /** + * Returns the path as relative reference from the current Request path. + * + * Only the URIs path component (no schema, host etc.) is relevant and must be given. + * Both paths must be absolute and not contain relative parts. + * Relative URLs from one resource to another are useful when generating self-contained downloadable document archives. + * Furthermore, they can be used to reduce the link size in documents. + * + * Example target paths, given a base path of "/a/b/c/d": + * - "/a/b/c/d" -> "" + * - "/a/b/c/" -> "./" + * - "/a/b/" -> "../" + * - "/a/b/c/other" -> "other" + * - "/a/x/y" -> "../../x/y" + * + * @static + */ public static function getRelativeUriForPath($path) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getRelativeUriForPath($path); + } + /** + * Generates the normalized query string for the Request. + * + * It builds a normalized query string, where keys/value pairs are alphabetized + * and have consistent escaping. + * + * @static + */ public static function getQueryString() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getQueryString(); + } + /** + * Checks whether the request is secure or not. + * + * This method can read the client protocol from the "X-Forwarded-Proto" header + * when trusted proxies were set via "setTrustedProxies()". + * + * The "X-Forwarded-Proto" header must contain the protocol: "https" or "http". + * + * @static + */ public static function isSecure() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->isSecure(); + } + /** + * Returns the host name. + * + * This method can read the client host name from the "X-Forwarded-Host" header + * when trusted proxies were set via "setTrustedProxies()". + * + * The "X-Forwarded-Host" header must contain the client host name. + * + * @throws SuspiciousOperationException when the host name is invalid or not trusted + * @static + */ public static function getHost() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getHost(); + } + /** + * Sets the request method. + * + * @static + */ public static function setMethod($method) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->setMethod($method); + } + /** + * Gets the request "intended" method. + * + * If the X-HTTP-Method-Override header is set, and if the method is a POST, + * then it is used to determine the "real" intended HTTP method. + * + * The _method request parameter can also be used to determine the HTTP method, + * but only if enableHttpMethodParameterOverride() has been called. + * + * The method is always an uppercased string. + * + * @see getRealMethod() + * @static + */ public static function getMethod() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getMethod(); + } + /** + * Gets the "real" request method. + * + * @see getMethod() + * @static + */ public static function getRealMethod() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getRealMethod(); + } + /** + * Gets the mime type associated with the format. + * + * @static + */ public static function getMimeType($format) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getMimeType($format); + } + /** + * Gets the mime types associated with the format. + * + * @return string[] + * @static + */ public static function getMimeTypes($format) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + return \Illuminate\Http\Request::getMimeTypes($format); + } + /** + * Gets the format associated with the mime type. + * + * @static + */ public static function getFormat($mimeType) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getFormat($mimeType); + } + /** + * Associates a format with mime types. + * + * @param string|string[] $mimeTypes The associated mime types (the preferred one must be the first as it will be used as the content type) + * @static + */ public static function setFormat($format, $mimeTypes) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->setFormat($format, $mimeTypes); + } + /** + * Gets the request format. + * + * Here is the process to determine the format: + * + * * format defined by the user (with setRequestFormat()) + * * _format request attribute + * * $default + * + * @see getPreferredFormat + * @static + */ public static function getRequestFormat($default = 'html') + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getRequestFormat($default); + } + /** + * Sets the request format. + * + * @static + */ public static function setRequestFormat($format) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->setRequestFormat($format); + } + /** + * Gets the usual name of the format associated with the request's media type (provided in the Content-Type header). + * + * @see Request::$formats + * @static + */ public static function getContentTypeFormat() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getContentTypeFormat(); + } + /** + * Sets the default locale. + * + * @static + */ public static function setDefaultLocale($locale) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->setDefaultLocale($locale); + } + /** + * Get the default locale. + * + * @static + */ public static function getDefaultLocale() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getDefaultLocale(); + } + /** + * Sets the locale. + * + * @static + */ public static function setLocale($locale) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->setLocale($locale); + } + /** + * Get the locale. + * + * @static + */ public static function getLocale() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getLocale(); + } + /** + * Checks if the request method is of specified type. + * + * @param string $method Uppercase request method (GET, POST etc) + * @static + */ public static function isMethod($method) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->isMethod($method); + } + /** + * Checks whether or not the method is safe. + * + * @see https://tools.ietf.org/html/rfc7231#section-4.2.1 + * @static + */ public static function isMethodSafe() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->isMethodSafe(); + } + /** + * Checks whether or not the method is idempotent. + * + * @static + */ public static function isMethodIdempotent() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->isMethodIdempotent(); + } + /** + * Checks whether the method is cacheable or not. + * + * @see https://tools.ietf.org/html/rfc7231#section-4.2.3 + * @static + */ public static function isMethodCacheable() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->isMethodCacheable(); + } + /** + * Returns the protocol version. + * + * If the application is behind a proxy, the protocol version used in the + * requests between the client and the proxy and between the proxy and the + * server might be different. This returns the former (from the "Via" header) + * if the proxy is trusted (see "setTrustedProxies()"), otherwise it returns + * the latter (from the "SERVER_PROTOCOL" server parameter). + * + * @static + */ public static function getProtocolVersion() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getProtocolVersion(); + } + /** + * Returns the request body content. + * + * @param bool $asResource If true, a resource will be returned + * @return string|resource + * @psalm-return ($asResource is true ? resource : string) + * @static + */ public static function getContent($asResource = false) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getContent($asResource); + } + /** + * Gets the decoded form or json request body. + * + * @throws JsonException When the body cannot be decoded to an array + * @static + */ public static function getPayload() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getPayload(); + } + /** + * Gets the Etags. + * + * @static + */ public static function getETags() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getETags(); + } + /** + * + * + * @static + */ public static function isNoCache() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->isNoCache(); + } + /** + * Gets the preferred format for the response by inspecting, in the following order: + * * the request format set using setRequestFormat; + * * the values of the Accept HTTP header. + * + * Note that if you use this method, you should send the "Vary: Accept" header + * in the response to prevent any issues with intermediary HTTP caches. + * + * @static + */ public static function getPreferredFormat($default = 'html') + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getPreferredFormat($default); + } + /** + * Returns the preferred language. + * + * @param string[] $locales An array of ordered available locales + * @static + */ public static function getPreferredLanguage($locales = null) + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getPreferredLanguage($locales); + } + /** + * Gets a list of languages acceptable by the client browser ordered in the user browser preferences. + * + * @return string[] + * @static + */ public static function getLanguages() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getLanguages(); + } + /** + * Gets a list of charsets acceptable by the client browser in preferable order. + * + * @return string[] + * @static + */ public static function getCharsets() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getCharsets(); + } + /** + * Gets a list of encodings acceptable by the client browser in preferable order. + * + * @return string[] + * @static + */ public static function getEncodings() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getEncodings(); + } + /** + * Gets a list of content types acceptable by the client browser in preferable order. + * + * @return string[] + * @static + */ public static function getAcceptableContentTypes() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->getAcceptableContentTypes(); + } + /** + * Returns true if the request is an XMLHttpRequest. + * + * It works if your JavaScript library sets an X-Requested-With HTTP header. + * It is known to work with common JavaScript frameworks: + * + * @see https://wikipedia.org/wiki/List_of_Ajax_frameworks#JavaScript + * @static + */ public static function isXmlHttpRequest() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->isXmlHttpRequest(); + } + /** + * Checks whether the client browser prefers safe content or not according to RFC8674. + * + * @see https://tools.ietf.org/html/rfc8674 + * @static + */ public static function preferSafeContent() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->preferSafeContent(); + } + /** + * Indicates whether this request originated from a trusted proxy. + * + * This can be useful to determine whether or not to trust the + * contents of a proxy-specific header. + * + * @static + */ public static function isFromTrustedProxy() + { //Method inherited from \Symfony\Component\HttpFoundation\Request + /** @var \Illuminate\Http\Request $instance */ + return $instance->isFromTrustedProxy(); + } + /** + * Filter the given array of rules into an array of rules that are included in precognitive headers. + * + * @param array $rules + * @return array + * @static + */ public static function filterPrecognitiveRules($rules) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->filterPrecognitiveRules($rules); + } + /** + * Determine if the request is attempting to be precognitive. + * + * @return bool + * @static + */ public static function isAttemptingPrecognition() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->isAttemptingPrecognition(); + } + /** + * Determine if the request is precognitive. + * + * @return bool + * @static + */ public static function isPrecognitive() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->isPrecognitive(); + } + /** + * Determine if the request is sending JSON. + * + * @return bool + * @static + */ public static function isJson() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->isJson(); + } + /** + * Determine if the current request probably expects a JSON response. + * + * @return bool + * @static + */ public static function expectsJson() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->expectsJson(); + } + /** + * Determine if the current request is asking for JSON. + * + * @return bool + * @static + */ public static function wantsJson() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->wantsJson(); + } + /** + * Determines whether the current requests accepts a given content type. + * + * @param string|array $contentTypes + * @return bool + * @static + */ public static function accepts($contentTypes) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->accepts($contentTypes); + } + /** + * Return the most suitable content type from the given array based on content negotiation. + * + * @param string|array $contentTypes + * @return string|null + * @static + */ public static function prefers($contentTypes) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->prefers($contentTypes); + } + /** + * Determine if the current request accepts any content type. + * + * @return bool + * @static + */ public static function acceptsAnyContentType() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->acceptsAnyContentType(); + } + /** + * Determines whether a request accepts JSON. + * + * @return bool + * @static + */ public static function acceptsJson() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->acceptsJson(); + } + /** + * Determines whether a request accepts HTML. + * + * @return bool + * @static + */ public static function acceptsHtml() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->acceptsHtml(); + } + /** + * Determine if the given content types match. + * + * @param string $actual + * @param string $type + * @return bool + * @static + */ public static function matchesType($actual, $type) + { + return \Illuminate\Http\Request::matchesType($actual, $type); + } + /** + * Get the data format expected in the response. + * + * @param string $default + * @return string + * @static + */ public static function format($default = 'html') + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->format($default); + } + /** + * Retrieve an old input item. + * + * @param string|null $key + * @param \Illuminate\Database\Eloquent\Model|string|array|null $default + * @return string|array|null + * @static + */ public static function old($key = null, $default = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->old($key, $default); + } + /** + * Flash the input for the current request to the session. + * + * @return void + * @static + */ public static function flash() + { + /** @var \Illuminate\Http\Request $instance */ + $instance->flash(); + } + /** + * Flash only some of the input to the session. + * + * @param array|mixed $keys + * @return void + * @static + */ public static function flashOnly($keys) + { + /** @var \Illuminate\Http\Request $instance */ + $instance->flashOnly($keys); + } + /** + * Flash only some of the input to the session. + * + * @param array|mixed $keys + * @return void + * @static + */ public static function flashExcept($keys) + { + /** @var \Illuminate\Http\Request $instance */ + $instance->flashExcept($keys); + } + /** + * Flush all of the old input from the session. + * + * @return void + * @static + */ public static function flush() + { + /** @var \Illuminate\Http\Request $instance */ + $instance->flush(); + } + /** + * Retrieve a server variable from the request. + * + * @param string|null $key + * @param string|array|null $default + * @return string|array|null + * @static + */ public static function server($key = null, $default = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->server($key, $default); + } + /** + * Determine if a header is set on the request. + * + * @param string $key + * @return bool + * @static + */ public static function hasHeader($key) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->hasHeader($key); + } + /** + * Retrieve a header from the request. + * + * @param string|null $key + * @param string|array|null $default + * @return string|array|null + * @static + */ public static function header($key = null, $default = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->header($key, $default); + } + /** + * Get the bearer token from the request headers. + * + * @return string|null + * @static + */ public static function bearerToken() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->bearerToken(); + } + /** + * Determine if the request contains a given input item key. + * + * @param string|array $key + * @return bool + * @static + */ public static function exists($key) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->exists($key); + } + /** + * Determine if the request contains a given input item key. + * + * @param string|array $key + * @return bool + * @static + */ public static function has($key) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->has($key); + } + /** + * Determine if the request contains any of the given inputs. + * + * @param string|array $keys + * @return bool + * @static + */ public static function hasAny($keys) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->hasAny($keys); + } + /** + * Apply the callback if the request contains the given input item key. + * + * @param string $key + * @param callable $callback + * @param callable|null $default + * @return $this|mixed + * @static + */ public static function whenHas($key, $callback, $default = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->whenHas($key, $callback, $default); + } + /** + * Determine if the request contains a non-empty value for an input item. + * + * @param string|array $key + * @return bool + * @static + */ public static function filled($key) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->filled($key); + } + /** + * Determine if the request contains an empty value for an input item. + * + * @param string|array $key + * @return bool + * @static + */ public static function isNotFilled($key) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->isNotFilled($key); + } + /** + * Determine if the request contains a non-empty value for any of the given inputs. + * + * @param string|array $keys + * @return bool + * @static + */ public static function anyFilled($keys) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->anyFilled($keys); + } + /** + * Apply the callback if the request contains a non-empty value for the given input item key. + * + * @param string $key + * @param callable $callback + * @param callable|null $default + * @return $this|mixed + * @static + */ public static function whenFilled($key, $callback, $default = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->whenFilled($key, $callback, $default); + } + /** + * Determine if the request is missing a given input item key. + * + * @param string|array $key + * @return bool + * @static + */ public static function missing($key) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->missing($key); + } + /** + * Apply the callback if the request is missing the given input item key. + * + * @param string $key + * @param callable $callback + * @param callable|null $default + * @return $this|mixed + * @static + */ public static function whenMissing($key, $callback, $default = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->whenMissing($key, $callback, $default); + } + /** + * Get the keys for all of the input and files. + * + * @return array + * @static + */ public static function keys() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->keys(); + } + /** + * Get all of the input and files for the request. + * + * @param array|mixed|null $keys + * @return array + * @static + */ public static function all($keys = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->all($keys); + } + /** + * Retrieve an input item from the request. + * + * @param string|null $key + * @param mixed $default + * @return mixed + * @static + */ public static function input($key = null, $default = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->input($key, $default); + } + /** + * Retrieve input from the request as a Stringable instance. + * + * @param string $key + * @param mixed $default + * @return \Illuminate\Support\Stringable + * @static + */ public static function str($key, $default = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->str($key, $default); + } + /** + * Retrieve input from the request as a Stringable instance. + * + * @param string $key + * @param mixed $default + * @return \Illuminate\Support\Stringable + * @static + */ public static function string($key, $default = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->string($key, $default); + } + /** + * Retrieve input as a boolean value. + * + * Returns true when value is "1", "true", "on", and "yes". Otherwise, returns false. + * + * @param string|null $key + * @param bool $default + * @return bool + * @static + */ public static function boolean($key = null, $default = false) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->boolean($key, $default); + } + /** + * Retrieve input as an integer value. + * + * @param string $key + * @param int $default + * @return int + * @static + */ public static function integer($key, $default = 0) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->integer($key, $default); + } + /** + * Retrieve input as a float value. + * + * @param string $key + * @param float $default + * @return float + * @static + */ public static function float($key, $default = 0.0) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->float($key, $default); + } + /** + * Retrieve input from the request as a Carbon instance. + * + * @param string $key + * @param string|null $format + * @param string|null $tz + * @return \Illuminate\Support\Carbon|null + * @throws \Carbon\Exceptions\InvalidFormatException + * @static + */ public static function date($key, $format = null, $tz = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->date($key, $format, $tz); + } + /** + * Retrieve input from the request as an enum. + * + * @template TEnum + * @param string $key + * @param \Illuminate\Http\class-string $enumClass + * @return \Illuminate\Http\TEnum|null + * @static + */ public static function enum($key, $enumClass) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->enum($key, $enumClass); + } + /** + * Retrieve input from the request as a collection. + * + * @param array|string|null $key + * @return \Illuminate\Support\Collection + * @static + */ public static function collect($key = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->collect($key); + } + /** + * Get a subset containing the provided keys with values from the input data. + * + * @param array|mixed $keys + * @return array + * @static + */ public static function only($keys) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->only($keys); + } + /** + * Get all of the input except for a specified array of items. + * + * @param array|mixed $keys + * @return array + * @static + */ public static function except($keys) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->except($keys); + } + /** + * Retrieve a query string item from the request. + * + * @param string|null $key + * @param string|array|null $default + * @return string|array|null + * @static + */ public static function query($key = null, $default = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->query($key, $default); + } + /** + * Retrieve a request payload item from the request. + * + * @param string|null $key + * @param string|array|null $default + * @return string|array|null + * @static + */ public static function post($key = null, $default = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->post($key, $default); + } + /** + * Determine if a cookie is set on the request. + * + * @param string $key + * @return bool + * @static + */ public static function hasCookie($key) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->hasCookie($key); + } + /** + * Retrieve a cookie from the request. + * + * @param string|null $key + * @param string|array|null $default + * @return string|array|null + * @static + */ public static function cookie($key = null, $default = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->cookie($key, $default); + } + /** + * Get an array of all of the files on the request. + * + * @return array + * @static + */ public static function allFiles() + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->allFiles(); + } + /** + * Determine if the uploaded data contains a file. + * + * @param string $key + * @return bool + * @static + */ public static function hasFile($key) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->hasFile($key); + } + /** + * Retrieve a file from the request. + * + * @param string|null $key + * @param mixed $default + * @return \Illuminate\Http\UploadedFile|\Illuminate\Http\UploadedFile[]|array|null + * @static + */ public static function file($key = null, $default = null) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->file($key, $default); + } + /** + * Dump the items. + * + * @param mixed $keys + * @return \Illuminate\Http\Request + * @static + */ public static function dump($keys = []) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->dump($keys); + } + /** + * Dump the given arguments and terminate execution. + * + * @param mixed $args + * @return \Illuminate\Http\never + * @static + */ public static function dd(...$args) + { + /** @var \Illuminate\Http\Request $instance */ + return $instance->dd(...$args); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Http\Request::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Http\Request::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Http\Request::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Http\Request::flushMacros(); + } + /** + * + * + * @see \Illuminate\Foundation\Providers\FoundationServiceProvider::registerRequestValidation() + * @param array $rules + * @param mixed $params + * @static + */ public static function validate($rules, ...$params) + { + return \Illuminate\Http\Request::validate($rules, ...$params); + } + /** + * + * + * @see \Illuminate\Foundation\Providers\FoundationServiceProvider::registerRequestValidation() + * @param string $errorBag + * @param array $rules + * @param mixed $params + * @static + */ public static function validateWithBag($errorBag, $rules, ...$params) + { + return \Illuminate\Http\Request::validateWithBag($errorBag, $rules, ...$params); + } + /** + * + * + * @see \Illuminate\Foundation\Providers\FoundationServiceProvider::registerRequestSignatureValidation() + * @param mixed $absolute + * @static + */ public static function hasValidSignature($absolute = true) + { + return \Illuminate\Http\Request::hasValidSignature($absolute); + } + /** + * + * + * @see \Illuminate\Foundation\Providers\FoundationServiceProvider::registerRequestSignatureValidation() + * @static + */ public static function hasValidRelativeSignature() + { + return \Illuminate\Http\Request::hasValidRelativeSignature(); + } + /** + * + * + * @see \Illuminate\Foundation\Providers\FoundationServiceProvider::registerRequestSignatureValidation() + * @param mixed $ignoreQuery + * @param mixed $absolute + * @static + */ public static function hasValidSignatureWhileIgnoring($ignoreQuery = [], $absolute = true) + { + return \Illuminate\Http\Request::hasValidSignatureWhileIgnoring($ignoreQuery, $absolute); + } + /** + * + * + * @see \Illuminate\Foundation\Providers\FoundationServiceProvider::registerRequestSignatureValidation() + * @param mixed $ignoreQuery + * @static + */ public static function hasValidRelativeSignatureWhileIgnoring($ignoreQuery = []) + { + return \Illuminate\Http\Request::hasValidRelativeSignatureWhileIgnoring($ignoreQuery); + } + } + /** + * + * + * @see \Illuminate\Routing\ResponseFactory + */ class Response { + /** + * Create a new response instance. + * + * @param mixed $content + * @param int $status + * @param array $headers + * @return \Illuminate\Http\Response + * @static + */ public static function make($content = '', $status = 200, $headers = []) + { + /** @var \Illuminate\Routing\ResponseFactory $instance */ + return $instance->make($content, $status, $headers); + } + /** + * Create a new "no content" response. + * + * @param int $status + * @param array $headers + * @return \Illuminate\Http\Response + * @static + */ public static function noContent($status = 204, $headers = []) + { + /** @var \Illuminate\Routing\ResponseFactory $instance */ + return $instance->noContent($status, $headers); + } + /** + * Create a new response for a given view. + * + * @param string|array $view + * @param array $data + * @param int $status + * @param array $headers + * @return \Illuminate\Http\Response + * @static + */ public static function view($view, $data = [], $status = 200, $headers = []) + { + /** @var \Illuminate\Routing\ResponseFactory $instance */ + return $instance->view($view, $data, $status, $headers); + } + /** + * Create a new JSON response instance. + * + * @param mixed $data + * @param int $status + * @param array $headers + * @param int $options + * @return \Illuminate\Http\JsonResponse + * @static + */ public static function json($data = [], $status = 200, $headers = [], $options = 0) + { + /** @var \Illuminate\Routing\ResponseFactory $instance */ + return $instance->json($data, $status, $headers, $options); + } + /** + * Create a new JSONP response instance. + * + * @param string $callback + * @param mixed $data + * @param int $status + * @param array $headers + * @param int $options + * @return \Illuminate\Http\JsonResponse + * @static + */ public static function jsonp($callback, $data = [], $status = 200, $headers = [], $options = 0) + { + /** @var \Illuminate\Routing\ResponseFactory $instance */ + return $instance->jsonp($callback, $data, $status, $headers, $options); + } + /** + * Create a new streamed response instance. + * + * @param callable $callback + * @param int $status + * @param array $headers + * @return \Symfony\Component\HttpFoundation\StreamedResponse + * @static + */ public static function stream($callback, $status = 200, $headers = []) + { + /** @var \Illuminate\Routing\ResponseFactory $instance */ + return $instance->stream($callback, $status, $headers); + } + /** + * Create a new streamed response instance. + * + * @param array $data + * @param int $status + * @param array $headers + * @param int $encodingOptions + * @return \Symfony\Component\HttpFoundation\StreamedJsonResponse + * @static + */ public static function streamJson($data, $status = 200, $headers = [], $encodingOptions = 15) + { + /** @var \Illuminate\Routing\ResponseFactory $instance */ + return $instance->streamJson($data, $status, $headers, $encodingOptions); + } + /** + * Create a new streamed response instance as a file download. + * + * @param callable $callback + * @param string|null $name + * @param array $headers + * @param string|null $disposition + * @return \Symfony\Component\HttpFoundation\StreamedResponse + * @throws \Illuminate\Routing\Exceptions\StreamedResponseException + * @static + */ public static function streamDownload($callback, $name = null, $headers = [], $disposition = 'attachment') + { + /** @var \Illuminate\Routing\ResponseFactory $instance */ + return $instance->streamDownload($callback, $name, $headers, $disposition); + } + /** + * Create a new file download response. + * + * @param \SplFileInfo|string $file + * @param string|null $name + * @param array $headers + * @param string|null $disposition + * @return \Symfony\Component\HttpFoundation\BinaryFileResponse + * @static + */ public static function download($file, $name = null, $headers = [], $disposition = 'attachment') + { + /** @var \Illuminate\Routing\ResponseFactory $instance */ + return $instance->download($file, $name, $headers, $disposition); + } + /** + * Return the raw contents of a binary file. + * + * @param \SplFileInfo|string $file + * @param array $headers + * @return \Symfony\Component\HttpFoundation\BinaryFileResponse + * @static + */ public static function file($file, $headers = []) + { + /** @var \Illuminate\Routing\ResponseFactory $instance */ + return $instance->file($file, $headers); + } + /** + * Create a new redirect response to the given path. + * + * @param string $path + * @param int $status + * @param array $headers + * @param bool|null $secure + * @return \Illuminate\Http\RedirectResponse + * @static + */ public static function redirectTo($path, $status = 302, $headers = [], $secure = null) + { + /** @var \Illuminate\Routing\ResponseFactory $instance */ + return $instance->redirectTo($path, $status, $headers, $secure); + } + /** + * Create a new redirect response to a named route. + * + * @param string $route + * @param mixed $parameters + * @param int $status + * @param array $headers + * @return \Illuminate\Http\RedirectResponse + * @static + */ public static function redirectToRoute($route, $parameters = [], $status = 302, $headers = []) + { + /** @var \Illuminate\Routing\ResponseFactory $instance */ + return $instance->redirectToRoute($route, $parameters, $status, $headers); + } + /** + * Create a new redirect response to a controller action. + * + * @param array|string $action + * @param mixed $parameters + * @param int $status + * @param array $headers + * @return \Illuminate\Http\RedirectResponse + * @static + */ public static function redirectToAction($action, $parameters = [], $status = 302, $headers = []) + { + /** @var \Illuminate\Routing\ResponseFactory $instance */ + return $instance->redirectToAction($action, $parameters, $status, $headers); + } + /** + * Create a new redirect response, while putting the current URL in the session. + * + * @param string $path + * @param int $status + * @param array $headers + * @param bool|null $secure + * @return \Illuminate\Http\RedirectResponse + * @static + */ public static function redirectGuest($path, $status = 302, $headers = [], $secure = null) + { + /** @var \Illuminate\Routing\ResponseFactory $instance */ + return $instance->redirectGuest($path, $status, $headers, $secure); + } + /** + * Create a new redirect response to the previously intended location. + * + * @param string $default + * @param int $status + * @param array $headers + * @param bool|null $secure + * @return \Illuminate\Http\RedirectResponse + * @static + */ public static function redirectToIntended($default = '/', $status = 302, $headers = [], $secure = null) + { + /** @var \Illuminate\Routing\ResponseFactory $instance */ + return $instance->redirectToIntended($default, $status, $headers, $secure); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Routing\ResponseFactory::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Routing\ResponseFactory::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Routing\ResponseFactory::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Routing\ResponseFactory::flushMacros(); + } + } + /** + * + * + * @method static \Illuminate\Routing\RouteRegistrar attribute(string $key, mixed $value) + * @method static \Illuminate\Routing\RouteRegistrar whereAlpha(array|string $parameters) + * @method static \Illuminate\Routing\RouteRegistrar whereAlphaNumeric(array|string $parameters) + * @method static \Illuminate\Routing\RouteRegistrar whereNumber(array|string $parameters) + * @method static \Illuminate\Routing\RouteRegistrar whereUlid(array|string $parameters) + * @method static \Illuminate\Routing\RouteRegistrar whereUuid(array|string $parameters) + * @method static \Illuminate\Routing\RouteRegistrar whereIn(array|string $parameters, array $values) + * @method static \Illuminate\Routing\RouteRegistrar as(string $value) + * @method static \Illuminate\Routing\RouteRegistrar controller(string $controller) + * @method static \Illuminate\Routing\RouteRegistrar domain(string $value) + * @method static \Illuminate\Routing\RouteRegistrar middleware(array|string|null $middleware) + * @method static \Illuminate\Routing\RouteRegistrar missing(\Closure $missing) + * @method static \Illuminate\Routing\RouteRegistrar name(string $value) + * @method static \Illuminate\Routing\RouteRegistrar namespace(string|null $value) + * @method static \Illuminate\Routing\RouteRegistrar prefix(string $prefix) + * @method static \Illuminate\Routing\RouteRegistrar scopeBindings() + * @method static \Illuminate\Routing\RouteRegistrar where(array $where) + * @method static \Illuminate\Routing\RouteRegistrar withoutMiddleware(array|string $middleware) + * @method static \Illuminate\Routing\RouteRegistrar withoutScopedBindings() + * @see \Illuminate\Routing\Router + */ class Route { + /** + * Register a new GET route with the router. + * + * @param string $uri + * @param array|string|callable|null $action + * @return \Illuminate\Routing\Route + * @static + */ public static function get($uri, $action = null) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->get($uri, $action); + } + /** + * Register a new POST route with the router. + * + * @param string $uri + * @param array|string|callable|null $action + * @return \Illuminate\Routing\Route + * @static + */ public static function post($uri, $action = null) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->post($uri, $action); + } + /** + * Register a new PUT route with the router. + * + * @param string $uri + * @param array|string|callable|null $action + * @return \Illuminate\Routing\Route + * @static + */ public static function put($uri, $action = null) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->put($uri, $action); + } + /** + * Register a new PATCH route with the router. + * + * @param string $uri + * @param array|string|callable|null $action + * @return \Illuminate\Routing\Route + * @static + */ public static function patch($uri, $action = null) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->patch($uri, $action); + } + /** + * Register a new DELETE route with the router. + * + * @param string $uri + * @param array|string|callable|null $action + * @return \Illuminate\Routing\Route + * @static + */ public static function delete($uri, $action = null) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->delete($uri, $action); + } + /** + * Register a new OPTIONS route with the router. + * + * @param string $uri + * @param array|string|callable|null $action + * @return \Illuminate\Routing\Route + * @static + */ public static function options($uri, $action = null) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->options($uri, $action); + } + /** + * Register a new route responding to all verbs. + * + * @param string $uri + * @param array|string|callable|null $action + * @return \Illuminate\Routing\Route + * @static + */ public static function any($uri, $action = null) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->any($uri, $action); + } + /** + * Register a new fallback route with the router. + * + * @param array|string|callable|null $action + * @return \Illuminate\Routing\Route + * @static + */ public static function fallback($action) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->fallback($action); + } + /** + * Create a redirect from one URI to another. + * + * @param string $uri + * @param string $destination + * @param int $status + * @return \Illuminate\Routing\Route + * @static + */ public static function redirect($uri, $destination, $status = 302) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->redirect($uri, $destination, $status); + } + /** + * Create a permanent redirect from one URI to another. + * + * @param string $uri + * @param string $destination + * @return \Illuminate\Routing\Route + * @static + */ public static function permanentRedirect($uri, $destination) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->permanentRedirect($uri, $destination); + } + /** + * Register a new route that returns a view. + * + * @param string $uri + * @param string $view + * @param array $data + * @param int|array $status + * @param array $headers + * @return \Illuminate\Routing\Route + * @static + */ public static function view($uri, $view, $data = [], $status = 200, $headers = []) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->view($uri, $view, $data, $status, $headers); + } + /** + * Register a new route with the given verbs. + * + * @param array|string $methods + * @param string $uri + * @param array|string|callable|null $action + * @return \Illuminate\Routing\Route + * @static + */ public static function match($methods, $uri, $action = null) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->match($methods, $uri, $action); + } + /** + * Register an array of resource controllers. + * + * @param array $resources + * @param array $options + * @return void + * @static + */ public static function resources($resources, $options = []) + { + /** @var \Illuminate\Routing\Router $instance */ + $instance->resources($resources, $options); + } + /** + * Route a resource to a controller. + * + * @param string $name + * @param string $controller + * @param array $options + * @return \Illuminate\Routing\PendingResourceRegistration + * @static + */ public static function resource($name, $controller, $options = []) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->resource($name, $controller, $options); + } + /** + * Register an array of API resource controllers. + * + * @param array $resources + * @param array $options + * @return void + * @static + */ public static function apiResources($resources, $options = []) + { + /** @var \Illuminate\Routing\Router $instance */ + $instance->apiResources($resources, $options); + } + /** + * Route an API resource to a controller. + * + * @param string $name + * @param string $controller + * @param array $options + * @return \Illuminate\Routing\PendingResourceRegistration + * @static + */ public static function apiResource($name, $controller, $options = []) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->apiResource($name, $controller, $options); + } + /** + * Register an array of singleton resource controllers. + * + * @param array $singletons + * @param array $options + * @return void + * @static + */ public static function singletons($singletons, $options = []) + { + /** @var \Illuminate\Routing\Router $instance */ + $instance->singletons($singletons, $options); + } + /** + * Route a singleton resource to a controller. + * + * @param string $name + * @param string $controller + * @param array $options + * @return \Illuminate\Routing\PendingSingletonResourceRegistration + * @static + */ public static function singleton($name, $controller, $options = []) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->singleton($name, $controller, $options); + } + /** + * Register an array of API singleton resource controllers. + * + * @param array $singletons + * @param array $options + * @return void + * @static + */ public static function apiSingletons($singletons, $options = []) + { + /** @var \Illuminate\Routing\Router $instance */ + $instance->apiSingletons($singletons, $options); + } + /** + * Route an API singleton resource to a controller. + * + * @param string $name + * @param string $controller + * @param array $options + * @return \Illuminate\Routing\PendingSingletonResourceRegistration + * @static + */ public static function apiSingleton($name, $controller, $options = []) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->apiSingleton($name, $controller, $options); + } + /** + * Create a route group with shared attributes. + * + * @param array $attributes + * @param \Closure|array|string $routes + * @return \Illuminate\Routing\Router + * @static + */ public static function group($attributes, $routes) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->group($attributes, $routes); + } + /** + * Merge the given array with the last group stack. + * + * @param array $new + * @param bool $prependExistingPrefix + * @return array + * @static + */ public static function mergeWithLastGroup($new, $prependExistingPrefix = true) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->mergeWithLastGroup($new, $prependExistingPrefix); + } + /** + * Get the prefix from the last group on the stack. + * + * @return string + * @static + */ public static function getLastGroupPrefix() + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->getLastGroupPrefix(); + } + /** + * Add a route to the underlying route collection. + * + * @param array|string $methods + * @param string $uri + * @param array|string|callable|null $action + * @return \Illuminate\Routing\Route + * @static + */ public static function addRoute($methods, $uri, $action) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->addRoute($methods, $uri, $action); + } + /** + * Create a new Route object. + * + * @param array|string $methods + * @param string $uri + * @param mixed $action + * @return \Illuminate\Routing\Route + * @static + */ public static function newRoute($methods, $uri, $action) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->newRoute($methods, $uri, $action); + } + /** + * Return the response returned by the given route. + * + * @param string $name + * @return \Symfony\Component\HttpFoundation\Response + * @static + */ public static function respondWithRoute($name) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->respondWithRoute($name); + } + /** + * Dispatch the request to the application. + * + * @param \Illuminate\Http\Request $request + * @return \Symfony\Component\HttpFoundation\Response + * @static + */ public static function dispatch($request) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->dispatch($request); + } + /** + * Dispatch the request to a route and return the response. + * + * @param \Illuminate\Http\Request $request + * @return \Symfony\Component\HttpFoundation\Response + * @static + */ public static function dispatchToRoute($request) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->dispatchToRoute($request); + } + /** + * Gather the middleware for the given route with resolved class names. + * + * @param \Illuminate\Routing\Route $route + * @return array + * @static + */ public static function gatherRouteMiddleware($route) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->gatherRouteMiddleware($route); + } + /** + * Resolve a flat array of middleware classes from the provided array. + * + * @param array $middleware + * @param array $excluded + * @return array + * @static + */ public static function resolveMiddleware($middleware, $excluded = []) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->resolveMiddleware($middleware, $excluded); + } + /** + * Create a response instance from the given value. + * + * @param \Symfony\Component\HttpFoundation\Request $request + * @param mixed $response + * @return \Symfony\Component\HttpFoundation\Response + * @static + */ public static function prepareResponse($request, $response) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->prepareResponse($request, $response); + } + /** + * Static version of prepareResponse. + * + * @param \Symfony\Component\HttpFoundation\Request $request + * @param mixed $response + * @return \Symfony\Component\HttpFoundation\Response + * @static + */ public static function toResponse($request, $response) + { + return \Illuminate\Routing\Router::toResponse($request, $response); + } + /** + * Substitute the route bindings onto the route. + * + * @param \Illuminate\Routing\Route $route + * @return \Illuminate\Routing\Route + * @throws \Illuminate\Database\Eloquent\ModelNotFoundException<\Illuminate\Database\Eloquent\Model> + * @throws \Illuminate\Routing\Exceptions\BackedEnumCaseNotFoundException + * @static + */ public static function substituteBindings($route) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->substituteBindings($route); + } + /** + * Substitute the implicit route bindings for the given route. + * + * @param \Illuminate\Routing\Route $route + * @return void + * @throws \Illuminate\Database\Eloquent\ModelNotFoundException<\Illuminate\Database\Eloquent\Model> + * @throws \Illuminate\Routing\Exceptions\BackedEnumCaseNotFoundException + * @static + */ public static function substituteImplicitBindings($route) + { + /** @var \Illuminate\Routing\Router $instance */ + $instance->substituteImplicitBindings($route); + } + /** + * Register a callback to run after implicit bindings are substituted. + * + * @param callable $callback + * @return \Illuminate\Routing\Router + * @static + */ public static function substituteImplicitBindingsUsing($callback) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->substituteImplicitBindingsUsing($callback); + } + /** + * Register a route matched event listener. + * + * @param string|callable $callback + * @return void + * @static + */ public static function matched($callback) + { + /** @var \Illuminate\Routing\Router $instance */ + $instance->matched($callback); + } + /** + * Get all of the defined middleware short-hand names. + * + * @return array + * @static + */ public static function getMiddleware() + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->getMiddleware(); + } + /** + * Register a short-hand name for a middleware. + * + * @param string $name + * @param string $class + * @return \Illuminate\Routing\Router + * @static + */ public static function aliasMiddleware($name, $class) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->aliasMiddleware($name, $class); + } + /** + * Check if a middlewareGroup with the given name exists. + * + * @param string $name + * @return bool + * @static + */ public static function hasMiddlewareGroup($name) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->hasMiddlewareGroup($name); + } + /** + * Get all of the defined middleware groups. + * + * @return array + * @static + */ public static function getMiddlewareGroups() + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->getMiddlewareGroups(); + } + /** + * Register a group of middleware. + * + * @param string $name + * @param array $middleware + * @return \Illuminate\Routing\Router + * @static + */ public static function middlewareGroup($name, $middleware) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->middlewareGroup($name, $middleware); + } + /** + * Add a middleware to the beginning of a middleware group. + * + * If the middleware is already in the group, it will not be added again. + * + * @param string $group + * @param string $middleware + * @return \Illuminate\Routing\Router + * @static + */ public static function prependMiddlewareToGroup($group, $middleware) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->prependMiddlewareToGroup($group, $middleware); + } + /** + * Add a middleware to the end of a middleware group. + * + * If the middleware is already in the group, it will not be added again. + * + * @param string $group + * @param string $middleware + * @return \Illuminate\Routing\Router + * @static + */ public static function pushMiddlewareToGroup($group, $middleware) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->pushMiddlewareToGroup($group, $middleware); + } + /** + * Remove the given middleware from the specified group. + * + * @param string $group + * @param string $middleware + * @return \Illuminate\Routing\Router + * @static + */ public static function removeMiddlewareFromGroup($group, $middleware) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->removeMiddlewareFromGroup($group, $middleware); + } + /** + * Flush the router's middleware groups. + * + * @return \Illuminate\Routing\Router + * @static + */ public static function flushMiddlewareGroups() + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->flushMiddlewareGroups(); + } + /** + * Add a new route parameter binder. + * + * @param string $key + * @param string|callable $binder + * @return void + * @static + */ public static function bind($key, $binder) + { + /** @var \Illuminate\Routing\Router $instance */ + $instance->bind($key, $binder); + } + /** + * Register a model binder for a wildcard. + * + * @param string $key + * @param string $class + * @param \Closure|null $callback + * @return void + * @static + */ public static function model($key, $class, $callback = null) + { + /** @var \Illuminate\Routing\Router $instance */ + $instance->model($key, $class, $callback); + } + /** + * Get the binding callback for a given binding. + * + * @param string $key + * @return \Closure|null + * @static + */ public static function getBindingCallback($key) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->getBindingCallback($key); + } + /** + * Get the global "where" patterns. + * + * @return array + * @static + */ public static function getPatterns() + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->getPatterns(); + } + /** + * Set a global where pattern on all routes. + * + * @param string $key + * @param string $pattern + * @return void + * @static + */ public static function pattern($key, $pattern) + { + /** @var \Illuminate\Routing\Router $instance */ + $instance->pattern($key, $pattern); + } + /** + * Set a group of global where patterns on all routes. + * + * @param array $patterns + * @return void + * @static + */ public static function patterns($patterns) + { + /** @var \Illuminate\Routing\Router $instance */ + $instance->patterns($patterns); + } + /** + * Determine if the router currently has a group stack. + * + * @return bool + * @static + */ public static function hasGroupStack() + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->hasGroupStack(); + } + /** + * Get the current group stack for the router. + * + * @return array + * @static + */ public static function getGroupStack() + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->getGroupStack(); + } + /** + * Get a route parameter for the current route. + * + * @param string $key + * @param string|null $default + * @return mixed + * @static + */ public static function input($key, $default = null) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->input($key, $default); + } + /** + * Get the request currently being dispatched. + * + * @return \Illuminate\Http\Request + * @static + */ public static function getCurrentRequest() + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->getCurrentRequest(); + } + /** + * Get the currently dispatched route instance. + * + * @return \Illuminate\Routing\Route|null + * @static + */ public static function getCurrentRoute() + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->getCurrentRoute(); + } + /** + * Get the currently dispatched route instance. + * + * @return \Illuminate\Routing\Route|null + * @static + */ public static function current() + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->current(); + } + /** + * Check if a route with the given name exists. + * + * @param string|array $name + * @return bool + * @static + */ public static function has($name) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->has($name); + } + /** + * Get the current route name. + * + * @return string|null + * @static + */ public static function currentRouteName() + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->currentRouteName(); + } + /** + * Alias for the "currentRouteNamed" method. + * + * @param mixed $patterns + * @return bool + * @static + */ public static function is(...$patterns) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->is(...$patterns); + } + /** + * Determine if the current route matches a pattern. + * + * @param mixed $patterns + * @return bool + * @static + */ public static function currentRouteNamed(...$patterns) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->currentRouteNamed(...$patterns); + } + /** + * Get the current route action. + * + * @return string|null + * @static + */ public static function currentRouteAction() + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->currentRouteAction(); + } + /** + * Alias for the "currentRouteUses" method. + * + * @param array $patterns + * @return bool + * @static + */ public static function uses(...$patterns) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->uses(...$patterns); + } + /** + * Determine if the current route action matches a given action. + * + * @param string $action + * @return bool + * @static + */ public static function currentRouteUses($action) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->currentRouteUses($action); + } + /** + * Set the unmapped global resource parameters to singular. + * + * @param bool $singular + * @return void + * @static + */ public static function singularResourceParameters($singular = true) + { + /** @var \Illuminate\Routing\Router $instance */ + $instance->singularResourceParameters($singular); + } + /** + * Set the global resource parameter mapping. + * + * @param array $parameters + * @return void + * @static + */ public static function resourceParameters($parameters = []) + { + /** @var \Illuminate\Routing\Router $instance */ + $instance->resourceParameters($parameters); + } + /** + * Get or set the verbs used in the resource URIs. + * + * @param array $verbs + * @return array|null + * @static + */ public static function resourceVerbs($verbs = []) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->resourceVerbs($verbs); + } + /** + * Get the underlying route collection. + * + * @return \Illuminate\Routing\RouteCollectionInterface + * @static + */ public static function getRoutes() + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->getRoutes(); + } + /** + * Set the route collection instance. + * + * @param \Illuminate\Routing\RouteCollection $routes + * @return void + * @static + */ public static function setRoutes($routes) + { + /** @var \Illuminate\Routing\Router $instance */ + $instance->setRoutes($routes); + } + /** + * Set the compiled route collection instance. + * + * @param array $routes + * @return void + * @static + */ public static function setCompiledRoutes($routes) + { + /** @var \Illuminate\Routing\Router $instance */ + $instance->setCompiledRoutes($routes); + } + /** + * Remove any duplicate middleware from the given array. + * + * @param array $middleware + * @return array + * @static + */ public static function uniqueMiddleware($middleware) + { + return \Illuminate\Routing\Router::uniqueMiddleware($middleware); + } + /** + * Set the container instance used by the router. + * + * @param \Illuminate\Container\Container $container + * @return \Illuminate\Routing\Router + * @static + */ public static function setContainer($container) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->setContainer($container); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Routing\Router::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Routing\Router::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Routing\Router::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Routing\Router::flushMacros(); + } + /** + * Dynamically handle calls to the class. + * + * @param string $method + * @param array $parameters + * @return mixed + * @throws \BadMethodCallException + * @static + */ public static function macroCall($method, $parameters) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->macroCall($method, $parameters); + } + /** + * Call the given Closure with this instance then return the instance. + * + * @param \Illuminate\Routing\(callable($this): mixed)|null $callback + * @return \Illuminate\Routing\($callback is null ? \Illuminate\Support\HigherOrderTapProxy : $this) + * @static + */ public static function tap($callback = null) + { + /** @var \Illuminate\Routing\Router $instance */ + return $instance->tap($callback); + } + } + /** + * + * + * @see \Illuminate\Console\Scheduling\Schedule + */ class Schedule { + /** + * Add a new callback event to the schedule. + * + * @param string|callable $callback + * @param array $parameters + * @return \Illuminate\Console\Scheduling\CallbackEvent + * @static + */ public static function call($callback, $parameters = []) + { + /** @var \Illuminate\Console\Scheduling\Schedule $instance */ + return $instance->call($callback, $parameters); + } + /** + * Add a new Artisan command event to the schedule. + * + * @param string $command + * @param array $parameters + * @return \Illuminate\Console\Scheduling\Event + * @static + */ public static function command($command, $parameters = []) + { + /** @var \Illuminate\Console\Scheduling\Schedule $instance */ + return $instance->command($command, $parameters); + } + /** + * Add a new job callback event to the schedule. + * + * @param object|string $job + * @param string|null $queue + * @param string|null $connection + * @return \Illuminate\Console\Scheduling\CallbackEvent + * @static + */ public static function job($job, $queue = null, $connection = null) + { + /** @var \Illuminate\Console\Scheduling\Schedule $instance */ + return $instance->job($job, $queue, $connection); + } + /** + * Add a new command event to the schedule. + * + * @param string $command + * @param array $parameters + * @return \Illuminate\Console\Scheduling\Event + * @static + */ public static function exec($command, $parameters = []) + { + /** @var \Illuminate\Console\Scheduling\Schedule $instance */ + return $instance->exec($command, $parameters); + } + /** + * Compile array input for a command. + * + * @param string|int $key + * @param array $value + * @return string + * @static + */ public static function compileArrayInput($key, $value) + { + /** @var \Illuminate\Console\Scheduling\Schedule $instance */ + return $instance->compileArrayInput($key, $value); + } + /** + * Determine if the server is allowed to run this event. + * + * @param \Illuminate\Console\Scheduling\Event $event + * @param \DateTimeInterface $time + * @return bool + * @static + */ public static function serverShouldRun($event, $time) + { + /** @var \Illuminate\Console\Scheduling\Schedule $instance */ + return $instance->serverShouldRun($event, $time); + } + /** + * Get all of the events on the schedule that are due. + * + * @param \Illuminate\Contracts\Foundation\Application $app + * @return \Illuminate\Support\Collection + * @static + */ public static function dueEvents($app) + { + /** @var \Illuminate\Console\Scheduling\Schedule $instance */ + return $instance->dueEvents($app); + } + /** + * Get all of the events on the schedule. + * + * @return \Illuminate\Console\Scheduling\Event[] + * @static + */ public static function events() + { + /** @var \Illuminate\Console\Scheduling\Schedule $instance */ + return $instance->events(); + } + /** + * Specify the cache store that should be used to store mutexes. + * + * @param string $store + * @return \Illuminate\Console\Scheduling\Schedule + * @static + */ public static function useCache($store) + { + /** @var \Illuminate\Console\Scheduling\Schedule $instance */ + return $instance->useCache($store); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Console\Scheduling\Schedule::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Console\Scheduling\Schedule::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Console\Scheduling\Schedule::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Console\Scheduling\Schedule::flushMacros(); + } + } + /** + * + * + * @see \Illuminate\Database\Schema\Builder + */ class Schema { + /** + * Create a database in the schema. + * + * @param string $name + * @return bool + * @static + */ public static function createDatabase($name) + { + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->createDatabase($name); + } + /** + * Drop a database from the schema if the database exists. + * + * @param string $name + * @return bool + * @static + */ public static function dropDatabaseIfExists($name) + { + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->dropDatabaseIfExists($name); + } + /** + * Get the tables for the database. + * + * @param bool $withSize + * @return array + * @static + */ public static function getTables($withSize = true) + { + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->getTables($withSize); + } + /** + * Get the columns for a given table. + * + * @param string $table + * @return array + * @static + */ public static function getColumns($table) + { + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->getColumns($table); + } + /** + * Drop all tables from the database. + * + * @return void + * @static + */ public static function dropAllTables() + { + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + $instance->dropAllTables(); + } + /** + * Drop all views from the database. + * + * @return void + * @static + */ public static function dropAllViews() + { + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + $instance->dropAllViews(); + } + /** + * Set the busy timeout. + * + * @param int $milliseconds + * @return bool + * @static + */ public static function setBusyTimeout($milliseconds) + { + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->setBusyTimeout($milliseconds); + } + /** + * Set the journal mode. + * + * @param string $mode + * @return bool + * @static + */ public static function setJournalMode($mode) + { + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->setJournalMode($mode); + } + /** + * Set the synchronous mode. + * + * @param int $mode + * @return bool + * @static + */ public static function setSynchronous($mode) + { + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->setSynchronous($mode); + } + /** + * Empty the database file. + * + * @return void + * @static + */ public static function refreshDatabaseFile() + { + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + $instance->refreshDatabaseFile(); + } + /** + * Set the default string length for migrations. + * + * @param int $length + * @return void + * @static + */ public static function defaultStringLength($length) + { //Method inherited from \Illuminate\Database\Schema\Builder + \Illuminate\Database\Schema\SQLiteBuilder::defaultStringLength($length); + } + /** + * Set the default morph key type for migrations. + * + * @param string $type + * @return void + * @throws \InvalidArgumentException + * @static + */ public static function defaultMorphKeyType($type) + { //Method inherited from \Illuminate\Database\Schema\Builder + \Illuminate\Database\Schema\SQLiteBuilder::defaultMorphKeyType($type); + } + /** + * Set the default morph key type for migrations to UUIDs. + * + * @return void + * @static + */ public static function morphUsingUuids() + { //Method inherited from \Illuminate\Database\Schema\Builder + \Illuminate\Database\Schema\SQLiteBuilder::morphUsingUuids(); + } + /** + * Set the default morph key type for migrations to ULIDs. + * + * @return void + * @static + */ public static function morphUsingUlids() + { //Method inherited from \Illuminate\Database\Schema\Builder + \Illuminate\Database\Schema\SQLiteBuilder::morphUsingUlids(); + } + /** + * Determine if the given table exists. + * + * @param string $table + * @return bool + * @static + */ public static function hasTable($table) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->hasTable($table); + } + /** + * Determine if the given view exists. + * + * @param string $view + * @return bool + * @static + */ public static function hasView($view) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->hasView($view); + } + /** + * Get the names of the tables that belong to the database. + * + * @return array + * @static + */ public static function getTableListing() + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->getTableListing(); + } + /** + * Get the views that belong to the database. + * + * @return array + * @static + */ public static function getViews() + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->getViews(); + } + /** + * Get the user-defined types that belong to the database. + * + * @return array + * @static + */ public static function getTypes() + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->getTypes(); + } + /** + * Determine if the given table has a given column. + * + * @param string $table + * @param string $column + * @return bool + * @static + */ public static function hasColumn($table, $column) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->hasColumn($table, $column); + } + /** + * Determine if the given table has given columns. + * + * @param string $table + * @param array $columns + * @return bool + * @static + */ public static function hasColumns($table, $columns) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->hasColumns($table, $columns); + } + /** + * Execute a table builder callback if the given table has a given column. + * + * @param string $table + * @param string $column + * @param \Closure $callback + * @return void + * @static + */ public static function whenTableHasColumn($table, $column, $callback) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + $instance->whenTableHasColumn($table, $column, $callback); + } + /** + * Execute a table builder callback if the given table doesn't have a given column. + * + * @param string $table + * @param string $column + * @param \Closure $callback + * @return void + * @static + */ public static function whenTableDoesntHaveColumn($table, $column, $callback) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + $instance->whenTableDoesntHaveColumn($table, $column, $callback); + } + /** + * Get the data type for the given column name. + * + * @param string $table + * @param string $column + * @param bool $fullDefinition + * @return string + * @static + */ public static function getColumnType($table, $column, $fullDefinition = false) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->getColumnType($table, $column, $fullDefinition); + } + /** + * Get the column listing for a given table. + * + * @param string $table + * @return array + * @static + */ public static function getColumnListing($table) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->getColumnListing($table); + } + /** + * Get the indexes for a given table. + * + * @param string $table + * @return array + * @static + */ public static function getIndexes($table) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->getIndexes($table); + } + /** + * Get the names of the indexes for a given table. + * + * @param string $table + * @return array + * @static + */ public static function getIndexListing($table) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->getIndexListing($table); + } + /** + * Determine if the given table has a given index. + * + * @param string $table + * @param string|array $index + * @param string|null $type + * @return bool + * @static + */ public static function hasIndex($table, $index, $type = null) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->hasIndex($table, $index, $type); + } + /** + * Get the foreign keys for a given table. + * + * @param string $table + * @return array + * @static + */ public static function getForeignKeys($table) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->getForeignKeys($table); + } + /** + * Modify a table on the schema. + * + * @param string $table + * @param \Closure $callback + * @return void + * @static + */ public static function table($table, $callback) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + $instance->table($table, $callback); + } + /** + * Create a new table on the schema. + * + * @param string $table + * @param \Closure $callback + * @return void + * @static + */ public static function create($table, $callback) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + $instance->create($table, $callback); + } + /** + * Drop a table from the schema. + * + * @param string $table + * @return void + * @static + */ public static function drop($table) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + $instance->drop($table); + } + /** + * Drop a table from the schema if it exists. + * + * @param string $table + * @return void + * @static + */ public static function dropIfExists($table) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + $instance->dropIfExists($table); + } + /** + * Drop columns from a table schema. + * + * @param string $table + * @param string|array $columns + * @return void + * @static + */ public static function dropColumns($table, $columns) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + $instance->dropColumns($table, $columns); + } + /** + * Drop all types from the database. + * + * @return void + * @throws \LogicException + * @static + */ public static function dropAllTypes() + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + $instance->dropAllTypes(); + } + /** + * Rename a table on the schema. + * + * @param string $from + * @param string $to + * @return void + * @static + */ public static function rename($from, $to) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + $instance->rename($from, $to); + } + /** + * Enable foreign key constraints. + * + * @return bool + * @static + */ public static function enableForeignKeyConstraints() + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->enableForeignKeyConstraints(); + } + /** + * Disable foreign key constraints. + * + * @return bool + * @static + */ public static function disableForeignKeyConstraints() + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->disableForeignKeyConstraints(); + } + /** + * Disable foreign key constraints during the execution of a callback. + * + * @param \Closure $callback + * @return mixed + * @static + */ public static function withoutForeignKeyConstraints($callback) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->withoutForeignKeyConstraints($callback); + } + /** + * Get the database connection instance. + * + * @return \Illuminate\Database\Connection + * @static + */ public static function getConnection() + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->getConnection(); + } + /** + * Set the database connection instance. + * + * @param \Illuminate\Database\Connection $connection + * @return \Illuminate\Database\Schema\SQLiteBuilder + * @static + */ public static function setConnection($connection) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + return $instance->setConnection($connection); + } + /** + * Set the Schema Blueprint resolver callback. + * + * @param \Closure $resolver + * @return void + * @static + */ public static function blueprintResolver($resolver) + { //Method inherited from \Illuminate\Database\Schema\Builder + /** @var \Illuminate\Database\Schema\SQLiteBuilder $instance */ + $instance->blueprintResolver($resolver); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { //Method inherited from \Illuminate\Database\Schema\Builder + \Illuminate\Database\Schema\SQLiteBuilder::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { //Method inherited from \Illuminate\Database\Schema\Builder + \Illuminate\Database\Schema\SQLiteBuilder::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { //Method inherited from \Illuminate\Database\Schema\Builder + return \Illuminate\Database\Schema\SQLiteBuilder::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { //Method inherited from \Illuminate\Database\Schema\Builder + \Illuminate\Database\Schema\SQLiteBuilder::flushMacros(); + } + } + /** + * + * + * @see \Illuminate\Session\SessionManager + */ class Session { + /** + * Determine if requests for the same session should wait for each to finish before executing. + * + * @return bool + * @static + */ public static function shouldBlock() + { + /** @var \Illuminate\Session\SessionManager $instance */ + return $instance->shouldBlock(); + } + /** + * Get the name of the cache store / driver that should be used to acquire session locks. + * + * @return string|null + * @static + */ public static function blockDriver() + { + /** @var \Illuminate\Session\SessionManager $instance */ + return $instance->blockDriver(); + } + /** + * Get the maximum number of seconds the session lock should be held for. + * + * @return int + * @static + */ public static function defaultRouteBlockLockSeconds() + { + /** @var \Illuminate\Session\SessionManager $instance */ + return $instance->defaultRouteBlockLockSeconds(); + } + /** + * Get the maximum number of seconds to wait while attempting to acquire a route block session lock. + * + * @return int + * @static + */ public static function defaultRouteBlockWaitSeconds() + { + /** @var \Illuminate\Session\SessionManager $instance */ + return $instance->defaultRouteBlockWaitSeconds(); + } + /** + * Get the session configuration. + * + * @return array + * @static + */ public static function getSessionConfig() + { + /** @var \Illuminate\Session\SessionManager $instance */ + return $instance->getSessionConfig(); + } + /** + * Get the default session driver name. + * + * @return string + * @static + */ public static function getDefaultDriver() + { + /** @var \Illuminate\Session\SessionManager $instance */ + return $instance->getDefaultDriver(); + } + /** + * Set the default session driver name. + * + * @param string $name + * @return void + * @static + */ public static function setDefaultDriver($name) + { + /** @var \Illuminate\Session\SessionManager $instance */ + $instance->setDefaultDriver($name); + } + /** + * Get a driver instance. + * + * @param string|null $driver + * @return mixed + * @throws \InvalidArgumentException + * @static + */ public static function driver($driver = null) + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Session\SessionManager $instance */ + return $instance->driver($driver); + } + /** + * Register a custom driver creator Closure. + * + * @param string $driver + * @param \Closure $callback + * @return \Illuminate\Session\SessionManager + * @static + */ public static function extend($driver, $callback) + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Session\SessionManager $instance */ + return $instance->extend($driver, $callback); + } + /** + * Get all of the created "drivers". + * + * @return array + * @static + */ public static function getDrivers() + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Session\SessionManager $instance */ + return $instance->getDrivers(); + } + /** + * Get the container instance used by the manager. + * + * @return \Illuminate\Contracts\Container\Container + * @static + */ public static function getContainer() + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Session\SessionManager $instance */ + return $instance->getContainer(); + } + /** + * Set the container instance used by the manager. + * + * @param \Illuminate\Contracts\Container\Container $container + * @return \Illuminate\Session\SessionManager + * @static + */ public static function setContainer($container) + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Session\SessionManager $instance */ + return $instance->setContainer($container); + } + /** + * Forget all of the resolved driver instances. + * + * @return \Illuminate\Session\SessionManager + * @static + */ public static function forgetDrivers() + { //Method inherited from \Illuminate\Support\Manager + /** @var \Illuminate\Session\SessionManager $instance */ + return $instance->forgetDrivers(); + } + /** + * Start the session, reading the data from a handler. + * + * @return bool + * @static + */ public static function start() + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->start(); + } + /** + * Save the session data to storage. + * + * @return void + * @static + */ public static function save() + { + /** @var \Illuminate\Session\Store $instance */ + $instance->save(); + } + /** + * Age the flash data for the session. + * + * @return void + * @static + */ public static function ageFlashData() + { + /** @var \Illuminate\Session\Store $instance */ + $instance->ageFlashData(); + } + /** + * Get all of the session data. + * + * @return array + * @static + */ public static function all() + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->all(); + } + /** + * Get a subset of the session data. + * + * @param array $keys + * @return array + * @static + */ public static function only($keys) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->only($keys); + } + /** + * Get all the session data except for a specified array of items. + * + * @param array $keys + * @return array + * @static + */ public static function except($keys) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->except($keys); + } + /** + * Checks if a key exists. + * + * @param string|array $key + * @return bool + * @static + */ public static function exists($key) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->exists($key); + } + /** + * Determine if the given key is missing from the session data. + * + * @param string|array $key + * @return bool + * @static + */ public static function missing($key) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->missing($key); + } + /** + * Determine if a key is present and not null. + * + * @param string|array $key + * @return bool + * @static + */ public static function has($key) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->has($key); + } + /** + * Determine if any of the given keys are present and not null. + * + * @param string|array $key + * @return bool + * @static + */ public static function hasAny($key) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->hasAny($key); + } + /** + * Get an item from the session. + * + * @param string $key + * @param mixed $default + * @return mixed + * @static + */ public static function get($key, $default = null) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->get($key, $default); + } + /** + * Get the value of a given key and then forget it. + * + * @param string $key + * @param mixed $default + * @return mixed + * @static + */ public static function pull($key, $default = null) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->pull($key, $default); + } + /** + * Determine if the session contains old input. + * + * @param string|null $key + * @return bool + * @static + */ public static function hasOldInput($key = null) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->hasOldInput($key); + } + /** + * Get the requested item from the flashed input array. + * + * @param string|null $key + * @param mixed $default + * @return mixed + * @static + */ public static function getOldInput($key = null, $default = null) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->getOldInput($key, $default); + } + /** + * Replace the given session attributes entirely. + * + * @param array $attributes + * @return void + * @static + */ public static function replace($attributes) + { + /** @var \Illuminate\Session\Store $instance */ + $instance->replace($attributes); + } + /** + * Put a key / value pair or array of key / value pairs in the session. + * + * @param string|array $key + * @param mixed $value + * @return void + * @static + */ public static function put($key, $value = null) + { + /** @var \Illuminate\Session\Store $instance */ + $instance->put($key, $value); + } + /** + * Get an item from the session, or store the default value. + * + * @param string $key + * @param \Closure $callback + * @return mixed + * @static + */ public static function remember($key, $callback) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->remember($key, $callback); + } + /** + * Push a value onto a session array. + * + * @param string $key + * @param mixed $value + * @return void + * @static + */ public static function push($key, $value) + { + /** @var \Illuminate\Session\Store $instance */ + $instance->push($key, $value); + } + /** + * Increment the value of an item in the session. + * + * @param string $key + * @param int $amount + * @return mixed + * @static + */ public static function increment($key, $amount = 1) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->increment($key, $amount); + } + /** + * Decrement the value of an item in the session. + * + * @param string $key + * @param int $amount + * @return int + * @static + */ public static function decrement($key, $amount = 1) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->decrement($key, $amount); + } + /** + * Flash a key / value pair to the session. + * + * @param string $key + * @param mixed $value + * @return void + * @static + */ public static function flash($key, $value = true) + { + /** @var \Illuminate\Session\Store $instance */ + $instance->flash($key, $value); + } + /** + * Flash a key / value pair to the session for immediate use. + * + * @param string $key + * @param mixed $value + * @return void + * @static + */ public static function now($key, $value) + { + /** @var \Illuminate\Session\Store $instance */ + $instance->now($key, $value); + } + /** + * Reflash all of the session flash data. + * + * @return void + * @static + */ public static function reflash() + { + /** @var \Illuminate\Session\Store $instance */ + $instance->reflash(); + } + /** + * Reflash a subset of the current flash data. + * + * @param array|mixed $keys + * @return void + * @static + */ public static function keep($keys = null) + { + /** @var \Illuminate\Session\Store $instance */ + $instance->keep($keys); + } + /** + * Flash an input array to the session. + * + * @param array $value + * @return void + * @static + */ public static function flashInput($value) + { + /** @var \Illuminate\Session\Store $instance */ + $instance->flashInput($value); + } + /** + * Remove an item from the session, returning its value. + * + * @param string $key + * @return mixed + * @static + */ public static function remove($key) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->remove($key); + } + /** + * Remove one or many items from the session. + * + * @param string|array $keys + * @return void + * @static + */ public static function forget($keys) + { + /** @var \Illuminate\Session\Store $instance */ + $instance->forget($keys); + } + /** + * Remove all of the items from the session. + * + * @return void + * @static + */ public static function flush() + { + /** @var \Illuminate\Session\Store $instance */ + $instance->flush(); + } + /** + * Flush the session data and regenerate the ID. + * + * @return bool + * @static + */ public static function invalidate() + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->invalidate(); + } + /** + * Generate a new session identifier. + * + * @param bool $destroy + * @return bool + * @static + */ public static function regenerate($destroy = false) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->regenerate($destroy); + } + /** + * Generate a new session ID for the session. + * + * @param bool $destroy + * @return bool + * @static + */ public static function migrate($destroy = false) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->migrate($destroy); + } + /** + * Determine if the session has been started. + * + * @return bool + * @static + */ public static function isStarted() + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->isStarted(); + } + /** + * Get the name of the session. + * + * @return string + * @static + */ public static function getName() + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->getName(); + } + /** + * Set the name of the session. + * + * @param string $name + * @return void + * @static + */ public static function setName($name) + { + /** @var \Illuminate\Session\Store $instance */ + $instance->setName($name); + } + /** + * Get the current session ID. + * + * @return string + * @static + */ public static function id() + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->id(); + } + /** + * Get the current session ID. + * + * @return string + * @static + */ public static function getId() + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->getId(); + } + /** + * Set the session ID. + * + * @param string|null $id + * @return void + * @static + */ public static function setId($id) + { + /** @var \Illuminate\Session\Store $instance */ + $instance->setId($id); + } + /** + * Determine if this is a valid session ID. + * + * @param string|null $id + * @return bool + * @static + */ public static function isValidId($id) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->isValidId($id); + } + /** + * Set the existence of the session on the handler if applicable. + * + * @param bool $value + * @return void + * @static + */ public static function setExists($value) + { + /** @var \Illuminate\Session\Store $instance */ + $instance->setExists($value); + } + /** + * Get the CSRF token value. + * + * @return string + * @static + */ public static function token() + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->token(); + } + /** + * Regenerate the CSRF token value. + * + * @return void + * @static + */ public static function regenerateToken() + { + /** @var \Illuminate\Session\Store $instance */ + $instance->regenerateToken(); + } + /** + * Get the previous URL from the session. + * + * @return string|null + * @static + */ public static function previousUrl() + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->previousUrl(); + } + /** + * Set the "previous" URL in the session. + * + * @param string $url + * @return void + * @static + */ public static function setPreviousUrl($url) + { + /** @var \Illuminate\Session\Store $instance */ + $instance->setPreviousUrl($url); + } + /** + * Specify that the user has confirmed their password. + * + * @return void + * @static + */ public static function passwordConfirmed() + { + /** @var \Illuminate\Session\Store $instance */ + $instance->passwordConfirmed(); + } + /** + * Get the underlying session handler implementation. + * + * @return \SessionHandlerInterface + * @static + */ public static function getHandler() + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->getHandler(); + } + /** + * Set the underlying session handler implementation. + * + * @param \SessionHandlerInterface $handler + * @return \SessionHandlerInterface + * @static + */ public static function setHandler($handler) + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->setHandler($handler); + } + /** + * Determine if the session handler needs a request. + * + * @return bool + * @static + */ public static function handlerNeedsRequest() + { + /** @var \Illuminate\Session\Store $instance */ + return $instance->handlerNeedsRequest(); + } + /** + * Set the request on the handler instance. + * + * @param \Illuminate\Http\Request $request + * @return void + * @static + */ public static function setRequestOnHandler($request) + { + /** @var \Illuminate\Session\Store $instance */ + $instance->setRequestOnHandler($request); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Session\Store::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Session\Store::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Session\Store::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Session\Store::flushMacros(); + } + } + /** + * + * + * @method static bool has(string $location) + * @method static string read(string $location) + * @method static \League\Flysystem\DirectoryListing listContents(string $location, bool $deep = false) + * @method static int fileSize(string $path) + * @method static string visibility(string $path) + * @method static void write(string $location, string $contents, array $config = []) + * @method static void createDirectory(string $location, array $config = []) + * @see \Illuminate\Filesystem\FilesystemManager + */ class Storage { + /** + * Get a filesystem instance. + * + * @param string|null $name + * @return \Illuminate\Filesystem\FilesystemAdapter + * @static + */ public static function drive($name = null) + { + /** @var \Illuminate\Filesystem\FilesystemManager $instance */ + return $instance->drive($name); + } + /** + * Get a filesystem instance. + * + * @param string|null $name + * @return \Illuminate\Filesystem\FilesystemAdapter + * @static + */ public static function disk($name = null) + { + /** @var \Illuminate\Filesystem\FilesystemManager $instance */ + return $instance->disk($name); + } + /** + * Get a default cloud filesystem instance. + * + * @return \Illuminate\Contracts\Filesystem\Cloud + * @static + */ public static function cloud() + { + /** @var \Illuminate\Filesystem\FilesystemManager $instance */ + return $instance->cloud(); + } + /** + * Build an on-demand disk. + * + * @param string|array $config + * @return \Illuminate\Filesystem\FilesystemAdapter + * @static + */ public static function build($config) + { + /** @var \Illuminate\Filesystem\FilesystemManager $instance */ + return $instance->build($config); + } + /** + * Create an instance of the local driver. + * + * @param array $config + * @return \Illuminate\Filesystem\FilesystemAdapter + * @static + */ public static function createLocalDriver($config) + { + /** @var \Illuminate\Filesystem\FilesystemManager $instance */ + return $instance->createLocalDriver($config); + } + /** + * Create an instance of the ftp driver. + * + * @param array $config + * @return \Illuminate\Filesystem\FilesystemAdapter + * @static + */ public static function createFtpDriver($config) + { + /** @var \Illuminate\Filesystem\FilesystemManager $instance */ + return $instance->createFtpDriver($config); + } + /** + * Create an instance of the sftp driver. + * + * @param array $config + * @return \Illuminate\Filesystem\FilesystemAdapter + * @static + */ public static function createSftpDriver($config) + { + /** @var \Illuminate\Filesystem\FilesystemManager $instance */ + return $instance->createSftpDriver($config); + } + /** + * Create an instance of the Amazon S3 driver. + * + * @param array $config + * @return \Illuminate\Contracts\Filesystem\Cloud + * @static + */ public static function createS3Driver($config) + { + /** @var \Illuminate\Filesystem\FilesystemManager $instance */ + return $instance->createS3Driver($config); + } + /** + * Create a scoped driver. + * + * @param array $config + * @return \Illuminate\Filesystem\FilesystemAdapter + * @static + */ public static function createScopedDriver($config) + { + /** @var \Illuminate\Filesystem\FilesystemManager $instance */ + return $instance->createScopedDriver($config); + } + /** + * Set the given disk instance. + * + * @param string $name + * @param mixed $disk + * @return \Illuminate\Filesystem\FilesystemManager + * @static + */ public static function set($name, $disk) + { + /** @var \Illuminate\Filesystem\FilesystemManager $instance */ + return $instance->set($name, $disk); + } + /** + * Get the default driver name. + * + * @return string + * @static + */ public static function getDefaultDriver() + { + /** @var \Illuminate\Filesystem\FilesystemManager $instance */ + return $instance->getDefaultDriver(); + } + /** + * Get the default cloud driver name. + * + * @return string + * @static + */ public static function getDefaultCloudDriver() + { + /** @var \Illuminate\Filesystem\FilesystemManager $instance */ + return $instance->getDefaultCloudDriver(); + } + /** + * Unset the given disk instances. + * + * @param array|string $disk + * @return \Illuminate\Filesystem\FilesystemManager + * @static + */ public static function forgetDisk($disk) + { + /** @var \Illuminate\Filesystem\FilesystemManager $instance */ + return $instance->forgetDisk($disk); + } + /** + * Disconnect the given disk and remove from local cache. + * + * @param string|null $name + * @return void + * @static + */ public static function purge($name = null) + { + /** @var \Illuminate\Filesystem\FilesystemManager $instance */ + $instance->purge($name); + } + /** + * Register a custom driver creator Closure. + * + * @param string $driver + * @param \Closure $callback + * @return \Illuminate\Filesystem\FilesystemManager + * @static + */ public static function extend($driver, $callback) + { + /** @var \Illuminate\Filesystem\FilesystemManager $instance */ + return $instance->extend($driver, $callback); + } + /** + * Set the application instance used by the manager. + * + * @param \Illuminate\Contracts\Foundation\Application $app + * @return \Illuminate\Filesystem\FilesystemManager + * @static + */ public static function setApplication($app) + { + /** @var \Illuminate\Filesystem\FilesystemManager $instance */ + return $instance->setApplication($app); + } + /** + * Assert that the given file or directory exists. + * + * @param string|array $path + * @param string|null $content + * @return \Illuminate\Filesystem\FilesystemAdapter + * @static + */ public static function assertExists($path, $content = null) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->assertExists($path, $content); + } + /** + * Assert that the given file or directory does not exist. + * + * @param string|array $path + * @return \Illuminate\Filesystem\FilesystemAdapter + * @static + */ public static function assertMissing($path) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->assertMissing($path); + } + /** + * Assert that the given directory is empty. + * + * @param string $path + * @return \Illuminate\Filesystem\FilesystemAdapter + * @static + */ public static function assertDirectoryEmpty($path) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->assertDirectoryEmpty($path); + } + /** + * Determine if a file or directory exists. + * + * @param string $path + * @return bool + * @static + */ public static function exists($path) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->exists($path); + } + /** + * Determine if a file or directory is missing. + * + * @param string $path + * @return bool + * @static + */ public static function missing($path) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->missing($path); + } + /** + * Determine if a file exists. + * + * @param string $path + * @return bool + * @static + */ public static function fileExists($path) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->fileExists($path); + } + /** + * Determine if a file is missing. + * + * @param string $path + * @return bool + * @static + */ public static function fileMissing($path) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->fileMissing($path); + } + /** + * Determine if a directory exists. + * + * @param string $path + * @return bool + * @static + */ public static function directoryExists($path) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->directoryExists($path); + } + /** + * Determine if a directory is missing. + * + * @param string $path + * @return bool + * @static + */ public static function directoryMissing($path) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->directoryMissing($path); + } + /** + * Get the full path to the file that exists at the given relative path. + * + * @param string $path + * @return string + * @static + */ public static function path($path) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->path($path); + } + /** + * Get the contents of a file. + * + * @param string $path + * @return string|null + * @static + */ public static function get($path) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->get($path); + } + /** + * Get the contents of a file as decoded JSON. + * + * @param string $path + * @param int $flags + * @return array|null + * @static + */ public static function json($path, $flags = 0) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->json($path, $flags); + } + /** + * Create a streamed response for a given file. + * + * @param string $path + * @param string|null $name + * @param array $headers + * @param string|null $disposition + * @return \Symfony\Component\HttpFoundation\StreamedResponse + * @static + */ public static function response($path, $name = null, $headers = [], $disposition = 'inline') + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->response($path, $name, $headers, $disposition); + } + /** + * Create a streamed download response for a given file. + * + * @param string $path + * @param string|null $name + * @return \Symfony\Component\HttpFoundation\StreamedResponse + * @static + */ public static function download($path, $name = null, $headers = []) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->download($path, $name, $headers); + } + /** + * Write the contents of a file. + * + * @param string $path + * @param \Psr\Http\Message\StreamInterface|\Illuminate\Http\File|\Illuminate\Http\UploadedFile|string|resource $contents + * @param mixed $options + * @return string|bool + * @static + */ public static function put($path, $contents, $options = []) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->put($path, $contents, $options); + } + /** + * Store the uploaded file on the disk. + * + * @param \Illuminate\Http\File|\Illuminate\Http\UploadedFile|string $path + * @param \Illuminate\Http\File|\Illuminate\Http\UploadedFile|string|array|null $file + * @param mixed $options + * @return string|false + * @static + */ public static function putFile($path, $file = null, $options = []) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->putFile($path, $file, $options); + } + /** + * Store the uploaded file on the disk with a given name. + * + * @param \Illuminate\Http\File|\Illuminate\Http\UploadedFile|string $path + * @param \Illuminate\Http\File|\Illuminate\Http\UploadedFile|string|array|null $file + * @param string|array|null $name + * @param mixed $options + * @return string|false + * @static + */ public static function putFileAs($path, $file, $name = null, $options = []) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->putFileAs($path, $file, $name, $options); + } + /** + * Get the visibility for the given path. + * + * @param string $path + * @return string + * @static + */ public static function getVisibility($path) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->getVisibility($path); + } + /** + * Set the visibility for the given path. + * + * @param string $path + * @param string $visibility + * @return bool + * @static + */ public static function setVisibility($path, $visibility) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->setVisibility($path, $visibility); + } + /** + * Prepend to a file. + * + * @param string $path + * @param string $data + * @param string $separator + * @return bool + * @static + */ public static function prepend($path, $data, $separator = ' +') + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->prepend($path, $data, $separator); + } + /** + * Append to a file. + * + * @param string $path + * @param string $data + * @param string $separator + * @return bool + * @static + */ public static function append($path, $data, $separator = ' +') + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->append($path, $data, $separator); + } + /** + * Delete the file at a given path. + * + * @param string|array $paths + * @return bool + * @static + */ public static function delete($paths) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->delete($paths); + } + /** + * Copy a file to a new location. + * + * @param string $from + * @param string $to + * @return bool + * @static + */ public static function copy($from, $to) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->copy($from, $to); + } + /** + * Move a file to a new location. + * + * @param string $from + * @param string $to + * @return bool + * @static + */ public static function move($from, $to) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->move($from, $to); + } + /** + * Get the file size of a given file. + * + * @param string $path + * @return int + * @static + */ public static function size($path) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->size($path); + } + /** + * Get the checksum for a file. + * + * @return string|false + * @throws UnableToProvideChecksum + * @static + */ public static function checksum($path, $options = []) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->checksum($path, $options); + } + /** + * Get the mime-type of a given file. + * + * @param string $path + * @return string|false + * @static + */ public static function mimeType($path) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->mimeType($path); + } + /** + * Get the file's last modification time. + * + * @param string $path + * @return int + * @static + */ public static function lastModified($path) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->lastModified($path); + } + /** + * Get a resource to read the file. + * + * @param string $path + * @return resource|null The path resource or null on failure. + * @static + */ public static function readStream($path) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->readStream($path); + } + /** + * Write a new file using a stream. + * + * @param string $path + * @param resource $resource + * @param array $options + * @return bool + * @static + */ public static function writeStream($path, $resource, $options = []) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->writeStream($path, $resource, $options); + } + /** + * Get the URL for the file at the given path. + * + * @param string $path + * @return string + * @throws \RuntimeException + * @static + */ public static function url($path) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->url($path); + } + /** + * Determine if temporary URLs can be generated. + * + * @return bool + * @static + */ public static function providesTemporaryUrls() + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->providesTemporaryUrls(); + } + /** + * Get a temporary URL for the file at the given path. + * + * @param string $path + * @param \DateTimeInterface $expiration + * @param array $options + * @return string + * @throws \RuntimeException + * @static + */ public static function temporaryUrl($path, $expiration, $options = []) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->temporaryUrl($path, $expiration, $options); + } + /** + * Get a temporary upload URL for the file at the given path. + * + * @param string $path + * @param \DateTimeInterface $expiration + * @param array $options + * @return array + * @throws \RuntimeException + * @static + */ public static function temporaryUploadUrl($path, $expiration, $options = []) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->temporaryUploadUrl($path, $expiration, $options); + } + /** + * Get an array of all files in a directory. + * + * @param string|null $directory + * @param bool $recursive + * @return array + * @static + */ public static function files($directory = null, $recursive = false) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->files($directory, $recursive); + } + /** + * Get all of the files from the given directory (recursive). + * + * @param string|null $directory + * @return array + * @static + */ public static function allFiles($directory = null) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->allFiles($directory); + } + /** + * Get all of the directories within a given directory. + * + * @param string|null $directory + * @param bool $recursive + * @return array + * @static + */ public static function directories($directory = null, $recursive = false) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->directories($directory, $recursive); + } + /** + * Get all the directories within a given directory (recursive). + * + * @param string|null $directory + * @return array + * @static + */ public static function allDirectories($directory = null) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->allDirectories($directory); + } + /** + * Create a directory. + * + * @param string $path + * @return bool + * @static + */ public static function makeDirectory($path) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->makeDirectory($path); + } + /** + * Recursively delete a directory. + * + * @param string $directory + * @return bool + * @static + */ public static function deleteDirectory($directory) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->deleteDirectory($directory); + } + /** + * Get the Flysystem driver. + * + * @return \League\Flysystem\FilesystemOperator + * @static + */ public static function getDriver() + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->getDriver(); + } + /** + * Get the Flysystem adapter. + * + * @return \League\Flysystem\FilesystemAdapter + * @static + */ public static function getAdapter() + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->getAdapter(); + } + /** + * Get the configuration values. + * + * @return array + * @static + */ public static function getConfig() + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->getConfig(); + } + /** + * Define a custom temporary URL builder callback. + * + * @param \Closure $callback + * @return void + * @static + */ public static function buildTemporaryUrlsUsing($callback) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + $instance->buildTemporaryUrlsUsing($callback); + } + /** + * Apply the callback if the given "value" is (or resolves to) truthy. + * + * @template TWhenParameter + * @template TWhenReturnType + * @param \Illuminate\Filesystem\(\Closure($this): TWhenParameter)|TWhenParameter|null $value + * @param \Illuminate\Filesystem\(callable($this, TWhenParameter): TWhenReturnType)|null $callback + * @param \Illuminate\Filesystem\(callable($this, TWhenParameter): TWhenReturnType)|null $default + * @return $this|\Illuminate\Filesystem\TWhenReturnType + * @static + */ public static function when($value = null, $callback = null, $default = null) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->when($value, $callback, $default); + } + /** + * Apply the callback if the given "value" is (or resolves to) falsy. + * + * @template TUnlessParameter + * @template TUnlessReturnType + * @param \Illuminate\Filesystem\(\Closure($this): TUnlessParameter)|TUnlessParameter|null $value + * @param \Illuminate\Filesystem\(callable($this, TUnlessParameter): TUnlessReturnType)|null $callback + * @param \Illuminate\Filesystem\(callable($this, TUnlessParameter): TUnlessReturnType)|null $default + * @return $this|\Illuminate\Filesystem\TUnlessReturnType + * @static + */ public static function unless($value = null, $callback = null, $default = null) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->unless($value, $callback, $default); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Filesystem\FilesystemAdapter::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Filesystem\FilesystemAdapter::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Filesystem\FilesystemAdapter::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Filesystem\FilesystemAdapter::flushMacros(); + } + /** + * Dynamically handle calls to the class. + * + * @param string $method + * @param array $parameters + * @return mixed + * @throws \BadMethodCallException + * @static + */ public static function macroCall($method, $parameters) + { + /** @var \Illuminate\Filesystem\FilesystemAdapter $instance */ + return $instance->macroCall($method, $parameters); + } + } + /** + * + * + * @see \Illuminate\Routing\UrlGenerator + */ class URL { + /** + * Get the full URL for the current request. + * + * @return string + * @static + */ public static function full() + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->full(); + } + /** + * Get the current URL for the request. + * + * @return string + * @static + */ public static function current() + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->current(); + } + /** + * Get the URL for the previous request. + * + * @param mixed $fallback + * @return string + * @static + */ public static function previous($fallback = false) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->previous($fallback); + } + /** + * Get the previous path info for the request. + * + * @param mixed $fallback + * @return string + * @static + */ public static function previousPath($fallback = false) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->previousPath($fallback); + } + /** + * Generate an absolute URL to the given path. + * + * @param string $path + * @param mixed $extra + * @param bool|null $secure + * @return string + * @static + */ public static function to($path, $extra = [], $secure = null) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->to($path, $extra, $secure); + } + /** + * Generate an absolute URL with the given query parameters. + * + * @param string $path + * @param array $query + * @param mixed $extra + * @param bool|null $secure + * @return string + * @static + */ public static function query($path, $query = [], $extra = [], $secure = null) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->query($path, $query, $extra, $secure); + } + /** + * Generate a secure, absolute URL to the given path. + * + * @param string $path + * @param array $parameters + * @return string + * @static + */ public static function secure($path, $parameters = []) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->secure($path, $parameters); + } + /** + * Generate the URL to an application asset. + * + * @param string $path + * @param bool|null $secure + * @return string + * @static + */ public static function asset($path, $secure = null) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->asset($path, $secure); + } + /** + * Generate the URL to a secure asset. + * + * @param string $path + * @return string + * @static + */ public static function secureAsset($path) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->secureAsset($path); + } + /** + * Generate the URL to an asset from a custom root domain such as CDN, etc. + * + * @param string $root + * @param string $path + * @param bool|null $secure + * @return string + * @static + */ public static function assetFrom($root, $path, $secure = null) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->assetFrom($root, $path, $secure); + } + /** + * Get the default scheme for a raw URL. + * + * @param bool|null $secure + * @return string + * @static + */ public static function formatScheme($secure = null) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->formatScheme($secure); + } + /** + * Create a signed route URL for a named route. + * + * @param string $name + * @param mixed $parameters + * @param \DateTimeInterface|\DateInterval|int|null $expiration + * @param bool $absolute + * @return string + * @throws \InvalidArgumentException + * @static + */ public static function signedRoute($name, $parameters = [], $expiration = null, $absolute = true) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->signedRoute($name, $parameters, $expiration, $absolute); + } + /** + * Create a temporary signed route URL for a named route. + * + * @param string $name + * @param \DateTimeInterface|\DateInterval|int $expiration + * @param array $parameters + * @param bool $absolute + * @return string + * @static + */ public static function temporarySignedRoute($name, $expiration, $parameters = [], $absolute = true) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->temporarySignedRoute($name, $expiration, $parameters, $absolute); + } + /** + * Determine if the given request has a valid signature. + * + * @param \Illuminate\Http\Request $request + * @param bool $absolute + * @param array $ignoreQuery + * @return bool + * @static + */ public static function hasValidSignature($request, $absolute = true, $ignoreQuery = []) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->hasValidSignature($request, $absolute, $ignoreQuery); + } + /** + * Determine if the given request has a valid signature for a relative URL. + * + * @param \Illuminate\Http\Request $request + * @param array $ignoreQuery + * @return bool + * @static + */ public static function hasValidRelativeSignature($request, $ignoreQuery = []) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->hasValidRelativeSignature($request, $ignoreQuery); + } + /** + * Determine if the signature from the given request matches the URL. + * + * @param \Illuminate\Http\Request $request + * @param bool $absolute + * @param array $ignoreQuery + * @return bool + * @static + */ public static function hasCorrectSignature($request, $absolute = true, $ignoreQuery = []) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->hasCorrectSignature($request, $absolute, $ignoreQuery); + } + /** + * Determine if the expires timestamp from the given request is not from the past. + * + * @param \Illuminate\Http\Request $request + * @return bool + * @static + */ public static function signatureHasNotExpired($request) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->signatureHasNotExpired($request); + } + /** + * Get the URL to a named route. + * + * @param string $name + * @param mixed $parameters + * @param bool $absolute + * @return string + * @throws \Symfony\Component\Routing\Exception\RouteNotFoundException + * @static + */ public static function route($name, $parameters = [], $absolute = true) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->route($name, $parameters, $absolute); + } + /** + * Get the URL for a given route instance. + * + * @param \Illuminate\Routing\Route $route + * @param mixed $parameters + * @param bool $absolute + * @return string + * @throws \Illuminate\Routing\Exceptions\UrlGenerationException + * @static + */ public static function toRoute($route, $parameters, $absolute) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->toRoute($route, $parameters, $absolute); + } + /** + * Get the URL to a controller action. + * + * @param string|array $action + * @param mixed $parameters + * @param bool $absolute + * @return string + * @throws \InvalidArgumentException + * @static + */ public static function action($action, $parameters = [], $absolute = true) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->action($action, $parameters, $absolute); + } + /** + * Format the array of URL parameters. + * + * @param mixed|array $parameters + * @return array + * @static + */ public static function formatParameters($parameters) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->formatParameters($parameters); + } + /** + * Get the base URL for the request. + * + * @param string $scheme + * @param string|null $root + * @return string + * @static + */ public static function formatRoot($scheme, $root = null) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->formatRoot($scheme, $root); + } + /** + * Format the given URL segments into a single URL. + * + * @param string $root + * @param string $path + * @param \Illuminate\Routing\Route|null $route + * @return string + * @static + */ public static function format($root, $path, $route = null) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->format($root, $path, $route); + } + /** + * Determine if the given path is a valid URL. + * + * @param string $path + * @return bool + * @static + */ public static function isValidUrl($path) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->isValidUrl($path); + } + /** + * Set the default named parameters used by the URL generator. + * + * @param array $defaults + * @return void + * @static + */ public static function defaults($defaults) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + $instance->defaults($defaults); + } + /** + * Get the default named parameters used by the URL generator. + * + * @return array + * @static + */ public static function getDefaultParameters() + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->getDefaultParameters(); + } + /** + * Force the scheme for URLs. + * + * @param string|null $scheme + * @return void + * @static + */ public static function forceScheme($scheme) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + $instance->forceScheme($scheme); + } + /** + * Set the forced root URL. + * + * @param string|null $root + * @return void + * @static + */ public static function forceRootUrl($root) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + $instance->forceRootUrl($root); + } + /** + * Set a callback to be used to format the host of generated URLs. + * + * @param \Closure $callback + * @return \Illuminate\Routing\UrlGenerator + * @static + */ public static function formatHostUsing($callback) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->formatHostUsing($callback); + } + /** + * Set a callback to be used to format the path of generated URLs. + * + * @param \Closure $callback + * @return \Illuminate\Routing\UrlGenerator + * @static + */ public static function formatPathUsing($callback) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->formatPathUsing($callback); + } + /** + * Get the path formatter being used by the URL generator. + * + * @return \Closure + * @static + */ public static function pathFormatter() + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->pathFormatter(); + } + /** + * Get the request instance. + * + * @return \Illuminate\Http\Request + * @static + */ public static function getRequest() + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->getRequest(); + } + /** + * Set the current request instance. + * + * @param \Illuminate\Http\Request $request + * @return void + * @static + */ public static function setRequest($request) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + $instance->setRequest($request); + } + /** + * Set the route collection. + * + * @param \Illuminate\Routing\RouteCollectionInterface $routes + * @return \Illuminate\Routing\UrlGenerator + * @static + */ public static function setRoutes($routes) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->setRoutes($routes); + } + /** + * Set the session resolver for the generator. + * + * @param callable $sessionResolver + * @return \Illuminate\Routing\UrlGenerator + * @static + */ public static function setSessionResolver($sessionResolver) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->setSessionResolver($sessionResolver); + } + /** + * Set the encryption key resolver. + * + * @param callable $keyResolver + * @return \Illuminate\Routing\UrlGenerator + * @static + */ public static function setKeyResolver($keyResolver) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->setKeyResolver($keyResolver); + } + /** + * Clone a new instance of the URL generator with a different encryption key resolver. + * + * @param callable $keyResolver + * @return \Illuminate\Routing\UrlGenerator + * @static + */ public static function withKeyResolver($keyResolver) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->withKeyResolver($keyResolver); + } + /** + * Set the callback that should be used to attempt to resolve missing named routes. + * + * @param callable $missingNamedRouteResolver + * @return \Illuminate\Routing\UrlGenerator + * @static + */ public static function resolveMissingNamedRoutesUsing($missingNamedRouteResolver) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->resolveMissingNamedRoutesUsing($missingNamedRouteResolver); + } + /** + * Get the root controller namespace. + * + * @return string + * @static + */ public static function getRootControllerNamespace() + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->getRootControllerNamespace(); + } + /** + * Set the root controller namespace. + * + * @param string $rootNamespace + * @return \Illuminate\Routing\UrlGenerator + * @static + */ public static function setRootControllerNamespace($rootNamespace) + { + /** @var \Illuminate\Routing\UrlGenerator $instance */ + return $instance->setRootControllerNamespace($rootNamespace); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Routing\UrlGenerator::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Routing\UrlGenerator::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Routing\UrlGenerator::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Routing\UrlGenerator::flushMacros(); + } + } + /** + * + * + * @see \Illuminate\Validation\Factory + */ class Validator { + /** + * Create a new Validator instance. + * + * @param array $data + * @param array $rules + * @param array $messages + * @param array $attributes + * @return \Illuminate\Validation\Validator + * @static + */ public static function make($data, $rules, $messages = [], $attributes = []) + { + /** @var \Illuminate\Validation\Factory $instance */ + return $instance->make($data, $rules, $messages, $attributes); + } + /** + * Validate the given data against the provided rules. + * + * @param array $data + * @param array $rules + * @param array $messages + * @param array $attributes + * @return array + * @throws \Illuminate\Validation\ValidationException + * @static + */ public static function validate($data, $rules, $messages = [], $attributes = []) + { + /** @var \Illuminate\Validation\Factory $instance */ + return $instance->validate($data, $rules, $messages, $attributes); + } + /** + * Register a custom validator extension. + * + * @param string $rule + * @param \Closure|string $extension + * @param string|null $message + * @return void + * @static + */ public static function extend($rule, $extension, $message = null) + { + /** @var \Illuminate\Validation\Factory $instance */ + $instance->extend($rule, $extension, $message); + } + /** + * Register a custom implicit validator extension. + * + * @param string $rule + * @param \Closure|string $extension + * @param string|null $message + * @return void + * @static + */ public static function extendImplicit($rule, $extension, $message = null) + { + /** @var \Illuminate\Validation\Factory $instance */ + $instance->extendImplicit($rule, $extension, $message); + } + /** + * Register a custom dependent validator extension. + * + * @param string $rule + * @param \Closure|string $extension + * @param string|null $message + * @return void + * @static + */ public static function extendDependent($rule, $extension, $message = null) + { + /** @var \Illuminate\Validation\Factory $instance */ + $instance->extendDependent($rule, $extension, $message); + } + /** + * Register a custom validator message replacer. + * + * @param string $rule + * @param \Closure|string $replacer + * @return void + * @static + */ public static function replacer($rule, $replacer) + { + /** @var \Illuminate\Validation\Factory $instance */ + $instance->replacer($rule, $replacer); + } + /** + * Indicate that unvalidated array keys should be included in validated data when the parent array is validated. + * + * @return void + * @static + */ public static function includeUnvalidatedArrayKeys() + { + /** @var \Illuminate\Validation\Factory $instance */ + $instance->includeUnvalidatedArrayKeys(); + } + /** + * Indicate that unvalidated array keys should be excluded from the validated data, even if the parent array was validated. + * + * @return void + * @static + */ public static function excludeUnvalidatedArrayKeys() + { + /** @var \Illuminate\Validation\Factory $instance */ + $instance->excludeUnvalidatedArrayKeys(); + } + /** + * Set the Validator instance resolver. + * + * @param \Closure $resolver + * @return void + * @static + */ public static function resolver($resolver) + { + /** @var \Illuminate\Validation\Factory $instance */ + $instance->resolver($resolver); + } + /** + * Get the Translator implementation. + * + * @return \Illuminate\Contracts\Translation\Translator + * @static + */ public static function getTranslator() + { + /** @var \Illuminate\Validation\Factory $instance */ + return $instance->getTranslator(); + } + /** + * Get the Presence Verifier implementation. + * + * @return \Illuminate\Validation\PresenceVerifierInterface + * @static + */ public static function getPresenceVerifier() + { + /** @var \Illuminate\Validation\Factory $instance */ + return $instance->getPresenceVerifier(); + } + /** + * Set the Presence Verifier implementation. + * + * @param \Illuminate\Validation\PresenceVerifierInterface $presenceVerifier + * @return void + * @static + */ public static function setPresenceVerifier($presenceVerifier) + { + /** @var \Illuminate\Validation\Factory $instance */ + $instance->setPresenceVerifier($presenceVerifier); + } + /** + * Get the container instance used by the validation factory. + * + * @return \Illuminate\Contracts\Container\Container|null + * @static + */ public static function getContainer() + { + /** @var \Illuminate\Validation\Factory $instance */ + return $instance->getContainer(); + } + /** + * Set the container instance used by the validation factory. + * + * @param \Illuminate\Contracts\Container\Container $container + * @return \Illuminate\Validation\Factory + * @static + */ public static function setContainer($container) + { + /** @var \Illuminate\Validation\Factory $instance */ + return $instance->setContainer($container); + } + } + /** + * + * + * @see \Illuminate\View\Factory + */ class View { + /** + * Get the evaluated view contents for the given view. + * + * @param string $path + * @param \Illuminate\Contracts\Support\Arrayable|array $data + * @param array $mergeData + * @return \Illuminate\Contracts\View\View + * @static + */ public static function file($path, $data = [], $mergeData = []) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->file($path, $data, $mergeData); + } + /** + * Get the evaluated view contents for the given view. + * + * @param string $view + * @param \Illuminate\Contracts\Support\Arrayable|array $data + * @param array $mergeData + * @return \Illuminate\Contracts\View\View + * @static + */ public static function make($view, $data = [], $mergeData = []) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->make($view, $data, $mergeData); + } + /** + * Get the first view that actually exists from the given list. + * + * @param array $views + * @param \Illuminate\Contracts\Support\Arrayable|array $data + * @param array $mergeData + * @return \Illuminate\Contracts\View\View + * @throws \InvalidArgumentException + * @static + */ public static function first($views, $data = [], $mergeData = []) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->first($views, $data, $mergeData); + } + /** + * Get the rendered content of the view based on a given condition. + * + * @param bool $condition + * @param string $view + * @param \Illuminate\Contracts\Support\Arrayable|array $data + * @param array $mergeData + * @return string + * @static + */ public static function renderWhen($condition, $view, $data = [], $mergeData = []) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->renderWhen($condition, $view, $data, $mergeData); + } + /** + * Get the rendered content of the view based on the negation of a given condition. + * + * @param bool $condition + * @param string $view + * @param \Illuminate\Contracts\Support\Arrayable|array $data + * @param array $mergeData + * @return string + * @static + */ public static function renderUnless($condition, $view, $data = [], $mergeData = []) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->renderUnless($condition, $view, $data, $mergeData); + } + /** + * Get the rendered contents of a partial from a loop. + * + * @param string $view + * @param array $data + * @param string $iterator + * @param string $empty + * @return string + * @static + */ public static function renderEach($view, $data, $iterator, $empty = 'raw|') + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->renderEach($view, $data, $iterator, $empty); + } + /** + * Determine if a given view exists. + * + * @param string $view + * @return bool + * @static + */ public static function exists($view) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->exists($view); + } + /** + * Get the appropriate view engine for the given path. + * + * @param string $path + * @return \Illuminate\Contracts\View\Engine + * @throws \InvalidArgumentException + * @static + */ public static function getEngineFromPath($path) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->getEngineFromPath($path); + } + /** + * Add a piece of shared data to the environment. + * + * @param array|string $key + * @param mixed|null $value + * @return mixed + * @static + */ public static function share($key, $value = null) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->share($key, $value); + } + /** + * Increment the rendering counter. + * + * @return void + * @static + */ public static function incrementRender() + { + /** @var \Illuminate\View\Factory $instance */ + $instance->incrementRender(); + } + /** + * Decrement the rendering counter. + * + * @return void + * @static + */ public static function decrementRender() + { + /** @var \Illuminate\View\Factory $instance */ + $instance->decrementRender(); + } + /** + * Check if there are no active render operations. + * + * @return bool + * @static + */ public static function doneRendering() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->doneRendering(); + } + /** + * Determine if the given once token has been rendered. + * + * @param string $id + * @return bool + * @static + */ public static function hasRenderedOnce($id) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->hasRenderedOnce($id); + } + /** + * Mark the given once token as having been rendered. + * + * @param string $id + * @return void + * @static + */ public static function markAsRenderedOnce($id) + { + /** @var \Illuminate\View\Factory $instance */ + $instance->markAsRenderedOnce($id); + } + /** + * Add a location to the array of view locations. + * + * @param string $location + * @return void + * @static + */ public static function addLocation($location) + { + /** @var \Illuminate\View\Factory $instance */ + $instance->addLocation($location); + } + /** + * Add a new namespace to the loader. + * + * @param string $namespace + * @param string|array $hints + * @return \Illuminate\View\Factory + * @static + */ public static function addNamespace($namespace, $hints) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->addNamespace($namespace, $hints); + } + /** + * Prepend a new namespace to the loader. + * + * @param string $namespace + * @param string|array $hints + * @return \Illuminate\View\Factory + * @static + */ public static function prependNamespace($namespace, $hints) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->prependNamespace($namespace, $hints); + } + /** + * Replace the namespace hints for the given namespace. + * + * @param string $namespace + * @param string|array $hints + * @return \Illuminate\View\Factory + * @static + */ public static function replaceNamespace($namespace, $hints) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->replaceNamespace($namespace, $hints); + } + /** + * Register a valid view extension and its engine. + * + * @param string $extension + * @param string $engine + * @param \Closure|null $resolver + * @return void + * @static + */ public static function addExtension($extension, $engine, $resolver = null) + { + /** @var \Illuminate\View\Factory $instance */ + $instance->addExtension($extension, $engine, $resolver); + } + /** + * Flush all of the factory state like sections and stacks. + * + * @return void + * @static + */ public static function flushState() + { + /** @var \Illuminate\View\Factory $instance */ + $instance->flushState(); + } + /** + * Flush all of the section contents if done rendering. + * + * @return void + * @static + */ public static function flushStateIfDoneRendering() + { + /** @var \Illuminate\View\Factory $instance */ + $instance->flushStateIfDoneRendering(); + } + /** + * Get the extension to engine bindings. + * + * @return array + * @static + */ public static function getExtensions() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->getExtensions(); + } + /** + * Get the engine resolver instance. + * + * @return \Illuminate\View\Engines\EngineResolver + * @static + */ public static function getEngineResolver() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->getEngineResolver(); + } + /** + * Get the view finder instance. + * + * @return \Illuminate\View\ViewFinderInterface + * @static + */ public static function getFinder() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->getFinder(); + } + /** + * Set the view finder instance. + * + * @param \Illuminate\View\ViewFinderInterface $finder + * @return void + * @static + */ public static function setFinder($finder) + { + /** @var \Illuminate\View\Factory $instance */ + $instance->setFinder($finder); + } + /** + * Flush the cache of views located by the finder. + * + * @return void + * @static + */ public static function flushFinderCache() + { + /** @var \Illuminate\View\Factory $instance */ + $instance->flushFinderCache(); + } + /** + * Get the event dispatcher instance. + * + * @return \Illuminate\Contracts\Events\Dispatcher + * @static + */ public static function getDispatcher() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->getDispatcher(); + } + /** + * Set the event dispatcher instance. + * + * @param \Illuminate\Contracts\Events\Dispatcher $events + * @return void + * @static + */ public static function setDispatcher($events) + { + /** @var \Illuminate\View\Factory $instance */ + $instance->setDispatcher($events); + } + /** + * Get the IoC container instance. + * + * @return \Illuminate\Contracts\Container\Container + * @static + */ public static function getContainer() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->getContainer(); + } + /** + * Set the IoC container instance. + * + * @param \Illuminate\Contracts\Container\Container $container + * @return void + * @static + */ public static function setContainer($container) + { + /** @var \Illuminate\View\Factory $instance */ + $instance->setContainer($container); + } + /** + * Get an item from the shared data. + * + * @param string $key + * @param mixed $default + * @return mixed + * @static + */ public static function shared($key, $default = null) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->shared($key, $default); + } + /** + * Get all of the shared data for the environment. + * + * @return array + * @static + */ public static function getShared() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->getShared(); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\View\Factory::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\View\Factory::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\View\Factory::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\View\Factory::flushMacros(); + } + /** + * Start a component rendering process. + * + * @param \Illuminate\Contracts\View\View|\Illuminate\Contracts\Support\Htmlable|\Closure|string $view + * @param array $data + * @return void + * @static + */ public static function startComponent($view, $data = []) + { + /** @var \Illuminate\View\Factory $instance */ + $instance->startComponent($view, $data); + } + /** + * Get the first view that actually exists from the given list, and start a component. + * + * @param array $names + * @param array $data + * @return void + * @static + */ public static function startComponentFirst($names, $data = []) + { + /** @var \Illuminate\View\Factory $instance */ + $instance->startComponentFirst($names, $data); + } + /** + * Render the current component. + * + * @return string + * @static + */ public static function renderComponent() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->renderComponent(); + } + /** + * Get an item from the component data that exists above the current component. + * + * @param string $key + * @param mixed $default + * @return mixed|null + * @static + */ public static function getConsumableComponentData($key, $default = null) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->getConsumableComponentData($key, $default); + } + /** + * Start the slot rendering process. + * + * @param string $name + * @param string|null $content + * @param array $attributes + * @return void + * @static + */ public static function slot($name, $content = null, $attributes = []) + { + /** @var \Illuminate\View\Factory $instance */ + $instance->slot($name, $content, $attributes); + } + /** + * Save the slot content for rendering. + * + * @return void + * @static + */ public static function endSlot() + { + /** @var \Illuminate\View\Factory $instance */ + $instance->endSlot(); + } + /** + * Register a view creator event. + * + * @param array|string $views + * @param \Closure|string $callback + * @return array + * @static + */ public static function creator($views, $callback) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->creator($views, $callback); + } + /** + * Register multiple view composers via an array. + * + * @param array $composers + * @return array + * @static + */ public static function composers($composers) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->composers($composers); + } + /** + * Register a view composer event. + * + * @param array|string $views + * @param \Closure|string $callback + * @return array + * @static + */ public static function composer($views, $callback) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->composer($views, $callback); + } + /** + * Call the composer for a given view. + * + * @param \Illuminate\Contracts\View\View $view + * @return void + * @static + */ public static function callComposer($view) + { + /** @var \Illuminate\View\Factory $instance */ + $instance->callComposer($view); + } + /** + * Call the creator for a given view. + * + * @param \Illuminate\Contracts\View\View $view + * @return void + * @static + */ public static function callCreator($view) + { + /** @var \Illuminate\View\Factory $instance */ + $instance->callCreator($view); + } + /** + * Start injecting content into a fragment. + * + * @param string $fragment + * @return void + * @static + */ public static function startFragment($fragment) + { + /** @var \Illuminate\View\Factory $instance */ + $instance->startFragment($fragment); + } + /** + * Stop injecting content into a fragment. + * + * @return string + * @throws \InvalidArgumentException + * @static + */ public static function stopFragment() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->stopFragment(); + } + /** + * Get the contents of a fragment. + * + * @param string $name + * @param string|null $default + * @return mixed + * @static + */ public static function getFragment($name, $default = null) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->getFragment($name, $default); + } + /** + * Get the entire array of rendered fragments. + * + * @return array + * @static + */ public static function getFragments() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->getFragments(); + } + /** + * Flush all of the fragments. + * + * @return void + * @static + */ public static function flushFragments() + { + /** @var \Illuminate\View\Factory $instance */ + $instance->flushFragments(); + } + /** + * Start injecting content into a section. + * + * @param string $section + * @param string|null $content + * @return void + * @static + */ public static function startSection($section, $content = null) + { + /** @var \Illuminate\View\Factory $instance */ + $instance->startSection($section, $content); + } + /** + * Inject inline content into a section. + * + * @param string $section + * @param string $content + * @return void + * @static + */ public static function inject($section, $content) + { + /** @var \Illuminate\View\Factory $instance */ + $instance->inject($section, $content); + } + /** + * Stop injecting content into a section and return its contents. + * + * @return string + * @static + */ public static function yieldSection() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->yieldSection(); + } + /** + * Stop injecting content into a section. + * + * @param bool $overwrite + * @return string + * @throws \InvalidArgumentException + * @static + */ public static function stopSection($overwrite = false) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->stopSection($overwrite); + } + /** + * Stop injecting content into a section and append it. + * + * @return string + * @throws \InvalidArgumentException + * @static + */ public static function appendSection() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->appendSection(); + } + /** + * Get the string contents of a section. + * + * @param string $section + * @param string $default + * @return string + * @static + */ public static function yieldContent($section, $default = '') + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->yieldContent($section, $default); + } + /** + * Get the parent placeholder for the current request. + * + * @param string $section + * @return string + * @static + */ public static function parentPlaceholder($section = '') + { + return \Illuminate\View\Factory::parentPlaceholder($section); + } + /** + * Check if section exists. + * + * @param string $name + * @return bool + * @static + */ public static function hasSection($name) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->hasSection($name); + } + /** + * Check if section does not exist. + * + * @param string $name + * @return bool + * @static + */ public static function sectionMissing($name) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->sectionMissing($name); + } + /** + * Get the contents of a section. + * + * @param string $name + * @param string|null $default + * @return mixed + * @static + */ public static function getSection($name, $default = null) + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->getSection($name, $default); + } + /** + * Get the entire array of sections. + * + * @return array + * @static + */ public static function getSections() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->getSections(); + } + /** + * Flush all of the sections. + * + * @return void + * @static + */ public static function flushSections() + { + /** @var \Illuminate\View\Factory $instance */ + $instance->flushSections(); + } + /** + * Add new loop to the stack. + * + * @param \Countable|array $data + * @return void + * @static + */ public static function addLoop($data) + { + /** @var \Illuminate\View\Factory $instance */ + $instance->addLoop($data); + } + /** + * Increment the top loop's indices. + * + * @return void + * @static + */ public static function incrementLoopIndices() + { + /** @var \Illuminate\View\Factory $instance */ + $instance->incrementLoopIndices(); + } + /** + * Pop a loop from the top of the loop stack. + * + * @return void + * @static + */ public static function popLoop() + { + /** @var \Illuminate\View\Factory $instance */ + $instance->popLoop(); + } + /** + * Get an instance of the last loop in the stack. + * + * @return \stdClass|null + * @static + */ public static function getLastLoop() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->getLastLoop(); + } + /** + * Get the entire loop stack. + * + * @return array + * @static + */ public static function getLoopStack() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->getLoopStack(); + } + /** + * Start injecting content into a push section. + * + * @param string $section + * @param string $content + * @return void + * @static + */ public static function startPush($section, $content = '') + { + /** @var \Illuminate\View\Factory $instance */ + $instance->startPush($section, $content); + } + /** + * Stop injecting content into a push section. + * + * @return string + * @throws \InvalidArgumentException + * @static + */ public static function stopPush() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->stopPush(); + } + /** + * Start prepending content into a push section. + * + * @param string $section + * @param string $content + * @return void + * @static + */ public static function startPrepend($section, $content = '') + { + /** @var \Illuminate\View\Factory $instance */ + $instance->startPrepend($section, $content); + } + /** + * Stop prepending content into a push section. + * + * @return string + * @throws \InvalidArgumentException + * @static + */ public static function stopPrepend() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->stopPrepend(); + } + /** + * Get the string contents of a push section. + * + * @param string $section + * @param string $default + * @return string + * @static + */ public static function yieldPushContent($section, $default = '') + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->yieldPushContent($section, $default); + } + /** + * Flush all of the stacks. + * + * @return void + * @static + */ public static function flushStacks() + { + /** @var \Illuminate\View\Factory $instance */ + $instance->flushStacks(); + } + /** + * Start a translation block. + * + * @param array $replacements + * @return void + * @static + */ public static function startTranslation($replacements = []) + { + /** @var \Illuminate\View\Factory $instance */ + $instance->startTranslation($replacements); + } + /** + * Render the current translation. + * + * @return string + * @static + */ public static function renderTranslation() + { + /** @var \Illuminate\View\Factory $instance */ + return $instance->renderTranslation(); + } + } + /** + * + * + * @see \Illuminate\Foundation\Vite + */ class Vite { + /** + * Get the preloaded assets. + * + * @return array + * @static + */ public static function preloadedAssets() + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->preloadedAssets(); + } + /** + * Get the Content Security Policy nonce applied to all generated tags. + * + * @return string|null + * @static + */ public static function cspNonce() + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->cspNonce(); + } + /** + * Generate or set a Content Security Policy nonce to apply to all generated tags. + * + * @param string|null $nonce + * @return string + * @static + */ public static function useCspNonce($nonce = null) + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->useCspNonce($nonce); + } + /** + * Use the given key to detect integrity hashes in the manifest. + * + * @param string|false $key + * @return \Illuminate\Foundation\Vite + * @static + */ public static function useIntegrityKey($key) + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->useIntegrityKey($key); + } + /** + * Set the Vite entry points. + * + * @param array $entryPoints + * @return \Illuminate\Foundation\Vite + * @static + */ public static function withEntryPoints($entryPoints) + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->withEntryPoints($entryPoints); + } + /** + * Set the filename for the manifest file. + * + * @param string $filename + * @return \Illuminate\Foundation\Vite + * @static + */ public static function useManifestFilename($filename) + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->useManifestFilename($filename); + } + /** + * Resolve asset paths using the provided resolver. + * + * @param callable|null $resolver + * @return \Illuminate\Foundation\Vite + * @static + */ public static function createAssetPathsUsing($resolver) + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->createAssetPathsUsing($resolver); + } + /** + * Get the Vite "hot" file path. + * + * @return string + * @static + */ public static function hotFile() + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->hotFile(); + } + /** + * Set the Vite "hot" file path. + * + * @param string $path + * @return \Illuminate\Foundation\Vite + * @static + */ public static function useHotFile($path) + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->useHotFile($path); + } + /** + * Set the Vite build directory. + * + * @param string $path + * @return \Illuminate\Foundation\Vite + * @static + */ public static function useBuildDirectory($path) + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->useBuildDirectory($path); + } + /** + * Use the given callback to resolve attributes for script tags. + * + * @param \Illuminate\Foundation\(callable(string, string, ?array, ?array): array)|array $attributes + * @return \Illuminate\Foundation\Vite + * @static + */ public static function useScriptTagAttributes($attributes) + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->useScriptTagAttributes($attributes); + } + /** + * Use the given callback to resolve attributes for style tags. + * + * @param \Illuminate\Foundation\(callable(string, string, ?array, ?array): array)|array $attributes + * @return \Illuminate\Foundation\Vite + * @static + */ public static function useStyleTagAttributes($attributes) + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->useStyleTagAttributes($attributes); + } + /** + * Use the given callback to resolve attributes for preload tags. + * + * @param \Illuminate\Foundation\(callable(string, string, ?array, ?array): (array|false))|array|false $attributes + * @return \Illuminate\Foundation\Vite + * @static + */ public static function usePreloadTagAttributes($attributes) + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->usePreloadTagAttributes($attributes); + } + /** + * Generate React refresh runtime script. + * + * @return \Illuminate\Support\HtmlString|void + * @static + */ public static function reactRefresh() + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->reactRefresh(); + } + /** + * Get the URL for an asset. + * + * @param string $asset + * @param string|null $buildDirectory + * @return string + * @static + */ public static function asset($asset, $buildDirectory = null) + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->asset($asset, $buildDirectory); + } + /** + * Get the content of a given asset. + * + * @param string $asset + * @param string|null $buildDirectory + * @return string + * @throws \Illuminate\Foundation\ViteException + * @static + */ public static function content($asset, $buildDirectory = null) + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->content($asset, $buildDirectory); + } + /** + * Get a unique hash representing the current manifest, or null if there is no manifest. + * + * @param string|null $buildDirectory + * @return string|null + * @static + */ public static function manifestHash($buildDirectory = null) + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->manifestHash($buildDirectory); + } + /** + * Determine if the HMR server is running. + * + * @return bool + * @static + */ public static function isRunningHot() + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->isRunningHot(); + } + /** + * Get the Vite tag content as a string of HTML. + * + * @return string + * @static + */ public static function toHtml() + { + /** @var \Illuminate\Foundation\Vite $instance */ + return $instance->toHtml(); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Foundation\Vite::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Foundation\Vite::mixin($mixin, $replace); + } + /** + * Checks if macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + return \Illuminate\Foundation\Vite::hasMacro($name); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Foundation\Vite::flushMacros(); + } + } + } + +namespace Spatie\LaravelIgnition\Facades { + /** + * + * + * @see \Spatie\FlareClient\Flare + */ class Flare { + /** + * + * + * @static + */ public static function make($apiKey = null, $contextDetector = null) + { + return \Spatie\FlareClient\Flare::make($apiKey, $contextDetector); + } + /** + * + * + * @static + */ public static function setApiToken($apiToken) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->setApiToken($apiToken); + } + /** + * + * + * @static + */ public static function apiTokenSet() + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->apiTokenSet(); + } + /** + * + * + * @static + */ public static function setBaseUrl($baseUrl) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->setBaseUrl($baseUrl); + } + /** + * + * + * @static + */ public static function setStage($stage) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->setStage($stage); + } + /** + * + * + * @static + */ public static function sendReportsImmediately() + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->sendReportsImmediately(); + } + /** + * + * + * @static + */ public static function determineVersionUsing($determineVersionCallable) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->determineVersionUsing($determineVersionCallable); + } + /** + * + * + * @static + */ public static function reportErrorLevels($reportErrorLevels) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->reportErrorLevels($reportErrorLevels); + } + /** + * + * + * @static + */ public static function filterExceptionsUsing($filterExceptionsCallable) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->filterExceptionsUsing($filterExceptionsCallable); + } + /** + * + * + * @static + */ public static function filterReportsUsing($filterReportsCallable) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->filterReportsUsing($filterReportsCallable); + } + /** + * + * + * @param array|ArgumentReducer>|\Spatie\Backtrace\Arguments\ArgumentReducers|null $argumentReducers + * @static + */ public static function argumentReducers($argumentReducers) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->argumentReducers($argumentReducers); + } + /** + * + * + * @static + */ public static function withStackFrameArguments($withStackFrameArguments = true, $forcePHPIniSetting = false) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->withStackFrameArguments($withStackFrameArguments, $forcePHPIniSetting); + } + /** + * + * + * @static + */ public static function version() + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->version(); + } + /** + * + * + * @return array> + * @static + */ public static function getMiddleware() + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->getMiddleware(); + } + /** + * + * + * @static + */ public static function setContextProviderDetector($contextDetector) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->setContextProviderDetector($contextDetector); + } + /** + * + * + * @static + */ public static function setContainer($container) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->setContainer($container); + } + /** + * + * + * @static + */ public static function registerFlareHandlers() + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->registerFlareHandlers(); + } + /** + * + * + * @static + */ public static function registerExceptionHandler() + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->registerExceptionHandler(); + } + /** + * + * + * @static + */ public static function registerErrorHandler($errorLevels = null) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->registerErrorHandler($errorLevels); + } + /** + * + * + * @param \Spatie\FlareClient\FlareMiddleware\FlareMiddleware|array|\Spatie\FlareClient\class-string|callable $middleware + * @return \Spatie\FlareClient\Flare + * @static + */ public static function registerMiddleware($middleware) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->registerMiddleware($middleware); + } + /** + * + * + * @return array> + * @static + */ public static function getMiddlewares() + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->getMiddlewares(); + } + /** + * + * + * @param string $name + * @param string $messageLevel + * @param array $metaData + * @return \Spatie\FlareClient\Flare + * @static + */ public static function glow($name, $messageLevel = 'info', $metaData = []) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->glow($name, $messageLevel, $metaData); + } + /** + * + * + * @static + */ public static function handleException($throwable) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->handleException($throwable); + } + /** + * + * + * @return mixed + * @static + */ public static function handleError($code, $message, $file = '', $line = 0) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->handleError($code, $message, $file, $line); + } + /** + * + * + * @static + */ public static function applicationPath($applicationPath) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->applicationPath($applicationPath); + } + /** + * + * + * @static + */ public static function report($throwable, $callback = null, $report = null, $handled = null) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->report($throwable, $callback, $report, $handled); + } + /** + * + * + * @static + */ public static function reportHandled($throwable) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->reportHandled($throwable); + } + /** + * + * + * @static + */ public static function reportMessage($message, $logLevel, $callback = null) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->reportMessage($message, $logLevel, $callback); + } + /** + * + * + * @static + */ public static function sendTestReport($throwable) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->sendTestReport($throwable); + } + /** + * + * + * @static + */ public static function reset() + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->reset(); + } + /** + * + * + * @static + */ public static function anonymizeIp() + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->anonymizeIp(); + } + /** + * + * + * @param array $fieldNames + * @return \Spatie\FlareClient\Flare + * @static + */ public static function censorRequestBodyFields($fieldNames) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->censorRequestBodyFields($fieldNames); + } + /** + * + * + * @static + */ public static function createReport($throwable) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->createReport($throwable); + } + /** + * + * + * @static + */ public static function createReportFromMessage($message, $logLevel) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->createReportFromMessage($message, $logLevel); + } + /** + * + * + * @static + */ public static function stage($stage) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->stage($stage); + } + /** + * + * + * @static + */ public static function messageLevel($messageLevel) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->messageLevel($messageLevel); + } + /** + * + * + * @param string $groupName + * @param mixed $default + * @return array + * @static + */ public static function getGroup($groupName = 'context', $default = []) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->getGroup($groupName, $default); + } + /** + * + * + * @static + */ public static function context($key, $value) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->context($key, $value); + } + /** + * + * + * @param string $groupName + * @param array $properties + * @return \Spatie\FlareClient\Flare + * @static + */ public static function group($groupName, $properties) + { + /** @var \Spatie\FlareClient\Flare $instance */ + return $instance->group($groupName, $properties); + } + } + } + +namespace Illuminate\Http { + /** + * + * + */ class Request { + /** + * + * + * @see \Illuminate\Foundation\Providers\FoundationServiceProvider::registerRequestValidation() + * @param array $rules + * @param mixed $params + * @static + */ public static function validate($rules, ...$params) + { + return \Illuminate\Http\Request::validate($rules, ...$params); + } + /** + * + * + * @see \Illuminate\Foundation\Providers\FoundationServiceProvider::registerRequestValidation() + * @param string $errorBag + * @param array $rules + * @param mixed $params + * @static + */ public static function validateWithBag($errorBag, $rules, ...$params) + { + return \Illuminate\Http\Request::validateWithBag($errorBag, $rules, ...$params); + } + /** + * + * + * @see \Illuminate\Foundation\Providers\FoundationServiceProvider::registerRequestSignatureValidation() + * @param mixed $absolute + * @static + */ public static function hasValidSignature($absolute = true) + { + return \Illuminate\Http\Request::hasValidSignature($absolute); + } + /** + * + * + * @see \Illuminate\Foundation\Providers\FoundationServiceProvider::registerRequestSignatureValidation() + * @static + */ public static function hasValidRelativeSignature() + { + return \Illuminate\Http\Request::hasValidRelativeSignature(); + } + /** + * + * + * @see \Illuminate\Foundation\Providers\FoundationServiceProvider::registerRequestSignatureValidation() + * @param mixed $ignoreQuery + * @param mixed $absolute + * @static + */ public static function hasValidSignatureWhileIgnoring($ignoreQuery = [], $absolute = true) + { + return \Illuminate\Http\Request::hasValidSignatureWhileIgnoring($ignoreQuery, $absolute); + } + /** + * + * + * @see \Illuminate\Foundation\Providers\FoundationServiceProvider::registerRequestSignatureValidation() + * @param mixed $ignoreQuery + * @static + */ public static function hasValidRelativeSignatureWhileIgnoring($ignoreQuery = []) + { + return \Illuminate\Http\Request::hasValidRelativeSignatureWhileIgnoring($ignoreQuery); + } + } + } + +namespace Illuminate\Database\Schema { + /** + * + * + */ class Blueprint { + /** + * + * + * @see \Kalnoy\Nestedset\NestedSetServiceProvider::register() + * @static + */ public static function nestedSet() + { + return \Illuminate\Database\Schema\Blueprint::nestedSet(); + } + /** + * + * + * @see \Kalnoy\Nestedset\NestedSetServiceProvider::register() + * @static + */ public static function dropNestedSet() + { + return \Illuminate\Database\Schema\Blueprint::dropNestedSet(); + } + } + } + +namespace Illuminate\Routing { + /** + * + * + */ class Route { + /** + * + * + * @see \Spatie\Permission\PermissionServiceProvider::registerMacroHelpers() + * @param mixed $roles + * @static + */ public static function role($roles = []) + { + return \Illuminate\Routing\Route::role($roles); + } + /** + * + * + * @see \Spatie\Permission\PermissionServiceProvider::registerMacroHelpers() + * @param mixed $permissions + * @static + */ public static function permission($permissions = []) + { + return \Illuminate\Routing\Route::permission($permissions); + } + } + } + + +namespace { + class App extends \Illuminate\Support\Facades\App {} + class Arr extends \Illuminate\Support\Arr {} + class Artisan extends \Illuminate\Support\Facades\Artisan {} + class Auth extends \Illuminate\Support\Facades\Auth {} + class Blade extends \Illuminate\Support\Facades\Blade {} + class Broadcast extends \Illuminate\Support\Facades\Broadcast {} + class Bus extends \Illuminate\Support\Facades\Bus {} + class Cache extends \Illuminate\Support\Facades\Cache {} + class Config extends \Illuminate\Support\Facades\Config {} + class Context extends \Illuminate\Support\Facades\Context {} + class Cookie extends \Illuminate\Support\Facades\Cookie {} + class Date extends \Illuminate\Support\Facades\Date {} + class DB extends \Illuminate\Support\Facades\DB {} + class Eloquent extends \Illuminate\Database\Eloquent\Model { /** + * Create and return an un-saved model instance. + * + * @param array $attributes + * @return \Illuminate\Database\Eloquent\TModel + * @static + */ public static function make($attributes = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->make($attributes); + } + /** + * Register a new global scope. + * + * @param string $identifier + * @param \Illuminate\Database\Eloquent\Scope|\Closure $scope + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function withGlobalScope($identifier, $scope) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->withGlobalScope($identifier, $scope); + } + /** + * Remove a registered global scope. + * + * @param \Illuminate\Database\Eloquent\Scope|string $scope + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function withoutGlobalScope($scope) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->withoutGlobalScope($scope); + } + /** + * Remove all or passed registered global scopes. + * + * @param array|null $scopes + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function withoutGlobalScopes($scopes = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->withoutGlobalScopes($scopes); + } + /** + * Get an array of global scopes that were removed from the query. + * + * @return array + * @static + */ public static function removedScopes() + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->removedScopes(); + } + /** + * Add a where clause on the primary key to the query. + * + * @param mixed $id + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function whereKey($id) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->whereKey($id); + } + /** + * Add a where clause on the primary key to the query. + * + * @param mixed $id + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function whereKeyNot($id) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->whereKeyNot($id); + } + /** + * Add a basic where clause to the query. + * + * @param \Illuminate\Database\Eloquent\(\Closure(static): mixed)|string|array|\Illuminate\Contracts\Database\Query\Expression $column + * @param mixed $operator + * @param mixed $value + * @param string $boolean + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function where($column, $operator = null, $value = null, $boolean = 'and') + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->where($column, $operator, $value, $boolean); + } + /** + * Add a basic where clause to the query, and return the first result. + * + * @param \Illuminate\Database\Eloquent\(\Closure(static): mixed)|string|array|\Illuminate\Contracts\Database\Query\Expression $column + * @param mixed $operator + * @param mixed $value + * @param string $boolean + * @return \Illuminate\Database\Eloquent\TModel|null + * @static + */ public static function firstWhere($column, $operator = null, $value = null, $boolean = 'and') + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->firstWhere($column, $operator, $value, $boolean); + } + /** + * Add an "or where" clause to the query. + * + * @param \Illuminate\Database\Eloquent\(\Closure(static): mixed)|array|string|\Illuminate\Contracts\Database\Query\Expression $column + * @param mixed $operator + * @param mixed $value + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function orWhere($column, $operator = null, $value = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->orWhere($column, $operator, $value); + } + /** + * Add a basic "where not" clause to the query. + * + * @param \Illuminate\Database\Eloquent\(\Closure(static): mixed)|string|array|\Illuminate\Contracts\Database\Query\Expression $column + * @param mixed $operator + * @param mixed $value + * @param string $boolean + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function whereNot($column, $operator = null, $value = null, $boolean = 'and') + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->whereNot($column, $operator, $value, $boolean); + } + /** + * Add an "or where not" clause to the query. + * + * @param \Illuminate\Database\Eloquent\(\Closure(static): mixed)|array|string|\Illuminate\Contracts\Database\Query\Expression $column + * @param mixed $operator + * @param mixed $value + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function orWhereNot($column, $operator = null, $value = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->orWhereNot($column, $operator, $value); + } + /** + * Add an "order by" clause for a timestamp to the query. + * + * @param string|\Illuminate\Contracts\Database\Query\Expression $column + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function latest($column = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->latest($column); + } + /** + * Add an "order by" clause for a timestamp to the query. + * + * @param string|\Illuminate\Contracts\Database\Query\Expression $column + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function oldest($column = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->oldest($column); + } + /** + * Create a collection of models from plain arrays. + * + * @param array $items + * @return \Illuminate\Database\Eloquent\Collection + * @static + */ public static function hydrate($items) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->hydrate($items); + } + /** + * Create a collection of models from a raw query. + * + * @param string $query + * @param array $bindings + * @return \Illuminate\Database\Eloquent\Collection + * @static + */ public static function fromQuery($query, $bindings = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->fromQuery($query, $bindings); + } + /** + * Find a model by its primary key. + * + * @param mixed $id + * @param array|string $columns + * @return \Illuminate\Database\Eloquent\($id is (\Illuminate\Contracts\Support\Arrayable|array) ? \Illuminate\Database\Eloquent\Collection : TModel|null) + * @static + */ public static function find($id, $columns = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->find($id, $columns); + } + /** + * Find multiple models by their primary keys. + * + * @param \Illuminate\Contracts\Support\Arrayable|array $ids + * @param array|string $columns + * @return \Illuminate\Database\Eloquent\Collection + * @static + */ public static function findMany($ids, $columns = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->findMany($ids, $columns); + } + /** + * Find a model by its primary key or throw an exception. + * + * @param mixed $id + * @param array|string $columns + * @return \Illuminate\Database\Eloquent\($id is (\Illuminate\Contracts\Support\Arrayable|array) ? \Illuminate\Database\Eloquent\Collection : TModel) + * @throws \Illuminate\Database\Eloquent\ModelNotFoundException + * @static + */ public static function findOrFail($id, $columns = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->findOrFail($id, $columns); + } + /** + * Find a model by its primary key or return fresh model instance. + * + * @param mixed $id + * @param array|string $columns + * @return \Illuminate\Database\Eloquent\($id is (\Illuminate\Contracts\Support\Arrayable|array) ? \Illuminate\Database\Eloquent\Collection : TModel) + * @static + */ public static function findOrNew($id, $columns = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->findOrNew($id, $columns); + } + /** + * Find a model by its primary key or call a callback. + * + * @template TValue + * @param mixed $id + * @param \Illuminate\Database\Eloquent\(\Closure(): TValue)|list|string $columns + * @param \Illuminate\Database\Eloquent\(\Closure(): TValue)|null $callback + * @return \Illuminate\Database\Eloquent\( $id is (\Illuminate\Contracts\Support\Arrayable|array) + * ? \Illuminate\Database\Eloquent\Collection + * : TModel|TValue + * ) + * @static + */ public static function findOr($id, $columns = [], $callback = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->findOr($id, $columns, $callback); + } + /** + * Get the first record matching the attributes or instantiate it. + * + * @param array $attributes + * @param array $values + * @return \Illuminate\Database\Eloquent\TModel + * @static + */ public static function firstOrNew($attributes = [], $values = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->firstOrNew($attributes, $values); + } + /** + * Get the first record matching the attributes. If the record is not found, create it. + * + * @param array $attributes + * @param array $values + * @return \Illuminate\Database\Eloquent\TModel + * @static + */ public static function firstOrCreate($attributes = [], $values = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->firstOrCreate($attributes, $values); + } + /** + * Attempt to create the record. If a unique constraint violation occurs, attempt to find the matching record. + * + * @param array $attributes + * @param array $values + * @return \Illuminate\Database\Eloquent\TModel + * @static + */ public static function createOrFirst($attributes = [], $values = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->createOrFirst($attributes, $values); + } + /** + * Create or update a record matching the attributes, and fill it with values. + * + * @param array $attributes + * @param array $values + * @return \Illuminate\Database\Eloquent\TModel + * @static + */ public static function updateOrCreate($attributes, $values = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->updateOrCreate($attributes, $values); + } + /** + * Execute the query and get the first result or throw an exception. + * + * @param array|string $columns + * @return \Illuminate\Database\Eloquent\TModel + * @throws \Illuminate\Database\Eloquent\ModelNotFoundException + * @static + */ public static function firstOrFail($columns = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->firstOrFail($columns); + } + /** + * Execute the query and get the first result or call a callback. + * + * @template TValue + * @param \Illuminate\Database\Eloquent\(\Closure(): TValue)|list $columns + * @param \Illuminate\Database\Eloquent\(\Closure(): TValue)|null $callback + * @return \Illuminate\Database\Eloquent\TModel|\Illuminate\Database\Eloquent\TValue + * @static + */ public static function firstOr($columns = [], $callback = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->firstOr($columns, $callback); + } + /** + * Execute the query and get the first result if it's the sole matching record. + * + * @param array|string $columns + * @return \Illuminate\Database\Eloquent\TModel + * @throws \Illuminate\Database\Eloquent\ModelNotFoundException + * @throws \Illuminate\Database\MultipleRecordsFoundException + * @static + */ public static function sole($columns = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->sole($columns); + } + /** + * Get a single column's value from the first result of a query. + * + * @param string|\Illuminate\Contracts\Database\Query\Expression $column + * @return mixed + * @static + */ public static function value($column) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->value($column); + } + /** + * Get a single column's value from the first result of a query if it's the sole matching record. + * + * @param string|\Illuminate\Contracts\Database\Query\Expression $column + * @return mixed + * @throws \Illuminate\Database\Eloquent\ModelNotFoundException + * @throws \Illuminate\Database\MultipleRecordsFoundException + * @static + */ public static function soleValue($column) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->soleValue($column); + } + /** + * Get a single column's value from the first result of the query or throw an exception. + * + * @param string|\Illuminate\Contracts\Database\Query\Expression $column + * @return mixed + * @throws \Illuminate\Database\Eloquent\ModelNotFoundException + * @static + */ public static function valueOrFail($column) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->valueOrFail($column); + } + /** + * Execute the query as a "select" statement. + * + * @param array|string $columns + * @return \Illuminate\Database\Eloquent\Collection + * @static + */ public static function get($columns = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->get($columns); + } + /** + * Get the hydrated models without eager loading. + * + * @param array|string $columns + * @return array + * @static + */ public static function getModels($columns = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->getModels($columns); + } + /** + * Eager load the relationships for the models. + * + * @param array $models + * @return array + * @static + */ public static function eagerLoadRelations($models) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->eagerLoadRelations($models); + } + /** + * Register a closure to be invoked after the query is executed. + * + * @param \Closure $callback + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function afterQuery($callback) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->afterQuery($callback); + } + /** + * Invoke the "after query" modification callbacks. + * + * @param mixed $result + * @return mixed + * @static + */ public static function applyAfterQueryCallbacks($result) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->applyAfterQueryCallbacks($result); + } + /** + * Get a lazy collection for the given query. + * + * @return \Illuminate\Support\LazyCollection + * @static + */ public static function cursor() + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->cursor(); + } + /** + * Get a collection with the values of a given column. + * + * @param string|\Illuminate\Contracts\Database\Query\Expression $column + * @param string|null $key + * @return \Illuminate\Support\Collection + * @static + */ public static function pluck($column, $key = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->pluck($column, $key); + } + /** + * Paginate the given query. + * + * @param int|null|\Closure $perPage + * @param array|string $columns + * @param string $pageName + * @param int|null $page + * @param \Closure|int|null $total + * @return \Illuminate\Contracts\Pagination\LengthAwarePaginator + * @throws \InvalidArgumentException + * @static + */ public static function paginate($perPage = null, $columns = [], $pageName = 'page', $page = null, $total = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->paginate($perPage, $columns, $pageName, $page, $total); + } + /** + * Paginate the given query into a simple paginator. + * + * @param int|null $perPage + * @param array|string $columns + * @param string $pageName + * @param int|null $page + * @return \Illuminate\Contracts\Pagination\Paginator + * @static + */ public static function simplePaginate($perPage = null, $columns = [], $pageName = 'page', $page = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->simplePaginate($perPage, $columns, $pageName, $page); + } + /** + * Paginate the given query into a cursor paginator. + * + * @param int|null $perPage + * @param array|string $columns + * @param string $cursorName + * @param \Illuminate\Pagination\Cursor|string|null $cursor + * @return \Illuminate\Contracts\Pagination\CursorPaginator + * @static + */ public static function cursorPaginate($perPage = null, $columns = [], $cursorName = 'cursor', $cursor = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->cursorPaginate($perPage, $columns, $cursorName, $cursor); + } + /** + * Save a new model and return the instance. + * + * @param array $attributes + * @return \Illuminate\Database\Eloquent\TModel + * @static + */ public static function create($attributes = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->create($attributes); + } + /** + * Save a new model and return the instance. Allow mass-assignment. + * + * @param array $attributes + * @return \Illuminate\Database\Eloquent\TModel + * @static + */ public static function forceCreate($attributes) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->forceCreate($attributes); + } + /** + * Save a new model instance with mass assignment without raising model events. + * + * @param array $attributes + * @return \Illuminate\Database\Eloquent\TModel + * @static + */ public static function forceCreateQuietly($attributes = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->forceCreateQuietly($attributes); + } + /** + * Insert new records or update the existing ones. + * + * @param array $values + * @param array|string $uniqueBy + * @param array|null $update + * @return int + * @static + */ public static function upsert($values, $uniqueBy, $update = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->upsert($values, $uniqueBy, $update); + } + /** + * Register a replacement for the default delete function. + * + * @param \Closure $callback + * @return void + * @static + */ public static function onDelete($callback) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + $instance->onDelete($callback); + } + /** + * Call the given local model scopes. + * + * @param array|string $scopes + * @return static|mixed + * @static + */ public static function scopes($scopes) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->scopes($scopes); + } + /** + * Apply the scopes to the Eloquent builder instance and return it. + * + * @return static + * @static + */ public static function applyScopes() + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->applyScopes(); + } + /** + * Prevent the specified relations from being eager loaded. + * + * @param mixed $relations + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function without($relations) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->without($relations); + } + /** + * Set the relationships that should be eager loaded while removing any previously added eager loading specifications. + * + * @param mixed $relations + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function withOnly($relations) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->withOnly($relations); + } + /** + * Create a new instance of the model being queried. + * + * @param array $attributes + * @return \Illuminate\Database\Eloquent\TModel + * @static + */ public static function newModelInstance($attributes = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->newModelInstance($attributes); + } + /** + * Apply query-time casts to the model instance. + * + * @param array $casts + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function withCasts($casts) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->withCasts($casts); + } + /** + * Execute the given Closure within a transaction savepoint if needed. + * + * @template TModelValue + * @param \Closure(): TModelValue $scope + * @return \Illuminate\Database\Eloquent\TModelValue + * @static + */ public static function withSavepointIfNeeded($scope) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->withSavepointIfNeeded($scope); + } + /** + * Get the underlying query builder instance. + * + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function getQuery() + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->getQuery(); + } + /** + * Set the underlying query builder instance. + * + * @param \Illuminate\Database\Query\Builder $query + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function setQuery($query) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->setQuery($query); + } + /** + * Get a base query builder instance. + * + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function toBase() + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->toBase(); + } + /** + * Get the relationships being eagerly loaded. + * + * @return array + * @static + */ public static function getEagerLoads() + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->getEagerLoads(); + } + /** + * Set the relationships being eagerly loaded. + * + * @param array $eagerLoad + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function setEagerLoads($eagerLoad) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->setEagerLoads($eagerLoad); + } + /** + * Indicate that the given relationships should not be eagerly loaded. + * + * @param array $relations + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function withoutEagerLoad($relations) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->withoutEagerLoad($relations); + } + /** + * Flush the relationships being eagerly loaded. + * + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function withoutEagerLoads() + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->withoutEagerLoads(); + } + /** + * Get the model instance being queried. + * + * @return \Illuminate\Database\Eloquent\TModel + * @static + */ public static function getModel() + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->getModel(); + } + /** + * Set a model instance for the model being queried. + * + * @template TModelNew of \Illuminate\Database\Eloquent\Model + * @param \Illuminate\Database\Eloquent\TModelNew $model + * @return \Illuminate\Database\Eloquent\static + * @static + */ public static function setModel($model) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->setModel($model); + } + /** + * Get the given macro by name. + * + * @param string $name + * @return \Closure + * @static + */ public static function getMacro($name) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->getMacro($name); + } + /** + * Checks if a macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasMacro($name) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->hasMacro($name); + } + /** + * Get the given global macro by name. + * + * @param string $name + * @return \Closure + * @static + */ public static function getGlobalMacro($name) + { + return \Illuminate\Database\Eloquent\Builder::getGlobalMacro($name); + } + /** + * Checks if a global macro is registered. + * + * @param string $name + * @return bool + * @static + */ public static function hasGlobalMacro($name) + { + return \Illuminate\Database\Eloquent\Builder::hasGlobalMacro($name); + } + /** + * Clone the Eloquent query builder. + * + * @return static + * @static + */ public static function clone() + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->clone(); + } + /** + * Chunk the results of the query. + * + * @param int $count + * @param \Illuminate\Database\Eloquent\callable(\Illuminate\Support\Collection, int): mixed $callback + * @return bool + * @static + */ public static function chunk($count, $callback) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->chunk($count, $callback); + } + /** + * Run a map over each item while chunking. + * + * @template TReturn + * @param \Illuminate\Database\Eloquent\callable(TValue): TReturn $callback + * @param int $count + * @return \Illuminate\Support\Collection + * @static + */ public static function chunkMap($callback, $count = 1000) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->chunkMap($callback, $count); + } + /** + * Execute a callback over each item while chunking. + * + * @param \Illuminate\Database\Eloquent\callable(TValue, int): mixed $callback + * @param int $count + * @return bool + * @throws \RuntimeException + * @static + */ public static function each($callback, $count = 1000) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->each($callback, $count); + } + /** + * Chunk the results of a query by comparing IDs. + * + * @param int $count + * @param \Illuminate\Database\Eloquent\callable(\Illuminate\Support\Collection, int): mixed $callback + * @param string|null $column + * @param string|null $alias + * @return bool + * @static + */ public static function chunkById($count, $callback, $column = null, $alias = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->chunkById($count, $callback, $column, $alias); + } + /** + * Chunk the results of a query by comparing IDs in descending order. + * + * @param int $count + * @param \Illuminate\Database\Eloquent\callable(\Illuminate\Support\Collection, int): mixed $callback + * @param string|null $column + * @param string|null $alias + * @return bool + * @static + */ public static function chunkByIdDesc($count, $callback, $column = null, $alias = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->chunkByIdDesc($count, $callback, $column, $alias); + } + /** + * Chunk the results of a query by comparing IDs in a given order. + * + * @param int $count + * @param \Illuminate\Database\Eloquent\callable(\Illuminate\Support\Collection, int): mixed $callback + * @param string|null $column + * @param string|null $alias + * @param bool $descending + * @return bool + * @throws \RuntimeException + * @static + */ public static function orderedChunkById($count, $callback, $column = null, $alias = null, $descending = false) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->orderedChunkById($count, $callback, $column, $alias, $descending); + } + /** + * Execute a callback over each item while chunking by ID. + * + * @param \Illuminate\Database\Eloquent\callable(TValue, int): mixed $callback + * @param int $count + * @param string|null $column + * @param string|null $alias + * @return bool + * @static + */ public static function eachById($callback, $count = 1000, $column = null, $alias = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->eachById($callback, $count, $column, $alias); + } + /** + * Query lazily, by chunks of the given size. + * + * @param int $chunkSize + * @return \Illuminate\Support\LazyCollection + * @throws \InvalidArgumentException + * @static + */ public static function lazy($chunkSize = 1000) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->lazy($chunkSize); + } + /** + * Query lazily, by chunking the results of a query by comparing IDs. + * + * @param int $chunkSize + * @param string|null $column + * @param string|null $alias + * @return \Illuminate\Support\LazyCollection + * @throws \InvalidArgumentException + * @static + */ public static function lazyById($chunkSize = 1000, $column = null, $alias = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->lazyById($chunkSize, $column, $alias); + } + /** + * Query lazily, by chunking the results of a query by comparing IDs in descending order. + * + * @param int $chunkSize + * @param string|null $column + * @param string|null $alias + * @return \Illuminate\Support\LazyCollection + * @throws \InvalidArgumentException + * @static + */ public static function lazyByIdDesc($chunkSize = 1000, $column = null, $alias = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->lazyByIdDesc($chunkSize, $column, $alias); + } + /** + * Execute the query and get the first result. + * + * @param array|string $columns + * @return \Illuminate\Database\Eloquent\TValue|null + * @static + */ public static function first($columns = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->first($columns); + } + /** + * Execute the query and get the first result if it's the sole matching record. + * + * @param array|string $columns + * @return \Illuminate\Database\Eloquent\TValue + * @throws \Illuminate\Database\RecordsNotFoundException + * @throws \Illuminate\Database\MultipleRecordsFoundException + * @static + */ public static function baseSole($columns = []) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->baseSole($columns); + } + /** + * Pass the query to a given callback. + * + * @param \Illuminate\Database\Eloquent\callable($this): mixed $callback + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function tap($callback) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->tap($callback); + } + /** + * Apply the callback if the given "value" is (or resolves to) truthy. + * + * @template TWhenParameter + * @template TWhenReturnType + * @param \Illuminate\Database\Eloquent\(\Closure($this): TWhenParameter)|TWhenParameter|null $value + * @param \Illuminate\Database\Eloquent\(callable($this, TWhenParameter): TWhenReturnType)|null $callback + * @param \Illuminate\Database\Eloquent\(callable($this, TWhenParameter): TWhenReturnType)|null $default + * @return $this|\Illuminate\Database\Eloquent\TWhenReturnType + * @static + */ public static function when($value = null, $callback = null, $default = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->when($value, $callback, $default); + } + /** + * Apply the callback if the given "value" is (or resolves to) falsy. + * + * @template TUnlessParameter + * @template TUnlessReturnType + * @param \Illuminate\Database\Eloquent\(\Closure($this): TUnlessParameter)|TUnlessParameter|null $value + * @param \Illuminate\Database\Eloquent\(callable($this, TUnlessParameter): TUnlessReturnType)|null $callback + * @param \Illuminate\Database\Eloquent\(callable($this, TUnlessParameter): TUnlessReturnType)|null $default + * @return $this|\Illuminate\Database\Eloquent\TUnlessReturnType + * @static + */ public static function unless($value = null, $callback = null, $default = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->unless($value, $callback, $default); + } + /** + * Add a relationship count / exists condition to the query. + * + * @param \Illuminate\Database\Eloquent\Relations\Relation<*, *, *>|string $relation + * @param string $operator + * @param int $count + * @param string $boolean + * @param \Closure|null $callback + * @return \Illuminate\Database\Eloquent\Builder|static + * @throws \RuntimeException + * @static + */ public static function has($relation, $operator = '>=', $count = 1, $boolean = 'and', $callback = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->has($relation, $operator, $count, $boolean, $callback); + } + /** + * Add a relationship count / exists condition to the query with an "or". + * + * @param \Illuminate\Database\Eloquent\Relations\Relation<*, *, *>|string $relation + * @param string $operator + * @param int $count + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function orHas($relation, $operator = '>=', $count = 1) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->orHas($relation, $operator, $count); + } + /** + * Add a relationship count / exists condition to the query. + * + * @param \Illuminate\Database\Eloquent\Relations\Relation<*, *, *>|string $relation + * @param string $boolean + * @param \Closure|null $callback + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function doesntHave($relation, $boolean = 'and', $callback = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->doesntHave($relation, $boolean, $callback); + } + /** + * Add a relationship count / exists condition to the query with an "or". + * + * @param \Illuminate\Database\Eloquent\Relations\Relation<*, *, *>|string $relation + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function orDoesntHave($relation) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->orDoesntHave($relation); + } + /** + * Add a relationship count / exists condition to the query with where clauses. + * + * @param \Illuminate\Database\Eloquent\Relations\Relation<*, *, *>|string $relation + * @param \Closure|null $callback + * @param string $operator + * @param int $count + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function whereHas($relation, $callback = null, $operator = '>=', $count = 1) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->whereHas($relation, $callback, $operator, $count); + } + /** + * Add a relationship count / exists condition to the query with where clauses. + * + * Also load the relationship with same condition. + * + * @param \Illuminate\Database\Eloquent\Relations\Relation<*, *, *>|string $relation + * @param \Closure|null $callback + * @param string $operator + * @param int $count + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function withWhereHas($relation, $callback = null, $operator = '>=', $count = 1) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->withWhereHas($relation, $callback, $operator, $count); + } + /** + * Add a relationship count / exists condition to the query with where clauses and an "or". + * + * @param \Illuminate\Database\Eloquent\Relations\Relation<*, *, *>|string $relation + * @param \Closure|null $callback + * @param string $operator + * @param int $count + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function orWhereHas($relation, $callback = null, $operator = '>=', $count = 1) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->orWhereHas($relation, $callback, $operator, $count); + } + /** + * Add a relationship count / exists condition to the query with where clauses. + * + * @param \Illuminate\Database\Eloquent\Relations\Relation<*, *, *>|string $relation + * @param \Closure|null $callback + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function whereDoesntHave($relation, $callback = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->whereDoesntHave($relation, $callback); + } + /** + * Add a relationship count / exists condition to the query with where clauses and an "or". + * + * @param \Illuminate\Database\Eloquent\Relations\Relation<*, *, *>|string $relation + * @param \Closure|null $callback + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function orWhereDoesntHave($relation, $callback = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->orWhereDoesntHave($relation, $callback); + } + /** + * Add a polymorphic relationship count / exists condition to the query. + * + * @param \Illuminate\Database\Eloquent\Relations\MorphTo<*, *>|string $relation + * @param string|array $types + * @param string $operator + * @param int $count + * @param string $boolean + * @param \Closure|null $callback + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function hasMorph($relation, $types, $operator = '>=', $count = 1, $boolean = 'and', $callback = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->hasMorph($relation, $types, $operator, $count, $boolean, $callback); + } + /** + * Add a polymorphic relationship count / exists condition to the query with an "or". + * + * @param \Illuminate\Database\Eloquent\Relations\MorphTo<*, *>|string $relation + * @param string|array $types + * @param string $operator + * @param int $count + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function orHasMorph($relation, $types, $operator = '>=', $count = 1) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->orHasMorph($relation, $types, $operator, $count); + } + /** + * Add a polymorphic relationship count / exists condition to the query. + * + * @param \Illuminate\Database\Eloquent\Relations\MorphTo<*, *>|string $relation + * @param string|array $types + * @param string $boolean + * @param \Closure|null $callback + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function doesntHaveMorph($relation, $types, $boolean = 'and', $callback = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->doesntHaveMorph($relation, $types, $boolean, $callback); + } + /** + * Add a polymorphic relationship count / exists condition to the query with an "or". + * + * @param \Illuminate\Database\Eloquent\Relations\MorphTo<*, *>|string $relation + * @param string|array $types + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function orDoesntHaveMorph($relation, $types) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->orDoesntHaveMorph($relation, $types); + } + /** + * Add a polymorphic relationship count / exists condition to the query with where clauses. + * + * @param \Illuminate\Database\Eloquent\Relations\MorphTo<*, *>|string $relation + * @param string|array $types + * @param \Closure|null $callback + * @param string $operator + * @param int $count + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function whereHasMorph($relation, $types, $callback = null, $operator = '>=', $count = 1) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->whereHasMorph($relation, $types, $callback, $operator, $count); + } + /** + * Add a polymorphic relationship count / exists condition to the query with where clauses and an "or". + * + * @param \Illuminate\Database\Eloquent\Relations\MorphTo<*, *>|string $relation + * @param string|array $types + * @param \Closure|null $callback + * @param string $operator + * @param int $count + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function orWhereHasMorph($relation, $types, $callback = null, $operator = '>=', $count = 1) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->orWhereHasMorph($relation, $types, $callback, $operator, $count); + } + /** + * Add a polymorphic relationship count / exists condition to the query with where clauses. + * + * @param \Illuminate\Database\Eloquent\Relations\MorphTo<*, *>|string $relation + * @param string|array $types + * @param \Closure|null $callback + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function whereDoesntHaveMorph($relation, $types, $callback = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->whereDoesntHaveMorph($relation, $types, $callback); + } + /** + * Add a polymorphic relationship count / exists condition to the query with where clauses and an "or". + * + * @param \Illuminate\Database\Eloquent\Relations\MorphTo<*, *>|string $relation + * @param string|array $types + * @param \Closure|null $callback + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function orWhereDoesntHaveMorph($relation, $types, $callback = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->orWhereDoesntHaveMorph($relation, $types, $callback); + } + /** + * Add a basic where clause to a relationship query. + * + * @param \Illuminate\Database\Eloquent\Relations\Relation<*, *, *>|string $relation + * @param \Closure|string|array|\Illuminate\Contracts\Database\Query\Expression $column + * @param mixed $operator + * @param mixed $value + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function whereRelation($relation, $column, $operator = null, $value = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->whereRelation($relation, $column, $operator, $value); + } + /** + * Add an "or where" clause to a relationship query. + * + * @param \Illuminate\Database\Eloquent\Relations\Relation<*, *, *>|string $relation + * @param \Closure|string|array|\Illuminate\Contracts\Database\Query\Expression $column + * @param mixed $operator + * @param mixed $value + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function orWhereRelation($relation, $column, $operator = null, $value = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->orWhereRelation($relation, $column, $operator, $value); + } + /** + * Add a polymorphic relationship condition to the query with a where clause. + * + * @param \Illuminate\Database\Eloquent\Relations\MorphTo<*, *>|string $relation + * @param string|array $types + * @param \Closure|string|array|\Illuminate\Contracts\Database\Query\Expression $column + * @param mixed $operator + * @param mixed $value + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function whereMorphRelation($relation, $types, $column, $operator = null, $value = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->whereMorphRelation($relation, $types, $column, $operator, $value); + } + /** + * Add a polymorphic relationship condition to the query with an "or where" clause. + * + * @param \Illuminate\Database\Eloquent\Relations\MorphTo<*, *>|string $relation + * @param string|array $types + * @param \Closure|string|array|\Illuminate\Contracts\Database\Query\Expression $column + * @param mixed $operator + * @param mixed $value + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function orWhereMorphRelation($relation, $types, $column, $operator = null, $value = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->orWhereMorphRelation($relation, $types, $column, $operator, $value); + } + /** + * Add a morph-to relationship condition to the query. + * + * @param \Illuminate\Database\Eloquent\Relations\MorphTo<*, *>|string $relation + * @param \Illuminate\Database\Eloquent\Model|string|null $model + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function whereMorphedTo($relation, $model, $boolean = 'and') + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->whereMorphedTo($relation, $model, $boolean); + } + /** + * Add a not morph-to relationship condition to the query. + * + * @param \Illuminate\Database\Eloquent\Relations\MorphTo<*, *>|string $relation + * @param \Illuminate\Database\Eloquent\Model|string $model + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function whereNotMorphedTo($relation, $model, $boolean = 'and') + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->whereNotMorphedTo($relation, $model, $boolean); + } + /** + * Add a morph-to relationship condition to the query with an "or where" clause. + * + * @param \Illuminate\Database\Eloquent\Relations\MorphTo<*, *>|string $relation + * @param \Illuminate\Database\Eloquent\Model|string|null $model + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function orWhereMorphedTo($relation, $model) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->orWhereMorphedTo($relation, $model); + } + /** + * Add a not morph-to relationship condition to the query with an "or where" clause. + * + * @param \Illuminate\Database\Eloquent\Relations\MorphTo<*, *>|string $relation + * @param \Illuminate\Database\Eloquent\Model|string $model + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function orWhereNotMorphedTo($relation, $model) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->orWhereNotMorphedTo($relation, $model); + } + /** + * Add a "belongs to" relationship where clause to the query. + * + * @param \Illuminate\Database\Eloquent\Model|\Illuminate\Database\Eloquent\Collection $related + * @param string|null $relationshipName + * @param string $boolean + * @return \Illuminate\Database\Eloquent\Builder|static + * @throws \Illuminate\Database\Eloquent\RelationNotFoundException + * @static + */ public static function whereBelongsTo($related, $relationshipName = null, $boolean = 'and') + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->whereBelongsTo($related, $relationshipName, $boolean); + } + /** + * Add an "BelongsTo" relationship with an "or where" clause to the query. + * + * @param \Illuminate\Database\Eloquent\Model $related + * @param string|null $relationshipName + * @return \Illuminate\Database\Eloquent\Builder|static + * @throws \RuntimeException + * @static + */ public static function orWhereBelongsTo($related, $relationshipName = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->orWhereBelongsTo($related, $relationshipName); + } + /** + * Add subselect queries to include an aggregate value for a relationship. + * + * @param mixed $relations + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param string $function + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function withAggregate($relations, $column, $function = null) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->withAggregate($relations, $column, $function); + } + /** + * Add subselect queries to count the relations. + * + * @param mixed $relations + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function withCount($relations) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->withCount($relations); + } + /** + * Add subselect queries to include the max of the relation's column. + * + * @param string|array $relation + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function withMax($relation, $column) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->withMax($relation, $column); + } + /** + * Add subselect queries to include the min of the relation's column. + * + * @param string|array $relation + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function withMin($relation, $column) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->withMin($relation, $column); + } + /** + * Add subselect queries to include the sum of the relation's column. + * + * @param string|array $relation + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function withSum($relation, $column) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->withSum($relation, $column); + } + /** + * Add subselect queries to include the average of the relation's column. + * + * @param string|array $relation + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function withAvg($relation, $column) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->withAvg($relation, $column); + } + /** + * Add subselect queries to include the existence of related models. + * + * @param string|array $relation + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function withExists($relation) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->withExists($relation); + } + /** + * Merge the where constraints from another query to the current query. + * + * @param \Illuminate\Database\Eloquent\Builder<*> $from + * @return \Illuminate\Database\Eloquent\Builder|static + * @static + */ public static function mergeConstraintsFrom($from) + { + /** @var \Illuminate\Database\Eloquent\Builder $instance */ + return $instance->mergeConstraintsFrom($from); + } + /** + * Set the columns to be selected. + * + * @param array|mixed $columns + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function select($columns = []) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->select($columns); + } + /** + * Add a subselect expression to the query. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*>|string $query + * @param string $as + * @return \Illuminate\Database\Query\Builder + * @throws \InvalidArgumentException + * @static + */ public static function selectSub($query, $as) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->selectSub($query, $as); + } + /** + * Add a new "raw" select expression to the query. + * + * @param string $expression + * @param array $bindings + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function selectRaw($expression, $bindings = []) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->selectRaw($expression, $bindings); + } + /** + * Makes "from" fetch from a subquery. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*>|string $query + * @param string $as + * @return \Illuminate\Database\Query\Builder + * @throws \InvalidArgumentException + * @static + */ public static function fromSub($query, $as) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->fromSub($query, $as); + } + /** + * Add a raw from clause to the query. + * + * @param string $expression + * @param mixed $bindings + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function fromRaw($expression, $bindings = []) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->fromRaw($expression, $bindings); + } + /** + * Add a new select column to the query. + * + * @param array|mixed $column + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function addSelect($column) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->addSelect($column); + } + /** + * Force the query to only return distinct results. + * + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function distinct() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->distinct(); + } + /** + * Set the table which the query is targeting. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*>|\Illuminate\Contracts\Database\Query\Expression|string $table + * @param string|null $as + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function from($table, $as = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->from($table, $as); + } + /** + * Add an index hint to suggest a query index. + * + * @param string $index + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function useIndex($index) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->useIndex($index); + } + /** + * Add an index hint to force a query index. + * + * @param string $index + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function forceIndex($index) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->forceIndex($index); + } + /** + * Add an index hint to ignore a query index. + * + * @param string $index + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function ignoreIndex($index) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->ignoreIndex($index); + } + /** + * Add a join clause to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $table + * @param \Closure|\Illuminate\Contracts\Database\Query\Expression|string $first + * @param string|null $operator + * @param \Illuminate\Contracts\Database\Query\Expression|string|null $second + * @param string $type + * @param bool $where + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function join($table, $first, $operator = null, $second = null, $type = 'inner', $where = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->join($table, $first, $operator, $second, $type, $where); + } + /** + * Add a "join where" clause to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $table + * @param \Closure|\Illuminate\Contracts\Database\Query\Expression|string $first + * @param string $operator + * @param \Illuminate\Contracts\Database\Query\Expression|string $second + * @param string $type + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function joinWhere($table, $first, $operator, $second, $type = 'inner') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->joinWhere($table, $first, $operator, $second, $type); + } + /** + * Add a subquery join clause to the query. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*>|string $query + * @param string $as + * @param \Closure|\Illuminate\Contracts\Database\Query\Expression|string $first + * @param string|null $operator + * @param \Illuminate\Contracts\Database\Query\Expression|string|null $second + * @param string $type + * @param bool $where + * @return \Illuminate\Database\Query\Builder + * @throws \InvalidArgumentException + * @static + */ public static function joinSub($query, $as, $first, $operator = null, $second = null, $type = 'inner', $where = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->joinSub($query, $as, $first, $operator, $second, $type, $where); + } + /** + * Add a lateral join clause to the query. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*>|string $query + * @param string $as + * @param string $type + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function joinLateral($query, $as, $type = 'inner') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->joinLateral($query, $as, $type); + } + /** + * Add a lateral left join to the query. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*>|string $query + * @param string $as + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function leftJoinLateral($query, $as) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->leftJoinLateral($query, $as); + } + /** + * Add a left join to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $table + * @param \Closure|\Illuminate\Contracts\Database\Query\Expression|string $first + * @param string|null $operator + * @param \Illuminate\Contracts\Database\Query\Expression|string|null $second + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function leftJoin($table, $first, $operator = null, $second = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->leftJoin($table, $first, $operator, $second); + } + /** + * Add a "join where" clause to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $table + * @param \Closure|\Illuminate\Contracts\Database\Query\Expression|string $first + * @param string $operator + * @param \Illuminate\Contracts\Database\Query\Expression|string|null $second + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function leftJoinWhere($table, $first, $operator, $second) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->leftJoinWhere($table, $first, $operator, $second); + } + /** + * Add a subquery left join to the query. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*>|string $query + * @param string $as + * @param \Closure|\Illuminate\Contracts\Database\Query\Expression|string $first + * @param string|null $operator + * @param \Illuminate\Contracts\Database\Query\Expression|string|null $second + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function leftJoinSub($query, $as, $first, $operator = null, $second = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->leftJoinSub($query, $as, $first, $operator, $second); + } + /** + * Add a right join to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $table + * @param \Closure|string $first + * @param string|null $operator + * @param \Illuminate\Contracts\Database\Query\Expression|string|null $second + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function rightJoin($table, $first, $operator = null, $second = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->rightJoin($table, $first, $operator, $second); + } + /** + * Add a "right join where" clause to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $table + * @param \Closure|\Illuminate\Contracts\Database\Query\Expression|string $first + * @param string $operator + * @param \Illuminate\Contracts\Database\Query\Expression|string $second + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function rightJoinWhere($table, $first, $operator, $second) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->rightJoinWhere($table, $first, $operator, $second); + } + /** + * Add a subquery right join to the query. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*>|string $query + * @param string $as + * @param \Closure|\Illuminate\Contracts\Database\Query\Expression|string $first + * @param string|null $operator + * @param \Illuminate\Contracts\Database\Query\Expression|string|null $second + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function rightJoinSub($query, $as, $first, $operator = null, $second = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->rightJoinSub($query, $as, $first, $operator, $second); + } + /** + * Add a "cross join" clause to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $table + * @param \Closure|\Illuminate\Contracts\Database\Query\Expression|string|null $first + * @param string|null $operator + * @param \Illuminate\Contracts\Database\Query\Expression|string|null $second + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function crossJoin($table, $first = null, $operator = null, $second = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->crossJoin($table, $first, $operator, $second); + } + /** + * Add a subquery cross join to the query. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*>|string $query + * @param string $as + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function crossJoinSub($query, $as) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->crossJoinSub($query, $as); + } + /** + * Merge an array of where clauses and bindings. + * + * @param array $wheres + * @param array $bindings + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function mergeWheres($wheres, $bindings) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->mergeWheres($wheres, $bindings); + } + /** + * Prepare the value and operator for a where clause. + * + * @param string $value + * @param string $operator + * @param bool $useDefault + * @return array + * @throws \InvalidArgumentException + * @static + */ public static function prepareValueAndOperator($value, $operator, $useDefault = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->prepareValueAndOperator($value, $operator, $useDefault); + } + /** + * Add a "where" clause comparing two columns to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string|array $first + * @param string|null $operator + * @param string|null $second + * @param string|null $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereColumn($first, $operator = null, $second = null, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereColumn($first, $operator, $second, $boolean); + } + /** + * Add an "or where" clause comparing two columns to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string|array $first + * @param string|null $operator + * @param string|null $second + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereColumn($first, $operator = null, $second = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereColumn($first, $operator, $second); + } + /** + * Add a raw where clause to the query. + * + * @param string $sql + * @param mixed $bindings + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereRaw($sql, $bindings = [], $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereRaw($sql, $bindings, $boolean); + } + /** + * Add a raw or where clause to the query. + * + * @param string $sql + * @param mixed $bindings + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereRaw($sql, $bindings = []) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereRaw($sql, $bindings); + } + /** + * Add a "where like" clause to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param string $value + * @param bool $caseSensitive + * @param string $boolean + * @param bool $not + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereLike($column, $value, $caseSensitive = false, $boolean = 'and', $not = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereLike($column, $value, $caseSensitive, $boolean, $not); + } + /** + * Add an "or where like" clause to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param string $value + * @param bool $caseSensitive + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereLike($column, $value, $caseSensitive = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereLike($column, $value, $caseSensitive); + } + /** + * Add a "where not like" clause to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param string $value + * @param bool $caseSensitive + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereNotLike($column, $value, $caseSensitive = false, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereNotLike($column, $value, $caseSensitive, $boolean); + } + /** + * Add an "or where not like" clause to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param string $value + * @param bool $caseSensitive + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereNotLike($column, $value, $caseSensitive = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereNotLike($column, $value, $caseSensitive); + } + /** + * Add a "where in" clause to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param mixed $values + * @param string $boolean + * @param bool $not + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereIn($column, $values, $boolean = 'and', $not = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereIn($column, $values, $boolean, $not); + } + /** + * Add an "or where in" clause to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param mixed $values + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereIn($column, $values) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereIn($column, $values); + } + /** + * Add a "where not in" clause to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param mixed $values + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereNotIn($column, $values, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereNotIn($column, $values, $boolean); + } + /** + * Add an "or where not in" clause to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param mixed $values + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereNotIn($column, $values) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereNotIn($column, $values); + } + /** + * Add a "where in raw" clause for integer values to the query. + * + * @param string $column + * @param \Illuminate\Contracts\Support\Arrayable|array $values + * @param string $boolean + * @param bool $not + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereIntegerInRaw($column, $values, $boolean = 'and', $not = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereIntegerInRaw($column, $values, $boolean, $not); + } + /** + * Add an "or where in raw" clause for integer values to the query. + * + * @param string $column + * @param \Illuminate\Contracts\Support\Arrayable|array $values + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereIntegerInRaw($column, $values) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereIntegerInRaw($column, $values); + } + /** + * Add a "where not in raw" clause for integer values to the query. + * + * @param string $column + * @param \Illuminate\Contracts\Support\Arrayable|array $values + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereIntegerNotInRaw($column, $values, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereIntegerNotInRaw($column, $values, $boolean); + } + /** + * Add an "or where not in raw" clause for integer values to the query. + * + * @param string $column + * @param \Illuminate\Contracts\Support\Arrayable|array $values + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereIntegerNotInRaw($column, $values) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereIntegerNotInRaw($column, $values); + } + /** + * Add a "where null" clause to the query. + * + * @param string|array|\Illuminate\Contracts\Database\Query\Expression $columns + * @param string $boolean + * @param bool $not + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereNull($columns, $boolean = 'and', $not = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereNull($columns, $boolean, $not); + } + /** + * Add an "or where null" clause to the query. + * + * @param string|array|\Illuminate\Contracts\Database\Query\Expression $column + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereNull($column) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereNull($column); + } + /** + * Add a "where not null" clause to the query. + * + * @param string|array|\Illuminate\Contracts\Database\Query\Expression $columns + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereNotNull($columns, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereNotNull($columns, $boolean); + } + /** + * Add a where between statement to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param \Illuminate\Database\Query\iterable $values + * @param string $boolean + * @param bool $not + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereBetween($column, $values, $boolean = 'and', $not = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereBetween($column, $values, $boolean, $not); + } + /** + * Add a where between statement using columns to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param array $values + * @param string $boolean + * @param bool $not + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereBetweenColumns($column, $values, $boolean = 'and', $not = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereBetweenColumns($column, $values, $boolean, $not); + } + /** + * Add an or where between statement to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param \Illuminate\Database\Query\iterable $values + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereBetween($column, $values) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereBetween($column, $values); + } + /** + * Add an or where between statement using columns to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param array $values + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereBetweenColumns($column, $values) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereBetweenColumns($column, $values); + } + /** + * Add a where not between statement to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param \Illuminate\Database\Query\iterable $values + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereNotBetween($column, $values, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereNotBetween($column, $values, $boolean); + } + /** + * Add a where not between statement using columns to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param array $values + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereNotBetweenColumns($column, $values, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereNotBetweenColumns($column, $values, $boolean); + } + /** + * Add an or where not between statement to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param \Illuminate\Database\Query\iterable $values + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereNotBetween($column, $values) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereNotBetween($column, $values); + } + /** + * Add an or where not between statement using columns to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param array $values + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereNotBetweenColumns($column, $values) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereNotBetweenColumns($column, $values); + } + /** + * Add an "or where not null" clause to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereNotNull($column) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereNotNull($column); + } + /** + * Add a "where date" statement to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param \DateTimeInterface|string|null $operator + * @param \DateTimeInterface|string|null $value + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereDate($column, $operator, $value = null, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereDate($column, $operator, $value, $boolean); + } + /** + * Add an "or where date" statement to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param \DateTimeInterface|string|null $operator + * @param \DateTimeInterface|string|null $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereDate($column, $operator, $value = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereDate($column, $operator, $value); + } + /** + * Add a "where time" statement to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param \DateTimeInterface|string|null $operator + * @param \DateTimeInterface|string|null $value + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereTime($column, $operator, $value = null, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereTime($column, $operator, $value, $boolean); + } + /** + * Add an "or where time" statement to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param \DateTimeInterface|string|null $operator + * @param \DateTimeInterface|string|null $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereTime($column, $operator, $value = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereTime($column, $operator, $value); + } + /** + * Add a "where day" statement to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param \DateTimeInterface|string|int|null $operator + * @param \DateTimeInterface|string|int|null $value + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereDay($column, $operator, $value = null, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereDay($column, $operator, $value, $boolean); + } + /** + * Add an "or where day" statement to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param \DateTimeInterface|string|int|null $operator + * @param \DateTimeInterface|string|int|null $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereDay($column, $operator, $value = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereDay($column, $operator, $value); + } + /** + * Add a "where month" statement to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param \DateTimeInterface|string|int|null $operator + * @param \DateTimeInterface|string|int|null $value + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereMonth($column, $operator, $value = null, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereMonth($column, $operator, $value, $boolean); + } + /** + * Add an "or where month" statement to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param \DateTimeInterface|string|int|null $operator + * @param \DateTimeInterface|string|int|null $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereMonth($column, $operator, $value = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereMonth($column, $operator, $value); + } + /** + * Add a "where year" statement to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param \DateTimeInterface|string|int|null $operator + * @param \DateTimeInterface|string|int|null $value + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereYear($column, $operator, $value = null, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereYear($column, $operator, $value, $boolean); + } + /** + * Add an "or where year" statement to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @param \DateTimeInterface|string|int|null $operator + * @param \DateTimeInterface|string|int|null $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereYear($column, $operator, $value = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereYear($column, $operator, $value); + } + /** + * Add a nested where statement to the query. + * + * @param \Closure $callback + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereNested($callback, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereNested($callback, $boolean); + } + /** + * Create a new query instance for nested where condition. + * + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function forNestedWhere() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->forNestedWhere(); + } + /** + * Add another query builder as a nested where to the query builder. + * + * @param \Illuminate\Database\Query\Builder $query + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function addNestedWhereQuery($query, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->addNestedWhereQuery($query, $boolean); + } + /** + * Add an exists clause to the query. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*> $callback + * @param string $boolean + * @param bool $not + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereExists($callback, $boolean = 'and', $not = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereExists($callback, $boolean, $not); + } + /** + * Add an or exists clause to the query. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*> $callback + * @param bool $not + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereExists($callback, $not = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereExists($callback, $not); + } + /** + * Add a where not exists clause to the query. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*> $callback + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereNotExists($callback, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereNotExists($callback, $boolean); + } + /** + * Add a where not exists clause to the query. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*> $callback + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereNotExists($callback) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereNotExists($callback); + } + /** + * Add an exists clause to the query. + * + * @param \Illuminate\Database\Query\Builder $query + * @param string $boolean + * @param bool $not + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function addWhereExistsQuery($query, $boolean = 'and', $not = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->addWhereExistsQuery($query, $boolean, $not); + } + /** + * Adds a where condition using row values. + * + * @param array $columns + * @param string $operator + * @param array $values + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @throws \InvalidArgumentException + * @static + */ public static function whereRowValues($columns, $operator, $values, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereRowValues($columns, $operator, $values, $boolean); + } + /** + * Adds an or where condition using row values. + * + * @param array $columns + * @param string $operator + * @param array $values + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereRowValues($columns, $operator, $values) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereRowValues($columns, $operator, $values); + } + /** + * Add a "where JSON contains" clause to the query. + * + * @param string $column + * @param mixed $value + * @param string $boolean + * @param bool $not + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereJsonContains($column, $value, $boolean = 'and', $not = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereJsonContains($column, $value, $boolean, $not); + } + /** + * Add an "or where JSON contains" clause to the query. + * + * @param string $column + * @param mixed $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereJsonContains($column, $value) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereJsonContains($column, $value); + } + /** + * Add a "where JSON not contains" clause to the query. + * + * @param string $column + * @param mixed $value + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereJsonDoesntContain($column, $value, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereJsonDoesntContain($column, $value, $boolean); + } + /** + * Add an "or where JSON not contains" clause to the query. + * + * @param string $column + * @param mixed $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereJsonDoesntContain($column, $value) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereJsonDoesntContain($column, $value); + } + /** + * Add a "where JSON overlaps" clause to the query. + * + * @param string $column + * @param mixed $value + * @param string $boolean + * @param bool $not + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereJsonOverlaps($column, $value, $boolean = 'and', $not = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereJsonOverlaps($column, $value, $boolean, $not); + } + /** + * Add an "or where JSON overlaps" clause to the query. + * + * @param string $column + * @param mixed $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereJsonOverlaps($column, $value) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereJsonOverlaps($column, $value); + } + /** + * Add a "where JSON not overlap" clause to the query. + * + * @param string $column + * @param mixed $value + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereJsonDoesntOverlap($column, $value, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereJsonDoesntOverlap($column, $value, $boolean); + } + /** + * Add an "or where JSON not overlap" clause to the query. + * + * @param string $column + * @param mixed $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereJsonDoesntOverlap($column, $value) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereJsonDoesntOverlap($column, $value); + } + /** + * Add a clause that determines if a JSON path exists to the query. + * + * @param string $column + * @param string $boolean + * @param bool $not + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereJsonContainsKey($column, $boolean = 'and', $not = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereJsonContainsKey($column, $boolean, $not); + } + /** + * Add an "or" clause that determines if a JSON path exists to the query. + * + * @param string $column + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereJsonContainsKey($column) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereJsonContainsKey($column); + } + /** + * Add a clause that determines if a JSON path does not exist to the query. + * + * @param string $column + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereJsonDoesntContainKey($column, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereJsonDoesntContainKey($column, $boolean); + } + /** + * Add an "or" clause that determines if a JSON path does not exist to the query. + * + * @param string $column + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereJsonDoesntContainKey($column) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereJsonDoesntContainKey($column); + } + /** + * Add a "where JSON length" clause to the query. + * + * @param string $column + * @param mixed $operator + * @param mixed $value + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereJsonLength($column, $operator, $value = null, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereJsonLength($column, $operator, $value, $boolean); + } + /** + * Add an "or where JSON length" clause to the query. + * + * @param string $column + * @param mixed $operator + * @param mixed $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereJsonLength($column, $operator, $value = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereJsonLength($column, $operator, $value); + } + /** + * Handles dynamic "where" clauses to the query. + * + * @param string $method + * @param array $parameters + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function dynamicWhere($method, $parameters) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->dynamicWhere($method, $parameters); + } + /** + * Add a "where fulltext" clause to the query. + * + * @param string|string[] $columns + * @param string $value + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereFullText($columns, $value, $options = [], $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereFullText($columns, $value, $options, $boolean); + } + /** + * Add a "or where fulltext" clause to the query. + * + * @param string|string[] $columns + * @param string $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereFullText($columns, $value, $options = []) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereFullText($columns, $value, $options); + } + /** + * Add a "where" clause to the query for multiple columns with "and" conditions between them. + * + * @param \Illuminate\Contracts\Database\Query\Expression[]|string[] $columns + * @param mixed $operator + * @param mixed $value + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereAll($columns, $operator = null, $value = null, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereAll($columns, $operator, $value, $boolean); + } + /** + * Add an "or where" clause to the query for multiple columns with "and" conditions between them. + * + * @param \Illuminate\Contracts\Database\Query\Expression[]|string[] $columns + * @param mixed $operator + * @param mixed $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereAll($columns, $operator = null, $value = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereAll($columns, $operator, $value); + } + /** + * Add a "where" clause to the query for multiple columns with "or" conditions between them. + * + * @param \Illuminate\Contracts\Database\Query\Expression[]|string[] $columns + * @param mixed $operator + * @param mixed $value + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereAny($columns, $operator = null, $value = null, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereAny($columns, $operator, $value, $boolean); + } + /** + * Add an "or where" clause to the query for multiple columns with "or" conditions between them. + * + * @param \Illuminate\Contracts\Database\Query\Expression[]|string[] $columns + * @param mixed $operator + * @param mixed $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereAny($columns, $operator = null, $value = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereAny($columns, $operator, $value); + } + /** + * Add a "where not" clause to the query for multiple columns where none of the conditions should be true. + * + * @param \Illuminate\Contracts\Database\Query\Expression[]|string[] $columns + * @param mixed $operator + * @param mixed $value + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function whereNone($columns, $operator = null, $value = null, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->whereNone($columns, $operator, $value, $boolean); + } + /** + * Add an "or where not" clause to the query for multiple columns where none of the conditions should be true. + * + * @param \Illuminate\Contracts\Database\Query\Expression[]|string[] $columns + * @param mixed $operator + * @param mixed $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orWhereNone($columns, $operator = null, $value = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orWhereNone($columns, $operator, $value); + } + /** + * Add a "group by" clause to the query. + * + * @param array|\Illuminate\Contracts\Database\Query\Expression|string $groups + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function groupBy(...$groups) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->groupBy(...$groups); + } + /** + * Add a raw groupBy clause to the query. + * + * @param string $sql + * @param array $bindings + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function groupByRaw($sql, $bindings = []) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->groupByRaw($sql, $bindings); + } + /** + * Add a "having" clause to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|\Closure|string $column + * @param string|int|float|null $operator + * @param string|int|float|null $value + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function having($column, $operator = null, $value = null, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->having($column, $operator, $value, $boolean); + } + /** + * Add an "or having" clause to the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|\Closure|string $column + * @param string|int|float|null $operator + * @param string|int|float|null $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orHaving($column, $operator = null, $value = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orHaving($column, $operator, $value); + } + /** + * Add a nested having statement to the query. + * + * @param \Closure $callback + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function havingNested($callback, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->havingNested($callback, $boolean); + } + /** + * Add another query builder as a nested having to the query builder. + * + * @param \Illuminate\Database\Query\Builder $query + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function addNestedHavingQuery($query, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->addNestedHavingQuery($query, $boolean); + } + /** + * Add a "having null" clause to the query. + * + * @param string|array $columns + * @param string $boolean + * @param bool $not + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function havingNull($columns, $boolean = 'and', $not = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->havingNull($columns, $boolean, $not); + } + /** + * Add an "or having null" clause to the query. + * + * @param string $column + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orHavingNull($column) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orHavingNull($column); + } + /** + * Add a "having not null" clause to the query. + * + * @param string|array $columns + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function havingNotNull($columns, $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->havingNotNull($columns, $boolean); + } + /** + * Add an "or having not null" clause to the query. + * + * @param string $column + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orHavingNotNull($column) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orHavingNotNull($column); + } + /** + * Add a "having between " clause to the query. + * + * @param string $column + * @param \Illuminate\Database\Query\iterable $values + * @param string $boolean + * @param bool $not + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function havingBetween($column, $values, $boolean = 'and', $not = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->havingBetween($column, $values, $boolean, $not); + } + /** + * Add a raw having clause to the query. + * + * @param string $sql + * @param array $bindings + * @param string $boolean + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function havingRaw($sql, $bindings = [], $boolean = 'and') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->havingRaw($sql, $bindings, $boolean); + } + /** + * Add a raw or having clause to the query. + * + * @param string $sql + * @param array $bindings + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orHavingRaw($sql, $bindings = []) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orHavingRaw($sql, $bindings); + } + /** + * Add an "order by" clause to the query. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*>|\Illuminate\Contracts\Database\Query\Expression|string $column + * @param string $direction + * @return \Illuminate\Database\Query\Builder + * @throws \InvalidArgumentException + * @static + */ public static function orderBy($column, $direction = 'asc') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orderBy($column, $direction); + } + /** + * Add a descending "order by" clause to the query. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*>|\Illuminate\Contracts\Database\Query\Expression|string $column + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orderByDesc($column) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orderByDesc($column); + } + /** + * Put the query's results in random order. + * + * @param string|int $seed + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function inRandomOrder($seed = '') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->inRandomOrder($seed); + } + /** + * Add a raw "order by" clause to the query. + * + * @param string $sql + * @param array $bindings + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function orderByRaw($sql, $bindings = []) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->orderByRaw($sql, $bindings); + } + /** + * Alias to set the "offset" value of the query. + * + * @param int $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function skip($value) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->skip($value); + } + /** + * Set the "offset" value of the query. + * + * @param int $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function offset($value) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->offset($value); + } + /** + * Alias to set the "limit" value of the query. + * + * @param int $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function take($value) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->take($value); + } + /** + * Set the "limit" value of the query. + * + * @param int $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function limit($value) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->limit($value); + } + /** + * Add a "group limit" clause to the query. + * + * @param int $value + * @param string $column + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function groupLimit($value, $column) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->groupLimit($value, $column); + } + /** + * Set the limit and offset for a given page. + * + * @param int $page + * @param int $perPage + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function forPage($page, $perPage = 15) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->forPage($page, $perPage); + } + /** + * Constrain the query to the previous "page" of results before a given ID. + * + * @param int $perPage + * @param int|null $lastId + * @param string $column + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function forPageBeforeId($perPage = 15, $lastId = 0, $column = 'id') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->forPageBeforeId($perPage, $lastId, $column); + } + /** + * Constrain the query to the next "page" of results after a given ID. + * + * @param int $perPage + * @param int|null $lastId + * @param string $column + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function forPageAfterId($perPage = 15, $lastId = 0, $column = 'id') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->forPageAfterId($perPage, $lastId, $column); + } + /** + * Remove all existing orders and optionally add a new order. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Contracts\Database\Query\Expression|string|null $column + * @param string $direction + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function reorder($column = null, $direction = 'asc') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->reorder($column, $direction); + } + /** + * Add a union statement to the query. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*> $query + * @param bool $all + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function union($query, $all = false) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->union($query, $all); + } + /** + * Add a union all statement to the query. + * + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*> $query + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function unionAll($query) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->unionAll($query); + } + /** + * Lock the selected rows in the table. + * + * @param string|bool $value + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function lock($value = true) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->lock($value); + } + /** + * Lock the selected rows in the table for updating. + * + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function lockForUpdate() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->lockForUpdate(); + } + /** + * Share lock the selected rows in the table. + * + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function sharedLock() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->sharedLock(); + } + /** + * Register a closure to be invoked before the query is executed. + * + * @param callable $callback + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function beforeQuery($callback) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->beforeQuery($callback); + } + /** + * Invoke the "before query" modification callbacks. + * + * @return void + * @static + */ public static function applyBeforeQueryCallbacks() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + $instance->applyBeforeQueryCallbacks(); + } + /** + * Get the SQL representation of the query. + * + * @return string + * @static + */ public static function toSql() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->toSql(); + } + /** + * Get the raw SQL representation of the query with embedded bindings. + * + * @return string + * @static + */ public static function toRawSql() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->toRawSql(); + } + /** + * Get a single expression value from the first result of a query. + * + * @param string $expression + * @param array $bindings + * @return mixed + * @static + */ public static function rawValue($expression, $bindings = []) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->rawValue($expression, $bindings); + } + /** + * Get the count of the total records for the paginator. + * + * @param array $columns + * @return int + * @static + */ public static function getCountForPagination($columns = []) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->getCountForPagination($columns); + } + /** + * Concatenate values of a given column as a string. + * + * @param string $column + * @param string $glue + * @return string + * @static + */ public static function implode($column, $glue = '') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->implode($column, $glue); + } + /** + * Determine if any rows exist for the current query. + * + * @return bool + * @static + */ public static function exists() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->exists(); + } + /** + * Determine if no rows exist for the current query. + * + * @return bool + * @static + */ public static function doesntExist() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->doesntExist(); + } + /** + * Execute the given callback if no rows exist for the current query. + * + * @param \Closure $callback + * @return mixed + * @static + */ public static function existsOr($callback) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->existsOr($callback); + } + /** + * Execute the given callback if rows exist for the current query. + * + * @param \Closure $callback + * @return mixed + * @static + */ public static function doesntExistOr($callback) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->doesntExistOr($callback); + } + /** + * Retrieve the "count" result of the query. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $columns + * @return int + * @static + */ public static function count($columns = '*') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->count($columns); + } + /** + * Retrieve the minimum value of a given column. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @return mixed + * @static + */ public static function min($column) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->min($column); + } + /** + * Retrieve the maximum value of a given column. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @return mixed + * @static + */ public static function max($column) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->max($column); + } + /** + * Retrieve the sum of the values of a given column. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @return mixed + * @static + */ public static function sum($column) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->sum($column); + } + /** + * Retrieve the average of the values of a given column. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @return mixed + * @static + */ public static function avg($column) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->avg($column); + } + /** + * Alias for the "avg" method. + * + * @param \Illuminate\Contracts\Database\Query\Expression|string $column + * @return mixed + * @static + */ public static function average($column) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->average($column); + } + /** + * Execute an aggregate function on the database. + * + * @param string $function + * @param array $columns + * @return mixed + * @static + */ public static function aggregate($function, $columns = []) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->aggregate($function, $columns); + } + /** + * Execute a numeric aggregate function on the database. + * + * @param string $function + * @param array $columns + * @return float|int + * @static + */ public static function numericAggregate($function, $columns = []) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->numericAggregate($function, $columns); + } + /** + * Insert new records into the database. + * + * @param array $values + * @return bool + * @static + */ public static function insert($values) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->insert($values); + } + /** + * Insert new records into the database while ignoring errors. + * + * @param array $values + * @return int + * @static + */ public static function insertOrIgnore($values) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->insertOrIgnore($values); + } + /** + * Insert a new record and get the value of the primary key. + * + * @param array $values + * @param string|null $sequence + * @return int + * @static + */ public static function insertGetId($values, $sequence = null) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->insertGetId($values, $sequence); + } + /** + * Insert new records into the table using a subquery. + * + * @param array $columns + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*>|string $query + * @return int + * @static + */ public static function insertUsing($columns, $query) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->insertUsing($columns, $query); + } + /** + * Insert new records into the table using a subquery while ignoring errors. + * + * @param array $columns + * @param \Closure|\Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder<*>|string $query + * @return int + * @static + */ public static function insertOrIgnoreUsing($columns, $query) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->insertOrIgnoreUsing($columns, $query); + } + /** + * Update records in a PostgreSQL database using the update from syntax. + * + * @param array $values + * @return int + * @static + */ public static function updateFrom($values) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->updateFrom($values); + } + /** + * Insert or update a record matching the attributes, and fill it with values. + * + * @param array $attributes + * @param array|callable $values + * @return bool + * @static + */ public static function updateOrInsert($attributes, $values = []) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->updateOrInsert($attributes, $values); + } + /** + * Increment the given column's values by the given amounts. + * + * @param array $columns + * @param array $extra + * @return int + * @throws \InvalidArgumentException + * @static + */ public static function incrementEach($columns, $extra = []) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->incrementEach($columns, $extra); + } + /** + * Decrement the given column's values by the given amounts. + * + * @param array $columns + * @param array $extra + * @return int + * @throws \InvalidArgumentException + * @static + */ public static function decrementEach($columns, $extra = []) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->decrementEach($columns, $extra); + } + /** + * Run a truncate statement on the table. + * + * @return void + * @static + */ public static function truncate() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + $instance->truncate(); + } + /** + * Get all of the query builder's columns in a text-only array with all expressions evaluated. + * + * @return array + * @static + */ public static function getColumns() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->getColumns(); + } + /** + * Create a raw database expression. + * + * @param mixed $value + * @return \Illuminate\Contracts\Database\Query\Expression + * @static + */ public static function raw($value) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->raw($value); + } + /** + * Get the current query value bindings in a flattened array. + * + * @return array + * @static + */ public static function getBindings() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->getBindings(); + } + /** + * Get the raw array of bindings. + * + * @return array + * @static + */ public static function getRawBindings() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->getRawBindings(); + } + /** + * Set the bindings on the query builder. + * + * @param array $bindings + * @param string $type + * @return \Illuminate\Database\Query\Builder + * @throws \InvalidArgumentException + * @static + */ public static function setBindings($bindings, $type = 'where') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->setBindings($bindings, $type); + } + /** + * Add a binding to the query. + * + * @param mixed $value + * @param string $type + * @return \Illuminate\Database\Query\Builder + * @throws \InvalidArgumentException + * @static + */ public static function addBinding($value, $type = 'where') + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->addBinding($value, $type); + } + /** + * Cast the given binding value. + * + * @param mixed $value + * @return mixed + * @static + */ public static function castBinding($value) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->castBinding($value); + } + /** + * Merge an array of bindings into our bindings. + * + * @param \Illuminate\Database\Query\Builder $query + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function mergeBindings($query) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->mergeBindings($query); + } + /** + * Remove all of the expressions from a list of bindings. + * + * @param array $bindings + * @return array + * @static + */ public static function cleanBindings($bindings) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->cleanBindings($bindings); + } + /** + * Get the database query processor instance. + * + * @return \Illuminate\Database\Query\Processors\Processor + * @static + */ public static function getProcessor() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->getProcessor(); + } + /** + * Get the query grammar instance. + * + * @return \Illuminate\Database\Query\Grammars\Grammar + * @static + */ public static function getGrammar() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->getGrammar(); + } + /** + * Use the "write" PDO connection when executing the query. + * + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function useWritePdo() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->useWritePdo(); + } + /** + * Clone the query without the given properties. + * + * @param array $properties + * @return static + * @static + */ public static function cloneWithout($properties) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->cloneWithout($properties); + } + /** + * Clone the query without the given bindings. + * + * @param array $except + * @return static + * @static + */ public static function cloneWithoutBindings($except) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->cloneWithoutBindings($except); + } + /** + * Dump the current SQL and bindings. + * + * @param mixed $args + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function dump(...$args) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->dump(...$args); + } + /** + * Dump the raw current SQL with embedded bindings. + * + * @return \Illuminate\Database\Query\Builder + * @static + */ public static function dumpRawSql() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->dumpRawSql(); + } + /** + * Die and dump the current SQL and bindings. + * + * @return \Illuminate\Database\Query\never + * @static + */ public static function dd() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->dd(); + } + /** + * Die and dump the current SQL with embedded bindings. + * + * @return \Illuminate\Database\Query\never + * @static + */ public static function ddRawSql() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->ddRawSql(); + } + /** + * Explains the query. + * + * @return \Illuminate\Support\Collection + * @static + */ public static function explain() + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->explain(); + } + /** + * Register a custom macro. + * + * @param string $name + * @param object|callable $macro + * @param-closure-this static $macro + * @return void + * @static + */ public static function macro($name, $macro) + { + \Illuminate\Database\Query\Builder::macro($name, $macro); + } + /** + * Mix another object into the class. + * + * @param object $mixin + * @param bool $replace + * @return void + * @throws \ReflectionException + * @static + */ public static function mixin($mixin, $replace = true) + { + \Illuminate\Database\Query\Builder::mixin($mixin, $replace); + } + /** + * Flush the existing macros. + * + * @return void + * @static + */ public static function flushMacros() + { + \Illuminate\Database\Query\Builder::flushMacros(); + } + /** + * Dynamically handle calls to the class. + * + * @param string $method + * @param array $parameters + * @return mixed + * @throws \BadMethodCallException + * @static + */ public static function macroCall($method, $parameters) + { + /** @var \Illuminate\Database\Query\Builder $instance */ + return $instance->macroCall($method, $parameters); + } + } + class Event extends \Illuminate\Support\Facades\Event {} + class File extends \Illuminate\Support\Facades\File {} + class Gate extends \Illuminate\Support\Facades\Gate {} + class Hash extends \Illuminate\Support\Facades\Hash {} + class Http extends \Illuminate\Support\Facades\Http {} + class Js extends \Illuminate\Support\Js {} + class Lang extends \Illuminate\Support\Facades\Lang {} + class Log extends \Illuminate\Support\Facades\Log {} + class Mail extends \Illuminate\Support\Facades\Mail {} + class Notification extends \Illuminate\Support\Facades\Notification {} + class Number extends \Illuminate\Support\Number {} + class Password extends \Illuminate\Support\Facades\Password {} + class Process extends \Illuminate\Support\Facades\Process {} + class Queue extends \Illuminate\Support\Facades\Queue {} + class RateLimiter extends \Illuminate\Support\Facades\RateLimiter {} + class Redirect extends \Illuminate\Support\Facades\Redirect {} + class Request extends \Illuminate\Support\Facades\Request {} + class Response extends \Illuminate\Support\Facades\Response {} + class Route extends \Illuminate\Support\Facades\Route {} + class Schedule extends \Illuminate\Support\Facades\Schedule {} + class Schema extends \Illuminate\Support\Facades\Schema {} + class Session extends \Illuminate\Support\Facades\Session {} + class Storage extends \Illuminate\Support\Facades\Storage {} + class Str extends \Illuminate\Support\Str {} + class URL extends \Illuminate\Support\Facades\URL {} + class Validator extends \Illuminate\Support\Facades\Validator {} + class View extends \Illuminate\Support\Facades\View {} + class Vite extends \Illuminate\Support\Facades\Vite {} + class Flare extends \Spatie\LaravelIgnition\Facades\Flare {} + } + + + + + diff --git a/app/Console/Commands/AppVersionUpdateCommand.php b/app/Console/Commands/AppVersionUpdateCommand.php new file mode 100644 index 0000000..bccd0ff --- /dev/null +++ b/app/Console/Commands/AppVersionUpdateCommand.php @@ -0,0 +1,48 @@ +error('.env 文件不存在'); + return; + } + $current = env('APP_VERSION'); + $version = $this->argument('version'); + if ($version) { + if (!preg_match('/^\d+\.\d+\.\d+$/', $version)) { + $this->error('版本号格式错误'); + return; + } + } else { + $version = preg_replace_callback('/(\d+)$/', fn ($matches) => $matches[1] + 1, $current); + } + + $isAuto = $this->option('auto'); + if ($isAuto) { + file_put_contents($envPath, preg_replace('/APP_VERSION=.*/', 'APP_VERSION=' . $version, file_get_contents($envPath))); + $this->info('更新成功 ' . $current . ' -> ' . $version); + return Command::SUCCESS; + } + + $confirmed = $this->confirm('当前版本号:' . $current . ' 新版号 ' . $version . ' 确认更新么', true); + if (!$confirmed) { + $this->line('已取消'); + return Command::SUCCESS; + } + + file_put_contents($envPath, preg_replace('/APP_VERSION=.*/', 'APP_VERSION=' . $version, file_get_contents($envPath))); + $this->info('更新成功 ' . $current . ' -> ' . $version); + return Command::SUCCESS; + } +} diff --git a/app/Foundation/PersonalAccessToken.php b/app/Foundation/PersonalAccessToken.php new file mode 100644 index 0000000..f83bdb1 --- /dev/null +++ b/app/Foundation/PersonalAccessToken.php @@ -0,0 +1,25 @@ + 'json', + 'meta' => 'json', + 'last_used_at' => 'datetime', + 'expires_at' => 'datetime', + ]; + + public function addMeta($data) + { + $data = array_merge($this->meta, $data); + $this->update(['meta' => $data]); + } +} diff --git a/app/Http/Controllers/Controller.php b/app/Http/Controllers/Controller.php new file mode 100644 index 0000000..2e8af07 --- /dev/null +++ b/app/Http/Controllers/Controller.php @@ -0,0 +1,5 @@ +createGuestToken($request); + $request->merge(['clientToken' => $token]); + return $next($request); + } + + public function createGuestToken(Request $request) + { + return sha1($request->ip() . $request->header('User-Agent')); + } +} diff --git a/app/Models/Media.php b/app/Models/Media.php new file mode 100644 index 0000000..32074bc --- /dev/null +++ b/app/Models/Media.php @@ -0,0 +1,29 @@ +model + ->addMediaFromDisk($key, 'public') + ->usingFileName($key) + ->toMediaCollection($this->collection_name); + } + + protected function casts() + { + return [ + 'created_at' => 'datetime:Y-m-d H:i:s', + 'updated_at' => 'datetime:Y-m-d H:i:s', + ]; + } +} diff --git a/app/Models/User.php b/app/Models/User.php new file mode 100644 index 0000000..90155c7 --- /dev/null +++ b/app/Models/User.php @@ -0,0 +1,48 @@ + + */ + protected $fillable = [ + 'name', + 'email', + 'password', + ]; + + /** + * The attributes that should be hidden for serialization. + * + * @var array + */ + protected $hidden = [ + 'password', + 'remember_token', + ]; + + /** + * Get the attributes that should be cast. + * + * @return array + */ + protected function casts(): array + { + return [ + 'email_verified_at' => 'datetime', + 'password' => 'hashed', + ]; + } +} diff --git a/app/Providers/AppServiceProvider.php b/app/Providers/AppServiceProvider.php new file mode 100644 index 0000000..6703463 --- /dev/null +++ b/app/Providers/AppServiceProvider.php @@ -0,0 +1,30 @@ +ip() . $request->header('User-Agent')); + return Limit::perMinute(10)->by($key); + }); + } +} diff --git a/artisan b/artisan new file mode 100755 index 0000000..8e04b42 --- /dev/null +++ b/artisan @@ -0,0 +1,15 @@ +#!/usr/bin/env php +handleCommand(new ArgvInput); + +exit($status); diff --git a/bootstrap/app.php b/bootstrap/app.php new file mode 100644 index 0000000..86554c8 --- /dev/null +++ b/bootstrap/app.php @@ -0,0 +1,67 @@ +withRouting( + web: __DIR__ . '/../routes/web.php', + commands: __DIR__ . '/../routes/console.php', + health: '/up', + ) + ->withMiddleware(function (Middleware $middleware) { + $middleware->redirectGuestsTo(fn(Request $request) => null); + + $middleware->remove([ + EncryptCookies::class, + AddQueuedCookiesToResponse::class, + StartSession::class, + ShareErrorsFromSession::class, + ValidateCsrfToken::class, + ConvertEmptyStringsToNull::class, + ]); + + $middleware->removeFromGroup('web', [ + EncryptCookies::class, + AddQueuedCookiesToResponse::class, + StartSession::class, + ShareErrorsFromSession::class, + ValidateCsrfToken::class, + ]); + }) + ->withExceptions(function (Exceptions $exceptions) { + $exceptions->renderable(function (ThrottleRequestsException $e, $request) { + return response()->json(['message' => 'Too many requests'], 429); + }); + $exceptions->render(function (Throwable $th, Request $request) { + if ($th instanceof NotFoundHttpException) { + return response('NotFound', 404); + } + if ($th instanceof ValidationException) { + $message = $th->validator->errors()->first(); + return response()->json(['code' => 400, 'message' => $message]); + } + if ($th instanceof MethodNotAllowedHttpException) { + return response()->json(['code' => 400, 'message' => 'MethodNotAllowed']); + } + + info('===== application exception: ', [get_class($th)]); + return response()->json(['message' => 'unknow exception'], 400); + }); + + // $exceptions->renderable(function(MiniappException $th, $request){}); + // $exceptions->render([AppException::class, 'render']); + // $exceptions->dontReport(AppException::$dontReport); + })->create(); diff --git a/bootstrap/cache/.gitignore b/bootstrap/cache/.gitignore new file mode 100644 index 0000000..d6b7ef3 --- /dev/null +++ b/bootstrap/cache/.gitignore @@ -0,0 +1,2 @@ +* +!.gitignore diff --git a/bootstrap/providers.php b/bootstrap/providers.php new file mode 100644 index 0000000..35fe5f9 --- /dev/null +++ b/bootstrap/providers.php @@ -0,0 +1,6 @@ +=5.5" + }, + "require-dev": { + "phpunit/phpunit": "*", + "symfony/dotenv": "^3.4", + "symfony/var-dumper": "^3.4" + }, + "suggest": { + "ext-sockets": "To use client-side monitoring" + }, + "type": "library", + "autoload": { + "psr-4": { + "AlibabaCloud\\Tea\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "Alibaba Cloud SDK", + "email": "sdk-team@alibabacloud.com", + "homepage": "http://www.alibabacloud.com" + } + ], + "description": "Client of Tea for PHP", + "homepage": "https://www.alibabacloud.com/", + "keywords": [ + "alibabacloud", + "client", + "cloud", + "tea" + ], + "support": { + "issues": "https://github.com/aliyun/tea-php/issues", + "source": "https://github.com/aliyun/tea-php" + }, + "time": "2023-05-16T06:43:41+00:00" + }, + { + "name": "alibabacloud/tea-fileform", + "version": "0.3.4", + "source": { + "type": "git", + "url": "https://github.com/alibabacloud-sdk-php/tea-fileform.git", + "reference": "4bf0c75a045c8115aa8cb1a394bd08d8bb833181" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/alibabacloud-sdk-php/tea-fileform/zipball/4bf0c75a045c8115aa8cb1a394bd08d8bb833181", + "reference": "4bf0c75a045c8115aa8cb1a394bd08d8bb833181", + "shasum": "" + }, + "require": { + "alibabacloud/tea": "^3.0", + "php": ">5.5" + }, + "require-dev": { + "phpunit/phpunit": "^4.8.35|^5.4.3" + }, + "type": "library", + "autoload": { + "psr-4": { + "AlibabaCloud\\Tea\\FileForm\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "Alibaba Cloud SDK", + "email": "sdk-team@alibabacloud.com" + } + ], + "description": "Alibaba Cloud Tea File Library for PHP", + "support": { + "issues": "https://github.com/alibabacloud-sdk-php/tea-fileform/issues", + "source": "https://github.com/alibabacloud-sdk-php/tea-fileform/tree/0.3.4" + }, + "time": "2020-12-01T07:24:35+00:00" + }, + { + "name": "alipaysdk/easysdk", + "version": "2.2.3", + "source": { + "type": "git", + "url": "https://github.com/alipay/alipay-easysdk.git", + "reference": "c6008839a22a5fca08e9f8536730f7abfed522d5" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/alipay/alipay-easysdk/zipball/c6008839a22a5fca08e9f8536730f7abfed522d5", + "reference": "c6008839a22a5fca08e9f8536730f7abfed522d5", + "shasum": "" + }, + "require": { + "alibabacloud/tea": "^3.1", + "alibabacloud/tea-fileform": "^0.3.2", + "ext-ctype": "*", + "ext-curl": "*", + "ext-dom": "*", + "ext-fileinfo": "*", + "ext-json": "*", + "ext-libxml": "*", + "ext-mbstring": "*", + "ext-openssl": "*", + "ext-simplexml": "*", + "ext-xmlwriter": "*", + "guzzlehttp/guzzle": ">=6.3", + "php": ">=7.0" + }, + "require-dev": { + "phpunit/phpunit": "^7.5" + }, + "type": "library", + "autoload": { + "psr-4": { + "Alipay\\EasySDK\\": "php/src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "junying.wjy", + "email": "junying.wjy@antfin.com" + } + ], + "description": "支付宝官方 Alipay Easy SDK", + "support": { + "source": "https://github.com/alipay/alipay-easysdk/tree/v2.2.3" + }, + "time": "2022-11-28T14:04:57+00:00" + }, + { + "name": "brick/math", + "version": "0.12.1", + "source": { + "type": "git", + "url": "https://github.com/brick/math.git", + "reference": "f510c0a40911935b77b86859eb5223d58d660df1" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/brick/math/zipball/f510c0a40911935b77b86859eb5223d58d660df1", + "reference": "f510c0a40911935b77b86859eb5223d58d660df1", + "shasum": "" + }, + "require": { + "php": "^8.1" + }, + "require-dev": { + "php-coveralls/php-coveralls": "^2.2", + "phpunit/phpunit": "^10.1", + "vimeo/psalm": "5.16.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Brick\\Math\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "Arbitrary-precision arithmetic library", + "keywords": [ + "Arbitrary-precision", + "BigInteger", + "BigRational", + "arithmetic", + "bigdecimal", + "bignum", + "bignumber", + "brick", + "decimal", + "integer", + "math", + "mathematics", + "rational" + ], + "support": { + "issues": "https://github.com/brick/math/issues", + "source": "https://github.com/brick/math/tree/0.12.1" + }, + "funding": [ + { + "url": "https://github.com/BenMorel", + "type": "github" + } + ], + "time": "2023-11-29T23:19:16+00:00" + }, + { + "name": "carbonphp/carbon-doctrine-types", + "version": "3.2.0", + "source": { + "type": "git", + "url": "https://github.com/CarbonPHP/carbon-doctrine-types.git", + "reference": "18ba5ddfec8976260ead6e866180bd5d2f71aa1d" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/CarbonPHP/carbon-doctrine-types/zipball/18ba5ddfec8976260ead6e866180bd5d2f71aa1d", + "reference": "18ba5ddfec8976260ead6e866180bd5d2f71aa1d", + "shasum": "" + }, + "require": { + "php": "^8.1" + }, + "conflict": { + "doctrine/dbal": "<4.0.0 || >=5.0.0" + }, + "require-dev": { + "doctrine/dbal": "^4.0.0", + "nesbot/carbon": "^2.71.0 || ^3.0.0", + "phpunit/phpunit": "^10.3" + }, + "type": "library", + "autoload": { + "psr-4": { + "Carbon\\Doctrine\\": "src/Carbon/Doctrine/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "KyleKatarn", + "email": "kylekatarnls@gmail.com" + } + ], + "description": "Types to use Carbon in Doctrine", + "keywords": [ + "carbon", + "date", + "datetime", + "doctrine", + "time" + ], + "support": { + "issues": "https://github.com/CarbonPHP/carbon-doctrine-types/issues", + "source": "https://github.com/CarbonPHP/carbon-doctrine-types/tree/3.2.0" + }, + "funding": [ + { + "url": "https://github.com/kylekatarnls", + "type": "github" + }, + { + "url": "https://opencollective.com/Carbon", + "type": "open_collective" + }, + { + "url": "https://tidelift.com/funding/github/packagist/nesbot/carbon", + "type": "tidelift" + } + ], + "time": "2024-02-09T16:56:22+00:00" + }, + { + "name": "chillerlan/php-qrcode", + "version": "5.0.2", + "source": { + "type": "git", + "url": "https://github.com/chillerlan/php-qrcode.git", + "reference": "da5bdb82c8755f54de112b271b402aaa8df53269" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/chillerlan/php-qrcode/zipball/da5bdb82c8755f54de112b271b402aaa8df53269", + "reference": "da5bdb82c8755f54de112b271b402aaa8df53269", + "shasum": "" + }, + "require": { + "chillerlan/php-settings-container": "^2.1.4 || ^3.1", + "ext-mbstring": "*", + "php": "^7.4 || ^8.0" + }, + "require-dev": { + "chillerlan/php-authenticator": "^4.1 || ^5.1", + "phan/phan": "^5.4", + "phpmd/phpmd": "^2.15", + "phpunit/phpunit": "^9.6", + "setasign/fpdf": "^1.8.2", + "squizlabs/php_codesniffer": "^3.8" + }, + "suggest": { + "chillerlan/php-authenticator": "Yet another Google authenticator! Also creates URIs for mobile apps.", + "setasign/fpdf": "Required to use the QR FPDF output.", + "simple-icons/simple-icons": "SVG icons that you can use to embed as logos in the QR Code" + }, + "type": "library", + "autoload": { + "psr-4": { + "chillerlan\\QRCode\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT", + "Apache-2.0" + ], + "authors": [ + { + "name": "Kazuhiko Arase", + "homepage": "https://github.com/kazuhikoarase/qrcode-generator" + }, + { + "name": "ZXing Authors", + "homepage": "https://github.com/zxing/zxing" + }, + { + "name": "Ashot Khanamiryan", + "homepage": "https://github.com/khanamiryan/php-qrcode-detector-decoder" + }, + { + "name": "Smiley", + "email": "smiley@chillerlan.net", + "homepage": "https://github.com/codemasher" + }, + { + "name": "Contributors", + "homepage": "https://github.com/chillerlan/php-qrcode/graphs/contributors" + } + ], + "description": "A QR code generator and reader with a user friendly API. PHP 7.4+", + "homepage": "https://github.com/chillerlan/php-qrcode", + "keywords": [ + "phpqrcode", + "qr", + "qr code", + "qr-reader", + "qrcode", + "qrcode-generator", + "qrcode-reader" + ], + "support": { + "docs": "https://php-qrcode.readthedocs.io", + "issues": "https://github.com/chillerlan/php-qrcode/issues", + "source": "https://github.com/chillerlan/php-qrcode" + }, + "funding": [ + { + "url": "https://www.paypal.com/donate?hosted_button_id=WLYUNAT9ZTJZ4", + "type": "custom" + }, + { + "url": "https://ko-fi.com/codemasher", + "type": "ko_fi" + } + ], + "time": "2024-02-27T14:37:26+00:00" + }, + { + "name": "chillerlan/php-settings-container", + "version": "3.2.1", + "source": { + "type": "git", + "url": "https://github.com/chillerlan/php-settings-container.git", + "reference": "95ed3e9676a1d47cab2e3174d19b43f5dbf52681" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/chillerlan/php-settings-container/zipball/95ed3e9676a1d47cab2e3174d19b43f5dbf52681", + "reference": "95ed3e9676a1d47cab2e3174d19b43f5dbf52681", + "shasum": "" + }, + "require": { + "ext-json": "*", + "php": "^8.1" + }, + "require-dev": { + "phpmd/phpmd": "^2.15", + "phpstan/phpstan": "^1.11", + "phpstan/phpstan-deprecation-rules": "^1.2", + "phpunit/phpunit": "^10.5", + "squizlabs/php_codesniffer": "^3.10" + }, + "type": "library", + "autoload": { + "psr-4": { + "chillerlan\\Settings\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Smiley", + "email": "smiley@chillerlan.net", + "homepage": "https://github.com/codemasher" + } + ], + "description": "A container class for immutable settings objects. Not a DI container.", + "homepage": "https://github.com/chillerlan/php-settings-container", + "keywords": [ + "Settings", + "configuration", + "container", + "helper" + ], + "support": { + "issues": "https://github.com/chillerlan/php-settings-container/issues", + "source": "https://github.com/chillerlan/php-settings-container" + }, + "funding": [ + { + "url": "https://www.paypal.com/donate?hosted_button_id=WLYUNAT9ZTJZ4", + "type": "custom" + }, + { + "url": "https://ko-fi.com/codemasher", + "type": "ko_fi" + } + ], + "time": "2024-07-16T11:13:48+00:00" + }, + { + "name": "composer/semver", + "version": "3.4.3", + "source": { + "type": "git", + "url": "https://github.com/composer/semver.git", + "reference": "4313d26ada5e0c4edfbd1dc481a92ff7bff91f12" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/composer/semver/zipball/4313d26ada5e0c4edfbd1dc481a92ff7bff91f12", + "reference": "4313d26ada5e0c4edfbd1dc481a92ff7bff91f12", + "shasum": "" + }, + "require": { + "php": "^5.3.2 || ^7.0 || ^8.0" + }, + "require-dev": { + "phpstan/phpstan": "^1.11", + "symfony/phpunit-bridge": "^3 || ^7" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.x-dev" + } + }, + "autoload": { + "psr-4": { + "Composer\\Semver\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nils Adermann", + "email": "naderman@naderman.de", + "homepage": "http://www.naderman.de" + }, + { + "name": "Jordi Boggiano", + "email": "j.boggiano@seld.be", + "homepage": "http://seld.be" + }, + { + "name": "Rob Bast", + "email": "rob.bast@gmail.com", + "homepage": "http://robbast.nl" + } + ], + "description": "Semver library that offers utilities, version constraint parsing and validation.", + "keywords": [ + "semantic", + "semver", + "validation", + "versioning" + ], + "support": { + "irc": "ircs://irc.libera.chat:6697/composer", + "issues": "https://github.com/composer/semver/issues", + "source": "https://github.com/composer/semver/tree/3.4.3" + }, + "funding": [ + { + "url": "https://packagist.com", + "type": "custom" + }, + { + "url": "https://github.com/composer", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/composer/composer", + "type": "tidelift" + } + ], + "time": "2024-09-19T14:15:21+00:00" + }, + { + "name": "dflydev/dot-access-data", + "version": "v3.0.3", + "source": { + "type": "git", + "url": "https://github.com/dflydev/dflydev-dot-access-data.git", + "reference": "a23a2bf4f31d3518f3ecb38660c95715dfead60f" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/dflydev/dflydev-dot-access-data/zipball/a23a2bf4f31d3518f3ecb38660c95715dfead60f", + "reference": "a23a2bf4f31d3518f3ecb38660c95715dfead60f", + "shasum": "" + }, + "require": { + "php": "^7.1 || ^8.0" + }, + "require-dev": { + "phpstan/phpstan": "^0.12.42", + "phpunit/phpunit": "^7.5 || ^8.5 || ^9.3", + "scrutinizer/ocular": "1.6.0", + "squizlabs/php_codesniffer": "^3.5", + "vimeo/psalm": "^4.0.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.x-dev" + } + }, + "autoload": { + "psr-4": { + "Dflydev\\DotAccessData\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Dragonfly Development Inc.", + "email": "info@dflydev.com", + "homepage": "http://dflydev.com" + }, + { + "name": "Beau Simensen", + "email": "beau@dflydev.com", + "homepage": "http://beausimensen.com" + }, + { + "name": "Carlos Frutos", + "email": "carlos@kiwing.it", + "homepage": "https://github.com/cfrutos" + }, + { + "name": "Colin O'Dell", + "email": "colinodell@gmail.com", + "homepage": "https://www.colinodell.com" + } + ], + "description": "Given a deep data structure, access data by dot notation.", + "homepage": "https://github.com/dflydev/dflydev-dot-access-data", + "keywords": [ + "access", + "data", + "dot", + "notation" + ], + "support": { + "issues": "https://github.com/dflydev/dflydev-dot-access-data/issues", + "source": "https://github.com/dflydev/dflydev-dot-access-data/tree/v3.0.3" + }, + "time": "2024-07-08T12:26:09+00:00" + }, + { + "name": "doctrine/inflector", + "version": "2.0.10", + "source": { + "type": "git", + "url": "https://github.com/doctrine/inflector.git", + "reference": "5817d0659c5b50c9b950feb9af7b9668e2c436bc" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/doctrine/inflector/zipball/5817d0659c5b50c9b950feb9af7b9668e2c436bc", + "reference": "5817d0659c5b50c9b950feb9af7b9668e2c436bc", + "shasum": "" + }, + "require": { + "php": "^7.2 || ^8.0" + }, + "require-dev": { + "doctrine/coding-standard": "^11.0", + "phpstan/phpstan": "^1.8", + "phpstan/phpstan-phpunit": "^1.1", + "phpstan/phpstan-strict-rules": "^1.3", + "phpunit/phpunit": "^8.5 || ^9.5", + "vimeo/psalm": "^4.25 || ^5.4" + }, + "type": "library", + "autoload": { + "psr-4": { + "Doctrine\\Inflector\\": "lib/Doctrine/Inflector" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Guilherme Blanco", + "email": "guilhermeblanco@gmail.com" + }, + { + "name": "Roman Borschel", + "email": "roman@code-factory.org" + }, + { + "name": "Benjamin Eberlei", + "email": "kontakt@beberlei.de" + }, + { + "name": "Jonathan Wage", + "email": "jonwage@gmail.com" + }, + { + "name": "Johannes Schmitt", + "email": "schmittjoh@gmail.com" + } + ], + "description": "PHP Doctrine Inflector is a small library that can perform string manipulations with regard to upper/lowercase and singular/plural forms of words.", + "homepage": "https://www.doctrine-project.org/projects/inflector.html", + "keywords": [ + "inflection", + "inflector", + "lowercase", + "manipulation", + "php", + "plural", + "singular", + "strings", + "uppercase", + "words" + ], + "support": { + "issues": "https://github.com/doctrine/inflector/issues", + "source": "https://github.com/doctrine/inflector/tree/2.0.10" + }, + "funding": [ + { + "url": "https://www.doctrine-project.org/sponsorship.html", + "type": "custom" + }, + { + "url": "https://www.patreon.com/phpdoctrine", + "type": "patreon" + }, + { + "url": "https://tidelift.com/funding/github/packagist/doctrine%2Finflector", + "type": "tidelift" + } + ], + "time": "2024-02-18T20:23:39+00:00" + }, + { + "name": "doctrine/lexer", + "version": "3.0.1", + "source": { + "type": "git", + "url": "https://github.com/doctrine/lexer.git", + "reference": "31ad66abc0fc9e1a1f2d9bc6a42668d2fbbcd6dd" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/doctrine/lexer/zipball/31ad66abc0fc9e1a1f2d9bc6a42668d2fbbcd6dd", + "reference": "31ad66abc0fc9e1a1f2d9bc6a42668d2fbbcd6dd", + "shasum": "" + }, + "require": { + "php": "^8.1" + }, + "require-dev": { + "doctrine/coding-standard": "^12", + "phpstan/phpstan": "^1.10", + "phpunit/phpunit": "^10.5", + "psalm/plugin-phpunit": "^0.18.3", + "vimeo/psalm": "^5.21" + }, + "type": "library", + "autoload": { + "psr-4": { + "Doctrine\\Common\\Lexer\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Guilherme Blanco", + "email": "guilhermeblanco@gmail.com" + }, + { + "name": "Roman Borschel", + "email": "roman@code-factory.org" + }, + { + "name": "Johannes Schmitt", + "email": "schmittjoh@gmail.com" + } + ], + "description": "PHP Doctrine Lexer parser library that can be used in Top-Down, Recursive Descent Parsers.", + "homepage": "https://www.doctrine-project.org/projects/lexer.html", + "keywords": [ + "annotations", + "docblock", + "lexer", + "parser", + "php" + ], + "support": { + "issues": "https://github.com/doctrine/lexer/issues", + "source": "https://github.com/doctrine/lexer/tree/3.0.1" + }, + "funding": [ + { + "url": "https://www.doctrine-project.org/sponsorship.html", + "type": "custom" + }, + { + "url": "https://www.patreon.com/phpdoctrine", + "type": "patreon" + }, + { + "url": "https://tidelift.com/funding/github/packagist/doctrine%2Flexer", + "type": "tidelift" + } + ], + "time": "2024-02-05T11:56:58+00:00" + }, + { + "name": "dragonmantank/cron-expression", + "version": "v3.4.0", + "source": { + "type": "git", + "url": "https://github.com/dragonmantank/cron-expression.git", + "reference": "8c784d071debd117328803d86b2097615b457500" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/dragonmantank/cron-expression/zipball/8c784d071debd117328803d86b2097615b457500", + "reference": "8c784d071debd117328803d86b2097615b457500", + "shasum": "" + }, + "require": { + "php": "^7.2|^8.0", + "webmozart/assert": "^1.0" + }, + "replace": { + "mtdowling/cron-expression": "^1.0" + }, + "require-dev": { + "phpstan/extension-installer": "^1.0", + "phpstan/phpstan": "^1.0", + "phpunit/phpunit": "^7.0|^8.0|^9.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "3.x-dev" + } + }, + "autoload": { + "psr-4": { + "Cron\\": "src/Cron/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Chris Tankersley", + "email": "chris@ctankersley.com", + "homepage": "https://github.com/dragonmantank" + } + ], + "description": "CRON for PHP: Calculate the next or previous run date and determine if a CRON expression is due", + "keywords": [ + "cron", + "schedule" + ], + "support": { + "issues": "https://github.com/dragonmantank/cron-expression/issues", + "source": "https://github.com/dragonmantank/cron-expression/tree/v3.4.0" + }, + "funding": [ + { + "url": "https://github.com/dragonmantank", + "type": "github" + } + ], + "time": "2024-10-09T13:47:03+00:00" + }, + { + "name": "egulias/email-validator", + "version": "4.0.2", + "source": { + "type": "git", + "url": "https://github.com/egulias/EmailValidator.git", + "reference": "ebaaf5be6c0286928352e054f2d5125608e5405e" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/egulias/EmailValidator/zipball/ebaaf5be6c0286928352e054f2d5125608e5405e", + "reference": "ebaaf5be6c0286928352e054f2d5125608e5405e", + "shasum": "" + }, + "require": { + "doctrine/lexer": "^2.0 || ^3.0", + "php": ">=8.1", + "symfony/polyfill-intl-idn": "^1.26" + }, + "require-dev": { + "phpunit/phpunit": "^10.2", + "vimeo/psalm": "^5.12" + }, + "suggest": { + "ext-intl": "PHP Internationalization Libraries are required to use the SpoofChecking validation" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "4.0.x-dev" + } + }, + "autoload": { + "psr-4": { + "Egulias\\EmailValidator\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Eduardo Gulias Davis" + } + ], + "description": "A library for validating emails against several RFCs", + "homepage": "https://github.com/egulias/EmailValidator", + "keywords": [ + "email", + "emailvalidation", + "emailvalidator", + "validation", + "validator" + ], + "support": { + "issues": "https://github.com/egulias/EmailValidator/issues", + "source": "https://github.com/egulias/EmailValidator/tree/4.0.2" + }, + "funding": [ + { + "url": "https://github.com/egulias", + "type": "github" + } + ], + "time": "2023-10-06T06:47:41+00:00" + }, + { + "name": "fruitcake/php-cors", + "version": "v1.3.0", + "source": { + "type": "git", + "url": "https://github.com/fruitcake/php-cors.git", + "reference": "3d158f36e7875e2f040f37bc0573956240a5a38b" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/fruitcake/php-cors/zipball/3d158f36e7875e2f040f37bc0573956240a5a38b", + "reference": "3d158f36e7875e2f040f37bc0573956240a5a38b", + "shasum": "" + }, + "require": { + "php": "^7.4|^8.0", + "symfony/http-foundation": "^4.4|^5.4|^6|^7" + }, + "require-dev": { + "phpstan/phpstan": "^1.4", + "phpunit/phpunit": "^9", + "squizlabs/php_codesniffer": "^3.5" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.2-dev" + } + }, + "autoload": { + "psr-4": { + "Fruitcake\\Cors\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fruitcake", + "homepage": "https://fruitcake.nl" + }, + { + "name": "Barryvdh", + "email": "barryvdh@gmail.com" + } + ], + "description": "Cross-origin resource sharing library for the Symfony HttpFoundation", + "homepage": "https://github.com/fruitcake/php-cors", + "keywords": [ + "cors", + "laravel", + "symfony" + ], + "support": { + "issues": "https://github.com/fruitcake/php-cors/issues", + "source": "https://github.com/fruitcake/php-cors/tree/v1.3.0" + }, + "funding": [ + { + "url": "https://fruitcake.nl", + "type": "custom" + }, + { + "url": "https://github.com/barryvdh", + "type": "github" + } + ], + "time": "2023-10-12T05:21:21+00:00" + }, + { + "name": "graham-campbell/result-type", + "version": "v1.1.3", + "source": { + "type": "git", + "url": "https://github.com/GrahamCampbell/Result-Type.git", + "reference": "3ba905c11371512af9d9bdd27d99b782216b6945" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/GrahamCampbell/Result-Type/zipball/3ba905c11371512af9d9bdd27d99b782216b6945", + "reference": "3ba905c11371512af9d9bdd27d99b782216b6945", + "shasum": "" + }, + "require": { + "php": "^7.2.5 || ^8.0", + "phpoption/phpoption": "^1.9.3" + }, + "require-dev": { + "phpunit/phpunit": "^8.5.39 || ^9.6.20 || ^10.5.28" + }, + "type": "library", + "autoload": { + "psr-4": { + "GrahamCampbell\\ResultType\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Graham Campbell", + "email": "hello@gjcampbell.co.uk", + "homepage": "https://github.com/GrahamCampbell" + } + ], + "description": "An Implementation Of The Result Type", + "keywords": [ + "Graham Campbell", + "GrahamCampbell", + "Result Type", + "Result-Type", + "result" + ], + "support": { + "issues": "https://github.com/GrahamCampbell/Result-Type/issues", + "source": "https://github.com/GrahamCampbell/Result-Type/tree/v1.1.3" + }, + "funding": [ + { + "url": "https://github.com/GrahamCampbell", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/graham-campbell/result-type", + "type": "tidelift" + } + ], + "time": "2024-07-20T21:45:45+00:00" + }, + { + "name": "guzzlehttp/guzzle", + "version": "7.9.2", + "source": { + "type": "git", + "url": "https://github.com/guzzle/guzzle.git", + "reference": "d281ed313b989f213357e3be1a179f02196ac99b" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/guzzle/guzzle/zipball/d281ed313b989f213357e3be1a179f02196ac99b", + "reference": "d281ed313b989f213357e3be1a179f02196ac99b", + "shasum": "" + }, + "require": { + "ext-json": "*", + "guzzlehttp/promises": "^1.5.3 || ^2.0.3", + "guzzlehttp/psr7": "^2.7.0", + "php": "^7.2.5 || ^8.0", + "psr/http-client": "^1.0", + "symfony/deprecation-contracts": "^2.2 || ^3.0" + }, + "provide": { + "psr/http-client-implementation": "1.0" + }, + "require-dev": { + "bamarni/composer-bin-plugin": "^1.8.2", + "ext-curl": "*", + "guzzle/client-integration-tests": "3.0.2", + "php-http/message-factory": "^1.1", + "phpunit/phpunit": "^8.5.39 || ^9.6.20", + "psr/log": "^1.1 || ^2.0 || ^3.0" + }, + "suggest": { + "ext-curl": "Required for CURL handler support", + "ext-intl": "Required for Internationalized Domain Name (IDN) support", + "psr/log": "Required for using the Log middleware" + }, + "type": "library", + "extra": { + "bamarni-bin": { + "bin-links": true, + "forward-command": false + } + }, + "autoload": { + "files": [ + "src/functions_include.php" + ], + "psr-4": { + "GuzzleHttp\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Graham Campbell", + "email": "hello@gjcampbell.co.uk", + "homepage": "https://github.com/GrahamCampbell" + }, + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + }, + { + "name": "Jeremy Lindblom", + "email": "jeremeamia@gmail.com", + "homepage": "https://github.com/jeremeamia" + }, + { + "name": "George Mponos", + "email": "gmponos@gmail.com", + "homepage": "https://github.com/gmponos" + }, + { + "name": "Tobias Nyholm", + "email": "tobias.nyholm@gmail.com", + "homepage": "https://github.com/Nyholm" + }, + { + "name": "Márk Sági-Kazár", + "email": "mark.sagikazar@gmail.com", + "homepage": "https://github.com/sagikazarmark" + }, + { + "name": "Tobias Schultze", + "email": "webmaster@tubo-world.de", + "homepage": "https://github.com/Tobion" + } + ], + "description": "Guzzle is a PHP HTTP client library", + "keywords": [ + "client", + "curl", + "framework", + "http", + "http client", + "psr-18", + "psr-7", + "rest", + "web service" + ], + "support": { + "issues": "https://github.com/guzzle/guzzle/issues", + "source": "https://github.com/guzzle/guzzle/tree/7.9.2" + }, + "funding": [ + { + "url": "https://github.com/GrahamCampbell", + "type": "github" + }, + { + "url": "https://github.com/Nyholm", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/guzzlehttp/guzzle", + "type": "tidelift" + } + ], + "time": "2024-07-24T11:22:20+00:00" + }, + { + "name": "guzzlehttp/promises", + "version": "2.0.4", + "source": { + "type": "git", + "url": "https://github.com/guzzle/promises.git", + "reference": "f9c436286ab2892c7db7be8c8da4ef61ccf7b455" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/guzzle/promises/zipball/f9c436286ab2892c7db7be8c8da4ef61ccf7b455", + "reference": "f9c436286ab2892c7db7be8c8da4ef61ccf7b455", + "shasum": "" + }, + "require": { + "php": "^7.2.5 || ^8.0" + }, + "require-dev": { + "bamarni/composer-bin-plugin": "^1.8.2", + "phpunit/phpunit": "^8.5.39 || ^9.6.20" + }, + "type": "library", + "extra": { + "bamarni-bin": { + "bin-links": true, + "forward-command": false + } + }, + "autoload": { + "psr-4": { + "GuzzleHttp\\Promise\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Graham Campbell", + "email": "hello@gjcampbell.co.uk", + "homepage": "https://github.com/GrahamCampbell" + }, + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + }, + { + "name": "Tobias Nyholm", + "email": "tobias.nyholm@gmail.com", + "homepage": "https://github.com/Nyholm" + }, + { + "name": "Tobias Schultze", + "email": "webmaster@tubo-world.de", + "homepage": "https://github.com/Tobion" + } + ], + "description": "Guzzle promises library", + "keywords": [ + "promise" + ], + "support": { + "issues": "https://github.com/guzzle/promises/issues", + "source": "https://github.com/guzzle/promises/tree/2.0.4" + }, + "funding": [ + { + "url": "https://github.com/GrahamCampbell", + "type": "github" + }, + { + "url": "https://github.com/Nyholm", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/guzzlehttp/promises", + "type": "tidelift" + } + ], + "time": "2024-10-17T10:06:22+00:00" + }, + { + "name": "guzzlehttp/psr7", + "version": "2.7.0", + "source": { + "type": "git", + "url": "https://github.com/guzzle/psr7.git", + "reference": "a70f5c95fb43bc83f07c9c948baa0dc1829bf201" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/guzzle/psr7/zipball/a70f5c95fb43bc83f07c9c948baa0dc1829bf201", + "reference": "a70f5c95fb43bc83f07c9c948baa0dc1829bf201", + "shasum": "" + }, + "require": { + "php": "^7.2.5 || ^8.0", + "psr/http-factory": "^1.0", + "psr/http-message": "^1.1 || ^2.0", + "ralouphie/getallheaders": "^3.0" + }, + "provide": { + "psr/http-factory-implementation": "1.0", + "psr/http-message-implementation": "1.0" + }, + "require-dev": { + "bamarni/composer-bin-plugin": "^1.8.2", + "http-interop/http-factory-tests": "0.9.0", + "phpunit/phpunit": "^8.5.39 || ^9.6.20" + }, + "suggest": { + "laminas/laminas-httphandlerrunner": "Emit PSR-7 responses" + }, + "type": "library", + "extra": { + "bamarni-bin": { + "bin-links": true, + "forward-command": false + } + }, + "autoload": { + "psr-4": { + "GuzzleHttp\\Psr7\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Graham Campbell", + "email": "hello@gjcampbell.co.uk", + "homepage": "https://github.com/GrahamCampbell" + }, + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + }, + { + "name": "George Mponos", + "email": "gmponos@gmail.com", + "homepage": "https://github.com/gmponos" + }, + { + "name": "Tobias Nyholm", + "email": "tobias.nyholm@gmail.com", + "homepage": "https://github.com/Nyholm" + }, + { + "name": "Márk Sági-Kazár", + "email": "mark.sagikazar@gmail.com", + "homepage": "https://github.com/sagikazarmark" + }, + { + "name": "Tobias Schultze", + "email": "webmaster@tubo-world.de", + "homepage": "https://github.com/Tobion" + }, + { + "name": "Márk Sági-Kazár", + "email": "mark.sagikazar@gmail.com", + "homepage": "https://sagikazarmark.hu" + } + ], + "description": "PSR-7 message implementation that also provides common utility methods", + "keywords": [ + "http", + "message", + "psr-7", + "request", + "response", + "stream", + "uri", + "url" + ], + "support": { + "issues": "https://github.com/guzzle/psr7/issues", + "source": "https://github.com/guzzle/psr7/tree/2.7.0" + }, + "funding": [ + { + "url": "https://github.com/GrahamCampbell", + "type": "github" + }, + { + "url": "https://github.com/Nyholm", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/guzzlehttp/psr7", + "type": "tidelift" + } + ], + "time": "2024-07-18T11:15:46+00:00" + }, + { + "name": "guzzlehttp/uri-template", + "version": "v1.0.3", + "source": { + "type": "git", + "url": "https://github.com/guzzle/uri-template.git", + "reference": "ecea8feef63bd4fef1f037ecb288386999ecc11c" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/guzzle/uri-template/zipball/ecea8feef63bd4fef1f037ecb288386999ecc11c", + "reference": "ecea8feef63bd4fef1f037ecb288386999ecc11c", + "shasum": "" + }, + "require": { + "php": "^7.2.5 || ^8.0", + "symfony/polyfill-php80": "^1.24" + }, + "require-dev": { + "bamarni/composer-bin-plugin": "^1.8.2", + "phpunit/phpunit": "^8.5.36 || ^9.6.15", + "uri-template/tests": "1.0.0" + }, + "type": "library", + "extra": { + "bamarni-bin": { + "bin-links": true, + "forward-command": false + } + }, + "autoload": { + "psr-4": { + "GuzzleHttp\\UriTemplate\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Graham Campbell", + "email": "hello@gjcampbell.co.uk", + "homepage": "https://github.com/GrahamCampbell" + }, + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + }, + { + "name": "George Mponos", + "email": "gmponos@gmail.com", + "homepage": "https://github.com/gmponos" + }, + { + "name": "Tobias Nyholm", + "email": "tobias.nyholm@gmail.com", + "homepage": "https://github.com/Nyholm" + } + ], + "description": "A polyfill class for uri_template of PHP", + "keywords": [ + "guzzlehttp", + "uri-template" + ], + "support": { + "issues": "https://github.com/guzzle/uri-template/issues", + "source": "https://github.com/guzzle/uri-template/tree/v1.0.3" + }, + "funding": [ + { + "url": "https://github.com/GrahamCampbell", + "type": "github" + }, + { + "url": "https://github.com/Nyholm", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/guzzlehttp/uri-template", + "type": "tidelift" + } + ], + "time": "2023-12-03T19:50:20+00:00" + }, + { + "name": "intervention/gif", + "version": "4.2.0", + "source": { + "type": "git", + "url": "https://github.com/Intervention/gif.git", + "reference": "42c131a31b93c440ad49061b599fa218f06f93be" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/Intervention/gif/zipball/42c131a31b93c440ad49061b599fa218f06f93be", + "reference": "42c131a31b93c440ad49061b599fa218f06f93be", + "shasum": "" + }, + "require": { + "php": "^8.1" + }, + "require-dev": { + "phpstan/phpstan": "^1", + "phpunit/phpunit": "^10.0", + "slevomat/coding-standard": "~8.0", + "squizlabs/php_codesniffer": "^3.8" + }, + "type": "library", + "autoload": { + "psr-4": { + "Intervention\\Gif\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Oliver Vogel", + "email": "oliver@intervention.io", + "homepage": "https://intervention.io/" + } + ], + "description": "Native PHP GIF Encoder/Decoder", + "homepage": "https://github.com/intervention/gif", + "keywords": [ + "animation", + "gd", + "gif", + "image" + ], + "support": { + "issues": "https://github.com/Intervention/gif/issues", + "source": "https://github.com/Intervention/gif/tree/4.2.0" + }, + "funding": [ + { + "url": "https://paypal.me/interventionio", + "type": "custom" + }, + { + "url": "https://github.com/Intervention", + "type": "github" + }, + { + "url": "https://ko-fi.com/interventionphp", + "type": "ko_fi" + } + ], + "time": "2024-09-20T13:35:02+00:00" + }, + { + "name": "intervention/image", + "version": "3.9.1", + "source": { + "type": "git", + "url": "https://github.com/Intervention/image.git", + "reference": "b496d1f6b9f812f96166623358dfcafb8c3b1683" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/Intervention/image/zipball/b496d1f6b9f812f96166623358dfcafb8c3b1683", + "reference": "b496d1f6b9f812f96166623358dfcafb8c3b1683", + "shasum": "" + }, + "require": { + "ext-mbstring": "*", + "intervention/gif": "^4.2", + "php": "^8.1" + }, + "require-dev": { + "mockery/mockery": "^1.6", + "phpstan/phpstan": "^1", + "phpunit/phpunit": "^10.0", + "slevomat/coding-standard": "~8.0", + "squizlabs/php_codesniffer": "^3.8" + }, + "suggest": { + "ext-exif": "Recommended to be able to read EXIF data properly." + }, + "type": "library", + "autoload": { + "psr-4": { + "Intervention\\Image\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Oliver Vogel", + "email": "oliver@intervention.io", + "homepage": "https://intervention.io/" + } + ], + "description": "PHP image manipulation", + "homepage": "https://image.intervention.io/", + "keywords": [ + "gd", + "image", + "imagick", + "resize", + "thumbnail", + "watermark" + ], + "support": { + "issues": "https://github.com/Intervention/image/issues", + "source": "https://github.com/Intervention/image/tree/3.9.1" + }, + "funding": [ + { + "url": "https://paypal.me/interventionio", + "type": "custom" + }, + { + "url": "https://github.com/Intervention", + "type": "github" + }, + { + "url": "https://ko-fi.com/interventionphp", + "type": "ko_fi" + } + ], + "time": "2024-10-27T10:15:54+00:00" + }, + { + "name": "kalnoy/nestedset", + "version": "v6.0.4", + "source": { + "type": "git", + "url": "https://github.com/lazychaser/laravel-nestedset.git", + "reference": "d81102c980b9962516c0fd8fda21dd916a23a3d7" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/lazychaser/laravel-nestedset/zipball/d81102c980b9962516c0fd8fda21dd916a23a3d7", + "reference": "d81102c980b9962516c0fd8fda21dd916a23a3d7", + "shasum": "" + }, + "require": { + "illuminate/database": "^7.0|^8.0|^9.0|^10.0|^11.0", + "illuminate/events": "^7.0|^8.0|^9.0|^10.0|^11.0", + "illuminate/support": "^7.0|^8.0|^9.0|^10.0|^11.0", + "php": "^7.2.5|^8.0" + }, + "require-dev": { + "phpunit/phpunit": "7.*|8.*|9.*|^10.5" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "v5.0.x-dev" + }, + "laravel": { + "providers": [ + "Kalnoy\\Nestedset\\NestedSetServiceProvider" + ] + } + }, + "autoload": { + "psr-4": { + "Kalnoy\\Nestedset\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Alexander Kalnoy", + "email": "lazychaser@gmail.com" + } + ], + "description": "Nested Set Model for Laravel 5.7 and up", + "keywords": [ + "database", + "hierarchy", + "laravel", + "nested sets", + "nsm" + ], + "support": { + "issues": "https://github.com/lazychaser/laravel-nestedset/issues", + "source": "https://github.com/lazychaser/laravel-nestedset/tree/v6.0.4" + }, + "time": "2024-04-08T06:10:42+00:00" + }, + { + "name": "laravel/framework", + "version": "v11.31.0", + "source": { + "type": "git", + "url": "https://github.com/laravel/framework.git", + "reference": "365090ed2c68244e3141cdb5e247cdf3dfba2c40" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/laravel/framework/zipball/365090ed2c68244e3141cdb5e247cdf3dfba2c40", + "reference": "365090ed2c68244e3141cdb5e247cdf3dfba2c40", + "shasum": "" + }, + "require": { + "brick/math": "^0.9.3|^0.10.2|^0.11|^0.12", + "composer-runtime-api": "^2.2", + "doctrine/inflector": "^2.0.5", + "dragonmantank/cron-expression": "^3.3.2", + "egulias/email-validator": "^3.2.1|^4.0", + "ext-ctype": "*", + "ext-filter": "*", + "ext-hash": "*", + "ext-mbstring": "*", + "ext-openssl": "*", + "ext-session": "*", + "ext-tokenizer": "*", + "fruitcake/php-cors": "^1.3", + "guzzlehttp/guzzle": "^7.8", + "guzzlehttp/uri-template": "^1.0", + "laravel/prompts": "^0.1.18|^0.2.0|^0.3.0", + "laravel/serializable-closure": "^1.3", + "league/commonmark": "^2.2.1", + "league/flysystem": "^3.8.0", + "monolog/monolog": "^3.0", + "nesbot/carbon": "^2.72.2|^3.0", + "nunomaduro/termwind": "^2.0", + "php": "^8.2", + "psr/container": "^1.1.1|^2.0.1", + "psr/log": "^1.0|^2.0|^3.0", + "psr/simple-cache": "^1.0|^2.0|^3.0", + "ramsey/uuid": "^4.7", + "symfony/console": "^7.0", + "symfony/error-handler": "^7.0", + "symfony/finder": "^7.0", + "symfony/http-foundation": "^7.0", + "symfony/http-kernel": "^7.0", + "symfony/mailer": "^7.0", + "symfony/mime": "^7.0", + "symfony/polyfill-php83": "^1.28", + "symfony/process": "^7.0", + "symfony/routing": "^7.0", + "symfony/uid": "^7.0", + "symfony/var-dumper": "^7.0", + "tijsverkoyen/css-to-inline-styles": "^2.2.5", + "vlucas/phpdotenv": "^5.4.1", + "voku/portable-ascii": "^2.0" + }, + "conflict": { + "mockery/mockery": "1.6.8", + "tightenco/collect": "<5.5.33" + }, + "provide": { + "psr/container-implementation": "1.1|2.0", + "psr/log-implementation": "1.0|2.0|3.0", + "psr/simple-cache-implementation": "1.0|2.0|3.0" + }, + "replace": { + "illuminate/auth": "self.version", + "illuminate/broadcasting": "self.version", + "illuminate/bus": "self.version", + "illuminate/cache": "self.version", + "illuminate/collections": "self.version", + "illuminate/concurrency": "self.version", + "illuminate/conditionable": "self.version", + "illuminate/config": "self.version", + "illuminate/console": "self.version", + "illuminate/container": "self.version", + "illuminate/contracts": "self.version", + "illuminate/cookie": "self.version", + "illuminate/database": "self.version", + "illuminate/encryption": "self.version", + "illuminate/events": "self.version", + "illuminate/filesystem": "self.version", + "illuminate/hashing": "self.version", + "illuminate/http": "self.version", + "illuminate/log": "self.version", + "illuminate/macroable": "self.version", + "illuminate/mail": "self.version", + "illuminate/notifications": "self.version", + "illuminate/pagination": "self.version", + "illuminate/pipeline": "self.version", + "illuminate/process": "self.version", + "illuminate/queue": "self.version", + "illuminate/redis": "self.version", + "illuminate/routing": "self.version", + "illuminate/session": "self.version", + "illuminate/support": "self.version", + "illuminate/testing": "self.version", + "illuminate/translation": "self.version", + "illuminate/validation": "self.version", + "illuminate/view": "self.version", + "spatie/once": "*" + }, + "require-dev": { + "ably/ably-php": "^1.0", + "aws/aws-sdk-php": "^3.235.5", + "ext-gmp": "*", + "fakerphp/faker": "^1.23", + "league/flysystem-aws-s3-v3": "^3.0", + "league/flysystem-ftp": "^3.0", + "league/flysystem-path-prefixing": "^3.3", + "league/flysystem-read-only": "^3.3", + "league/flysystem-sftp-v3": "^3.0", + "mockery/mockery": "^1.6", + "nyholm/psr7": "^1.2", + "orchestra/testbench-core": "^9.5", + "pda/pheanstalk": "^5.0", + "phpstan/phpstan": "^1.11.5", + "phpunit/phpunit": "^10.5|^11.0", + "predis/predis": "^2.0.2", + "resend/resend-php": "^0.10.0", + "symfony/cache": "^7.0", + "symfony/http-client": "^7.0", + "symfony/psr-http-message-bridge": "^7.0" + }, + "suggest": { + "ably/ably-php": "Required to use the Ably broadcast driver (^1.0).", + "aws/aws-sdk-php": "Required to use the SQS queue driver, DynamoDb failed job storage, and SES mail driver (^3.235.5).", + "brianium/paratest": "Required to run tests in parallel (^7.0|^8.0).", + "ext-apcu": "Required to use the APC cache driver.", + "ext-fileinfo": "Required to use the Filesystem class.", + "ext-ftp": "Required to use the Flysystem FTP driver.", + "ext-gd": "Required to use Illuminate\\Http\\Testing\\FileFactory::image().", + "ext-memcached": "Required to use the memcache cache driver.", + "ext-pcntl": "Required to use all features of the queue worker and console signal trapping.", + "ext-pdo": "Required to use all database features.", + "ext-posix": "Required to use all features of the queue worker.", + "ext-redis": "Required to use the Redis cache and queue drivers (^4.0|^5.0|^6.0).", + "fakerphp/faker": "Required to use the eloquent factory builder (^1.9.1).", + "filp/whoops": "Required for friendly error pages in development (^2.14.3).", + "laravel/tinker": "Required to use the tinker console command (^2.0).", + "league/flysystem-aws-s3-v3": "Required to use the Flysystem S3 driver (^3.0).", + "league/flysystem-ftp": "Required to use the Flysystem FTP driver (^3.0).", + "league/flysystem-path-prefixing": "Required to use the scoped driver (^3.3).", + "league/flysystem-read-only": "Required to use read-only disks (^3.3)", + "league/flysystem-sftp-v3": "Required to use the Flysystem SFTP driver (^3.0).", + "mockery/mockery": "Required to use mocking (^1.6).", + "nyholm/psr7": "Required to use PSR-7 bridging features (^1.2).", + "pda/pheanstalk": "Required to use the beanstalk queue driver (^5.0).", + "phpunit/phpunit": "Required to use assertions and run tests (^10.5|^11.0).", + "predis/predis": "Required to use the predis connector (^2.0.2).", + "psr/http-message": "Required to allow Storage::put to accept a StreamInterface (^1.0).", + "pusher/pusher-php-server": "Required to use the Pusher broadcast driver (^6.0|^7.0).", + "resend/resend-php": "Required to enable support for the Resend mail transport (^0.10.0).", + "symfony/cache": "Required to PSR-6 cache bridge (^7.0).", + "symfony/filesystem": "Required to enable support for relative symbolic links (^7.0).", + "symfony/http-client": "Required to enable support for the Symfony API mail transports (^7.0).", + "symfony/mailgun-mailer": "Required to enable support for the Mailgun mail transport (^7.0).", + "symfony/postmark-mailer": "Required to enable support for the Postmark mail transport (^7.0).", + "symfony/psr-http-message-bridge": "Required to use PSR-7 bridging features (^7.0)." + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "11.x-dev" + } + }, + "autoload": { + "files": [ + "src/Illuminate/Collections/helpers.php", + "src/Illuminate/Events/functions.php", + "src/Illuminate/Filesystem/functions.php", + "src/Illuminate/Foundation/helpers.php", + "src/Illuminate/Log/functions.php", + "src/Illuminate/Support/functions.php", + "src/Illuminate/Support/helpers.php" + ], + "psr-4": { + "Illuminate\\": "src/Illuminate/", + "Illuminate\\Support\\": [ + "src/Illuminate/Macroable/", + "src/Illuminate/Collections/", + "src/Illuminate/Conditionable/" + ] + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Taylor Otwell", + "email": "taylor@laravel.com" + } + ], + "description": "The Laravel Framework.", + "homepage": "https://laravel.com", + "keywords": [ + "framework", + "laravel" + ], + "support": { + "issues": "https://github.com/laravel/framework/issues", + "source": "https://github.com/laravel/framework" + }, + "time": "2024-11-12T15:36:15+00:00" + }, + { + "name": "laravel/prompts", + "version": "v0.3.2", + "source": { + "type": "git", + "url": "https://github.com/laravel/prompts.git", + "reference": "0e0535747c6b8d6d10adca8b68293cf4517abb0f" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/laravel/prompts/zipball/0e0535747c6b8d6d10adca8b68293cf4517abb0f", + "reference": "0e0535747c6b8d6d10adca8b68293cf4517abb0f", + "shasum": "" + }, + "require": { + "composer-runtime-api": "^2.2", + "ext-mbstring": "*", + "php": "^8.1", + "symfony/console": "^6.2|^7.0" + }, + "conflict": { + "illuminate/console": ">=10.17.0 <10.25.0", + "laravel/framework": ">=10.17.0 <10.25.0" + }, + "require-dev": { + "illuminate/collections": "^10.0|^11.0", + "mockery/mockery": "^1.5", + "pestphp/pest": "^2.3|^3.4", + "phpstan/phpstan": "^1.11", + "phpstan/phpstan-mockery": "^1.1" + }, + "suggest": { + "ext-pcntl": "Required for the spinner to be animated." + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "0.3.x-dev" + } + }, + "autoload": { + "files": [ + "src/helpers.php" + ], + "psr-4": { + "Laravel\\Prompts\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "Add beautiful and user-friendly forms to your command-line applications.", + "support": { + "issues": "https://github.com/laravel/prompts/issues", + "source": "https://github.com/laravel/prompts/tree/v0.3.2" + }, + "time": "2024-11-12T14:59:47+00:00" + }, + { + "name": "laravel/sanctum", + "version": "v4.0.3", + "source": { + "type": "git", + "url": "https://github.com/laravel/sanctum.git", + "reference": "54aea9d13743ae8a6cdd3c28dbef128a17adecab" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/laravel/sanctum/zipball/54aea9d13743ae8a6cdd3c28dbef128a17adecab", + "reference": "54aea9d13743ae8a6cdd3c28dbef128a17adecab", + "shasum": "" + }, + "require": { + "ext-json": "*", + "illuminate/console": "^11.0", + "illuminate/contracts": "^11.0", + "illuminate/database": "^11.0", + "illuminate/support": "^11.0", + "php": "^8.2", + "symfony/console": "^7.0" + }, + "require-dev": { + "mockery/mockery": "^1.6", + "orchestra/testbench": "^9.0", + "phpstan/phpstan": "^1.10", + "phpunit/phpunit": "^10.5" + }, + "type": "library", + "extra": { + "laravel": { + "providers": [ + "Laravel\\Sanctum\\SanctumServiceProvider" + ] + } + }, + "autoload": { + "psr-4": { + "Laravel\\Sanctum\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Taylor Otwell", + "email": "taylor@laravel.com" + } + ], + "description": "Laravel Sanctum provides a featherweight authentication system for SPAs and simple APIs.", + "keywords": [ + "auth", + "laravel", + "sanctum" + ], + "support": { + "issues": "https://github.com/laravel/sanctum/issues", + "source": "https://github.com/laravel/sanctum" + }, + "time": "2024-09-27T14:55:41+00:00" + }, + { + "name": "laravel/serializable-closure", + "version": "v1.3.6", + "source": { + "type": "git", + "url": "https://github.com/laravel/serializable-closure.git", + "reference": "f865a58ea3a0107c336b7045104c75243fa59d96" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/laravel/serializable-closure/zipball/f865a58ea3a0107c336b7045104c75243fa59d96", + "reference": "f865a58ea3a0107c336b7045104c75243fa59d96", + "shasum": "" + }, + "require": { + "php": "^7.3|^8.0" + }, + "require-dev": { + "illuminate/support": "^8.0|^9.0|^10.0|^11.0", + "nesbot/carbon": "^2.61|^3.0", + "pestphp/pest": "^1.21.3", + "phpstan/phpstan": "^1.8.2", + "symfony/var-dumper": "^5.4.11|^6.2.0|^7.0.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.x-dev" + } + }, + "autoload": { + "psr-4": { + "Laravel\\SerializableClosure\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Taylor Otwell", + "email": "taylor@laravel.com" + }, + { + "name": "Nuno Maduro", + "email": "nuno@laravel.com" + } + ], + "description": "Laravel Serializable Closure provides an easy and secure way to serialize closures in PHP.", + "keywords": [ + "closure", + "laravel", + "serializable" + ], + "support": { + "issues": "https://github.com/laravel/serializable-closure/issues", + "source": "https://github.com/laravel/serializable-closure" + }, + "time": "2024-11-11T17:06:04+00:00" + }, + { + "name": "laravel/tinker", + "version": "v2.10.0", + "source": { + "type": "git", + "url": "https://github.com/laravel/tinker.git", + "reference": "ba4d51eb56de7711b3a37d63aa0643e99a339ae5" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/laravel/tinker/zipball/ba4d51eb56de7711b3a37d63aa0643e99a339ae5", + "reference": "ba4d51eb56de7711b3a37d63aa0643e99a339ae5", + "shasum": "" + }, + "require": { + "illuminate/console": "^6.0|^7.0|^8.0|^9.0|^10.0|^11.0", + "illuminate/contracts": "^6.0|^7.0|^8.0|^9.0|^10.0|^11.0", + "illuminate/support": "^6.0|^7.0|^8.0|^9.0|^10.0|^11.0", + "php": "^7.2.5|^8.0", + "psy/psysh": "^0.11.1|^0.12.0", + "symfony/var-dumper": "^4.3.4|^5.0|^6.0|^7.0" + }, + "require-dev": { + "mockery/mockery": "~1.3.3|^1.4.2", + "phpstan/phpstan": "^1.10", + "phpunit/phpunit": "^8.5.8|^9.3.3" + }, + "suggest": { + "illuminate/database": "The Illuminate Database package (^6.0|^7.0|^8.0|^9.0|^10.0|^11.0)." + }, + "type": "library", + "extra": { + "laravel": { + "providers": [ + "Laravel\\Tinker\\TinkerServiceProvider" + ] + } + }, + "autoload": { + "psr-4": { + "Laravel\\Tinker\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Taylor Otwell", + "email": "taylor@laravel.com" + } + ], + "description": "Powerful REPL for the Laravel framework.", + "keywords": [ + "REPL", + "Tinker", + "laravel", + "psysh" + ], + "support": { + "issues": "https://github.com/laravel/tinker/issues", + "source": "https://github.com/laravel/tinker/tree/v2.10.0" + }, + "time": "2024-09-23T13:32:56+00:00" + }, + { + "name": "league/commonmark", + "version": "2.5.3", + "source": { + "type": "git", + "url": "https://github.com/thephpleague/commonmark.git", + "reference": "b650144166dfa7703e62a22e493b853b58d874b0" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/thephpleague/commonmark/zipball/b650144166dfa7703e62a22e493b853b58d874b0", + "reference": "b650144166dfa7703e62a22e493b853b58d874b0", + "shasum": "" + }, + "require": { + "ext-mbstring": "*", + "league/config": "^1.1.1", + "php": "^7.4 || ^8.0", + "psr/event-dispatcher": "^1.0", + "symfony/deprecation-contracts": "^2.1 || ^3.0", + "symfony/polyfill-php80": "^1.16" + }, + "require-dev": { + "cebe/markdown": "^1.0", + "commonmark/cmark": "0.31.1", + "commonmark/commonmark.js": "0.31.1", + "composer/package-versions-deprecated": "^1.8", + "embed/embed": "^4.4", + "erusev/parsedown": "^1.0", + "ext-json": "*", + "github/gfm": "0.29.0", + "michelf/php-markdown": "^1.4 || ^2.0", + "nyholm/psr7": "^1.5", + "phpstan/phpstan": "^1.8.2", + "phpunit/phpunit": "^9.5.21 || ^10.5.9 || ^11.0.0", + "scrutinizer/ocular": "^1.8.1", + "symfony/finder": "^5.3 | ^6.0 || ^7.0", + "symfony/yaml": "^2.3 | ^3.0 | ^4.0 | ^5.0 | ^6.0 || ^7.0", + "unleashedtech/php-coding-standard": "^3.1.1", + "vimeo/psalm": "^4.24.0 || ^5.0.0" + }, + "suggest": { + "symfony/yaml": "v2.3+ required if using the Front Matter extension" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "2.6-dev" + } + }, + "autoload": { + "psr-4": { + "League\\CommonMark\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Colin O'Dell", + "email": "colinodell@gmail.com", + "homepage": "https://www.colinodell.com", + "role": "Lead Developer" + } + ], + "description": "Highly-extensible PHP Markdown parser which fully supports the CommonMark spec and GitHub-Flavored Markdown (GFM)", + "homepage": "https://commonmark.thephpleague.com", + "keywords": [ + "commonmark", + "flavored", + "gfm", + "github", + "github-flavored", + "markdown", + "md", + "parser" + ], + "support": { + "docs": "https://commonmark.thephpleague.com/", + "forum": "https://github.com/thephpleague/commonmark/discussions", + "issues": "https://github.com/thephpleague/commonmark/issues", + "rss": "https://github.com/thephpleague/commonmark/releases.atom", + "source": "https://github.com/thephpleague/commonmark" + }, + "funding": [ + { + "url": "https://www.colinodell.com/sponsor", + "type": "custom" + }, + { + "url": "https://www.paypal.me/colinpodell/10.00", + "type": "custom" + }, + { + "url": "https://github.com/colinodell", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/league/commonmark", + "type": "tidelift" + } + ], + "time": "2024-08-16T11:46:16+00:00" + }, + { + "name": "league/config", + "version": "v1.2.0", + "source": { + "type": "git", + "url": "https://github.com/thephpleague/config.git", + "reference": "754b3604fb2984c71f4af4a9cbe7b57f346ec1f3" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/thephpleague/config/zipball/754b3604fb2984c71f4af4a9cbe7b57f346ec1f3", + "reference": "754b3604fb2984c71f4af4a9cbe7b57f346ec1f3", + "shasum": "" + }, + "require": { + "dflydev/dot-access-data": "^3.0.1", + "nette/schema": "^1.2", + "php": "^7.4 || ^8.0" + }, + "require-dev": { + "phpstan/phpstan": "^1.8.2", + "phpunit/phpunit": "^9.5.5", + "scrutinizer/ocular": "^1.8.1", + "unleashedtech/php-coding-standard": "^3.1", + "vimeo/psalm": "^4.7.3" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "1.2-dev" + } + }, + "autoload": { + "psr-4": { + "League\\Config\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Colin O'Dell", + "email": "colinodell@gmail.com", + "homepage": "https://www.colinodell.com", + "role": "Lead Developer" + } + ], + "description": "Define configuration arrays with strict schemas and access values with dot notation", + "homepage": "https://config.thephpleague.com", + "keywords": [ + "array", + "config", + "configuration", + "dot", + "dot-access", + "nested", + "schema" + ], + "support": { + "docs": "https://config.thephpleague.com/", + "issues": "https://github.com/thephpleague/config/issues", + "rss": "https://github.com/thephpleague/config/releases.atom", + "source": "https://github.com/thephpleague/config" + }, + "funding": [ + { + "url": "https://www.colinodell.com/sponsor", + "type": "custom" + }, + { + "url": "https://www.paypal.me/colinpodell/10.00", + "type": "custom" + }, + { + "url": "https://github.com/colinodell", + "type": "github" + } + ], + "time": "2022-12-11T20:36:23+00:00" + }, + { + "name": "league/flysystem", + "version": "3.29.1", + "source": { + "type": "git", + "url": "https://github.com/thephpleague/flysystem.git", + "reference": "edc1bb7c86fab0776c3287dbd19b5fa278347319" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/thephpleague/flysystem/zipball/edc1bb7c86fab0776c3287dbd19b5fa278347319", + "reference": "edc1bb7c86fab0776c3287dbd19b5fa278347319", + "shasum": "" + }, + "require": { + "league/flysystem-local": "^3.0.0", + "league/mime-type-detection": "^1.0.0", + "php": "^8.0.2" + }, + "conflict": { + "async-aws/core": "<1.19.0", + "async-aws/s3": "<1.14.0", + "aws/aws-sdk-php": "3.209.31 || 3.210.0", + "guzzlehttp/guzzle": "<7.0", + "guzzlehttp/ringphp": "<1.1.1", + "phpseclib/phpseclib": "3.0.15", + "symfony/http-client": "<5.2" + }, + "require-dev": { + "async-aws/s3": "^1.5 || ^2.0", + "async-aws/simple-s3": "^1.1 || ^2.0", + "aws/aws-sdk-php": "^3.295.10", + "composer/semver": "^3.0", + "ext-fileinfo": "*", + "ext-ftp": "*", + "ext-mongodb": "^1.3", + "ext-zip": "*", + "friendsofphp/php-cs-fixer": "^3.5", + "google/cloud-storage": "^1.23", + "guzzlehttp/psr7": "^2.6", + "microsoft/azure-storage-blob": "^1.1", + "mongodb/mongodb": "^1.2", + "phpseclib/phpseclib": "^3.0.36", + "phpstan/phpstan": "^1.10", + "phpunit/phpunit": "^9.5.11|^10.0", + "sabre/dav": "^4.6.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "League\\Flysystem\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Frank de Jonge", + "email": "info@frankdejonge.nl" + } + ], + "description": "File storage abstraction for PHP", + "keywords": [ + "WebDAV", + "aws", + "cloud", + "file", + "files", + "filesystem", + "filesystems", + "ftp", + "s3", + "sftp", + "storage" + ], + "support": { + "issues": "https://github.com/thephpleague/flysystem/issues", + "source": "https://github.com/thephpleague/flysystem/tree/3.29.1" + }, + "time": "2024-10-08T08:58:34+00:00" + }, + { + "name": "league/flysystem-local", + "version": "3.29.0", + "source": { + "type": "git", + "url": "https://github.com/thephpleague/flysystem-local.git", + "reference": "e0e8d52ce4b2ed154148453d321e97c8e931bd27" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/thephpleague/flysystem-local/zipball/e0e8d52ce4b2ed154148453d321e97c8e931bd27", + "reference": "e0e8d52ce4b2ed154148453d321e97c8e931bd27", + "shasum": "" + }, + "require": { + "ext-fileinfo": "*", + "league/flysystem": "^3.0.0", + "league/mime-type-detection": "^1.0.0", + "php": "^8.0.2" + }, + "type": "library", + "autoload": { + "psr-4": { + "League\\Flysystem\\Local\\": "" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Frank de Jonge", + "email": "info@frankdejonge.nl" + } + ], + "description": "Local filesystem adapter for Flysystem.", + "keywords": [ + "Flysystem", + "file", + "files", + "filesystem", + "local" + ], + "support": { + "source": "https://github.com/thephpleague/flysystem-local/tree/3.29.0" + }, + "time": "2024-08-09T21:24:39+00:00" + }, + { + "name": "league/mime-type-detection", + "version": "1.16.0", + "source": { + "type": "git", + "url": "https://github.com/thephpleague/mime-type-detection.git", + "reference": "2d6702ff215bf922936ccc1ad31007edc76451b9" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/thephpleague/mime-type-detection/zipball/2d6702ff215bf922936ccc1ad31007edc76451b9", + "reference": "2d6702ff215bf922936ccc1ad31007edc76451b9", + "shasum": "" + }, + "require": { + "ext-fileinfo": "*", + "php": "^7.4 || ^8.0" + }, + "require-dev": { + "friendsofphp/php-cs-fixer": "^3.2", + "phpstan/phpstan": "^0.12.68", + "phpunit/phpunit": "^8.5.8 || ^9.3 || ^10.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "League\\MimeTypeDetection\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Frank de Jonge", + "email": "info@frankdejonge.nl" + } + ], + "description": "Mime-type detection for Flysystem", + "support": { + "issues": "https://github.com/thephpleague/mime-type-detection/issues", + "source": "https://github.com/thephpleague/mime-type-detection/tree/1.16.0" + }, + "funding": [ + { + "url": "https://github.com/frankdejonge", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/league/flysystem", + "type": "tidelift" + } + ], + "time": "2024-09-21T08:32:55+00:00" + }, + { + "name": "maennchen/zipstream-php", + "version": "3.1.1", + "source": { + "type": "git", + "url": "https://github.com/maennchen/ZipStream-PHP.git", + "reference": "6187e9cc4493da94b9b63eb2315821552015fca9" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/maennchen/ZipStream-PHP/zipball/6187e9cc4493da94b9b63eb2315821552015fca9", + "reference": "6187e9cc4493da94b9b63eb2315821552015fca9", + "shasum": "" + }, + "require": { + "ext-mbstring": "*", + "ext-zlib": "*", + "php-64bit": "^8.1" + }, + "require-dev": { + "ext-zip": "*", + "friendsofphp/php-cs-fixer": "^3.16", + "guzzlehttp/guzzle": "^7.5", + "mikey179/vfsstream": "^1.6", + "php-coveralls/php-coveralls": "^2.5", + "phpunit/phpunit": "^10.0", + "vimeo/psalm": "^5.0" + }, + "suggest": { + "guzzlehttp/psr7": "^2.4", + "psr/http-message": "^2.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "ZipStream\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Paul Duncan", + "email": "pabs@pablotron.org" + }, + { + "name": "Jonatan Männchen", + "email": "jonatan@maennchen.ch" + }, + { + "name": "Jesse Donat", + "email": "donatj@gmail.com" + }, + { + "name": "András Kolesár", + "email": "kolesar@kolesar.hu" + } + ], + "description": "ZipStream is a library for dynamically streaming dynamic zip files from PHP without writing to the disk at all on the server.", + "keywords": [ + "stream", + "zip" + ], + "support": { + "issues": "https://github.com/maennchen/ZipStream-PHP/issues", + "source": "https://github.com/maennchen/ZipStream-PHP/tree/3.1.1" + }, + "funding": [ + { + "url": "https://github.com/maennchen", + "type": "github" + } + ], + "time": "2024-10-10T12:33:01+00:00" + }, + { + "name": "markbaker/complex", + "version": "3.0.2", + "source": { + "type": "git", + "url": "https://github.com/MarkBaker/PHPComplex.git", + "reference": "95c56caa1cf5c766ad6d65b6344b807c1e8405b9" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/MarkBaker/PHPComplex/zipball/95c56caa1cf5c766ad6d65b6344b807c1e8405b9", + "reference": "95c56caa1cf5c766ad6d65b6344b807c1e8405b9", + "shasum": "" + }, + "require": { + "php": "^7.2 || ^8.0" + }, + "require-dev": { + "dealerdirect/phpcodesniffer-composer-installer": "dev-master", + "phpcompatibility/php-compatibility": "^9.3", + "phpunit/phpunit": "^7.0 || ^8.0 || ^9.0", + "squizlabs/php_codesniffer": "^3.7" + }, + "type": "library", + "autoload": { + "psr-4": { + "Complex\\": "classes/src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Mark Baker", + "email": "mark@lange.demon.co.uk" + } + ], + "description": "PHP Class for working with complex numbers", + "homepage": "https://github.com/MarkBaker/PHPComplex", + "keywords": [ + "complex", + "mathematics" + ], + "support": { + "issues": "https://github.com/MarkBaker/PHPComplex/issues", + "source": "https://github.com/MarkBaker/PHPComplex/tree/3.0.2" + }, + "time": "2022-12-06T16:21:08+00:00" + }, + { + "name": "markbaker/matrix", + "version": "3.0.1", + "source": { + "type": "git", + "url": "https://github.com/MarkBaker/PHPMatrix.git", + "reference": "728434227fe21be27ff6d86621a1b13107a2562c" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/MarkBaker/PHPMatrix/zipball/728434227fe21be27ff6d86621a1b13107a2562c", + "reference": "728434227fe21be27ff6d86621a1b13107a2562c", + "shasum": "" + }, + "require": { + "php": "^7.1 || ^8.0" + }, + "require-dev": { + "dealerdirect/phpcodesniffer-composer-installer": "dev-master", + "phpcompatibility/php-compatibility": "^9.3", + "phpdocumentor/phpdocumentor": "2.*", + "phploc/phploc": "^4.0", + "phpmd/phpmd": "2.*", + "phpunit/phpunit": "^7.0 || ^8.0 || ^9.0", + "sebastian/phpcpd": "^4.0", + "squizlabs/php_codesniffer": "^3.7" + }, + "type": "library", + "autoload": { + "psr-4": { + "Matrix\\": "classes/src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Mark Baker", + "email": "mark@demon-angel.eu" + } + ], + "description": "PHP Class for working with matrices", + "homepage": "https://github.com/MarkBaker/PHPMatrix", + "keywords": [ + "mathematics", + "matrix", + "vector" + ], + "support": { + "issues": "https://github.com/MarkBaker/PHPMatrix/issues", + "source": "https://github.com/MarkBaker/PHPMatrix/tree/3.0.1" + }, + "time": "2022-12-02T22:17:43+00:00" + }, + { + "name": "monolog/monolog", + "version": "3.8.0", + "source": { + "type": "git", + "url": "https://github.com/Seldaek/monolog.git", + "reference": "32e515fdc02cdafbe4593e30a9350d486b125b67" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/Seldaek/monolog/zipball/32e515fdc02cdafbe4593e30a9350d486b125b67", + "reference": "32e515fdc02cdafbe4593e30a9350d486b125b67", + "shasum": "" + }, + "require": { + "php": ">=8.1", + "psr/log": "^2.0 || ^3.0" + }, + "provide": { + "psr/log-implementation": "3.0.0" + }, + "require-dev": { + "aws/aws-sdk-php": "^3.0", + "doctrine/couchdb": "~1.0@dev", + "elasticsearch/elasticsearch": "^7 || ^8", + "ext-json": "*", + "graylog2/gelf-php": "^1.4.2 || ^2.0", + "guzzlehttp/guzzle": "^7.4.5", + "guzzlehttp/psr7": "^2.2", + "mongodb/mongodb": "^1.8", + "php-amqplib/php-amqplib": "~2.4 || ^3", + "php-console/php-console": "^3.1.8", + "phpstan/phpstan": "^2", + "phpstan/phpstan-deprecation-rules": "^2", + "phpstan/phpstan-strict-rules": "^2", + "phpunit/phpunit": "^10.5.17 || ^11.0.7", + "predis/predis": "^1.1 || ^2", + "rollbar/rollbar": "^4.0", + "ruflin/elastica": "^7 || ^8", + "symfony/mailer": "^5.4 || ^6", + "symfony/mime": "^5.4 || ^6" + }, + "suggest": { + "aws/aws-sdk-php": "Allow sending log messages to AWS services like DynamoDB", + "doctrine/couchdb": "Allow sending log messages to a CouchDB server", + "elasticsearch/elasticsearch": "Allow sending log messages to an Elasticsearch server via official client", + "ext-amqp": "Allow sending log messages to an AMQP server (1.0+ required)", + "ext-curl": "Required to send log messages using the IFTTTHandler, the LogglyHandler, the SendGridHandler, the SlackWebhookHandler or the TelegramBotHandler", + "ext-mbstring": "Allow to work properly with unicode symbols", + "ext-mongodb": "Allow sending log messages to a MongoDB server (via driver)", + "ext-openssl": "Required to send log messages using SSL", + "ext-sockets": "Allow sending log messages to a Syslog server (via UDP driver)", + "graylog2/gelf-php": "Allow sending log messages to a GrayLog2 server", + "mongodb/mongodb": "Allow sending log messages to a MongoDB server (via library)", + "php-amqplib/php-amqplib": "Allow sending log messages to an AMQP server using php-amqplib", + "rollbar/rollbar": "Allow sending log messages to Rollbar", + "ruflin/elastica": "Allow sending log messages to an Elastic Search server" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.x-dev" + } + }, + "autoload": { + "psr-4": { + "Monolog\\": "src/Monolog" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Jordi Boggiano", + "email": "j.boggiano@seld.be", + "homepage": "https://seld.be" + } + ], + "description": "Sends your logs to files, sockets, inboxes, databases and various web services", + "homepage": "https://github.com/Seldaek/monolog", + "keywords": [ + "log", + "logging", + "psr-3" + ], + "support": { + "issues": "https://github.com/Seldaek/monolog/issues", + "source": "https://github.com/Seldaek/monolog/tree/3.8.0" + }, + "funding": [ + { + "url": "https://github.com/Seldaek", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/monolog/monolog", + "type": "tidelift" + } + ], + "time": "2024-11-12T13:57:08+00:00" + }, + { + "name": "nesbot/carbon", + "version": "3.8.2", + "source": { + "type": "git", + "url": "https://github.com/briannesbitt/Carbon.git", + "reference": "e1268cdbc486d97ce23fef2c666dc3c6b6de9947" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/briannesbitt/Carbon/zipball/e1268cdbc486d97ce23fef2c666dc3c6b6de9947", + "reference": "e1268cdbc486d97ce23fef2c666dc3c6b6de9947", + "shasum": "" + }, + "require": { + "carbonphp/carbon-doctrine-types": "<100.0", + "ext-json": "*", + "php": "^8.1", + "psr/clock": "^1.0", + "symfony/clock": "^6.3 || ^7.0", + "symfony/polyfill-mbstring": "^1.0", + "symfony/translation": "^4.4.18 || ^5.2.1|| ^6.0 || ^7.0" + }, + "provide": { + "psr/clock-implementation": "1.0" + }, + "require-dev": { + "doctrine/dbal": "^3.6.3 || ^4.0", + "doctrine/orm": "^2.15.2 || ^3.0", + "friendsofphp/php-cs-fixer": "^3.57.2", + "kylekatarnls/multi-tester": "^2.5.3", + "ondrejmirtes/better-reflection": "^6.25.0.4", + "phpmd/phpmd": "^2.15.0", + "phpstan/extension-installer": "^1.3.1", + "phpstan/phpstan": "^1.11.2", + "phpunit/phpunit": "^10.5.20", + "squizlabs/php_codesniffer": "^3.9.0" + }, + "bin": [ + "bin/carbon" + ], + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "3.x-dev", + "dev-2.x": "2.x-dev" + }, + "laravel": { + "providers": [ + "Carbon\\Laravel\\ServiceProvider" + ] + }, + "phpstan": { + "includes": [ + "extension.neon" + ] + } + }, + "autoload": { + "psr-4": { + "Carbon\\": "src/Carbon/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Brian Nesbitt", + "email": "brian@nesbot.com", + "homepage": "https://markido.com" + }, + { + "name": "kylekatarnls", + "homepage": "https://github.com/kylekatarnls" + } + ], + "description": "An API extension for DateTime that supports 281 different languages.", + "homepage": "https://carbon.nesbot.com", + "keywords": [ + "date", + "datetime", + "time" + ], + "support": { + "docs": "https://carbon.nesbot.com/docs", + "issues": "https://github.com/briannesbitt/Carbon/issues", + "source": "https://github.com/briannesbitt/Carbon" + }, + "funding": [ + { + "url": "https://github.com/sponsors/kylekatarnls", + "type": "github" + }, + { + "url": "https://opencollective.com/Carbon#sponsor", + "type": "opencollective" + }, + { + "url": "https://tidelift.com/subscription/pkg/packagist-nesbot-carbon?utm_source=packagist-nesbot-carbon&utm_medium=referral&utm_campaign=readme", + "type": "tidelift" + } + ], + "time": "2024-11-07T17:46:48+00:00" + }, + { + "name": "nette/schema", + "version": "v1.3.2", + "source": { + "type": "git", + "url": "https://github.com/nette/schema.git", + "reference": "da801d52f0354f70a638673c4a0f04e16529431d" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/nette/schema/zipball/da801d52f0354f70a638673c4a0f04e16529431d", + "reference": "da801d52f0354f70a638673c4a0f04e16529431d", + "shasum": "" + }, + "require": { + "nette/utils": "^4.0", + "php": "8.1 - 8.4" + }, + "require-dev": { + "nette/tester": "^2.5.2", + "phpstan/phpstan-nette": "^1.0", + "tracy/tracy": "^2.8" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.3-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause", + "GPL-2.0-only", + "GPL-3.0-only" + ], + "authors": [ + { + "name": "David Grudl", + "homepage": "https://davidgrudl.com" + }, + { + "name": "Nette Community", + "homepage": "https://nette.org/contributors" + } + ], + "description": "📐 Nette Schema: validating data structures against a given Schema.", + "homepage": "https://nette.org", + "keywords": [ + "config", + "nette" + ], + "support": { + "issues": "https://github.com/nette/schema/issues", + "source": "https://github.com/nette/schema/tree/v1.3.2" + }, + "time": "2024-10-06T23:10:23+00:00" + }, + { + "name": "nette/utils", + "version": "v4.0.5", + "source": { + "type": "git", + "url": "https://github.com/nette/utils.git", + "reference": "736c567e257dbe0fcf6ce81b4d6dbe05c6899f96" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/nette/utils/zipball/736c567e257dbe0fcf6ce81b4d6dbe05c6899f96", + "reference": "736c567e257dbe0fcf6ce81b4d6dbe05c6899f96", + "shasum": "" + }, + "require": { + "php": "8.0 - 8.4" + }, + "conflict": { + "nette/finder": "<3", + "nette/schema": "<1.2.2" + }, + "require-dev": { + "jetbrains/phpstorm-attributes": "dev-master", + "nette/tester": "^2.5", + "phpstan/phpstan": "^1.0", + "tracy/tracy": "^2.9" + }, + "suggest": { + "ext-gd": "to use Image", + "ext-iconv": "to use Strings::webalize(), toAscii(), chr() and reverse()", + "ext-intl": "to use Strings::webalize(), toAscii(), normalize() and compare()", + "ext-json": "to use Nette\\Utils\\Json", + "ext-mbstring": "to use Strings::lower() etc...", + "ext-tokenizer": "to use Nette\\Utils\\Reflection::getUseStatements()" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "4.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause", + "GPL-2.0-only", + "GPL-3.0-only" + ], + "authors": [ + { + "name": "David Grudl", + "homepage": "https://davidgrudl.com" + }, + { + "name": "Nette Community", + "homepage": "https://nette.org/contributors" + } + ], + "description": "🛠 Nette Utils: lightweight utilities for string & array manipulation, image handling, safe JSON encoding/decoding, validation, slug or strong password generating etc.", + "homepage": "https://nette.org", + "keywords": [ + "array", + "core", + "datetime", + "images", + "json", + "nette", + "paginator", + "password", + "slugify", + "string", + "unicode", + "utf-8", + "utility", + "validation" + ], + "support": { + "issues": "https://github.com/nette/utils/issues", + "source": "https://github.com/nette/utils/tree/v4.0.5" + }, + "time": "2024-08-07T15:39:19+00:00" + }, + { + "name": "nikic/php-parser", + "version": "v5.3.1", + "source": { + "type": "git", + "url": "https://github.com/nikic/PHP-Parser.git", + "reference": "8eea230464783aa9671db8eea6f8c6ac5285794b" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/nikic/PHP-Parser/zipball/8eea230464783aa9671db8eea6f8c6ac5285794b", + "reference": "8eea230464783aa9671db8eea6f8c6ac5285794b", + "shasum": "" + }, + "require": { + "ext-ctype": "*", + "ext-json": "*", + "ext-tokenizer": "*", + "php": ">=7.4" + }, + "require-dev": { + "ircmaxell/php-yacc": "^0.0.7", + "phpunit/phpunit": "^9.0" + }, + "bin": [ + "bin/php-parse" + ], + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "5.0-dev" + } + }, + "autoload": { + "psr-4": { + "PhpParser\\": "lib/PhpParser" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Nikita Popov" + } + ], + "description": "A PHP parser written in PHP", + "keywords": [ + "parser", + "php" + ], + "support": { + "issues": "https://github.com/nikic/PHP-Parser/issues", + "source": "https://github.com/nikic/PHP-Parser/tree/v5.3.1" + }, + "time": "2024-10-08T18:51:32+00:00" + }, + { + "name": "nunomaduro/termwind", + "version": "v2.2.0", + "source": { + "type": "git", + "url": "https://github.com/nunomaduro/termwind.git", + "reference": "42c84e4e8090766bbd6445d06cd6e57650626ea3" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/nunomaduro/termwind/zipball/42c84e4e8090766bbd6445d06cd6e57650626ea3", + "reference": "42c84e4e8090766bbd6445d06cd6e57650626ea3", + "shasum": "" + }, + "require": { + "ext-mbstring": "*", + "php": "^8.2", + "symfony/console": "^7.1.5" + }, + "require-dev": { + "illuminate/console": "^11.28.0", + "laravel/pint": "^1.18.1", + "mockery/mockery": "^1.6.12", + "pestphp/pest": "^2.36.0", + "phpstan/phpstan": "^1.12.6", + "phpstan/phpstan-strict-rules": "^1.6.1", + "symfony/var-dumper": "^7.1.5", + "thecodingmachine/phpstan-strict-rules": "^1.0.0" + }, + "type": "library", + "extra": { + "laravel": { + "providers": [ + "Termwind\\Laravel\\TermwindServiceProvider" + ] + }, + "branch-alias": { + "dev-2.x": "2.x-dev" + } + }, + "autoload": { + "files": [ + "src/Functions.php" + ], + "psr-4": { + "Termwind\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nuno Maduro", + "email": "enunomaduro@gmail.com" + } + ], + "description": "Its like Tailwind CSS, but for the console.", + "keywords": [ + "cli", + "console", + "css", + "package", + "php", + "style" + ], + "support": { + "issues": "https://github.com/nunomaduro/termwind/issues", + "source": "https://github.com/nunomaduro/termwind/tree/v2.2.0" + }, + "funding": [ + { + "url": "https://www.paypal.com/paypalme/enunomaduro", + "type": "custom" + }, + { + "url": "https://github.com/nunomaduro", + "type": "github" + }, + { + "url": "https://github.com/xiCO2k", + "type": "github" + } + ], + "time": "2024-10-15T16:15:16+00:00" + }, + { + "name": "nyholm/psr7", + "version": "1.8.2", + "source": { + "type": "git", + "url": "https://github.com/Nyholm/psr7.git", + "reference": "a71f2b11690f4b24d099d6b16690a90ae14fc6f3" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/Nyholm/psr7/zipball/a71f2b11690f4b24d099d6b16690a90ae14fc6f3", + "reference": "a71f2b11690f4b24d099d6b16690a90ae14fc6f3", + "shasum": "" + }, + "require": { + "php": ">=7.2", + "psr/http-factory": "^1.0", + "psr/http-message": "^1.1 || ^2.0" + }, + "provide": { + "php-http/message-factory-implementation": "1.0", + "psr/http-factory-implementation": "1.0", + "psr/http-message-implementation": "1.0" + }, + "require-dev": { + "http-interop/http-factory-tests": "^0.9", + "php-http/message-factory": "^1.0", + "php-http/psr7-integration-tests": "^1.0", + "phpunit/phpunit": "^7.5 || ^8.5 || ^9.4", + "symfony/error-handler": "^4.4" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.8-dev" + } + }, + "autoload": { + "psr-4": { + "Nyholm\\Psr7\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Tobias Nyholm", + "email": "tobias.nyholm@gmail.com" + }, + { + "name": "Martijn van der Ven", + "email": "martijn@vanderven.se" + } + ], + "description": "A fast PHP7 implementation of PSR-7", + "homepage": "https://tnyholm.se", + "keywords": [ + "psr-17", + "psr-7" + ], + "support": { + "issues": "https://github.com/Nyholm/psr7/issues", + "source": "https://github.com/Nyholm/psr7/tree/1.8.2" + }, + "funding": [ + { + "url": "https://github.com/Zegnat", + "type": "github" + }, + { + "url": "https://github.com/nyholm", + "type": "github" + } + ], + "time": "2024-09-09T07:06:30+00:00" + }, + { + "name": "nyholm/psr7-server", + "version": "1.1.0", + "source": { + "type": "git", + "url": "https://github.com/Nyholm/psr7-server.git", + "reference": "4335801d851f554ca43fa6e7d2602141538854dc" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/Nyholm/psr7-server/zipball/4335801d851f554ca43fa6e7d2602141538854dc", + "reference": "4335801d851f554ca43fa6e7d2602141538854dc", + "shasum": "" + }, + "require": { + "php": "^7.1 || ^8.0", + "psr/http-factory": "^1.0", + "psr/http-message": "^1.0 || ^2.0" + }, + "require-dev": { + "nyholm/nsa": "^1.1", + "nyholm/psr7": "^1.3", + "phpunit/phpunit": "^7.0 || ^8.5 || ^9.3" + }, + "type": "library", + "autoload": { + "psr-4": { + "Nyholm\\Psr7Server\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Tobias Nyholm", + "email": "tobias.nyholm@gmail.com" + }, + { + "name": "Martijn van der Ven", + "email": "martijn@vanderven.se" + } + ], + "description": "Helper classes to handle PSR-7 server requests", + "homepage": "http://tnyholm.se", + "keywords": [ + "psr-17", + "psr-7" + ], + "support": { + "issues": "https://github.com/Nyholm/psr7-server/issues", + "source": "https://github.com/Nyholm/psr7-server/tree/1.1.0" + }, + "funding": [ + { + "url": "https://github.com/Zegnat", + "type": "github" + }, + { + "url": "https://github.com/nyholm", + "type": "github" + } + ], + "time": "2023-11-08T09:30:43+00:00" + }, + { + "name": "overtrue/socialite", + "version": "4.11.2", + "source": { + "type": "git", + "url": "https://github.com/overtrue/socialite.git", + "reference": "83dd537a88b30cd9204ee2c46a5b2e181bc1fa66" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/overtrue/socialite/zipball/83dd537a88b30cd9204ee2c46a5b2e181bc1fa66", + "reference": "83dd537a88b30cd9204ee2c46a5b2e181bc1fa66", + "shasum": "" + }, + "require": { + "ext-json": "*", + "ext-openssl": "*", + "guzzlehttp/guzzle": "^7.0", + "php": ">=8.0.2" + }, + "require-dev": { + "jetbrains/phpstorm-attributes": "^1.0", + "laravel/pint": "^1.2", + "mockery/mockery": "^1.3", + "phpstan/phpstan": "^1.7", + "phpunit/phpunit": "^11.3" + }, + "type": "library", + "autoload": { + "files": [ + "src/Contracts/FactoryInterface.php", + "src/Contracts/UserInterface.php", + "src/Contracts/ProviderInterface.php" + ], + "psr-4": { + "Overtrue\\Socialite\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "overtrue", + "email": "anzhengchao@gmail.com" + } + ], + "description": "A collection of OAuth 2 packages.", + "keywords": [ + "Feishu", + "login", + "oauth", + "qcloud", + "qq", + "social", + "wechat", + "weibo" + ], + "support": { + "issues": "https://github.com/overtrue/socialite/issues", + "source": "https://github.com/overtrue/socialite/tree/4.11.2" + }, + "funding": [ + { + "url": "https://github.com/overtrue", + "type": "github" + } + ], + "time": "2024-10-08T16:23:14+00:00" + }, + { + "name": "phpoffice/phpspreadsheet", + "version": "2.3.2", + "source": { + "type": "git", + "url": "https://github.com/PHPOffice/PhpSpreadsheet.git", + "reference": "08d4e08cf0c7e6182750cef7958b860b8c7f10ad" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/PHPOffice/PhpSpreadsheet/zipball/08d4e08cf0c7e6182750cef7958b860b8c7f10ad", + "reference": "08d4e08cf0c7e6182750cef7958b860b8c7f10ad", + "shasum": "" + }, + "require": { + "ext-ctype": "*", + "ext-dom": "*", + "ext-fileinfo": "*", + "ext-gd": "*", + "ext-iconv": "*", + "ext-libxml": "*", + "ext-mbstring": "*", + "ext-simplexml": "*", + "ext-xml": "*", + "ext-xmlreader": "*", + "ext-xmlwriter": "*", + "ext-zip": "*", + "ext-zlib": "*", + "maennchen/zipstream-php": "^2.1 || ^3.0", + "markbaker/complex": "^3.0", + "markbaker/matrix": "^3.0", + "php": "^8.1", + "psr/http-client": "^1.0", + "psr/http-factory": "^1.0", + "psr/simple-cache": "^1.0 || ^2.0 || ^3.0" + }, + "require-dev": { + "dealerdirect/phpcodesniffer-composer-installer": "dev-main", + "dompdf/dompdf": "^2.0 || ^3.0", + "friendsofphp/php-cs-fixer": "^3.2", + "mitoteam/jpgraph": "^10.3", + "mpdf/mpdf": "^8.1.1", + "phpcompatibility/php-compatibility": "^9.3", + "phpstan/phpstan": "^1.1", + "phpstan/phpstan-phpunit": "^1.0", + "phpunit/phpunit": "^9.6 || ^10.5", + "squizlabs/php_codesniffer": "^3.7", + "tecnickcom/tcpdf": "^6.5" + }, + "suggest": { + "dompdf/dompdf": "Option for rendering PDF with PDF Writer", + "ext-intl": "PHP Internationalization Functions", + "mitoteam/jpgraph": "Option for rendering charts, or including charts with PDF or HTML Writers", + "mpdf/mpdf": "Option for rendering PDF with PDF Writer", + "tecnickcom/tcpdf": "Option for rendering PDF with PDF Writer" + }, + "type": "library", + "autoload": { + "psr-4": { + "PhpOffice\\PhpSpreadsheet\\": "src/PhpSpreadsheet" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Maarten Balliauw", + "homepage": "https://blog.maartenballiauw.be" + }, + { + "name": "Mark Baker", + "homepage": "https://markbakeruk.net" + }, + { + "name": "Franck Lefevre", + "homepage": "https://rootslabs.net" + }, + { + "name": "Erik Tilt" + }, + { + "name": "Adrien Crivelli" + } + ], + "description": "PHPSpreadsheet - Read, Create and Write Spreadsheet documents in PHP - Spreadsheet engine", + "homepage": "https://github.com/PHPOffice/PhpSpreadsheet", + "keywords": [ + "OpenXML", + "excel", + "gnumeric", + "ods", + "php", + "spreadsheet", + "xls", + "xlsx" + ], + "support": { + "issues": "https://github.com/PHPOffice/PhpSpreadsheet/issues", + "source": "https://github.com/PHPOffice/PhpSpreadsheet/tree/2.3.2" + }, + "time": "2024-11-10T09:35:47+00:00" + }, + { + "name": "phpoption/phpoption", + "version": "1.9.3", + "source": { + "type": "git", + "url": "https://github.com/schmittjoh/php-option.git", + "reference": "e3fac8b24f56113f7cb96af14958c0dd16330f54" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/schmittjoh/php-option/zipball/e3fac8b24f56113f7cb96af14958c0dd16330f54", + "reference": "e3fac8b24f56113f7cb96af14958c0dd16330f54", + "shasum": "" + }, + "require": { + "php": "^7.2.5 || ^8.0" + }, + "require-dev": { + "bamarni/composer-bin-plugin": "^1.8.2", + "phpunit/phpunit": "^8.5.39 || ^9.6.20 || ^10.5.28" + }, + "type": "library", + "extra": { + "bamarni-bin": { + "bin-links": true, + "forward-command": false + }, + "branch-alias": { + "dev-master": "1.9-dev" + } + }, + "autoload": { + "psr-4": { + "PhpOption\\": "src/PhpOption/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "Johannes M. Schmitt", + "email": "schmittjoh@gmail.com", + "homepage": "https://github.com/schmittjoh" + }, + { + "name": "Graham Campbell", + "email": "hello@gjcampbell.co.uk", + "homepage": "https://github.com/GrahamCampbell" + } + ], + "description": "Option Type for PHP", + "keywords": [ + "language", + "option", + "php", + "type" + ], + "support": { + "issues": "https://github.com/schmittjoh/php-option/issues", + "source": "https://github.com/schmittjoh/php-option/tree/1.9.3" + }, + "funding": [ + { + "url": "https://github.com/GrahamCampbell", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/phpoption/phpoption", + "type": "tidelift" + } + ], + "time": "2024-07-20T21:41:07+00:00" + }, + { + "name": "prettus/l5-repository", + "version": "2.9.1", + "source": { + "type": "git", + "url": "https://github.com/andersao/l5-repository.git", + "reference": "105115badd9ee3e12d2d9368c9392f47cb5d14a8" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/andersao/l5-repository/zipball/105115badd9ee3e12d2d9368c9392f47cb5d14a8", + "reference": "105115badd9ee3e12d2d9368c9392f47cb5d14a8", + "shasum": "" + }, + "require": { + "illuminate/config": "~5.0|~6.0|~7.0|^8.0|^9.0|^10.0|^11.0", + "illuminate/console": "~5.0|~6.0|~7.0|^8.0|^9.0|^10.0|^11.0", + "illuminate/database": "~5.0|~6.0|~7.0|^8.0|^9.0|^10.0|^11.0", + "illuminate/filesystem": "~5.0|~6.0|~7.0|^8.0|^9.0|^10.0|^11.0", + "illuminate/http": "~5.0|~6.0|~7.0|^8.0|^9.0|^10.0|^11.0", + "illuminate/pagination": "~5.0|~6.0|~7.0|^8.0|^9.0|^10.0|^11.0", + "illuminate/support": "~5.0|~6.0|~7.0|^8.0|^9.0|^10.0|^11.0", + "illuminate/validation": "~5.0|~6.0|~7.0|^8.0|^9.0|^10.0|^11.0", + "prettus/laravel-validation": "~1.1|~1.2|~1.3|~1.4|~1.5|~1.6" + }, + "suggest": { + "league/fractal": "Required to use the Fractal Presenter (0.12.*).", + "prettus/laravel-validation": "Required to provide easy validation with the repository (1.1.*)", + "robclancy/presenter": "Required to use the Presenter Model (1.3.*)" + }, + "type": "library", + "extra": { + "laravel": { + "providers": [ + "Prettus\\Repository\\Providers\\RepositoryServiceProvider" + ] + } + }, + "autoload": { + "psr-4": { + "Prettus\\Repository\\": "src/Prettus/Repository/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Anderson Andrade", + "email": "contato@andersonandra.de", + "homepage": "http://andersonandra.de", + "role": "Developer" + } + ], + "description": "Laravel 5|6|7|8|9|10|11 - Repositories to the database layer", + "homepage": "http://andersao.github.io/l5-repository", + "keywords": [ + "cache", + "eloquent", + "laravel", + "model", + "repository" + ], + "support": { + "docs": "http://andersao.github.io/l5-repository", + "email": "contato@andersonandra.de", + "issues": "https://github.com/andersao/l5-repository/issues", + "source": "https://github.com/andersao/l5-repository", + "wiki": "https://github.com/andersao/l5-repository" + }, + "time": "2024-05-06T14:42:53+00:00" + }, + { + "name": "prettus/laravel-validation", + "version": "1.6.0", + "source": { + "type": "git", + "url": "https://github.com/andersao/laravel-validator.git", + "reference": "d990a2cce135bcfced8db7cfff827cd9055740b2" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/andersao/laravel-validator/zipball/d990a2cce135bcfced8db7cfff827cd9055740b2", + "reference": "d990a2cce135bcfced8db7cfff827cd9055740b2", + "shasum": "" + }, + "require": { + "illuminate/support": "~5.4|^6.0|^7.0|^8.0|^9.0|^10.0|^11.0", + "illuminate/validation": "~5.4|^6.0|^7.0|^8.0|^9.0|^10.0|^11.0", + "php": ">=5.4.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Prettus\\Validator\\": "src/Prettus/Validator/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "authors": [ + { + "name": "Anderson Andrade", + "email": "contato@andersonandra.de", + "homepage": "http://andersonandra.de", + "role": "Developer" + } + ], + "description": "Laravel Validation Service", + "homepage": "http://andersao.github.io/laravel-validation", + "keywords": [ + "laravel", + "service", + "validation" + ], + "support": { + "docs": "http://andersao.github.io/laravel-validation", + "email": "contato@andersonandra.de", + "issues": "https://github.com/andersao/laravel-validation/issues", + "source": "https://github.com/andersao/laravel-validation", + "wiki": "https://github.com/andersao/laravel-validation" + }, + "time": "2024-05-05T23:33:47+00:00" + }, + { + "name": "psr/cache", + "version": "3.0.0", + "source": { + "type": "git", + "url": "https://github.com/php-fig/cache.git", + "reference": "aa5030cfa5405eccfdcb1083ce040c2cb8d253bf" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/cache/zipball/aa5030cfa5405eccfdcb1083ce040c2cb8d253bf", + "reference": "aa5030cfa5405eccfdcb1083ce040c2cb8d253bf", + "shasum": "" + }, + "require": { + "php": ">=8.0.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, + "autoload": { + "psr-4": { + "Psr\\Cache\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "Common interface for caching libraries", + "keywords": [ + "cache", + "psr", + "psr-6" + ], + "support": { + "source": "https://github.com/php-fig/cache/tree/3.0.0" + }, + "time": "2021-02-03T23:26:27+00:00" + }, + { + "name": "psr/clock", + "version": "1.0.0", + "source": { + "type": "git", + "url": "https://github.com/php-fig/clock.git", + "reference": "e41a24703d4560fd0acb709162f73b8adfc3aa0d" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/clock/zipball/e41a24703d4560fd0acb709162f73b8adfc3aa0d", + "reference": "e41a24703d4560fd0acb709162f73b8adfc3aa0d", + "shasum": "" + }, + "require": { + "php": "^7.0 || ^8.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Psr\\Clock\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "Common interface for reading the clock.", + "homepage": "https://github.com/php-fig/clock", + "keywords": [ + "clock", + "now", + "psr", + "psr-20", + "time" + ], + "support": { + "issues": "https://github.com/php-fig/clock/issues", + "source": "https://github.com/php-fig/clock/tree/1.0.0" + }, + "time": "2022-11-25T14:36:26+00:00" + }, + { + "name": "psr/container", + "version": "2.0.2", + "source": { + "type": "git", + "url": "https://github.com/php-fig/container.git", + "reference": "c71ecc56dfe541dbd90c5360474fbc405f8d5963" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/container/zipball/c71ecc56dfe541dbd90c5360474fbc405f8d5963", + "reference": "c71ecc56dfe541dbd90c5360474fbc405f8d5963", + "shasum": "" + }, + "require": { + "php": ">=7.4.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.0.x-dev" + } + }, + "autoload": { + "psr-4": { + "Psr\\Container\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "Common Container Interface (PHP FIG PSR-11)", + "homepage": "https://github.com/php-fig/container", + "keywords": [ + "PSR-11", + "container", + "container-interface", + "container-interop", + "psr" + ], + "support": { + "issues": "https://github.com/php-fig/container/issues", + "source": "https://github.com/php-fig/container/tree/2.0.2" + }, + "time": "2021-11-05T16:47:00+00:00" + }, + { + "name": "psr/event-dispatcher", + "version": "1.0.0", + "source": { + "type": "git", + "url": "https://github.com/php-fig/event-dispatcher.git", + "reference": "dbefd12671e8a14ec7f180cab83036ed26714bb0" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/event-dispatcher/zipball/dbefd12671e8a14ec7f180cab83036ed26714bb0", + "reference": "dbefd12671e8a14ec7f180cab83036ed26714bb0", + "shasum": "" + }, + "require": { + "php": ">=7.2.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, + "autoload": { + "psr-4": { + "Psr\\EventDispatcher\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "http://www.php-fig.org/" + } + ], + "description": "Standard interfaces for event handling.", + "keywords": [ + "events", + "psr", + "psr-14" + ], + "support": { + "issues": "https://github.com/php-fig/event-dispatcher/issues", + "source": "https://github.com/php-fig/event-dispatcher/tree/1.0.0" + }, + "time": "2019-01-08T18:20:26+00:00" + }, + { + "name": "psr/http-client", + "version": "1.0.3", + "source": { + "type": "git", + "url": "https://github.com/php-fig/http-client.git", + "reference": "bb5906edc1c324c9a05aa0873d40117941e5fa90" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/http-client/zipball/bb5906edc1c324c9a05aa0873d40117941e5fa90", + "reference": "bb5906edc1c324c9a05aa0873d40117941e5fa90", + "shasum": "" + }, + "require": { + "php": "^7.0 || ^8.0", + "psr/http-message": "^1.0 || ^2.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, + "autoload": { + "psr-4": { + "Psr\\Http\\Client\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "Common interface for HTTP clients", + "homepage": "https://github.com/php-fig/http-client", + "keywords": [ + "http", + "http-client", + "psr", + "psr-18" + ], + "support": { + "source": "https://github.com/php-fig/http-client" + }, + "time": "2023-09-23T14:17:50+00:00" + }, + { + "name": "psr/http-factory", + "version": "1.1.0", + "source": { + "type": "git", + "url": "https://github.com/php-fig/http-factory.git", + "reference": "2b4765fddfe3b508ac62f829e852b1501d3f6e8a" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/http-factory/zipball/2b4765fddfe3b508ac62f829e852b1501d3f6e8a", + "reference": "2b4765fddfe3b508ac62f829e852b1501d3f6e8a", + "shasum": "" + }, + "require": { + "php": ">=7.1", + "psr/http-message": "^1.0 || ^2.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, + "autoload": { + "psr-4": { + "Psr\\Http\\Message\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "PSR-17: Common interfaces for PSR-7 HTTP message factories", + "keywords": [ + "factory", + "http", + "message", + "psr", + "psr-17", + "psr-7", + "request", + "response" + ], + "support": { + "source": "https://github.com/php-fig/http-factory" + }, + "time": "2024-04-15T12:06:14+00:00" + }, + { + "name": "psr/http-message", + "version": "2.0", + "source": { + "type": "git", + "url": "https://github.com/php-fig/http-message.git", + "reference": "402d35bcb92c70c026d1a6a9883f06b2ead23d71" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/http-message/zipball/402d35bcb92c70c026d1a6a9883f06b2ead23d71", + "reference": "402d35bcb92c70c026d1a6a9883f06b2ead23d71", + "shasum": "" + }, + "require": { + "php": "^7.2 || ^8.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.0.x-dev" + } + }, + "autoload": { + "psr-4": { + "Psr\\Http\\Message\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "Common interface for HTTP messages", + "homepage": "https://github.com/php-fig/http-message", + "keywords": [ + "http", + "http-message", + "psr", + "psr-7", + "request", + "response" + ], + "support": { + "source": "https://github.com/php-fig/http-message/tree/2.0" + }, + "time": "2023-04-04T09:54:51+00:00" + }, + { + "name": "psr/log", + "version": "3.0.2", + "source": { + "type": "git", + "url": "https://github.com/php-fig/log.git", + "reference": "f16e1d5863e37f8d8c2a01719f5b34baa2b714d3" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/log/zipball/f16e1d5863e37f8d8c2a01719f5b34baa2b714d3", + "reference": "f16e1d5863e37f8d8c2a01719f5b34baa2b714d3", + "shasum": "" + }, + "require": { + "php": ">=8.0.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "3.x-dev" + } + }, + "autoload": { + "psr-4": { + "Psr\\Log\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "Common interface for logging libraries", + "homepage": "https://github.com/php-fig/log", + "keywords": [ + "log", + "psr", + "psr-3" + ], + "support": { + "source": "https://github.com/php-fig/log/tree/3.0.2" + }, + "time": "2024-09-11T13:17:53+00:00" + }, + { + "name": "psr/simple-cache", + "version": "3.0.0", + "source": { + "type": "git", + "url": "https://github.com/php-fig/simple-cache.git", + "reference": "764e0b3939f5ca87cb904f570ef9be2d78a07865" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/simple-cache/zipball/764e0b3939f5ca87cb904f570ef9be2d78a07865", + "reference": "764e0b3939f5ca87cb904f570ef9be2d78a07865", + "shasum": "" + }, + "require": { + "php": ">=8.0.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "3.0.x-dev" + } + }, + "autoload": { + "psr-4": { + "Psr\\SimpleCache\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "Common interfaces for simple caching", + "keywords": [ + "cache", + "caching", + "psr", + "psr-16", + "simple-cache" + ], + "support": { + "source": "https://github.com/php-fig/simple-cache/tree/3.0.0" + }, + "time": "2021-10-29T13:26:27+00:00" + }, + { + "name": "psy/psysh", + "version": "v0.12.4", + "source": { + "type": "git", + "url": "https://github.com/bobthecow/psysh.git", + "reference": "2fd717afa05341b4f8152547f142cd2f130f6818" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/bobthecow/psysh/zipball/2fd717afa05341b4f8152547f142cd2f130f6818", + "reference": "2fd717afa05341b4f8152547f142cd2f130f6818", + "shasum": "" + }, + "require": { + "ext-json": "*", + "ext-tokenizer": "*", + "nikic/php-parser": "^5.0 || ^4.0", + "php": "^8.0 || ^7.4", + "symfony/console": "^7.0 || ^6.0 || ^5.0 || ^4.0 || ^3.4", + "symfony/var-dumper": "^7.0 || ^6.0 || ^5.0 || ^4.0 || ^3.4" + }, + "conflict": { + "symfony/console": "4.4.37 || 5.3.14 || 5.3.15 || 5.4.3 || 5.4.4 || 6.0.3 || 6.0.4" + }, + "require-dev": { + "bamarni/composer-bin-plugin": "^1.2" + }, + "suggest": { + "ext-pcntl": "Enabling the PCNTL extension makes PsySH a lot happier :)", + "ext-pdo-sqlite": "The doc command requires SQLite to work.", + "ext-posix": "If you have PCNTL, you'll want the POSIX extension as well." + }, + "bin": [ + "bin/psysh" + ], + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "0.12.x-dev" + }, + "bamarni-bin": { + "bin-links": false, + "forward-command": false + } + }, + "autoload": { + "files": [ + "src/functions.php" + ], + "psr-4": { + "Psy\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Justin Hileman", + "email": "justin@justinhileman.info", + "homepage": "http://justinhileman.com" + } + ], + "description": "An interactive shell for modern PHP.", + "homepage": "http://psysh.org", + "keywords": [ + "REPL", + "console", + "interactive", + "shell" + ], + "support": { + "issues": "https://github.com/bobthecow/psysh/issues", + "source": "https://github.com/bobthecow/psysh/tree/v0.12.4" + }, + "time": "2024-06-10T01:18:23+00:00" + }, + { + "name": "ralouphie/getallheaders", + "version": "3.0.3", + "source": { + "type": "git", + "url": "https://github.com/ralouphie/getallheaders.git", + "reference": "120b605dfeb996808c31b6477290a714d356e822" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/ralouphie/getallheaders/zipball/120b605dfeb996808c31b6477290a714d356e822", + "reference": "120b605dfeb996808c31b6477290a714d356e822", + "shasum": "" + }, + "require": { + "php": ">=5.6" + }, + "require-dev": { + "php-coveralls/php-coveralls": "^2.1", + "phpunit/phpunit": "^5 || ^6.5" + }, + "type": "library", + "autoload": { + "files": [ + "src/getallheaders.php" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Ralph Khattar", + "email": "ralph.khattar@gmail.com" + } + ], + "description": "A polyfill for getallheaders.", + "support": { + "issues": "https://github.com/ralouphie/getallheaders/issues", + "source": "https://github.com/ralouphie/getallheaders/tree/develop" + }, + "time": "2019-03-08T08:55:37+00:00" + }, + { + "name": "ramsey/collection", + "version": "2.0.0", + "source": { + "type": "git", + "url": "https://github.com/ramsey/collection.git", + "reference": "a4b48764bfbb8f3a6a4d1aeb1a35bb5e9ecac4a5" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/ramsey/collection/zipball/a4b48764bfbb8f3a6a4d1aeb1a35bb5e9ecac4a5", + "reference": "a4b48764bfbb8f3a6a4d1aeb1a35bb5e9ecac4a5", + "shasum": "" + }, + "require": { + "php": "^8.1" + }, + "require-dev": { + "captainhook/plugin-composer": "^5.3", + "ergebnis/composer-normalize": "^2.28.3", + "fakerphp/faker": "^1.21", + "hamcrest/hamcrest-php": "^2.0", + "jangregor/phpstan-prophecy": "^1.0", + "mockery/mockery": "^1.5", + "php-parallel-lint/php-console-highlighter": "^1.0", + "php-parallel-lint/php-parallel-lint": "^1.3", + "phpcsstandards/phpcsutils": "^1.0.0-rc1", + "phpspec/prophecy-phpunit": "^2.0", + "phpstan/extension-installer": "^1.2", + "phpstan/phpstan": "^1.9", + "phpstan/phpstan-mockery": "^1.1", + "phpstan/phpstan-phpunit": "^1.3", + "phpunit/phpunit": "^9.5", + "psalm/plugin-mockery": "^1.1", + "psalm/plugin-phpunit": "^0.18.4", + "ramsey/coding-standard": "^2.0.3", + "ramsey/conventional-commits": "^1.3", + "vimeo/psalm": "^5.4" + }, + "type": "library", + "extra": { + "captainhook": { + "force-install": true + }, + "ramsey/conventional-commits": { + "configFile": "conventional-commits.json" + } + }, + "autoload": { + "psr-4": { + "Ramsey\\Collection\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Ben Ramsey", + "email": "ben@benramsey.com", + "homepage": "https://benramsey.com" + } + ], + "description": "A PHP library for representing and manipulating collections.", + "keywords": [ + "array", + "collection", + "hash", + "map", + "queue", + "set" + ], + "support": { + "issues": "https://github.com/ramsey/collection/issues", + "source": "https://github.com/ramsey/collection/tree/2.0.0" + }, + "funding": [ + { + "url": "https://github.com/ramsey", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/ramsey/collection", + "type": "tidelift" + } + ], + "time": "2022-12-31T21:50:55+00:00" + }, + { + "name": "ramsey/uuid", + "version": "4.7.6", + "source": { + "type": "git", + "url": "https://github.com/ramsey/uuid.git", + "reference": "91039bc1faa45ba123c4328958e620d382ec7088" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/ramsey/uuid/zipball/91039bc1faa45ba123c4328958e620d382ec7088", + "reference": "91039bc1faa45ba123c4328958e620d382ec7088", + "shasum": "" + }, + "require": { + "brick/math": "^0.8.8 || ^0.9 || ^0.10 || ^0.11 || ^0.12", + "ext-json": "*", + "php": "^8.0", + "ramsey/collection": "^1.2 || ^2.0" + }, + "replace": { + "rhumsaa/uuid": "self.version" + }, + "require-dev": { + "captainhook/captainhook": "^5.10", + "captainhook/plugin-composer": "^5.3", + "dealerdirect/phpcodesniffer-composer-installer": "^0.7.0", + "doctrine/annotations": "^1.8", + "ergebnis/composer-normalize": "^2.15", + "mockery/mockery": "^1.3", + "paragonie/random-lib": "^2", + "php-mock/php-mock": "^2.2", + "php-mock/php-mock-mockery": "^1.3", + "php-parallel-lint/php-parallel-lint": "^1.1", + "phpbench/phpbench": "^1.0", + "phpstan/extension-installer": "^1.1", + "phpstan/phpstan": "^1.8", + "phpstan/phpstan-mockery": "^1.1", + "phpstan/phpstan-phpunit": "^1.1", + "phpunit/phpunit": "^8.5 || ^9", + "ramsey/composer-repl": "^1.4", + "slevomat/coding-standard": "^8.4", + "squizlabs/php_codesniffer": "^3.5", + "vimeo/psalm": "^4.9" + }, + "suggest": { + "ext-bcmath": "Enables faster math with arbitrary-precision integers using BCMath.", + "ext-gmp": "Enables faster math with arbitrary-precision integers using GMP.", + "ext-uuid": "Enables the use of PeclUuidTimeGenerator and PeclUuidRandomGenerator.", + "paragonie/random-lib": "Provides RandomLib for use with the RandomLibAdapter", + "ramsey/uuid-doctrine": "Allows the use of Ramsey\\Uuid\\Uuid as Doctrine field type." + }, + "type": "library", + "extra": { + "captainhook": { + "force-install": true + } + }, + "autoload": { + "files": [ + "src/functions.php" + ], + "psr-4": { + "Ramsey\\Uuid\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "A PHP library for generating and working with universally unique identifiers (UUIDs).", + "keywords": [ + "guid", + "identifier", + "uuid" + ], + "support": { + "issues": "https://github.com/ramsey/uuid/issues", + "source": "https://github.com/ramsey/uuid/tree/4.7.6" + }, + "funding": [ + { + "url": "https://github.com/ramsey", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/ramsey/uuid", + "type": "tidelift" + } + ], + "time": "2024-04-27T21:32:50+00:00" + }, + { + "name": "spatie/eloquent-sortable", + "version": "4.4.0", + "source": { + "type": "git", + "url": "https://github.com/spatie/eloquent-sortable.git", + "reference": "7a460c775d29741f42744bac52f993cb5b84be0f" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/spatie/eloquent-sortable/zipball/7a460c775d29741f42744bac52f993cb5b84be0f", + "reference": "7a460c775d29741f42744bac52f993cb5b84be0f", + "shasum": "" + }, + "require": { + "illuminate/database": "^9.31|^10.0|^11.0", + "illuminate/support": "^9.31|^10.0|^11.0", + "nesbot/carbon": "^2.63|^3.0", + "php": "^8.1", + "spatie/laravel-package-tools": "^1.9" + }, + "require-dev": { + "orchestra/testbench": "^7.0|^8.0|^9.0", + "phpunit/phpunit": "^9.5|^10.0" + }, + "type": "library", + "extra": { + "laravel": { + "providers": [ + "Spatie\\EloquentSortable\\EloquentSortableServiceProvider" + ] + } + }, + "autoload": { + "psr-4": { + "Spatie\\EloquentSortable\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Freek Van der Herten", + "email": "freek@spatie.be" + } + ], + "description": "Sortable behaviour for eloquent models", + "homepage": "https://github.com/spatie/eloquent-sortable", + "keywords": [ + "behaviour", + "eloquent", + "laravel", + "model", + "sort", + "sortable" + ], + "support": { + "issues": "https://github.com/spatie/eloquent-sortable/issues", + "source": "https://github.com/spatie/eloquent-sortable/tree/4.4.0" + }, + "funding": [ + { + "url": "https://spatie.be/open-source/support-us", + "type": "custom" + }, + { + "url": "https://github.com/spatie", + "type": "github" + } + ], + "time": "2024-06-04T11:09:54+00:00" + }, + { + "name": "spatie/image", + "version": "3.7.4", + "source": { + "type": "git", + "url": "https://github.com/spatie/image.git", + "reference": "d72d1ae07f91a3c1230e064acd4fd8c334ab237b" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/spatie/image/zipball/d72d1ae07f91a3c1230e064acd4fd8c334ab237b", + "reference": "d72d1ae07f91a3c1230e064acd4fd8c334ab237b", + "shasum": "" + }, + "require": { + "ext-exif": "*", + "ext-json": "*", + "ext-mbstring": "*", + "php": "^8.2", + "spatie/image-optimizer": "^1.7.5", + "spatie/temporary-directory": "^2.2", + "symfony/process": "^6.4|^7.0" + }, + "require-dev": { + "ext-gd": "*", + "ext-imagick": "*", + "laravel/sail": "^1.34", + "pestphp/pest": "^2.28", + "phpstan/phpstan": "^1.10.50", + "spatie/pest-plugin-snapshots": "^2.1", + "spatie/pixelmatch-php": "^1.0", + "spatie/ray": "^1.40.1", + "symfony/var-dumper": "^6.4|7.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Spatie\\Image\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Freek Van der Herten", + "email": "freek@spatie.be", + "homepage": "https://spatie.be", + "role": "Developer" + } + ], + "description": "Manipulate images with an expressive API", + "homepage": "https://github.com/spatie/image", + "keywords": [ + "image", + "spatie" + ], + "support": { + "source": "https://github.com/spatie/image/tree/3.7.4" + }, + "funding": [ + { + "url": "https://spatie.be/open-source/support-us", + "type": "custom" + }, + { + "url": "https://github.com/spatie", + "type": "github" + } + ], + "time": "2024-10-07T09:03:34+00:00" + }, + { + "name": "spatie/image-optimizer", + "version": "1.8.0", + "source": { + "type": "git", + "url": "https://github.com/spatie/image-optimizer.git", + "reference": "4fd22035e81d98fffced65a8c20d9ec4daa9671c" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/spatie/image-optimizer/zipball/4fd22035e81d98fffced65a8c20d9ec4daa9671c", + "reference": "4fd22035e81d98fffced65a8c20d9ec4daa9671c", + "shasum": "" + }, + "require": { + "ext-fileinfo": "*", + "php": "^7.3|^8.0", + "psr/log": "^1.0 | ^2.0 | ^3.0", + "symfony/process": "^4.2|^5.0|^6.0|^7.0" + }, + "require-dev": { + "pestphp/pest": "^1.21", + "phpunit/phpunit": "^8.5.21|^9.4.4", + "symfony/var-dumper": "^4.2|^5.0|^6.0|^7.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Spatie\\ImageOptimizer\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Freek Van der Herten", + "email": "freek@spatie.be", + "homepage": "https://spatie.be", + "role": "Developer" + } + ], + "description": "Easily optimize images using PHP", + "homepage": "https://github.com/spatie/image-optimizer", + "keywords": [ + "image-optimizer", + "spatie" + ], + "support": { + "issues": "https://github.com/spatie/image-optimizer/issues", + "source": "https://github.com/spatie/image-optimizer/tree/1.8.0" + }, + "time": "2024-11-04T08:24:54+00:00" + }, + { + "name": "spatie/laravel-medialibrary", + "version": "11.10.0", + "source": { + "type": "git", + "url": "https://github.com/spatie/laravel-medialibrary.git", + "reference": "39b7b54a690ffd7caf5c37cd2afc8798c21e29da" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/spatie/laravel-medialibrary/zipball/39b7b54a690ffd7caf5c37cd2afc8798c21e29da", + "reference": "39b7b54a690ffd7caf5c37cd2afc8798c21e29da", + "shasum": "" + }, + "require": { + "composer/semver": "^3.4", + "ext-exif": "*", + "ext-fileinfo": "*", + "ext-json": "*", + "illuminate/bus": "^10.0|^11.0", + "illuminate/conditionable": "^10.0|^11.0", + "illuminate/console": "^10.0|^11.0", + "illuminate/database": "^10.0|^11.0", + "illuminate/pipeline": "^10.0|^11.0", + "illuminate/support": "^10.0|^11.0", + "maennchen/zipstream-php": "^3.1", + "php": "^8.2", + "spatie/image": "^3.3.2", + "spatie/laravel-package-tools": "^1.16.1", + "spatie/temporary-directory": "^2.2", + "symfony/console": "^6.4.1|^7.0" + }, + "conflict": { + "php-ffmpeg/php-ffmpeg": "<0.6.1" + }, + "require-dev": { + "aws/aws-sdk-php": "^3.293.10", + "ext-imagick": "*", + "ext-pdo_sqlite": "*", + "ext-zip": "*", + "guzzlehttp/guzzle": "^7.8.1", + "larastan/larastan": "^2.7", + "league/flysystem-aws-s3-v3": "^3.22", + "mockery/mockery": "^1.6.7", + "orchestra/testbench": "^7.0|^8.17|^9.0", + "pestphp/pest": "^2.28", + "phpstan/extension-installer": "^1.3.1", + "spatie/laravel-ray": "^1.33", + "spatie/pdf-to-image": "^2.2|^3.0", + "spatie/pest-plugin-snapshots": "^2.1" + }, + "suggest": { + "league/flysystem-aws-s3-v3": "Required to use AWS S3 file storage", + "php-ffmpeg/php-ffmpeg": "Required for generating video thumbnails", + "spatie/pdf-to-image": "Required for generating thumbnails of PDFs and SVGs" + }, + "type": "library", + "extra": { + "laravel": { + "providers": [ + "Spatie\\MediaLibrary\\MediaLibraryServiceProvider" + ] + } + }, + "autoload": { + "psr-4": { + "Spatie\\MediaLibrary\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Freek Van der Herten", + "email": "freek@spatie.be", + "homepage": "https://spatie.be", + "role": "Developer" + } + ], + "description": "Associate files with Eloquent models", + "homepage": "https://github.com/spatie/laravel-medialibrary", + "keywords": [ + "cms", + "conversion", + "downloads", + "images", + "laravel", + "laravel-medialibrary", + "media", + "spatie" + ], + "support": { + "issues": "https://github.com/spatie/laravel-medialibrary/issues", + "source": "https://github.com/spatie/laravel-medialibrary/tree/11.10.0" + }, + "funding": [ + { + "url": "https://spatie.be/open-source/support-us", + "type": "custom" + }, + { + "url": "https://github.com/spatie", + "type": "github" + } + ], + "time": "2024-11-08T15:48:58+00:00" + }, + { + "name": "spatie/laravel-package-tools", + "version": "1.16.5", + "source": { + "type": "git", + "url": "https://github.com/spatie/laravel-package-tools.git", + "reference": "c7413972cf22ffdff97b68499c22baa04eddb6a2" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/spatie/laravel-package-tools/zipball/c7413972cf22ffdff97b68499c22baa04eddb6a2", + "reference": "c7413972cf22ffdff97b68499c22baa04eddb6a2", + "shasum": "" + }, + "require": { + "illuminate/contracts": "^9.28|^10.0|^11.0", + "php": "^8.0" + }, + "require-dev": { + "mockery/mockery": "^1.5", + "orchestra/testbench": "^7.7|^8.0", + "pestphp/pest": "^1.22", + "phpunit/phpunit": "^9.5.24", + "spatie/pest-plugin-test-time": "^1.1" + }, + "type": "library", + "autoload": { + "psr-4": { + "Spatie\\LaravelPackageTools\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Freek Van der Herten", + "email": "freek@spatie.be", + "role": "Developer" + } + ], + "description": "Tools for creating Laravel packages", + "homepage": "https://github.com/spatie/laravel-package-tools", + "keywords": [ + "laravel-package-tools", + "spatie" + ], + "support": { + "issues": "https://github.com/spatie/laravel-package-tools/issues", + "source": "https://github.com/spatie/laravel-package-tools/tree/1.16.5" + }, + "funding": [ + { + "url": "https://github.com/spatie", + "type": "github" + } + ], + "time": "2024-08-27T18:56:10+00:00" + }, + { + "name": "spatie/laravel-permission", + "version": "6.10.1", + "source": { + "type": "git", + "url": "https://github.com/spatie/laravel-permission.git", + "reference": "8bb69d6d67387f7a00d93a2f5fab98860f06e704" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/spatie/laravel-permission/zipball/8bb69d6d67387f7a00d93a2f5fab98860f06e704", + "reference": "8bb69d6d67387f7a00d93a2f5fab98860f06e704", + "shasum": "" + }, + "require": { + "illuminate/auth": "^8.12|^9.0|^10.0|^11.0", + "illuminate/container": "^8.12|^9.0|^10.0|^11.0", + "illuminate/contracts": "^8.12|^9.0|^10.0|^11.0", + "illuminate/database": "^8.12|^9.0|^10.0|^11.0", + "php": "^8.0" + }, + "require-dev": { + "larastan/larastan": "^1.0|^2.0", + "laravel/passport": "^11.0|^12.0", + "orchestra/testbench": "^6.23|^7.0|^8.0|^9.0", + "phpunit/phpunit": "^9.4|^10.1" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "6.x-dev", + "dev-master": "6.x-dev" + }, + "laravel": { + "providers": [ + "Spatie\\Permission\\PermissionServiceProvider" + ] + } + }, + "autoload": { + "files": [ + "src/helpers.php" + ], + "psr-4": { + "Spatie\\Permission\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Freek Van der Herten", + "email": "freek@spatie.be", + "homepage": "https://spatie.be", + "role": "Developer" + } + ], + "description": "Permission handling for Laravel 8.0 and up", + "homepage": "https://github.com/spatie/laravel-permission", + "keywords": [ + "acl", + "laravel", + "permission", + "permissions", + "rbac", + "roles", + "security", + "spatie" + ], + "support": { + "issues": "https://github.com/spatie/laravel-permission/issues", + "source": "https://github.com/spatie/laravel-permission/tree/6.10.1" + }, + "funding": [ + { + "url": "https://github.com/spatie", + "type": "github" + } + ], + "time": "2024-11-08T18:45:41+00:00" + }, + { + "name": "spatie/temporary-directory", + "version": "2.2.1", + "source": { + "type": "git", + "url": "https://github.com/spatie/temporary-directory.git", + "reference": "76949fa18f8e1a7f663fd2eaa1d00e0bcea0752a" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/spatie/temporary-directory/zipball/76949fa18f8e1a7f663fd2eaa1d00e0bcea0752a", + "reference": "76949fa18f8e1a7f663fd2eaa1d00e0bcea0752a", + "shasum": "" + }, + "require": { + "php": "^8.0" + }, + "require-dev": { + "phpunit/phpunit": "^9.5" + }, + "type": "library", + "autoload": { + "psr-4": { + "Spatie\\TemporaryDirectory\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Alex Vanderbist", + "email": "alex@spatie.be", + "homepage": "https://spatie.be", + "role": "Developer" + } + ], + "description": "Easily create, use and destroy temporary directories", + "homepage": "https://github.com/spatie/temporary-directory", + "keywords": [ + "php", + "spatie", + "temporary-directory" + ], + "support": { + "issues": "https://github.com/spatie/temporary-directory/issues", + "source": "https://github.com/spatie/temporary-directory/tree/2.2.1" + }, + "funding": [ + { + "url": "https://spatie.be/open-source/support-us", + "type": "custom" + }, + { + "url": "https://github.com/spatie", + "type": "github" + } + ], + "time": "2023-12-25T11:46:58+00:00" + }, + { + "name": "symfony/cache", + "version": "v7.1.7", + "source": { + "type": "git", + "url": "https://github.com/symfony/cache.git", + "reference": "23b61c9592ee72233c31625f0ae805dd1571e928" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/cache/zipball/23b61c9592ee72233c31625f0ae805dd1571e928", + "reference": "23b61c9592ee72233c31625f0ae805dd1571e928", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "psr/cache": "^2.0|^3.0", + "psr/log": "^1.1|^2|^3", + "symfony/cache-contracts": "^2.5|^3", + "symfony/deprecation-contracts": "^2.5|^3.0", + "symfony/service-contracts": "^2.5|^3", + "symfony/var-exporter": "^6.4|^7.0" + }, + "conflict": { + "doctrine/dbal": "<3.6", + "symfony/dependency-injection": "<6.4", + "symfony/http-kernel": "<6.4", + "symfony/var-dumper": "<6.4" + }, + "provide": { + "psr/cache-implementation": "2.0|3.0", + "psr/simple-cache-implementation": "1.0|2.0|3.0", + "symfony/cache-implementation": "1.1|2.0|3.0" + }, + "require-dev": { + "cache/integration-tests": "dev-master", + "doctrine/dbal": "^3.6|^4", + "predis/predis": "^1.1|^2.0", + "psr/simple-cache": "^1.0|^2.0|^3.0", + "symfony/config": "^6.4|^7.0", + "symfony/dependency-injection": "^6.4|^7.0", + "symfony/filesystem": "^6.4|^7.0", + "symfony/http-kernel": "^6.4|^7.0", + "symfony/messenger": "^6.4|^7.0", + "symfony/var-dumper": "^6.4|^7.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\Cache\\": "" + }, + "classmap": [ + "Traits/ValueWrapper.php" + ], + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Provides extended PSR-6, PSR-16 (and tags) implementations", + "homepage": "https://symfony.com", + "keywords": [ + "caching", + "psr6" + ], + "support": { + "source": "https://github.com/symfony/cache/tree/v7.1.7" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-11-05T15:34:55+00:00" + }, + { + "name": "symfony/cache-contracts", + "version": "v3.5.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/cache-contracts.git", + "reference": "df6a1a44c890faded49a5fca33c2d5c5fd3c2197" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/cache-contracts/zipball/df6a1a44c890faded49a5fca33c2d5c5fd3c2197", + "reference": "df6a1a44c890faded49a5fca33c2d5c5fd3c2197", + "shasum": "" + }, + "require": { + "php": ">=8.1", + "psr/cache": "^3.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.5-dev" + }, + "thanks": { + "name": "symfony/contracts", + "url": "https://github.com/symfony/contracts" + } + }, + "autoload": { + "psr-4": { + "Symfony\\Contracts\\Cache\\": "" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Generic abstractions related to caching", + "homepage": "https://symfony.com", + "keywords": [ + "abstractions", + "contracts", + "decoupling", + "interfaces", + "interoperability", + "standards" + ], + "support": { + "source": "https://github.com/symfony/cache-contracts/tree/v3.5.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-04-18T09:32:20+00:00" + }, + { + "name": "symfony/clock", + "version": "v7.1.6", + "source": { + "type": "git", + "url": "https://github.com/symfony/clock.git", + "reference": "97bebc53548684c17ed696bc8af016880f0f098d" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/clock/zipball/97bebc53548684c17ed696bc8af016880f0f098d", + "reference": "97bebc53548684c17ed696bc8af016880f0f098d", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "psr/clock": "^1.0", + "symfony/polyfill-php83": "^1.28" + }, + "provide": { + "psr/clock-implementation": "1.0" + }, + "type": "library", + "autoload": { + "files": [ + "Resources/now.php" + ], + "psr-4": { + "Symfony\\Component\\Clock\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Decouples applications from the system clock", + "homepage": "https://symfony.com", + "keywords": [ + "clock", + "psr20", + "time" + ], + "support": { + "source": "https://github.com/symfony/clock/tree/v7.1.6" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-25T14:20:29+00:00" + }, + { + "name": "symfony/console", + "version": "v7.1.7", + "source": { + "type": "git", + "url": "https://github.com/symfony/console.git", + "reference": "3284aafcac338b6e86fd955ee4d794cbe434151a" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/console/zipball/3284aafcac338b6e86fd955ee4d794cbe434151a", + "reference": "3284aafcac338b6e86fd955ee4d794cbe434151a", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "symfony/polyfill-mbstring": "~1.0", + "symfony/service-contracts": "^2.5|^3", + "symfony/string": "^6.4|^7.0" + }, + "conflict": { + "symfony/dependency-injection": "<6.4", + "symfony/dotenv": "<6.4", + "symfony/event-dispatcher": "<6.4", + "symfony/lock": "<6.4", + "symfony/process": "<6.4" + }, + "provide": { + "psr/log-implementation": "1.0|2.0|3.0" + }, + "require-dev": { + "psr/log": "^1|^2|^3", + "symfony/config": "^6.4|^7.0", + "symfony/dependency-injection": "^6.4|^7.0", + "symfony/event-dispatcher": "^6.4|^7.0", + "symfony/http-foundation": "^6.4|^7.0", + "symfony/http-kernel": "^6.4|^7.0", + "symfony/lock": "^6.4|^7.0", + "symfony/messenger": "^6.4|^7.0", + "symfony/process": "^6.4|^7.0", + "symfony/stopwatch": "^6.4|^7.0", + "symfony/var-dumper": "^6.4|^7.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\Console\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Eases the creation of beautiful and testable command line interfaces", + "homepage": "https://symfony.com", + "keywords": [ + "cli", + "command-line", + "console", + "terminal" + ], + "support": { + "source": "https://github.com/symfony/console/tree/v7.1.7" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-11-05T15:34:55+00:00" + }, + { + "name": "symfony/css-selector", + "version": "v7.1.6", + "source": { + "type": "git", + "url": "https://github.com/symfony/css-selector.git", + "reference": "4aa4f6b3d6749c14d3aa815eef8226632e7bbc66" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/css-selector/zipball/4aa4f6b3d6749c14d3aa815eef8226632e7bbc66", + "reference": "4aa4f6b3d6749c14d3aa815eef8226632e7bbc66", + "shasum": "" + }, + "require": { + "php": ">=8.2" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\CssSelector\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Jean-François Simon", + "email": "jeanfrancois.simon@sensiolabs.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Converts CSS selectors to XPath expressions", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/css-selector/tree/v7.1.6" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-25T14:20:29+00:00" + }, + { + "name": "symfony/deprecation-contracts", + "version": "v3.5.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/deprecation-contracts.git", + "reference": "0e0d29ce1f20deffb4ab1b016a7257c4f1e789a1" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/deprecation-contracts/zipball/0e0d29ce1f20deffb4ab1b016a7257c4f1e789a1", + "reference": "0e0d29ce1f20deffb4ab1b016a7257c4f1e789a1", + "shasum": "" + }, + "require": { + "php": ">=8.1" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.5-dev" + }, + "thanks": { + "name": "symfony/contracts", + "url": "https://github.com/symfony/contracts" + } + }, + "autoload": { + "files": [ + "function.php" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "A generic function and convention to trigger deprecation notices", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/deprecation-contracts/tree/v3.5.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-04-18T09:32:20+00:00" + }, + { + "name": "symfony/error-handler", + "version": "v7.1.7", + "source": { + "type": "git", + "url": "https://github.com/symfony/error-handler.git", + "reference": "010e44661f4c6babaf8c4862fe68c24a53903342" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/error-handler/zipball/010e44661f4c6babaf8c4862fe68c24a53903342", + "reference": "010e44661f4c6babaf8c4862fe68c24a53903342", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "psr/log": "^1|^2|^3", + "symfony/var-dumper": "^6.4|^7.0" + }, + "conflict": { + "symfony/deprecation-contracts": "<2.5", + "symfony/http-kernel": "<6.4" + }, + "require-dev": { + "symfony/deprecation-contracts": "^2.5|^3", + "symfony/http-kernel": "^6.4|^7.0", + "symfony/serializer": "^6.4|^7.0" + }, + "bin": [ + "Resources/bin/patch-type-declarations" + ], + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\ErrorHandler\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Provides tools to manage errors and ease debugging PHP code", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/error-handler/tree/v7.1.7" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-11-05T15:34:55+00:00" + }, + { + "name": "symfony/event-dispatcher", + "version": "v7.1.6", + "source": { + "type": "git", + "url": "https://github.com/symfony/event-dispatcher.git", + "reference": "87254c78dd50721cfd015b62277a8281c5589702" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/event-dispatcher/zipball/87254c78dd50721cfd015b62277a8281c5589702", + "reference": "87254c78dd50721cfd015b62277a8281c5589702", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "symfony/event-dispatcher-contracts": "^2.5|^3" + }, + "conflict": { + "symfony/dependency-injection": "<6.4", + "symfony/service-contracts": "<2.5" + }, + "provide": { + "psr/event-dispatcher-implementation": "1.0", + "symfony/event-dispatcher-implementation": "2.0|3.0" + }, + "require-dev": { + "psr/log": "^1|^2|^3", + "symfony/config": "^6.4|^7.0", + "symfony/dependency-injection": "^6.4|^7.0", + "symfony/error-handler": "^6.4|^7.0", + "symfony/expression-language": "^6.4|^7.0", + "symfony/http-foundation": "^6.4|^7.0", + "symfony/service-contracts": "^2.5|^3", + "symfony/stopwatch": "^6.4|^7.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\EventDispatcher\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Provides tools that allow your application components to communicate with each other by dispatching events and listening to them", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/event-dispatcher/tree/v7.1.6" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-25T14:20:29+00:00" + }, + { + "name": "symfony/event-dispatcher-contracts", + "version": "v3.5.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/event-dispatcher-contracts.git", + "reference": "8f93aec25d41b72493c6ddff14e916177c9efc50" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/event-dispatcher-contracts/zipball/8f93aec25d41b72493c6ddff14e916177c9efc50", + "reference": "8f93aec25d41b72493c6ddff14e916177c9efc50", + "shasum": "" + }, + "require": { + "php": ">=8.1", + "psr/event-dispatcher": "^1" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.5-dev" + }, + "thanks": { + "name": "symfony/contracts", + "url": "https://github.com/symfony/contracts" + } + }, + "autoload": { + "psr-4": { + "Symfony\\Contracts\\EventDispatcher\\": "" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Generic abstractions related to dispatching event", + "homepage": "https://symfony.com", + "keywords": [ + "abstractions", + "contracts", + "decoupling", + "interfaces", + "interoperability", + "standards" + ], + "support": { + "source": "https://github.com/symfony/event-dispatcher-contracts/tree/v3.5.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-04-18T09:32:20+00:00" + }, + { + "name": "symfony/finder", + "version": "v7.1.6", + "source": { + "type": "git", + "url": "https://github.com/symfony/finder.git", + "reference": "2cb89664897be33f78c65d3d2845954c8d7a43b8" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/finder/zipball/2cb89664897be33f78c65d3d2845954c8d7a43b8", + "reference": "2cb89664897be33f78c65d3d2845954c8d7a43b8", + "shasum": "" + }, + "require": { + "php": ">=8.2" + }, + "require-dev": { + "symfony/filesystem": "^6.4|^7.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\Finder\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Finds files and directories via an intuitive fluent interface", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/finder/tree/v7.1.6" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-10-01T08:31:23+00:00" + }, + { + "name": "symfony/http-client", + "version": "v7.1.7", + "source": { + "type": "git", + "url": "https://github.com/symfony/http-client.git", + "reference": "90ab2a4992dcf5d1f19a9b8737eba36a7c305fd0" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/http-client/zipball/90ab2a4992dcf5d1f19a9b8737eba36a7c305fd0", + "reference": "90ab2a4992dcf5d1f19a9b8737eba36a7c305fd0", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "psr/log": "^1|^2|^3", + "symfony/deprecation-contracts": "^2.5|^3", + "symfony/http-client-contracts": "^3.4.1", + "symfony/service-contracts": "^2.5|^3" + }, + "conflict": { + "php-http/discovery": "<1.15", + "symfony/http-foundation": "<6.4" + }, + "provide": { + "php-http/async-client-implementation": "*", + "php-http/client-implementation": "*", + "psr/http-client-implementation": "1.0", + "symfony/http-client-implementation": "3.0" + }, + "require-dev": { + "amphp/amp": "^2.5", + "amphp/http-client": "^4.2.1", + "amphp/http-tunnel": "^1.0", + "amphp/socket": "^1.1", + "guzzlehttp/promises": "^1.4|^2.0", + "nyholm/psr7": "^1.0", + "php-http/httplug": "^1.0|^2.0", + "psr/http-client": "^1.0", + "symfony/dependency-injection": "^6.4|^7.0", + "symfony/http-kernel": "^6.4|^7.0", + "symfony/messenger": "^6.4|^7.0", + "symfony/process": "^6.4|^7.0", + "symfony/rate-limiter": "^6.4|^7.0", + "symfony/stopwatch": "^6.4|^7.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\HttpClient\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Provides powerful methods to fetch HTTP resources synchronously or asynchronously", + "homepage": "https://symfony.com", + "keywords": [ + "http" + ], + "support": { + "source": "https://github.com/symfony/http-client/tree/v7.1.7" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-11-05T16:45:54+00:00" + }, + { + "name": "symfony/http-client-contracts", + "version": "v3.5.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/http-client-contracts.git", + "reference": "20414d96f391677bf80078aa55baece78b82647d" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/http-client-contracts/zipball/20414d96f391677bf80078aa55baece78b82647d", + "reference": "20414d96f391677bf80078aa55baece78b82647d", + "shasum": "" + }, + "require": { + "php": ">=8.1" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.5-dev" + }, + "thanks": { + "name": "symfony/contracts", + "url": "https://github.com/symfony/contracts" + } + }, + "autoload": { + "psr-4": { + "Symfony\\Contracts\\HttpClient\\": "" + }, + "exclude-from-classmap": [ + "/Test/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Generic abstractions related to HTTP clients", + "homepage": "https://symfony.com", + "keywords": [ + "abstractions", + "contracts", + "decoupling", + "interfaces", + "interoperability", + "standards" + ], + "support": { + "source": "https://github.com/symfony/http-client-contracts/tree/v3.5.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-04-18T09:32:20+00:00" + }, + { + "name": "symfony/http-foundation", + "version": "v7.1.7", + "source": { + "type": "git", + "url": "https://github.com/symfony/http-foundation.git", + "reference": "5183b61657807099d98f3367bcccb850238b17a9" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/http-foundation/zipball/5183b61657807099d98f3367bcccb850238b17a9", + "reference": "5183b61657807099d98f3367bcccb850238b17a9", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "symfony/polyfill-mbstring": "~1.1", + "symfony/polyfill-php83": "^1.27" + }, + "conflict": { + "doctrine/dbal": "<3.6", + "symfony/cache": "<6.4" + }, + "require-dev": { + "doctrine/dbal": "^3.6|^4", + "predis/predis": "^1.1|^2.0", + "symfony/cache": "^6.4|^7.0", + "symfony/dependency-injection": "^6.4|^7.0", + "symfony/expression-language": "^6.4|^7.0", + "symfony/http-kernel": "^6.4|^7.0", + "symfony/mime": "^6.4|^7.0", + "symfony/rate-limiter": "^6.4|^7.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\HttpFoundation\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Defines an object-oriented layer for the HTTP specification", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/http-foundation/tree/v7.1.7" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-11-06T09:02:46+00:00" + }, + { + "name": "symfony/http-kernel", + "version": "v7.1.7", + "source": { + "type": "git", + "url": "https://github.com/symfony/http-kernel.git", + "reference": "7f137cda31fd41e422edcdc01915f2c095b84399" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/http-kernel/zipball/7f137cda31fd41e422edcdc01915f2c095b84399", + "reference": "7f137cda31fd41e422edcdc01915f2c095b84399", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "psr/log": "^1|^2|^3", + "symfony/deprecation-contracts": "^2.5|^3", + "symfony/error-handler": "^6.4|^7.0", + "symfony/event-dispatcher": "^6.4|^7.0", + "symfony/http-foundation": "^6.4|^7.0", + "symfony/polyfill-ctype": "^1.8" + }, + "conflict": { + "symfony/browser-kit": "<6.4", + "symfony/cache": "<6.4", + "symfony/config": "<6.4", + "symfony/console": "<6.4", + "symfony/dependency-injection": "<6.4", + "symfony/doctrine-bridge": "<6.4", + "symfony/form": "<6.4", + "symfony/http-client": "<6.4", + "symfony/http-client-contracts": "<2.5", + "symfony/mailer": "<6.4", + "symfony/messenger": "<6.4", + "symfony/translation": "<6.4", + "symfony/translation-contracts": "<2.5", + "symfony/twig-bridge": "<6.4", + "symfony/validator": "<6.4", + "symfony/var-dumper": "<6.4", + "twig/twig": "<3.0.4" + }, + "provide": { + "psr/log-implementation": "1.0|2.0|3.0" + }, + "require-dev": { + "psr/cache": "^1.0|^2.0|^3.0", + "symfony/browser-kit": "^6.4|^7.0", + "symfony/clock": "^6.4|^7.0", + "symfony/config": "^6.4|^7.0", + "symfony/console": "^6.4|^7.0", + "symfony/css-selector": "^6.4|^7.0", + "symfony/dependency-injection": "^6.4|^7.0", + "symfony/dom-crawler": "^6.4|^7.0", + "symfony/expression-language": "^6.4|^7.0", + "symfony/finder": "^6.4|^7.0", + "symfony/http-client-contracts": "^2.5|^3", + "symfony/process": "^6.4|^7.0", + "symfony/property-access": "^7.1", + "symfony/routing": "^6.4|^7.0", + "symfony/serializer": "^7.1", + "symfony/stopwatch": "^6.4|^7.0", + "symfony/translation": "^6.4|^7.0", + "symfony/translation-contracts": "^2.5|^3", + "symfony/uid": "^6.4|^7.0", + "symfony/validator": "^6.4|^7.0", + "symfony/var-dumper": "^6.4|^7.0", + "symfony/var-exporter": "^6.4|^7.0", + "twig/twig": "^3.0.4" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\HttpKernel\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Provides a structured process for converting a Request into a Response", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/http-kernel/tree/v7.1.7" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-11-06T09:54:34+00:00" + }, + { + "name": "symfony/mailer", + "version": "v7.1.6", + "source": { + "type": "git", + "url": "https://github.com/symfony/mailer.git", + "reference": "69c9948451fb3a6a4d47dc8261d1794734e76cdd" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/mailer/zipball/69c9948451fb3a6a4d47dc8261d1794734e76cdd", + "reference": "69c9948451fb3a6a4d47dc8261d1794734e76cdd", + "shasum": "" + }, + "require": { + "egulias/email-validator": "^2.1.10|^3|^4", + "php": ">=8.2", + "psr/event-dispatcher": "^1", + "psr/log": "^1|^2|^3", + "symfony/event-dispatcher": "^6.4|^7.0", + "symfony/mime": "^6.4|^7.0", + "symfony/service-contracts": "^2.5|^3" + }, + "conflict": { + "symfony/http-client-contracts": "<2.5", + "symfony/http-kernel": "<6.4", + "symfony/messenger": "<6.4", + "symfony/mime": "<6.4", + "symfony/twig-bridge": "<6.4" + }, + "require-dev": { + "symfony/console": "^6.4|^7.0", + "symfony/http-client": "^6.4|^7.0", + "symfony/messenger": "^6.4|^7.0", + "symfony/twig-bridge": "^6.4|^7.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\Mailer\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Helps sending emails", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/mailer/tree/v7.1.6" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-25T14:20:29+00:00" + }, + { + "name": "symfony/mime", + "version": "v7.1.6", + "source": { + "type": "git", + "url": "https://github.com/symfony/mime.git", + "reference": "caa1e521edb2650b8470918dfe51708c237f0598" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/mime/zipball/caa1e521edb2650b8470918dfe51708c237f0598", + "reference": "caa1e521edb2650b8470918dfe51708c237f0598", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "symfony/polyfill-intl-idn": "^1.10", + "symfony/polyfill-mbstring": "^1.0" + }, + "conflict": { + "egulias/email-validator": "~3.0.0", + "phpdocumentor/reflection-docblock": "<3.2.2", + "phpdocumentor/type-resolver": "<1.4.0", + "symfony/mailer": "<6.4", + "symfony/serializer": "<6.4.3|>7.0,<7.0.3" + }, + "require-dev": { + "egulias/email-validator": "^2.1.10|^3.1|^4", + "league/html-to-markdown": "^5.0", + "phpdocumentor/reflection-docblock": "^3.0|^4.0|^5.0", + "symfony/dependency-injection": "^6.4|^7.0", + "symfony/process": "^6.4|^7.0", + "symfony/property-access": "^6.4|^7.0", + "symfony/property-info": "^6.4|^7.0", + "symfony/serializer": "^6.4.3|^7.0.3" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\Mime\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Allows manipulating MIME messages", + "homepage": "https://symfony.com", + "keywords": [ + "mime", + "mime-type" + ], + "support": { + "source": "https://github.com/symfony/mime/tree/v7.1.6" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-10-25T15:11:02+00:00" + }, + { + "name": "symfony/polyfill-ctype", + "version": "v1.31.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/polyfill-ctype.git", + "reference": "a3cc8b044a6ea513310cbd48ef7333b384945638" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/a3cc8b044a6ea513310cbd48ef7333b384945638", + "reference": "a3cc8b044a6ea513310cbd48ef7333b384945638", + "shasum": "" + }, + "require": { + "php": ">=7.2" + }, + "provide": { + "ext-ctype": "*" + }, + "suggest": { + "ext-ctype": "For best performance" + }, + "type": "library", + "extra": { + "thanks": { + "name": "symfony/polyfill", + "url": "https://github.com/symfony/polyfill" + } + }, + "autoload": { + "files": [ + "bootstrap.php" + ], + "psr-4": { + "Symfony\\Polyfill\\Ctype\\": "" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Gert de Pagter", + "email": "BackEndTea@gmail.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony polyfill for ctype functions", + "homepage": "https://symfony.com", + "keywords": [ + "compatibility", + "ctype", + "polyfill", + "portable" + ], + "support": { + "source": "https://github.com/symfony/polyfill-ctype/tree/v1.31.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-09T11:45:10+00:00" + }, + { + "name": "symfony/polyfill-intl-grapheme", + "version": "v1.31.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/polyfill-intl-grapheme.git", + "reference": "b9123926e3b7bc2f98c02ad54f6a4b02b91a8abe" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/polyfill-intl-grapheme/zipball/b9123926e3b7bc2f98c02ad54f6a4b02b91a8abe", + "reference": "b9123926e3b7bc2f98c02ad54f6a4b02b91a8abe", + "shasum": "" + }, + "require": { + "php": ">=7.2" + }, + "suggest": { + "ext-intl": "For best performance" + }, + "type": "library", + "extra": { + "thanks": { + "name": "symfony/polyfill", + "url": "https://github.com/symfony/polyfill" + } + }, + "autoload": { + "files": [ + "bootstrap.php" + ], + "psr-4": { + "Symfony\\Polyfill\\Intl\\Grapheme\\": "" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony polyfill for intl's grapheme_* functions", + "homepage": "https://symfony.com", + "keywords": [ + "compatibility", + "grapheme", + "intl", + "polyfill", + "portable", + "shim" + ], + "support": { + "source": "https://github.com/symfony/polyfill-intl-grapheme/tree/v1.31.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-09T11:45:10+00:00" + }, + { + "name": "symfony/polyfill-intl-idn", + "version": "v1.31.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/polyfill-intl-idn.git", + "reference": "c36586dcf89a12315939e00ec9b4474adcb1d773" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/polyfill-intl-idn/zipball/c36586dcf89a12315939e00ec9b4474adcb1d773", + "reference": "c36586dcf89a12315939e00ec9b4474adcb1d773", + "shasum": "" + }, + "require": { + "php": ">=7.2", + "symfony/polyfill-intl-normalizer": "^1.10" + }, + "suggest": { + "ext-intl": "For best performance" + }, + "type": "library", + "extra": { + "thanks": { + "name": "symfony/polyfill", + "url": "https://github.com/symfony/polyfill" + } + }, + "autoload": { + "files": [ + "bootstrap.php" + ], + "psr-4": { + "Symfony\\Polyfill\\Intl\\Idn\\": "" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Laurent Bassin", + "email": "laurent@bassin.info" + }, + { + "name": "Trevor Rowbotham", + "email": "trevor.rowbotham@pm.me" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony polyfill for intl's idn_to_ascii and idn_to_utf8 functions", + "homepage": "https://symfony.com", + "keywords": [ + "compatibility", + "idn", + "intl", + "polyfill", + "portable", + "shim" + ], + "support": { + "source": "https://github.com/symfony/polyfill-intl-idn/tree/v1.31.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-09T11:45:10+00:00" + }, + { + "name": "symfony/polyfill-intl-normalizer", + "version": "v1.31.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/polyfill-intl-normalizer.git", + "reference": "3833d7255cc303546435cb650316bff708a1c75c" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/polyfill-intl-normalizer/zipball/3833d7255cc303546435cb650316bff708a1c75c", + "reference": "3833d7255cc303546435cb650316bff708a1c75c", + "shasum": "" + }, + "require": { + "php": ">=7.2" + }, + "suggest": { + "ext-intl": "For best performance" + }, + "type": "library", + "extra": { + "thanks": { + "name": "symfony/polyfill", + "url": "https://github.com/symfony/polyfill" + } + }, + "autoload": { + "files": [ + "bootstrap.php" + ], + "psr-4": { + "Symfony\\Polyfill\\Intl\\Normalizer\\": "" + }, + "classmap": [ + "Resources/stubs" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony polyfill for intl's Normalizer class and related functions", + "homepage": "https://symfony.com", + "keywords": [ + "compatibility", + "intl", + "normalizer", + "polyfill", + "portable", + "shim" + ], + "support": { + "source": "https://github.com/symfony/polyfill-intl-normalizer/tree/v1.31.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-09T11:45:10+00:00" + }, + { + "name": "symfony/polyfill-mbstring", + "version": "v1.31.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/polyfill-mbstring.git", + "reference": "85181ba99b2345b0ef10ce42ecac37612d9fd341" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/85181ba99b2345b0ef10ce42ecac37612d9fd341", + "reference": "85181ba99b2345b0ef10ce42ecac37612d9fd341", + "shasum": "" + }, + "require": { + "php": ">=7.2" + }, + "provide": { + "ext-mbstring": "*" + }, + "suggest": { + "ext-mbstring": "For best performance" + }, + "type": "library", + "extra": { + "thanks": { + "name": "symfony/polyfill", + "url": "https://github.com/symfony/polyfill" + } + }, + "autoload": { + "files": [ + "bootstrap.php" + ], + "psr-4": { + "Symfony\\Polyfill\\Mbstring\\": "" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony polyfill for the Mbstring extension", + "homepage": "https://symfony.com", + "keywords": [ + "compatibility", + "mbstring", + "polyfill", + "portable", + "shim" + ], + "support": { + "source": "https://github.com/symfony/polyfill-mbstring/tree/v1.31.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-09T11:45:10+00:00" + }, + { + "name": "symfony/polyfill-php80", + "version": "v1.31.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/polyfill-php80.git", + "reference": "60328e362d4c2c802a54fcbf04f9d3fb892b4cf8" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/polyfill-php80/zipball/60328e362d4c2c802a54fcbf04f9d3fb892b4cf8", + "reference": "60328e362d4c2c802a54fcbf04f9d3fb892b4cf8", + "shasum": "" + }, + "require": { + "php": ">=7.2" + }, + "type": "library", + "extra": { + "thanks": { + "name": "symfony/polyfill", + "url": "https://github.com/symfony/polyfill" + } + }, + "autoload": { + "files": [ + "bootstrap.php" + ], + "psr-4": { + "Symfony\\Polyfill\\Php80\\": "" + }, + "classmap": [ + "Resources/stubs" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Ion Bazan", + "email": "ion.bazan@gmail.com" + }, + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony polyfill backporting some PHP 8.0+ features to lower PHP versions", + "homepage": "https://symfony.com", + "keywords": [ + "compatibility", + "polyfill", + "portable", + "shim" + ], + "support": { + "source": "https://github.com/symfony/polyfill-php80/tree/v1.31.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-09T11:45:10+00:00" + }, + { + "name": "symfony/polyfill-php81", + "version": "v1.31.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/polyfill-php81.git", + "reference": "4a4cfc2d253c21a5ad0e53071df248ed48c6ce5c" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/polyfill-php81/zipball/4a4cfc2d253c21a5ad0e53071df248ed48c6ce5c", + "reference": "4a4cfc2d253c21a5ad0e53071df248ed48c6ce5c", + "shasum": "" + }, + "require": { + "php": ">=7.2" + }, + "type": "library", + "extra": { + "thanks": { + "name": "symfony/polyfill", + "url": "https://github.com/symfony/polyfill" + } + }, + "autoload": { + "files": [ + "bootstrap.php" + ], + "psr-4": { + "Symfony\\Polyfill\\Php81\\": "" + }, + "classmap": [ + "Resources/stubs" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony polyfill backporting some PHP 8.1+ features to lower PHP versions", + "homepage": "https://symfony.com", + "keywords": [ + "compatibility", + "polyfill", + "portable", + "shim" + ], + "support": { + "source": "https://github.com/symfony/polyfill-php81/tree/v1.31.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-09T11:45:10+00:00" + }, + { + "name": "symfony/polyfill-php83", + "version": "v1.31.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/polyfill-php83.git", + "reference": "2fb86d65e2d424369ad2905e83b236a8805ba491" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/polyfill-php83/zipball/2fb86d65e2d424369ad2905e83b236a8805ba491", + "reference": "2fb86d65e2d424369ad2905e83b236a8805ba491", + "shasum": "" + }, + "require": { + "php": ">=7.2" + }, + "type": "library", + "extra": { + "thanks": { + "name": "symfony/polyfill", + "url": "https://github.com/symfony/polyfill" + } + }, + "autoload": { + "files": [ + "bootstrap.php" + ], + "psr-4": { + "Symfony\\Polyfill\\Php83\\": "" + }, + "classmap": [ + "Resources/stubs" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony polyfill backporting some PHP 8.3+ features to lower PHP versions", + "homepage": "https://symfony.com", + "keywords": [ + "compatibility", + "polyfill", + "portable", + "shim" + ], + "support": { + "source": "https://github.com/symfony/polyfill-php83/tree/v1.31.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-09T11:45:10+00:00" + }, + { + "name": "symfony/polyfill-uuid", + "version": "v1.31.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/polyfill-uuid.git", + "reference": "21533be36c24be3f4b1669c4725c7d1d2bab4ae2" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/polyfill-uuid/zipball/21533be36c24be3f4b1669c4725c7d1d2bab4ae2", + "reference": "21533be36c24be3f4b1669c4725c7d1d2bab4ae2", + "shasum": "" + }, + "require": { + "php": ">=7.2" + }, + "provide": { + "ext-uuid": "*" + }, + "suggest": { + "ext-uuid": "For best performance" + }, + "type": "library", + "extra": { + "thanks": { + "name": "symfony/polyfill", + "url": "https://github.com/symfony/polyfill" + } + }, + "autoload": { + "files": [ + "bootstrap.php" + ], + "psr-4": { + "Symfony\\Polyfill\\Uuid\\": "" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Grégoire Pineau", + "email": "lyrixx@lyrixx.info" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony polyfill for uuid functions", + "homepage": "https://symfony.com", + "keywords": [ + "compatibility", + "polyfill", + "portable", + "uuid" + ], + "support": { + "source": "https://github.com/symfony/polyfill-uuid/tree/v1.31.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-09T11:45:10+00:00" + }, + { + "name": "symfony/process", + "version": "v7.1.7", + "source": { + "type": "git", + "url": "https://github.com/symfony/process.git", + "reference": "9b8a40b7289767aa7117e957573c2a535efe6585" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/process/zipball/9b8a40b7289767aa7117e957573c2a535efe6585", + "reference": "9b8a40b7289767aa7117e957573c2a535efe6585", + "shasum": "" + }, + "require": { + "php": ">=8.2" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\Process\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Executes commands in sub-processes", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/process/tree/v7.1.7" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-11-06T09:25:12+00:00" + }, + { + "name": "symfony/psr-http-message-bridge", + "version": "v7.1.6", + "source": { + "type": "git", + "url": "https://github.com/symfony/psr-http-message-bridge.git", + "reference": "f16471bb19f6685b9ccf0a2c03c213840ae68cd6" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/psr-http-message-bridge/zipball/f16471bb19f6685b9ccf0a2c03c213840ae68cd6", + "reference": "f16471bb19f6685b9ccf0a2c03c213840ae68cd6", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "psr/http-message": "^1.0|^2.0", + "symfony/http-foundation": "^6.4|^7.0" + }, + "conflict": { + "php-http/discovery": "<1.15", + "symfony/http-kernel": "<6.4" + }, + "require-dev": { + "nyholm/psr7": "^1.1", + "php-http/discovery": "^1.15", + "psr/log": "^1.1.4|^2|^3", + "symfony/browser-kit": "^6.4|^7.0", + "symfony/config": "^6.4|^7.0", + "symfony/event-dispatcher": "^6.4|^7.0", + "symfony/framework-bundle": "^6.4|^7.0", + "symfony/http-kernel": "^6.4|^7.0" + }, + "type": "symfony-bridge", + "autoload": { + "psr-4": { + "Symfony\\Bridge\\PsrHttpMessage\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "PSR HTTP message bridge", + "homepage": "https://symfony.com", + "keywords": [ + "http", + "http-message", + "psr-17", + "psr-7" + ], + "support": { + "source": "https://github.com/symfony/psr-http-message-bridge/tree/v7.1.6" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-25T14:20:29+00:00" + }, + { + "name": "symfony/routing", + "version": "v7.1.6", + "source": { + "type": "git", + "url": "https://github.com/symfony/routing.git", + "reference": "66a2c469f6c22d08603235c46a20007c0701ea0a" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/routing/zipball/66a2c469f6c22d08603235c46a20007c0701ea0a", + "reference": "66a2c469f6c22d08603235c46a20007c0701ea0a", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "symfony/deprecation-contracts": "^2.5|^3" + }, + "conflict": { + "symfony/config": "<6.4", + "symfony/dependency-injection": "<6.4", + "symfony/yaml": "<6.4" + }, + "require-dev": { + "psr/log": "^1|^2|^3", + "symfony/config": "^6.4|^7.0", + "symfony/dependency-injection": "^6.4|^7.0", + "symfony/expression-language": "^6.4|^7.0", + "symfony/http-foundation": "^6.4|^7.0", + "symfony/yaml": "^6.4|^7.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\Routing\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Maps an HTTP request to a set of configuration variables", + "homepage": "https://symfony.com", + "keywords": [ + "router", + "routing", + "uri", + "url" + ], + "support": { + "source": "https://github.com/symfony/routing/tree/v7.1.6" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-10-01T08:31:23+00:00" + }, + { + "name": "symfony/service-contracts", + "version": "v3.5.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/service-contracts.git", + "reference": "bd1d9e59a81d8fa4acdcea3f617c581f7475a80f" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/service-contracts/zipball/bd1d9e59a81d8fa4acdcea3f617c581f7475a80f", + "reference": "bd1d9e59a81d8fa4acdcea3f617c581f7475a80f", + "shasum": "" + }, + "require": { + "php": ">=8.1", + "psr/container": "^1.1|^2.0", + "symfony/deprecation-contracts": "^2.5|^3" + }, + "conflict": { + "ext-psr": "<1.1|>=2" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.5-dev" + }, + "thanks": { + "name": "symfony/contracts", + "url": "https://github.com/symfony/contracts" + } + }, + "autoload": { + "psr-4": { + "Symfony\\Contracts\\Service\\": "" + }, + "exclude-from-classmap": [ + "/Test/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Generic abstractions related to writing services", + "homepage": "https://symfony.com", + "keywords": [ + "abstractions", + "contracts", + "decoupling", + "interfaces", + "interoperability", + "standards" + ], + "support": { + "source": "https://github.com/symfony/service-contracts/tree/v3.5.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-04-18T09:32:20+00:00" + }, + { + "name": "symfony/string", + "version": "v7.1.6", + "source": { + "type": "git", + "url": "https://github.com/symfony/string.git", + "reference": "61b72d66bf96c360a727ae6232df5ac83c71f626" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/string/zipball/61b72d66bf96c360a727ae6232df5ac83c71f626", + "reference": "61b72d66bf96c360a727ae6232df5ac83c71f626", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "symfony/polyfill-ctype": "~1.8", + "symfony/polyfill-intl-grapheme": "~1.0", + "symfony/polyfill-intl-normalizer": "~1.0", + "symfony/polyfill-mbstring": "~1.0" + }, + "conflict": { + "symfony/translation-contracts": "<2.5" + }, + "require-dev": { + "symfony/emoji": "^7.1", + "symfony/error-handler": "^6.4|^7.0", + "symfony/http-client": "^6.4|^7.0", + "symfony/intl": "^6.4|^7.0", + "symfony/translation-contracts": "^2.5|^3.0", + "symfony/var-exporter": "^6.4|^7.0" + }, + "type": "library", + "autoload": { + "files": [ + "Resources/functions.php" + ], + "psr-4": { + "Symfony\\Component\\String\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Provides an object-oriented API to strings and deals with bytes, UTF-8 code points and grapheme clusters in a unified way", + "homepage": "https://symfony.com", + "keywords": [ + "grapheme", + "i18n", + "string", + "unicode", + "utf-8", + "utf8" + ], + "support": { + "source": "https://github.com/symfony/string/tree/v7.1.6" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-25T14:20:29+00:00" + }, + { + "name": "symfony/translation", + "version": "v7.1.6", + "source": { + "type": "git", + "url": "https://github.com/symfony/translation.git", + "reference": "b9f72ab14efdb6b772f85041fa12f820dee8d55f" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/translation/zipball/b9f72ab14efdb6b772f85041fa12f820dee8d55f", + "reference": "b9f72ab14efdb6b772f85041fa12f820dee8d55f", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "symfony/polyfill-mbstring": "~1.0", + "symfony/translation-contracts": "^2.5|^3.0" + }, + "conflict": { + "symfony/config": "<6.4", + "symfony/console": "<6.4", + "symfony/dependency-injection": "<6.4", + "symfony/http-client-contracts": "<2.5", + "symfony/http-kernel": "<6.4", + "symfony/service-contracts": "<2.5", + "symfony/twig-bundle": "<6.4", + "symfony/yaml": "<6.4" + }, + "provide": { + "symfony/translation-implementation": "2.3|3.0" + }, + "require-dev": { + "nikic/php-parser": "^4.18|^5.0", + "psr/log": "^1|^2|^3", + "symfony/config": "^6.4|^7.0", + "symfony/console": "^6.4|^7.0", + "symfony/dependency-injection": "^6.4|^7.0", + "symfony/finder": "^6.4|^7.0", + "symfony/http-client-contracts": "^2.5|^3.0", + "symfony/http-kernel": "^6.4|^7.0", + "symfony/intl": "^6.4|^7.0", + "symfony/polyfill-intl-icu": "^1.21", + "symfony/routing": "^6.4|^7.0", + "symfony/service-contracts": "^2.5|^3", + "symfony/yaml": "^6.4|^7.0" + }, + "type": "library", + "autoload": { + "files": [ + "Resources/functions.php" + ], + "psr-4": { + "Symfony\\Component\\Translation\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Provides tools to internationalize your application", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/translation/tree/v7.1.6" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-28T12:35:13+00:00" + }, + { + "name": "symfony/translation-contracts", + "version": "v3.5.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/translation-contracts.git", + "reference": "b9d2189887bb6b2e0367a9fc7136c5239ab9b05a" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/translation-contracts/zipball/b9d2189887bb6b2e0367a9fc7136c5239ab9b05a", + "reference": "b9d2189887bb6b2e0367a9fc7136c5239ab9b05a", + "shasum": "" + }, + "require": { + "php": ">=8.1" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.5-dev" + }, + "thanks": { + "name": "symfony/contracts", + "url": "https://github.com/symfony/contracts" + } + }, + "autoload": { + "psr-4": { + "Symfony\\Contracts\\Translation\\": "" + }, + "exclude-from-classmap": [ + "/Test/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Generic abstractions related to translation", + "homepage": "https://symfony.com", + "keywords": [ + "abstractions", + "contracts", + "decoupling", + "interfaces", + "interoperability", + "standards" + ], + "support": { + "source": "https://github.com/symfony/translation-contracts/tree/v3.5.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-04-18T09:32:20+00:00" + }, + { + "name": "symfony/uid", + "version": "v7.1.6", + "source": { + "type": "git", + "url": "https://github.com/symfony/uid.git", + "reference": "65befb3bb2d503bbffbd08c815aa38b472999917" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/uid/zipball/65befb3bb2d503bbffbd08c815aa38b472999917", + "reference": "65befb3bb2d503bbffbd08c815aa38b472999917", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "symfony/polyfill-uuid": "^1.15" + }, + "require-dev": { + "symfony/console": "^6.4|^7.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\Uid\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Grégoire Pineau", + "email": "lyrixx@lyrixx.info" + }, + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Provides an object-oriented API to generate and represent UIDs", + "homepage": "https://symfony.com", + "keywords": [ + "UID", + "ulid", + "uuid" + ], + "support": { + "source": "https://github.com/symfony/uid/tree/v7.1.6" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-25T14:20:29+00:00" + }, + { + "name": "symfony/var-dumper", + "version": "v7.1.7", + "source": { + "type": "git", + "url": "https://github.com/symfony/var-dumper.git", + "reference": "f6ea51f669760cacd7464bf7eaa0be87b8072db1" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/var-dumper/zipball/f6ea51f669760cacd7464bf7eaa0be87b8072db1", + "reference": "f6ea51f669760cacd7464bf7eaa0be87b8072db1", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "symfony/polyfill-mbstring": "~1.0" + }, + "conflict": { + "symfony/console": "<6.4" + }, + "require-dev": { + "ext-iconv": "*", + "symfony/console": "^6.4|^7.0", + "symfony/http-kernel": "^6.4|^7.0", + "symfony/process": "^6.4|^7.0", + "symfony/uid": "^6.4|^7.0", + "twig/twig": "^3.0.4" + }, + "bin": [ + "Resources/bin/var-dump-server" + ], + "type": "library", + "autoload": { + "files": [ + "Resources/functions/dump.php" + ], + "psr-4": { + "Symfony\\Component\\VarDumper\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Provides mechanisms for walking through any arbitrary PHP variable", + "homepage": "https://symfony.com", + "keywords": [ + "debug", + "dump" + ], + "support": { + "source": "https://github.com/symfony/var-dumper/tree/v7.1.7" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-11-05T15:34:55+00:00" + }, + { + "name": "symfony/var-exporter", + "version": "v7.1.6", + "source": { + "type": "git", + "url": "https://github.com/symfony/var-exporter.git", + "reference": "90173ef89c40e7c8c616653241048705f84130ef" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/var-exporter/zipball/90173ef89c40e7c8c616653241048705f84130ef", + "reference": "90173ef89c40e7c8c616653241048705f84130ef", + "shasum": "" + }, + "require": { + "php": ">=8.2" + }, + "require-dev": { + "symfony/property-access": "^6.4|^7.0", + "symfony/serializer": "^6.4|^7.0", + "symfony/var-dumper": "^6.4|^7.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\VarExporter\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Allows exporting any serializable PHP data structure to plain PHP code", + "homepage": "https://symfony.com", + "keywords": [ + "clone", + "construct", + "export", + "hydrate", + "instantiate", + "lazy-loading", + "proxy", + "serialize" + ], + "support": { + "source": "https://github.com/symfony/var-exporter/tree/v7.1.6" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-25T14:20:29+00:00" + }, + { + "name": "thenorthmemory/xml", + "version": "1.1.1", + "source": { + "type": "git", + "url": "https://github.com/TheNorthMemory/xml.git", + "reference": "6f50c63450a0b098772423f8bdc3c4ad2c4c30bb" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/TheNorthMemory/xml/zipball/6f50c63450a0b098772423f8bdc3c4ad2c4c30bb", + "reference": "6f50c63450a0b098772423f8bdc3c4ad2c4c30bb", + "shasum": "" + }, + "require": { + "ext-libxml": "*", + "ext-simplexml": "*", + "php": ">=7.1.2" + }, + "require-dev": { + "phpstan/phpstan": "^0.12.89 || ^1.0", + "phpunit/phpunit": "^7.5 || ^8.5.16 || ^9.3.5" + }, + "type": "library", + "autoload": { + "psr-4": { + "TheNorthMemory\\Xml\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "James ZHANG", + "homepage": "https://github.com/TheNorthMemory" + } + ], + "description": "A wrapper of the XML parser and builder", + "homepage": "https://github.com/TheNorthMemory/xml", + "keywords": [ + "xml-builder", + "xml-parser" + ], + "support": { + "issues": "https://github.com/TheNorthMemory/xml/issues", + "source": "https://github.com/TheNorthMemory/xml/tree/1.1.1" + }, + "time": "2023-01-15T06:01:13+00:00" + }, + { + "name": "tijsverkoyen/css-to-inline-styles", + "version": "v2.2.7", + "source": { + "type": "git", + "url": "https://github.com/tijsverkoyen/CssToInlineStyles.git", + "reference": "83ee6f38df0a63106a9e4536e3060458b74ccedb" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/tijsverkoyen/CssToInlineStyles/zipball/83ee6f38df0a63106a9e4536e3060458b74ccedb", + "reference": "83ee6f38df0a63106a9e4536e3060458b74ccedb", + "shasum": "" + }, + "require": { + "ext-dom": "*", + "ext-libxml": "*", + "php": "^5.5 || ^7.0 || ^8.0", + "symfony/css-selector": "^2.7 || ^3.0 || ^4.0 || ^5.0 || ^6.0 || ^7.0" + }, + "require-dev": { + "phpunit/phpunit": "^4.8.35 || ^5.7 || ^6.0 || ^7.5 || ^8.5.21 || ^9.5.10" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.2.x-dev" + } + }, + "autoload": { + "psr-4": { + "TijsVerkoyen\\CssToInlineStyles\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Tijs Verkoyen", + "email": "css_to_inline_styles@verkoyen.eu", + "role": "Developer" + } + ], + "description": "CssToInlineStyles is a class that enables you to convert HTML-pages/files into HTML-pages/files with inline styles. This is very useful when you're sending emails.", + "homepage": "https://github.com/tijsverkoyen/CssToInlineStyles", + "support": { + "issues": "https://github.com/tijsverkoyen/CssToInlineStyles/issues", + "source": "https://github.com/tijsverkoyen/CssToInlineStyles/tree/v2.2.7" + }, + "time": "2023-12-08T13:03:43+00:00" + }, + { + "name": "vlucas/phpdotenv", + "version": "v5.6.1", + "source": { + "type": "git", + "url": "https://github.com/vlucas/phpdotenv.git", + "reference": "a59a13791077fe3d44f90e7133eb68e7d22eaff2" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/vlucas/phpdotenv/zipball/a59a13791077fe3d44f90e7133eb68e7d22eaff2", + "reference": "a59a13791077fe3d44f90e7133eb68e7d22eaff2", + "shasum": "" + }, + "require": { + "ext-pcre": "*", + "graham-campbell/result-type": "^1.1.3", + "php": "^7.2.5 || ^8.0", + "phpoption/phpoption": "^1.9.3", + "symfony/polyfill-ctype": "^1.24", + "symfony/polyfill-mbstring": "^1.24", + "symfony/polyfill-php80": "^1.24" + }, + "require-dev": { + "bamarni/composer-bin-plugin": "^1.8.2", + "ext-filter": "*", + "phpunit/phpunit": "^8.5.34 || ^9.6.13 || ^10.4.2" + }, + "suggest": { + "ext-filter": "Required to use the boolean validator." + }, + "type": "library", + "extra": { + "bamarni-bin": { + "bin-links": true, + "forward-command": false + }, + "branch-alias": { + "dev-master": "5.6-dev" + } + }, + "autoload": { + "psr-4": { + "Dotenv\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Graham Campbell", + "email": "hello@gjcampbell.co.uk", + "homepage": "https://github.com/GrahamCampbell" + }, + { + "name": "Vance Lucas", + "email": "vance@vancelucas.com", + "homepage": "https://github.com/vlucas" + } + ], + "description": "Loads environment variables from `.env` to `getenv()`, `$_ENV` and `$_SERVER` automagically.", + "keywords": [ + "dotenv", + "env", + "environment" + ], + "support": { + "issues": "https://github.com/vlucas/phpdotenv/issues", + "source": "https://github.com/vlucas/phpdotenv/tree/v5.6.1" + }, + "funding": [ + { + "url": "https://github.com/GrahamCampbell", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/vlucas/phpdotenv", + "type": "tidelift" + } + ], + "time": "2024-07-20T21:52:34+00:00" + }, + { + "name": "voku/portable-ascii", + "version": "2.0.1", + "source": { + "type": "git", + "url": "https://github.com/voku/portable-ascii.git", + "reference": "b56450eed252f6801410d810c8e1727224ae0743" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/voku/portable-ascii/zipball/b56450eed252f6801410d810c8e1727224ae0743", + "reference": "b56450eed252f6801410d810c8e1727224ae0743", + "shasum": "" + }, + "require": { + "php": ">=7.0.0" + }, + "require-dev": { + "phpunit/phpunit": "~6.0 || ~7.0 || ~9.0" + }, + "suggest": { + "ext-intl": "Use Intl for transliterator_transliterate() support" + }, + "type": "library", + "autoload": { + "psr-4": { + "voku\\": "src/voku/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Lars Moelleken", + "homepage": "http://www.moelleken.org/" + } + ], + "description": "Portable ASCII library - performance optimized (ascii) string functions for php.", + "homepage": "https://github.com/voku/portable-ascii", + "keywords": [ + "ascii", + "clean", + "php" + ], + "support": { + "issues": "https://github.com/voku/portable-ascii/issues", + "source": "https://github.com/voku/portable-ascii/tree/2.0.1" + }, + "funding": [ + { + "url": "https://www.paypal.me/moelleken", + "type": "custom" + }, + { + "url": "https://github.com/voku", + "type": "github" + }, + { + "url": "https://opencollective.com/portable-ascii", + "type": "open_collective" + }, + { + "url": "https://www.patreon.com/voku", + "type": "patreon" + }, + { + "url": "https://tidelift.com/funding/github/packagist/voku/portable-ascii", + "type": "tidelift" + } + ], + "time": "2022-03-08T17:03:00+00:00" + }, + { + "name": "w7corp/easywechat", + "version": "6.15.4", + "source": { + "type": "git", + "url": "https://github.com/w7corp/easywechat.git", + "reference": "3299422c387407b231de4dd293770b917f288c2b" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/w7corp/easywechat/zipball/3299422c387407b231de4dd293770b917f288c2b", + "reference": "3299422c387407b231de4dd293770b917f288c2b", + "shasum": "" + }, + "require": { + "ext-curl": "*", + "ext-fileinfo": "*", + "ext-libxml": "*", + "ext-openssl": "*", + "ext-simplexml": "*", + "ext-sodium": "*", + "nyholm/psr7": "^1.5", + "nyholm/psr7-server": "^1.0", + "overtrue/socialite": "^3.5.4|^4.0.1", + "php": ">=8.0.2", + "psr/http-client": "^1.0", + "psr/simple-cache": "^1.0|^2.0|^3.0", + "symfony/cache": "^5.4|^6.0|^7.0", + "symfony/http-client": "^5.4|^6.0|^7.0", + "symfony/http-foundation": "^5.4|^6.0|^7.0", + "symfony/mime": "^5.4|^6.0|^7.0", + "symfony/polyfill-php81": "^1.25", + "symfony/psr-http-message-bridge": "^2.1.2|^6.4.0|^7.1", + "thenorthmemory/xml": "^1.0" + }, + "require-dev": { + "jetbrains/phpstorm-attributes": "^1.0", + "laravel/pint": "^1.2", + "mikey179/vfsstream": "^1.6", + "mockery/mockery": "^1.4.4", + "phpstan/phpstan": "^1.0", + "phpunit/phpunit": "^9.5", + "symfony/var-dumper": "^5.2" + }, + "type": "library", + "autoload": { + "psr-4": { + "EasyWeChat\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "overtrue", + "email": "anzhengchao@gmail.com" + } + ], + "description": "微信SDK", + "keywords": [ + "easywechat", + "sdk", + "wechat", + "weixin", + "weixin-sdk" + ], + "support": { + "issues": "https://github.com/w7corp/easywechat/issues", + "source": "https://github.com/w7corp/easywechat/tree/6.15.4" + }, + "funding": [ + { + "url": "https://github.com/overtrue", + "type": "github" + } + ], + "time": "2024-10-09T07:07:09+00:00" + }, + { + "name": "webmozart/assert", + "version": "1.11.0", + "source": { + "type": "git", + "url": "https://github.com/webmozarts/assert.git", + "reference": "11cb2199493b2f8a3b53e7f19068fc6aac760991" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/webmozarts/assert/zipball/11cb2199493b2f8a3b53e7f19068fc6aac760991", + "reference": "11cb2199493b2f8a3b53e7f19068fc6aac760991", + "shasum": "" + }, + "require": { + "ext-ctype": "*", + "php": "^7.2 || ^8.0" + }, + "conflict": { + "phpstan/phpstan": "<0.12.20", + "vimeo/psalm": "<4.6.1 || 4.6.2" + }, + "require-dev": { + "phpunit/phpunit": "^8.5.13" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.10-dev" + } + }, + "autoload": { + "psr-4": { + "Webmozart\\Assert\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Bernhard Schussek", + "email": "bschussek@gmail.com" + } + ], + "description": "Assertions to validate method input/output with nice error messages.", + "keywords": [ + "assert", + "check", + "validate" + ], + "support": { + "issues": "https://github.com/webmozarts/assert/issues", + "source": "https://github.com/webmozarts/assert/tree/1.11.0" + }, + "time": "2022-06-03T18:03:27+00:00" + } + ], + "packages-dev": [ + { + "name": "barryvdh/laravel-ide-helper", + "version": "v3.2.2", + "source": { + "type": "git", + "url": "https://github.com/barryvdh/laravel-ide-helper.git", + "reference": "07e3bd8796f3d1414801a03d3783f9d3ec9efc08" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/barryvdh/laravel-ide-helper/zipball/07e3bd8796f3d1414801a03d3783f9d3ec9efc08", + "reference": "07e3bd8796f3d1414801a03d3783f9d3ec9efc08", + "shasum": "" + }, + "require": { + "barryvdh/reflection-docblock": "^2.1.2", + "composer/class-map-generator": "^1.0", + "ext-json": "*", + "illuminate/console": "^11.15", + "illuminate/database": "^11.15", + "illuminate/filesystem": "^11.15", + "illuminate/support": "^11.15", + "nikic/php-parser": "^4.18 || ^5", + "php": "^8.2", + "phpdocumentor/type-resolver": "^1.1.0" + }, + "require-dev": { + "ext-pdo_sqlite": "*", + "friendsofphp/php-cs-fixer": "^3", + "illuminate/config": "^11.15", + "illuminate/view": "^11.15", + "mockery/mockery": "^1.4", + "orchestra/testbench": "^9.2", + "phpunit/phpunit": "^10.5", + "spatie/phpunit-snapshot-assertions": "^4 || ^5", + "vimeo/psalm": "^5.4" + }, + "suggest": { + "illuminate/events": "Required for automatic helper generation (^6|^7|^8|^9|^10|^11)." + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "3.2-dev" + }, + "laravel": { + "providers": [ + "Barryvdh\\LaravelIdeHelper\\IdeHelperServiceProvider" + ] + } + }, + "autoload": { + "psr-4": { + "Barryvdh\\LaravelIdeHelper\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Barry vd. Heuvel", + "email": "barryvdh@gmail.com" + } + ], + "description": "Laravel IDE Helper, generates correct PHPDocs for all Facade classes, to improve auto-completion.", + "keywords": [ + "autocomplete", + "codeintel", + "helper", + "ide", + "laravel", + "netbeans", + "phpdoc", + "phpstorm", + "sublime" + ], + "support": { + "issues": "https://github.com/barryvdh/laravel-ide-helper/issues", + "source": "https://github.com/barryvdh/laravel-ide-helper/tree/v3.2.2" + }, + "funding": [ + { + "url": "https://fruitcake.nl", + "type": "custom" + }, + { + "url": "https://github.com/barryvdh", + "type": "github" + } + ], + "time": "2024-10-29T14:00:16+00:00" + }, + { + "name": "barryvdh/reflection-docblock", + "version": "v2.1.3", + "source": { + "type": "git", + "url": "https://github.com/barryvdh/ReflectionDocBlock.git", + "reference": "c6fad15f7c878be21650c51e1f841bca7e49752e" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/barryvdh/ReflectionDocBlock/zipball/c6fad15f7c878be21650c51e1f841bca7e49752e", + "reference": "c6fad15f7c878be21650c51e1f841bca7e49752e", + "shasum": "" + }, + "require": { + "php": ">=5.3.3" + }, + "require-dev": { + "phpunit/phpunit": "^8.5.14|^9" + }, + "suggest": { + "dflydev/markdown": "~1.0", + "erusev/parsedown": "~1.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.0.x-dev" + } + }, + "autoload": { + "psr-0": { + "Barryvdh": [ + "src/" + ] + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Mike van Riel", + "email": "mike.vanriel@naenius.com" + } + ], + "support": { + "source": "https://github.com/barryvdh/ReflectionDocBlock/tree/v2.1.3" + }, + "time": "2024-10-23T11:41:03+00:00" + }, + { + "name": "clue/ndjson-react", + "version": "v1.3.0", + "source": { + "type": "git", + "url": "https://github.com/clue/reactphp-ndjson.git", + "reference": "392dc165fce93b5bb5c637b67e59619223c931b0" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/clue/reactphp-ndjson/zipball/392dc165fce93b5bb5c637b67e59619223c931b0", + "reference": "392dc165fce93b5bb5c637b67e59619223c931b0", + "shasum": "" + }, + "require": { + "php": ">=5.3", + "react/stream": "^1.2" + }, + "require-dev": { + "phpunit/phpunit": "^9.5 || ^5.7 || ^4.8.35", + "react/event-loop": "^1.2" + }, + "type": "library", + "autoload": { + "psr-4": { + "Clue\\React\\NDJson\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Christian Lück", + "email": "christian@clue.engineering" + } + ], + "description": "Streaming newline-delimited JSON (NDJSON) parser and encoder for ReactPHP.", + "homepage": "https://github.com/clue/reactphp-ndjson", + "keywords": [ + "NDJSON", + "json", + "jsonlines", + "newline", + "reactphp", + "streaming" + ], + "support": { + "issues": "https://github.com/clue/reactphp-ndjson/issues", + "source": "https://github.com/clue/reactphp-ndjson/tree/v1.3.0" + }, + "funding": [ + { + "url": "https://clue.engineering/support", + "type": "custom" + }, + { + "url": "https://github.com/clue", + "type": "github" + } + ], + "time": "2022-12-23T10:58:28+00:00" + }, + { + "name": "composer/class-map-generator", + "version": "1.4.0", + "source": { + "type": "git", + "url": "https://github.com/composer/class-map-generator.git", + "reference": "98bbf6780e56e0fd2404fe4b82eb665a0f93b783" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/composer/class-map-generator/zipball/98bbf6780e56e0fd2404fe4b82eb665a0f93b783", + "reference": "98bbf6780e56e0fd2404fe4b82eb665a0f93b783", + "shasum": "" + }, + "require": { + "composer/pcre": "^2.1 || ^3.1", + "php": "^7.2 || ^8.0", + "symfony/finder": "^4.4 || ^5.3 || ^6 || ^7" + }, + "require-dev": { + "phpstan/phpstan": "^1.6", + "phpstan/phpstan-deprecation-rules": "^1", + "phpstan/phpstan-phpunit": "^1", + "phpstan/phpstan-strict-rules": "^1.1", + "phpunit/phpunit": "^8", + "symfony/filesystem": "^5.4 || ^6" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "1.x-dev" + } + }, + "autoload": { + "psr-4": { + "Composer\\ClassMapGenerator\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Jordi Boggiano", + "email": "j.boggiano@seld.be", + "homepage": "https://seld.be" + } + ], + "description": "Utilities to scan PHP code and generate class maps.", + "keywords": [ + "classmap" + ], + "support": { + "issues": "https://github.com/composer/class-map-generator/issues", + "source": "https://github.com/composer/class-map-generator/tree/1.4.0" + }, + "funding": [ + { + "url": "https://packagist.com", + "type": "custom" + }, + { + "url": "https://github.com/composer", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/composer/composer", + "type": "tidelift" + } + ], + "time": "2024-10-03T18:14:00+00:00" + }, + { + "name": "composer/pcre", + "version": "3.3.2", + "source": { + "type": "git", + "url": "https://github.com/composer/pcre.git", + "reference": "b2bed4734f0cc156ee1fe9c0da2550420d99a21e" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/composer/pcre/zipball/b2bed4734f0cc156ee1fe9c0da2550420d99a21e", + "reference": "b2bed4734f0cc156ee1fe9c0da2550420d99a21e", + "shasum": "" + }, + "require": { + "php": "^7.4 || ^8.0" + }, + "conflict": { + "phpstan/phpstan": "<1.11.10" + }, + "require-dev": { + "phpstan/phpstan": "^1.12 || ^2", + "phpstan/phpstan-strict-rules": "^1 || ^2", + "phpunit/phpunit": "^8 || ^9" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.x-dev" + }, + "phpstan": { + "includes": [ + "extension.neon" + ] + } + }, + "autoload": { + "psr-4": { + "Composer\\Pcre\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Jordi Boggiano", + "email": "j.boggiano@seld.be", + "homepage": "http://seld.be" + } + ], + "description": "PCRE wrapping library that offers type-safe preg_* replacements.", + "keywords": [ + "PCRE", + "preg", + "regex", + "regular expression" + ], + "support": { + "issues": "https://github.com/composer/pcre/issues", + "source": "https://github.com/composer/pcre/tree/3.3.2" + }, + "funding": [ + { + "url": "https://packagist.com", + "type": "custom" + }, + { + "url": "https://github.com/composer", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/composer/composer", + "type": "tidelift" + } + ], + "time": "2024-11-12T16:29:46+00:00" + }, + { + "name": "composer/xdebug-handler", + "version": "3.0.5", + "source": { + "type": "git", + "url": "https://github.com/composer/xdebug-handler.git", + "reference": "6c1925561632e83d60a44492e0b344cf48ab85ef" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/composer/xdebug-handler/zipball/6c1925561632e83d60a44492e0b344cf48ab85ef", + "reference": "6c1925561632e83d60a44492e0b344cf48ab85ef", + "shasum": "" + }, + "require": { + "composer/pcre": "^1 || ^2 || ^3", + "php": "^7.2.5 || ^8.0", + "psr/log": "^1 || ^2 || ^3" + }, + "require-dev": { + "phpstan/phpstan": "^1.0", + "phpstan/phpstan-strict-rules": "^1.1", + "phpunit/phpunit": "^8.5 || ^9.6 || ^10.5" + }, + "type": "library", + "autoload": { + "psr-4": { + "Composer\\XdebugHandler\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "John Stevenson", + "email": "john-stevenson@blueyonder.co.uk" + } + ], + "description": "Restarts a process without Xdebug.", + "keywords": [ + "Xdebug", + "performance" + ], + "support": { + "irc": "ircs://irc.libera.chat:6697/composer", + "issues": "https://github.com/composer/xdebug-handler/issues", + "source": "https://github.com/composer/xdebug-handler/tree/3.0.5" + }, + "funding": [ + { + "url": "https://packagist.com", + "type": "custom" + }, + { + "url": "https://github.com/composer", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/composer/composer", + "type": "tidelift" + } + ], + "time": "2024-05-06T16:37:16+00:00" + }, + { + "name": "doctrine/deprecations", + "version": "1.1.3", + "source": { + "type": "git", + "url": "https://github.com/doctrine/deprecations.git", + "reference": "dfbaa3c2d2e9a9df1118213f3b8b0c597bb99fab" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/doctrine/deprecations/zipball/dfbaa3c2d2e9a9df1118213f3b8b0c597bb99fab", + "reference": "dfbaa3c2d2e9a9df1118213f3b8b0c597bb99fab", + "shasum": "" + }, + "require": { + "php": "^7.1 || ^8.0" + }, + "require-dev": { + "doctrine/coding-standard": "^9", + "phpstan/phpstan": "1.4.10 || 1.10.15", + "phpstan/phpstan-phpunit": "^1.0", + "phpunit/phpunit": "^7.5 || ^8.5 || ^9.5", + "psalm/plugin-phpunit": "0.18.4", + "psr/log": "^1 || ^2 || ^3", + "vimeo/psalm": "4.30.0 || 5.12.0" + }, + "suggest": { + "psr/log": "Allows logging deprecations via PSR-3 logger implementation" + }, + "type": "library", + "autoload": { + "psr-4": { + "Doctrine\\Deprecations\\": "lib/Doctrine/Deprecations" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "A small layer on top of trigger_error(E_USER_DEPRECATED) or PSR-3 logging with options to disable all deprecations or selectively for packages.", + "homepage": "https://www.doctrine-project.org/", + "support": { + "issues": "https://github.com/doctrine/deprecations/issues", + "source": "https://github.com/doctrine/deprecations/tree/1.1.3" + }, + "time": "2024-01-30T19:34:25+00:00" + }, + { + "name": "evenement/evenement", + "version": "v3.0.2", + "source": { + "type": "git", + "url": "https://github.com/igorw/evenement.git", + "reference": "0a16b0d71ab13284339abb99d9d2bd813640efbc" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/igorw/evenement/zipball/0a16b0d71ab13284339abb99d9d2bd813640efbc", + "reference": "0a16b0d71ab13284339abb99d9d2bd813640efbc", + "shasum": "" + }, + "require": { + "php": ">=7.0" + }, + "require-dev": { + "phpunit/phpunit": "^9 || ^6" + }, + "type": "library", + "autoload": { + "psr-4": { + "Evenement\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Igor Wiedler", + "email": "igor@wiedler.ch" + } + ], + "description": "Événement is a very simple event dispatching library for PHP", + "keywords": [ + "event-dispatcher", + "event-emitter" + ], + "support": { + "issues": "https://github.com/igorw/evenement/issues", + "source": "https://github.com/igorw/evenement/tree/v3.0.2" + }, + "time": "2023-08-08T05:53:35+00:00" + }, + { + "name": "fakerphp/faker", + "version": "v1.24.0", + "source": { + "type": "git", + "url": "https://github.com/FakerPHP/Faker.git", + "reference": "a136842a532bac9ecd8a1c723852b09915d7db50" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/FakerPHP/Faker/zipball/a136842a532bac9ecd8a1c723852b09915d7db50", + "reference": "a136842a532bac9ecd8a1c723852b09915d7db50", + "shasum": "" + }, + "require": { + "php": "^7.4 || ^8.0", + "psr/container": "^1.0 || ^2.0", + "symfony/deprecation-contracts": "^2.2 || ^3.0" + }, + "conflict": { + "fzaninotto/faker": "*" + }, + "require-dev": { + "bamarni/composer-bin-plugin": "^1.4.1", + "doctrine/persistence": "^1.3 || ^2.0", + "ext-intl": "*", + "phpunit/phpunit": "^9.5.26", + "symfony/phpunit-bridge": "^5.4.16" + }, + "suggest": { + "doctrine/orm": "Required to use Faker\\ORM\\Doctrine", + "ext-curl": "Required by Faker\\Provider\\Image to download images.", + "ext-dom": "Required by Faker\\Provider\\HtmlLorem for generating random HTML.", + "ext-iconv": "Required by Faker\\Provider\\ru_RU\\Text::realText() for generating real Russian text.", + "ext-mbstring": "Required for multibyte Unicode string functionality." + }, + "type": "library", + "autoload": { + "psr-4": { + "Faker\\": "src/Faker/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "François Zaninotto" + } + ], + "description": "Faker is a PHP library that generates fake data for you.", + "keywords": [ + "data", + "faker", + "fixtures" + ], + "support": { + "issues": "https://github.com/FakerPHP/Faker/issues", + "source": "https://github.com/FakerPHP/Faker/tree/v1.24.0" + }, + "time": "2024-11-07T15:11:20+00:00" + }, + { + "name": "fidry/cpu-core-counter", + "version": "1.2.0", + "source": { + "type": "git", + "url": "https://github.com/theofidry/cpu-core-counter.git", + "reference": "8520451a140d3f46ac33042715115e290cf5785f" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/theofidry/cpu-core-counter/zipball/8520451a140d3f46ac33042715115e290cf5785f", + "reference": "8520451a140d3f46ac33042715115e290cf5785f", + "shasum": "" + }, + "require": { + "php": "^7.2 || ^8.0" + }, + "require-dev": { + "fidry/makefile": "^0.2.0", + "fidry/php-cs-fixer-config": "^1.1.2", + "phpstan/extension-installer": "^1.2.0", + "phpstan/phpstan": "^1.9.2", + "phpstan/phpstan-deprecation-rules": "^1.0.0", + "phpstan/phpstan-phpunit": "^1.2.2", + "phpstan/phpstan-strict-rules": "^1.4.4", + "phpunit/phpunit": "^8.5.31 || ^9.5.26", + "webmozarts/strict-phpunit": "^7.5" + }, + "type": "library", + "autoload": { + "psr-4": { + "Fidry\\CpuCoreCounter\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Théo FIDRY", + "email": "theo.fidry@gmail.com" + } + ], + "description": "Tiny utility to get the number of CPU cores.", + "keywords": [ + "CPU", + "core" + ], + "support": { + "issues": "https://github.com/theofidry/cpu-core-counter/issues", + "source": "https://github.com/theofidry/cpu-core-counter/tree/1.2.0" + }, + "funding": [ + { + "url": "https://github.com/theofidry", + "type": "github" + } + ], + "time": "2024-08-06T10:04:20+00:00" + }, + { + "name": "filp/whoops", + "version": "2.16.0", + "source": { + "type": "git", + "url": "https://github.com/filp/whoops.git", + "reference": "befcdc0e5dce67252aa6322d82424be928214fa2" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/filp/whoops/zipball/befcdc0e5dce67252aa6322d82424be928214fa2", + "reference": "befcdc0e5dce67252aa6322d82424be928214fa2", + "shasum": "" + }, + "require": { + "php": "^7.1 || ^8.0", + "psr/log": "^1.0.1 || ^2.0 || ^3.0" + }, + "require-dev": { + "mockery/mockery": "^1.0", + "phpunit/phpunit": "^7.5.20 || ^8.5.8 || ^9.3.3", + "symfony/var-dumper": "^4.0 || ^5.0" + }, + "suggest": { + "symfony/var-dumper": "Pretty print complex values better with var-dumper available", + "whoops/soap": "Formats errors as SOAP responses" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.7-dev" + } + }, + "autoload": { + "psr-4": { + "Whoops\\": "src/Whoops/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Filipe Dobreira", + "homepage": "https://github.com/filp", + "role": "Developer" + } + ], + "description": "php error handling for cool kids", + "homepage": "https://filp.github.io/whoops/", + "keywords": [ + "error", + "exception", + "handling", + "library", + "throwable", + "whoops" + ], + "support": { + "issues": "https://github.com/filp/whoops/issues", + "source": "https://github.com/filp/whoops/tree/2.16.0" + }, + "funding": [ + { + "url": "https://github.com/denis-sokolov", + "type": "github" + } + ], + "time": "2024-09-25T12:00:00+00:00" + }, + { + "name": "friendsofphp/php-cs-fixer", + "version": "v3.64.0", + "source": { + "type": "git", + "url": "https://github.com/PHP-CS-Fixer/PHP-CS-Fixer.git", + "reference": "58dd9c931c785a79739310aef5178928305ffa67" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/PHP-CS-Fixer/PHP-CS-Fixer/zipball/58dd9c931c785a79739310aef5178928305ffa67", + "reference": "58dd9c931c785a79739310aef5178928305ffa67", + "shasum": "" + }, + "require": { + "clue/ndjson-react": "^1.0", + "composer/semver": "^3.4", + "composer/xdebug-handler": "^3.0.3", + "ext-filter": "*", + "ext-json": "*", + "ext-tokenizer": "*", + "fidry/cpu-core-counter": "^1.0", + "php": "^7.4 || ^8.0", + "react/child-process": "^0.6.5", + "react/event-loop": "^1.0", + "react/promise": "^2.0 || ^3.0", + "react/socket": "^1.0", + "react/stream": "^1.0", + "sebastian/diff": "^4.0 || ^5.0 || ^6.0", + "symfony/console": "^5.4 || ^6.0 || ^7.0", + "symfony/event-dispatcher": "^5.4 || ^6.0 || ^7.0", + "symfony/filesystem": "^5.4 || ^6.0 || ^7.0", + "symfony/finder": "^5.4 || ^6.0 || ^7.0", + "symfony/options-resolver": "^5.4 || ^6.0 || ^7.0", + "symfony/polyfill-mbstring": "^1.28", + "symfony/polyfill-php80": "^1.28", + "symfony/polyfill-php81": "^1.28", + "symfony/process": "^5.4 || ^6.0 || ^7.0", + "symfony/stopwatch": "^5.4 || ^6.0 || ^7.0" + }, + "require-dev": { + "facile-it/paraunit": "^1.3 || ^2.3", + "infection/infection": "^0.29.5", + "justinrainbow/json-schema": "^5.2", + "keradus/cli-executor": "^2.1", + "mikey179/vfsstream": "^1.6.11", + "php-coveralls/php-coveralls": "^2.7", + "php-cs-fixer/accessible-object": "^1.1", + "php-cs-fixer/phpunit-constraint-isidenticalstring": "^1.5", + "php-cs-fixer/phpunit-constraint-xmlmatchesxsd": "^1.5", + "phpunit/phpunit": "^9.6.19 || ^10.5.21 || ^11.2", + "symfony/var-dumper": "^5.4 || ^6.0 || ^7.0", + "symfony/yaml": "^5.4 || ^6.0 || ^7.0" + }, + "suggest": { + "ext-dom": "For handling output formats in XML", + "ext-mbstring": "For handling non-UTF8 characters." + }, + "bin": [ + "php-cs-fixer" + ], + "type": "application", + "autoload": { + "psr-4": { + "PhpCsFixer\\": "src/" + }, + "exclude-from-classmap": [ + "src/Fixer/Internal/*" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Dariusz Rumiński", + "email": "dariusz.ruminski@gmail.com" + } + ], + "description": "A tool to automatically fix PHP code style", + "keywords": [ + "Static code analysis", + "fixer", + "standards", + "static analysis" + ], + "support": { + "issues": "https://github.com/PHP-CS-Fixer/PHP-CS-Fixer/issues", + "source": "https://github.com/PHP-CS-Fixer/PHP-CS-Fixer/tree/v3.64.0" + }, + "funding": [ + { + "url": "https://github.com/keradus", + "type": "github" + } + ], + "time": "2024-08-30T23:09:38+00:00" + }, + { + "name": "hamcrest/hamcrest-php", + "version": "v2.0.1", + "source": { + "type": "git", + "url": "https://github.com/hamcrest/hamcrest-php.git", + "reference": "8c3d0a3f6af734494ad8f6fbbee0ba92422859f3" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/hamcrest/hamcrest-php/zipball/8c3d0a3f6af734494ad8f6fbbee0ba92422859f3", + "reference": "8c3d0a3f6af734494ad8f6fbbee0ba92422859f3", + "shasum": "" + }, + "require": { + "php": "^5.3|^7.0|^8.0" + }, + "replace": { + "cordoval/hamcrest-php": "*", + "davedevelopment/hamcrest-php": "*", + "kodova/hamcrest-php": "*" + }, + "require-dev": { + "phpunit/php-file-iterator": "^1.4 || ^2.0", + "phpunit/phpunit": "^4.8.36 || ^5.7 || ^6.5 || ^7.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.1-dev" + } + }, + "autoload": { + "classmap": [ + "hamcrest" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "description": "This is the PHP port of Hamcrest Matchers", + "keywords": [ + "test" + ], + "support": { + "issues": "https://github.com/hamcrest/hamcrest-php/issues", + "source": "https://github.com/hamcrest/hamcrest-php/tree/v2.0.1" + }, + "time": "2020-07-09T08:09:16+00:00" + }, + { + "name": "laravel/pint", + "version": "v1.18.1", + "source": { + "type": "git", + "url": "https://github.com/laravel/pint.git", + "reference": "35c00c05ec43e6b46d295efc0f4386ceb30d50d9" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/laravel/pint/zipball/35c00c05ec43e6b46d295efc0f4386ceb30d50d9", + "reference": "35c00c05ec43e6b46d295efc0f4386ceb30d50d9", + "shasum": "" + }, + "require": { + "ext-json": "*", + "ext-mbstring": "*", + "ext-tokenizer": "*", + "ext-xml": "*", + "php": "^8.1.0" + }, + "require-dev": { + "friendsofphp/php-cs-fixer": "^3.64.0", + "illuminate/view": "^10.48.20", + "larastan/larastan": "^2.9.8", + "laravel-zero/framework": "^10.4.0", + "mockery/mockery": "^1.6.12", + "nunomaduro/termwind": "^1.15.1", + "pestphp/pest": "^2.35.1" + }, + "bin": [ + "builds/pint" + ], + "type": "project", + "autoload": { + "psr-4": { + "App\\": "app/", + "Database\\Seeders\\": "database/seeders/", + "Database\\Factories\\": "database/factories/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nuno Maduro", + "email": "enunomaduro@gmail.com" + } + ], + "description": "An opinionated code formatter for PHP.", + "homepage": "https://laravel.com", + "keywords": [ + "format", + "formatter", + "lint", + "linter", + "php" + ], + "support": { + "issues": "https://github.com/laravel/pint/issues", + "source": "https://github.com/laravel/pint" + }, + "time": "2024-09-24T17:22:50+00:00" + }, + { + "name": "laravel/sail", + "version": "v1.38.0", + "source": { + "type": "git", + "url": "https://github.com/laravel/sail.git", + "reference": "d17abae06661dd6c46d13627b1683a2924259145" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/laravel/sail/zipball/d17abae06661dd6c46d13627b1683a2924259145", + "reference": "d17abae06661dd6c46d13627b1683a2924259145", + "shasum": "" + }, + "require": { + "illuminate/console": "^9.52.16|^10.0|^11.0", + "illuminate/contracts": "^9.52.16|^10.0|^11.0", + "illuminate/support": "^9.52.16|^10.0|^11.0", + "php": "^8.0", + "symfony/console": "^6.0|^7.0", + "symfony/yaml": "^6.0|^7.0" + }, + "require-dev": { + "orchestra/testbench": "^7.0|^8.0|^9.0", + "phpstan/phpstan": "^1.10" + }, + "bin": [ + "bin/sail" + ], + "type": "library", + "extra": { + "laravel": { + "providers": [ + "Laravel\\Sail\\SailServiceProvider" + ] + } + }, + "autoload": { + "psr-4": { + "Laravel\\Sail\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Taylor Otwell", + "email": "taylor@laravel.com" + } + ], + "description": "Docker files for running a basic Laravel application.", + "keywords": [ + "docker", + "laravel" + ], + "support": { + "issues": "https://github.com/laravel/sail/issues", + "source": "https://github.com/laravel/sail" + }, + "time": "2024-11-11T20:16:51+00:00" + }, + { + "name": "mockery/mockery", + "version": "1.6.12", + "source": { + "type": "git", + "url": "https://github.com/mockery/mockery.git", + "reference": "1f4efdd7d3beafe9807b08156dfcb176d18f1699" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/mockery/mockery/zipball/1f4efdd7d3beafe9807b08156dfcb176d18f1699", + "reference": "1f4efdd7d3beafe9807b08156dfcb176d18f1699", + "shasum": "" + }, + "require": { + "hamcrest/hamcrest-php": "^2.0.1", + "lib-pcre": ">=7.0", + "php": ">=7.3" + }, + "conflict": { + "phpunit/phpunit": "<8.0" + }, + "require-dev": { + "phpunit/phpunit": "^8.5 || ^9.6.17", + "symplify/easy-coding-standard": "^12.1.14" + }, + "type": "library", + "autoload": { + "files": [ + "library/helpers.php", + "library/Mockery.php" + ], + "psr-4": { + "Mockery\\": "library/Mockery" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Pádraic Brady", + "email": "padraic.brady@gmail.com", + "homepage": "https://github.com/padraic", + "role": "Author" + }, + { + "name": "Dave Marshall", + "email": "dave.marshall@atstsolutions.co.uk", + "homepage": "https://davedevelopment.co.uk", + "role": "Developer" + }, + { + "name": "Nathanael Esayeas", + "email": "nathanael.esayeas@protonmail.com", + "homepage": "https://github.com/ghostwriter", + "role": "Lead Developer" + } + ], + "description": "Mockery is a simple yet flexible PHP mock object framework", + "homepage": "https://github.com/mockery/mockery", + "keywords": [ + "BDD", + "TDD", + "library", + "mock", + "mock objects", + "mockery", + "stub", + "test", + "test double", + "testing" + ], + "support": { + "docs": "https://docs.mockery.io/", + "issues": "https://github.com/mockery/mockery/issues", + "rss": "https://github.com/mockery/mockery/releases.atom", + "security": "https://github.com/mockery/mockery/security/advisories", + "source": "https://github.com/mockery/mockery" + }, + "time": "2024-05-16T03:13:13+00:00" + }, + { + "name": "myclabs/deep-copy", + "version": "1.12.1", + "source": { + "type": "git", + "url": "https://github.com/myclabs/DeepCopy.git", + "reference": "123267b2c49fbf30d78a7b2d333f6be754b94845" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/myclabs/DeepCopy/zipball/123267b2c49fbf30d78a7b2d333f6be754b94845", + "reference": "123267b2c49fbf30d78a7b2d333f6be754b94845", + "shasum": "" + }, + "require": { + "php": "^7.1 || ^8.0" + }, + "conflict": { + "doctrine/collections": "<1.6.8", + "doctrine/common": "<2.13.3 || >=3 <3.2.2" + }, + "require-dev": { + "doctrine/collections": "^1.6.8", + "doctrine/common": "^2.13.3 || ^3.2.2", + "phpspec/prophecy": "^1.10", + "phpunit/phpunit": "^7.5.20 || ^8.5.23 || ^9.5.13" + }, + "type": "library", + "autoload": { + "files": [ + "src/DeepCopy/deep_copy.php" + ], + "psr-4": { + "DeepCopy\\": "src/DeepCopy/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "Create deep copies (clones) of your objects", + "keywords": [ + "clone", + "copy", + "duplicate", + "object", + "object graph" + ], + "support": { + "issues": "https://github.com/myclabs/DeepCopy/issues", + "source": "https://github.com/myclabs/DeepCopy/tree/1.12.1" + }, + "funding": [ + { + "url": "https://tidelift.com/funding/github/packagist/myclabs/deep-copy", + "type": "tidelift" + } + ], + "time": "2024-11-08T17:47:46+00:00" + }, + { + "name": "nunomaduro/collision", + "version": "v8.5.0", + "source": { + "type": "git", + "url": "https://github.com/nunomaduro/collision.git", + "reference": "f5c101b929c958e849a633283adff296ed5f38f5" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/nunomaduro/collision/zipball/f5c101b929c958e849a633283adff296ed5f38f5", + "reference": "f5c101b929c958e849a633283adff296ed5f38f5", + "shasum": "" + }, + "require": { + "filp/whoops": "^2.16.0", + "nunomaduro/termwind": "^2.1.0", + "php": "^8.2.0", + "symfony/console": "^7.1.5" + }, + "conflict": { + "laravel/framework": "<11.0.0 || >=12.0.0", + "phpunit/phpunit": "<10.5.1 || >=12.0.0" + }, + "require-dev": { + "larastan/larastan": "^2.9.8", + "laravel/framework": "^11.28.0", + "laravel/pint": "^1.18.1", + "laravel/sail": "^1.36.0", + "laravel/sanctum": "^4.0.3", + "laravel/tinker": "^2.10.0", + "orchestra/testbench-core": "^9.5.3", + "pestphp/pest": "^2.36.0 || ^3.4.0", + "sebastian/environment": "^6.1.0 || ^7.2.0" + }, + "type": "library", + "extra": { + "laravel": { + "providers": [ + "NunoMaduro\\Collision\\Adapters\\Laravel\\CollisionServiceProvider" + ] + }, + "branch-alias": { + "dev-8.x": "8.x-dev" + } + }, + "autoload": { + "files": [ + "./src/Adapters/Phpunit/Autoload.php" + ], + "psr-4": { + "NunoMaduro\\Collision\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nuno Maduro", + "email": "enunomaduro@gmail.com" + } + ], + "description": "Cli error handling for console/command-line PHP applications.", + "keywords": [ + "artisan", + "cli", + "command-line", + "console", + "error", + "handling", + "laravel", + "laravel-zero", + "php", + "symfony" + ], + "support": { + "issues": "https://github.com/nunomaduro/collision/issues", + "source": "https://github.com/nunomaduro/collision" + }, + "funding": [ + { + "url": "https://www.paypal.com/paypalme/enunomaduro", + "type": "custom" + }, + { + "url": "https://github.com/nunomaduro", + "type": "github" + }, + { + "url": "https://www.patreon.com/nunomaduro", + "type": "patreon" + } + ], + "time": "2024-10-15T16:06:32+00:00" + }, + { + "name": "phar-io/manifest", + "version": "2.0.4", + "source": { + "type": "git", + "url": "https://github.com/phar-io/manifest.git", + "reference": "54750ef60c58e43759730615a392c31c80e23176" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/phar-io/manifest/zipball/54750ef60c58e43759730615a392c31c80e23176", + "reference": "54750ef60c58e43759730615a392c31c80e23176", + "shasum": "" + }, + "require": { + "ext-dom": "*", + "ext-libxml": "*", + "ext-phar": "*", + "ext-xmlwriter": "*", + "phar-io/version": "^3.0.1", + "php": "^7.2 || ^8.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.0.x-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Arne Blankerts", + "email": "arne@blankerts.de", + "role": "Developer" + }, + { + "name": "Sebastian Heuer", + "email": "sebastian@phpeople.de", + "role": "Developer" + }, + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "Developer" + } + ], + "description": "Component for reading phar.io manifest information from a PHP Archive (PHAR)", + "support": { + "issues": "https://github.com/phar-io/manifest/issues", + "source": "https://github.com/phar-io/manifest/tree/2.0.4" + }, + "funding": [ + { + "url": "https://github.com/theseer", + "type": "github" + } + ], + "time": "2024-03-03T12:33:53+00:00" + }, + { + "name": "phar-io/version", + "version": "3.2.1", + "source": { + "type": "git", + "url": "https://github.com/phar-io/version.git", + "reference": "4f7fd7836c6f332bb2933569e566a0d6c4cbed74" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/phar-io/version/zipball/4f7fd7836c6f332bb2933569e566a0d6c4cbed74", + "reference": "4f7fd7836c6f332bb2933569e566a0d6c4cbed74", + "shasum": "" + }, + "require": { + "php": "^7.2 || ^8.0" + }, + "type": "library", + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Arne Blankerts", + "email": "arne@blankerts.de", + "role": "Developer" + }, + { + "name": "Sebastian Heuer", + "email": "sebastian@phpeople.de", + "role": "Developer" + }, + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "Developer" + } + ], + "description": "Library for handling version information and constraints", + "support": { + "issues": "https://github.com/phar-io/version/issues", + "source": "https://github.com/phar-io/version/tree/3.2.1" + }, + "time": "2022-02-21T01:04:05+00:00" + }, + { + "name": "phpdocumentor/reflection-common", + "version": "2.2.0", + "source": { + "type": "git", + "url": "https://github.com/phpDocumentor/ReflectionCommon.git", + "reference": "1d01c49d4ed62f25aa84a747ad35d5a16924662b" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/phpDocumentor/ReflectionCommon/zipball/1d01c49d4ed62f25aa84a747ad35d5a16924662b", + "reference": "1d01c49d4ed62f25aa84a747ad35d5a16924662b", + "shasum": "" + }, + "require": { + "php": "^7.2 || ^8.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-2.x": "2.x-dev" + } + }, + "autoload": { + "psr-4": { + "phpDocumentor\\Reflection\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Jaap van Otterdijk", + "email": "opensource@ijaap.nl" + } + ], + "description": "Common reflection classes used by phpdocumentor to reflect the code structure", + "homepage": "http://www.phpdoc.org", + "keywords": [ + "FQSEN", + "phpDocumentor", + "phpdoc", + "reflection", + "static analysis" + ], + "support": { + "issues": "https://github.com/phpDocumentor/ReflectionCommon/issues", + "source": "https://github.com/phpDocumentor/ReflectionCommon/tree/2.x" + }, + "time": "2020-06-27T09:03:43+00:00" + }, + { + "name": "phpdocumentor/type-resolver", + "version": "1.10.0", + "source": { + "type": "git", + "url": "https://github.com/phpDocumentor/TypeResolver.git", + "reference": "679e3ce485b99e84c775d28e2e96fade9a7fb50a" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/phpDocumentor/TypeResolver/zipball/679e3ce485b99e84c775d28e2e96fade9a7fb50a", + "reference": "679e3ce485b99e84c775d28e2e96fade9a7fb50a", + "shasum": "" + }, + "require": { + "doctrine/deprecations": "^1.0", + "php": "^7.3 || ^8.0", + "phpdocumentor/reflection-common": "^2.0", + "phpstan/phpdoc-parser": "^1.18|^2.0" + }, + "require-dev": { + "ext-tokenizer": "*", + "phpbench/phpbench": "^1.2", + "phpstan/extension-installer": "^1.1", + "phpstan/phpstan": "^1.8", + "phpstan/phpstan-phpunit": "^1.1", + "phpunit/phpunit": "^9.5", + "rector/rector": "^0.13.9", + "vimeo/psalm": "^4.25" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-1.x": "1.x-dev" + } + }, + "autoload": { + "psr-4": { + "phpDocumentor\\Reflection\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Mike van Riel", + "email": "me@mikevanriel.com" + } + ], + "description": "A PSR-5 based resolver of Class names, Types and Structural Element Names", + "support": { + "issues": "https://github.com/phpDocumentor/TypeResolver/issues", + "source": "https://github.com/phpDocumentor/TypeResolver/tree/1.10.0" + }, + "time": "2024-11-09T15:12:26+00:00" + }, + { + "name": "phpstan/phpdoc-parser", + "version": "2.0.0", + "source": { + "type": "git", + "url": "https://github.com/phpstan/phpdoc-parser.git", + "reference": "c00d78fb6b29658347f9d37ebe104bffadf36299" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/phpstan/phpdoc-parser/zipball/c00d78fb6b29658347f9d37ebe104bffadf36299", + "reference": "c00d78fb6b29658347f9d37ebe104bffadf36299", + "shasum": "" + }, + "require": { + "php": "^7.4 || ^8.0" + }, + "require-dev": { + "doctrine/annotations": "^2.0", + "nikic/php-parser": "^5.3.0", + "php-parallel-lint/php-parallel-lint": "^1.2", + "phpstan/extension-installer": "^1.0", + "phpstan/phpstan": "^2.0", + "phpstan/phpstan-phpunit": "^2.0", + "phpstan/phpstan-strict-rules": "^2.0", + "phpunit/phpunit": "^9.6", + "symfony/process": "^5.2" + }, + "type": "library", + "autoload": { + "psr-4": { + "PHPStan\\PhpDocParser\\": [ + "src/" + ] + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "PHPDoc parser with support for nullable, intersection and generic types", + "support": { + "issues": "https://github.com/phpstan/phpdoc-parser/issues", + "source": "https://github.com/phpstan/phpdoc-parser/tree/2.0.0" + }, + "time": "2024-10-13T11:29:49+00:00" + }, + { + "name": "phpunit/php-code-coverage", + "version": "11.0.7", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/php-code-coverage.git", + "reference": "f7f08030e8811582cc459871d28d6f5a1a4d35ca" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/f7f08030e8811582cc459871d28d6f5a1a4d35ca", + "reference": "f7f08030e8811582cc459871d28d6f5a1a4d35ca", + "shasum": "" + }, + "require": { + "ext-dom": "*", + "ext-libxml": "*", + "ext-xmlwriter": "*", + "nikic/php-parser": "^5.3.1", + "php": ">=8.2", + "phpunit/php-file-iterator": "^5.1.0", + "phpunit/php-text-template": "^4.0.1", + "sebastian/code-unit-reverse-lookup": "^4.0.1", + "sebastian/complexity": "^4.0.1", + "sebastian/environment": "^7.2.0", + "sebastian/lines-of-code": "^3.0.1", + "sebastian/version": "^5.0.2", + "theseer/tokenizer": "^1.2.3" + }, + "require-dev": { + "phpunit/phpunit": "^11.4.1" + }, + "suggest": { + "ext-pcov": "PHP extension that provides line coverage", + "ext-xdebug": "PHP extension that provides line coverage as well as branch and path coverage" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "11.0.x-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Library that provides collection, processing, and rendering functionality for PHP code coverage information.", + "homepage": "https://github.com/sebastianbergmann/php-code-coverage", + "keywords": [ + "coverage", + "testing", + "xunit" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/php-code-coverage/issues", + "security": "https://github.com/sebastianbergmann/php-code-coverage/security/policy", + "source": "https://github.com/sebastianbergmann/php-code-coverage/tree/11.0.7" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-10-09T06:21:38+00:00" + }, + { + "name": "phpunit/php-file-iterator", + "version": "5.1.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/php-file-iterator.git", + "reference": "118cfaaa8bc5aef3287bf315b6060b1174754af6" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/php-file-iterator/zipball/118cfaaa8bc5aef3287bf315b6060b1174754af6", + "reference": "118cfaaa8bc5aef3287bf315b6060b1174754af6", + "shasum": "" + }, + "require": { + "php": ">=8.2" + }, + "require-dev": { + "phpunit/phpunit": "^11.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "5.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "FilterIterator implementation that filters files based on a list of suffixes.", + "homepage": "https://github.com/sebastianbergmann/php-file-iterator/", + "keywords": [ + "filesystem", + "iterator" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/php-file-iterator/issues", + "security": "https://github.com/sebastianbergmann/php-file-iterator/security/policy", + "source": "https://github.com/sebastianbergmann/php-file-iterator/tree/5.1.0" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-08-27T05:02:59+00:00" + }, + { + "name": "phpunit/php-invoker", + "version": "5.0.1", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/php-invoker.git", + "reference": "c1ca3814734c07492b3d4c5f794f4b0995333da2" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/php-invoker/zipball/c1ca3814734c07492b3d4c5f794f4b0995333da2", + "reference": "c1ca3814734c07492b3d4c5f794f4b0995333da2", + "shasum": "" + }, + "require": { + "php": ">=8.2" + }, + "require-dev": { + "ext-pcntl": "*", + "phpunit/phpunit": "^11.0" + }, + "suggest": { + "ext-pcntl": "*" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "5.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Invoke callables with a timeout", + "homepage": "https://github.com/sebastianbergmann/php-invoker/", + "keywords": [ + "process" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/php-invoker/issues", + "security": "https://github.com/sebastianbergmann/php-invoker/security/policy", + "source": "https://github.com/sebastianbergmann/php-invoker/tree/5.0.1" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-07-03T05:07:44+00:00" + }, + { + "name": "phpunit/php-text-template", + "version": "4.0.1", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/php-text-template.git", + "reference": "3e0404dc6b300e6bf56415467ebcb3fe4f33e964" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/php-text-template/zipball/3e0404dc6b300e6bf56415467ebcb3fe4f33e964", + "reference": "3e0404dc6b300e6bf56415467ebcb3fe4f33e964", + "shasum": "" + }, + "require": { + "php": ">=8.2" + }, + "require-dev": { + "phpunit/phpunit": "^11.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "4.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Simple template engine.", + "homepage": "https://github.com/sebastianbergmann/php-text-template/", + "keywords": [ + "template" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/php-text-template/issues", + "security": "https://github.com/sebastianbergmann/php-text-template/security/policy", + "source": "https://github.com/sebastianbergmann/php-text-template/tree/4.0.1" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-07-03T05:08:43+00:00" + }, + { + "name": "phpunit/php-timer", + "version": "7.0.1", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/php-timer.git", + "reference": "3b415def83fbcb41f991d9ebf16ae4ad8b7837b3" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/php-timer/zipball/3b415def83fbcb41f991d9ebf16ae4ad8b7837b3", + "reference": "3b415def83fbcb41f991d9ebf16ae4ad8b7837b3", + "shasum": "" + }, + "require": { + "php": ">=8.2" + }, + "require-dev": { + "phpunit/phpunit": "^11.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "7.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Utility class for timing", + "homepage": "https://github.com/sebastianbergmann/php-timer/", + "keywords": [ + "timer" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/php-timer/issues", + "security": "https://github.com/sebastianbergmann/php-timer/security/policy", + "source": "https://github.com/sebastianbergmann/php-timer/tree/7.0.1" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-07-03T05:09:35+00:00" + }, + { + "name": "phpunit/phpunit", + "version": "11.4.3", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/phpunit.git", + "reference": "e8e8ed1854de5d36c088ec1833beae40d2dedd76" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/e8e8ed1854de5d36c088ec1833beae40d2dedd76", + "reference": "e8e8ed1854de5d36c088ec1833beae40d2dedd76", + "shasum": "" + }, + "require": { + "ext-dom": "*", + "ext-json": "*", + "ext-libxml": "*", + "ext-mbstring": "*", + "ext-xml": "*", + "ext-xmlwriter": "*", + "myclabs/deep-copy": "^1.12.0", + "phar-io/manifest": "^2.0.4", + "phar-io/version": "^3.2.1", + "php": ">=8.2", + "phpunit/php-code-coverage": "^11.0.7", + "phpunit/php-file-iterator": "^5.1.0", + "phpunit/php-invoker": "^5.0.1", + "phpunit/php-text-template": "^4.0.1", + "phpunit/php-timer": "^7.0.1", + "sebastian/cli-parser": "^3.0.2", + "sebastian/code-unit": "^3.0.1", + "sebastian/comparator": "^6.1.1", + "sebastian/diff": "^6.0.2", + "sebastian/environment": "^7.2.0", + "sebastian/exporter": "^6.1.3", + "sebastian/global-state": "^7.0.2", + "sebastian/object-enumerator": "^6.0.1", + "sebastian/type": "^5.1.0", + "sebastian/version": "^5.0.2" + }, + "suggest": { + "ext-soap": "To be able to generate mocks based on WSDL files" + }, + "bin": [ + "phpunit" + ], + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "11.4-dev" + } + }, + "autoload": { + "files": [ + "src/Framework/Assert/Functions.php" + ], + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "The PHP Unit Testing framework.", + "homepage": "https://phpunit.de/", + "keywords": [ + "phpunit", + "testing", + "xunit" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/phpunit/issues", + "security": "https://github.com/sebastianbergmann/phpunit/security/policy", + "source": "https://github.com/sebastianbergmann/phpunit/tree/11.4.3" + }, + "funding": [ + { + "url": "https://phpunit.de/sponsors.html", + "type": "custom" + }, + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/phpunit/phpunit", + "type": "tidelift" + } + ], + "time": "2024-10-28T13:07:50+00:00" + }, + { + "name": "react/cache", + "version": "v1.2.0", + "source": { + "type": "git", + "url": "https://github.com/reactphp/cache.git", + "reference": "d47c472b64aa5608225f47965a484b75c7817d5b" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/reactphp/cache/zipball/d47c472b64aa5608225f47965a484b75c7817d5b", + "reference": "d47c472b64aa5608225f47965a484b75c7817d5b", + "shasum": "" + }, + "require": { + "php": ">=5.3.0", + "react/promise": "^3.0 || ^2.0 || ^1.1" + }, + "require-dev": { + "phpunit/phpunit": "^9.5 || ^5.7 || ^4.8.35" + }, + "type": "library", + "autoload": { + "psr-4": { + "React\\Cache\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Christian Lück", + "email": "christian@clue.engineering", + "homepage": "https://clue.engineering/" + }, + { + "name": "Cees-Jan Kiewiet", + "email": "reactphp@ceesjankiewiet.nl", + "homepage": "https://wyrihaximus.net/" + }, + { + "name": "Jan Sorgalla", + "email": "jsorgalla@gmail.com", + "homepage": "https://sorgalla.com/" + }, + { + "name": "Chris Boden", + "email": "cboden@gmail.com", + "homepage": "https://cboden.dev/" + } + ], + "description": "Async, Promise-based cache interface for ReactPHP", + "keywords": [ + "cache", + "caching", + "promise", + "reactphp" + ], + "support": { + "issues": "https://github.com/reactphp/cache/issues", + "source": "https://github.com/reactphp/cache/tree/v1.2.0" + }, + "funding": [ + { + "url": "https://opencollective.com/reactphp", + "type": "open_collective" + } + ], + "time": "2022-11-30T15:59:55+00:00" + }, + { + "name": "react/child-process", + "version": "v0.6.5", + "source": { + "type": "git", + "url": "https://github.com/reactphp/child-process.git", + "reference": "e71eb1aa55f057c7a4a0d08d06b0b0a484bead43" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/reactphp/child-process/zipball/e71eb1aa55f057c7a4a0d08d06b0b0a484bead43", + "reference": "e71eb1aa55f057c7a4a0d08d06b0b0a484bead43", + "shasum": "" + }, + "require": { + "evenement/evenement": "^3.0 || ^2.0 || ^1.0", + "php": ">=5.3.0", + "react/event-loop": "^1.2", + "react/stream": "^1.2" + }, + "require-dev": { + "phpunit/phpunit": "^9.3 || ^5.7 || ^4.8.35", + "react/socket": "^1.8", + "sebastian/environment": "^5.0 || ^3.0 || ^2.0 || ^1.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "React\\ChildProcess\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Christian Lück", + "email": "christian@clue.engineering", + "homepage": "https://clue.engineering/" + }, + { + "name": "Cees-Jan Kiewiet", + "email": "reactphp@ceesjankiewiet.nl", + "homepage": "https://wyrihaximus.net/" + }, + { + "name": "Jan Sorgalla", + "email": "jsorgalla@gmail.com", + "homepage": "https://sorgalla.com/" + }, + { + "name": "Chris Boden", + "email": "cboden@gmail.com", + "homepage": "https://cboden.dev/" + } + ], + "description": "Event-driven library for executing child processes with ReactPHP.", + "keywords": [ + "event-driven", + "process", + "reactphp" + ], + "support": { + "issues": "https://github.com/reactphp/child-process/issues", + "source": "https://github.com/reactphp/child-process/tree/v0.6.5" + }, + "funding": [ + { + "url": "https://github.com/WyriHaximus", + "type": "github" + }, + { + "url": "https://github.com/clue", + "type": "github" + } + ], + "time": "2022-09-16T13:41:56+00:00" + }, + { + "name": "react/dns", + "version": "v1.13.0", + "source": { + "type": "git", + "url": "https://github.com/reactphp/dns.git", + "reference": "eb8ae001b5a455665c89c1df97f6fb682f8fb0f5" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/reactphp/dns/zipball/eb8ae001b5a455665c89c1df97f6fb682f8fb0f5", + "reference": "eb8ae001b5a455665c89c1df97f6fb682f8fb0f5", + "shasum": "" + }, + "require": { + "php": ">=5.3.0", + "react/cache": "^1.0 || ^0.6 || ^0.5", + "react/event-loop": "^1.2", + "react/promise": "^3.2 || ^2.7 || ^1.2.1" + }, + "require-dev": { + "phpunit/phpunit": "^9.6 || ^5.7 || ^4.8.36", + "react/async": "^4.3 || ^3 || ^2", + "react/promise-timer": "^1.11" + }, + "type": "library", + "autoload": { + "psr-4": { + "React\\Dns\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Christian Lück", + "email": "christian@clue.engineering", + "homepage": "https://clue.engineering/" + }, + { + "name": "Cees-Jan Kiewiet", + "email": "reactphp@ceesjankiewiet.nl", + "homepage": "https://wyrihaximus.net/" + }, + { + "name": "Jan Sorgalla", + "email": "jsorgalla@gmail.com", + "homepage": "https://sorgalla.com/" + }, + { + "name": "Chris Boden", + "email": "cboden@gmail.com", + "homepage": "https://cboden.dev/" + } + ], + "description": "Async DNS resolver for ReactPHP", + "keywords": [ + "async", + "dns", + "dns-resolver", + "reactphp" + ], + "support": { + "issues": "https://github.com/reactphp/dns/issues", + "source": "https://github.com/reactphp/dns/tree/v1.13.0" + }, + "funding": [ + { + "url": "https://opencollective.com/reactphp", + "type": "open_collective" + } + ], + "time": "2024-06-13T14:18:03+00:00" + }, + { + "name": "react/event-loop", + "version": "v1.5.0", + "source": { + "type": "git", + "url": "https://github.com/reactphp/event-loop.git", + "reference": "bbe0bd8c51ffc05ee43f1729087ed3bdf7d53354" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/reactphp/event-loop/zipball/bbe0bd8c51ffc05ee43f1729087ed3bdf7d53354", + "reference": "bbe0bd8c51ffc05ee43f1729087ed3bdf7d53354", + "shasum": "" + }, + "require": { + "php": ">=5.3.0" + }, + "require-dev": { + "phpunit/phpunit": "^9.6 || ^5.7 || ^4.8.36" + }, + "suggest": { + "ext-pcntl": "For signal handling support when using the StreamSelectLoop" + }, + "type": "library", + "autoload": { + "psr-4": { + "React\\EventLoop\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Christian Lück", + "email": "christian@clue.engineering", + "homepage": "https://clue.engineering/" + }, + { + "name": "Cees-Jan Kiewiet", + "email": "reactphp@ceesjankiewiet.nl", + "homepage": "https://wyrihaximus.net/" + }, + { + "name": "Jan Sorgalla", + "email": "jsorgalla@gmail.com", + "homepage": "https://sorgalla.com/" + }, + { + "name": "Chris Boden", + "email": "cboden@gmail.com", + "homepage": "https://cboden.dev/" + } + ], + "description": "ReactPHP's core reactor event loop that libraries can use for evented I/O.", + "keywords": [ + "asynchronous", + "event-loop" + ], + "support": { + "issues": "https://github.com/reactphp/event-loop/issues", + "source": "https://github.com/reactphp/event-loop/tree/v1.5.0" + }, + "funding": [ + { + "url": "https://opencollective.com/reactphp", + "type": "open_collective" + } + ], + "time": "2023-11-13T13:48:05+00:00" + }, + { + "name": "react/promise", + "version": "v3.2.0", + "source": { + "type": "git", + "url": "https://github.com/reactphp/promise.git", + "reference": "8a164643313c71354582dc850b42b33fa12a4b63" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/reactphp/promise/zipball/8a164643313c71354582dc850b42b33fa12a4b63", + "reference": "8a164643313c71354582dc850b42b33fa12a4b63", + "shasum": "" + }, + "require": { + "php": ">=7.1.0" + }, + "require-dev": { + "phpstan/phpstan": "1.10.39 || 1.4.10", + "phpunit/phpunit": "^9.6 || ^7.5" + }, + "type": "library", + "autoload": { + "files": [ + "src/functions_include.php" + ], + "psr-4": { + "React\\Promise\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Jan Sorgalla", + "email": "jsorgalla@gmail.com", + "homepage": "https://sorgalla.com/" + }, + { + "name": "Christian Lück", + "email": "christian@clue.engineering", + "homepage": "https://clue.engineering/" + }, + { + "name": "Cees-Jan Kiewiet", + "email": "reactphp@ceesjankiewiet.nl", + "homepage": "https://wyrihaximus.net/" + }, + { + "name": "Chris Boden", + "email": "cboden@gmail.com", + "homepage": "https://cboden.dev/" + } + ], + "description": "A lightweight implementation of CommonJS Promises/A for PHP", + "keywords": [ + "promise", + "promises" + ], + "support": { + "issues": "https://github.com/reactphp/promise/issues", + "source": "https://github.com/reactphp/promise/tree/v3.2.0" + }, + "funding": [ + { + "url": "https://opencollective.com/reactphp", + "type": "open_collective" + } + ], + "time": "2024-05-24T10:39:05+00:00" + }, + { + "name": "react/socket", + "version": "v1.16.0", + "source": { + "type": "git", + "url": "https://github.com/reactphp/socket.git", + "reference": "23e4ff33ea3e160d2d1f59a0e6050e4b0fb0eac1" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/reactphp/socket/zipball/23e4ff33ea3e160d2d1f59a0e6050e4b0fb0eac1", + "reference": "23e4ff33ea3e160d2d1f59a0e6050e4b0fb0eac1", + "shasum": "" + }, + "require": { + "evenement/evenement": "^3.0 || ^2.0 || ^1.0", + "php": ">=5.3.0", + "react/dns": "^1.13", + "react/event-loop": "^1.2", + "react/promise": "^3.2 || ^2.6 || ^1.2.1", + "react/stream": "^1.4" + }, + "require-dev": { + "phpunit/phpunit": "^9.6 || ^5.7 || ^4.8.36", + "react/async": "^4.3 || ^3.3 || ^2", + "react/promise-stream": "^1.4", + "react/promise-timer": "^1.11" + }, + "type": "library", + "autoload": { + "psr-4": { + "React\\Socket\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Christian Lück", + "email": "christian@clue.engineering", + "homepage": "https://clue.engineering/" + }, + { + "name": "Cees-Jan Kiewiet", + "email": "reactphp@ceesjankiewiet.nl", + "homepage": "https://wyrihaximus.net/" + }, + { + "name": "Jan Sorgalla", + "email": "jsorgalla@gmail.com", + "homepage": "https://sorgalla.com/" + }, + { + "name": "Chris Boden", + "email": "cboden@gmail.com", + "homepage": "https://cboden.dev/" + } + ], + "description": "Async, streaming plaintext TCP/IP and secure TLS socket server and client connections for ReactPHP", + "keywords": [ + "Connection", + "Socket", + "async", + "reactphp", + "stream" + ], + "support": { + "issues": "https://github.com/reactphp/socket/issues", + "source": "https://github.com/reactphp/socket/tree/v1.16.0" + }, + "funding": [ + { + "url": "https://opencollective.com/reactphp", + "type": "open_collective" + } + ], + "time": "2024-07-26T10:38:09+00:00" + }, + { + "name": "react/stream", + "version": "v1.4.0", + "source": { + "type": "git", + "url": "https://github.com/reactphp/stream.git", + "reference": "1e5b0acb8fe55143b5b426817155190eb6f5b18d" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/reactphp/stream/zipball/1e5b0acb8fe55143b5b426817155190eb6f5b18d", + "reference": "1e5b0acb8fe55143b5b426817155190eb6f5b18d", + "shasum": "" + }, + "require": { + "evenement/evenement": "^3.0 || ^2.0 || ^1.0", + "php": ">=5.3.8", + "react/event-loop": "^1.2" + }, + "require-dev": { + "clue/stream-filter": "~1.2", + "phpunit/phpunit": "^9.6 || ^5.7 || ^4.8.36" + }, + "type": "library", + "autoload": { + "psr-4": { + "React\\Stream\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Christian Lück", + "email": "christian@clue.engineering", + "homepage": "https://clue.engineering/" + }, + { + "name": "Cees-Jan Kiewiet", + "email": "reactphp@ceesjankiewiet.nl", + "homepage": "https://wyrihaximus.net/" + }, + { + "name": "Jan Sorgalla", + "email": "jsorgalla@gmail.com", + "homepage": "https://sorgalla.com/" + }, + { + "name": "Chris Boden", + "email": "cboden@gmail.com", + "homepage": "https://cboden.dev/" + } + ], + "description": "Event-driven readable and writable streams for non-blocking I/O in ReactPHP", + "keywords": [ + "event-driven", + "io", + "non-blocking", + "pipe", + "reactphp", + "readable", + "stream", + "writable" + ], + "support": { + "issues": "https://github.com/reactphp/stream/issues", + "source": "https://github.com/reactphp/stream/tree/v1.4.0" + }, + "funding": [ + { + "url": "https://opencollective.com/reactphp", + "type": "open_collective" + } + ], + "time": "2024-06-11T12:45:25+00:00" + }, + { + "name": "sebastian/cli-parser", + "version": "3.0.2", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/cli-parser.git", + "reference": "15c5dd40dc4f38794d383bb95465193f5e0ae180" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/cli-parser/zipball/15c5dd40dc4f38794d383bb95465193f5e0ae180", + "reference": "15c5dd40dc4f38794d383bb95465193f5e0ae180", + "shasum": "" + }, + "require": { + "php": ">=8.2" + }, + "require-dev": { + "phpunit/phpunit": "^11.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Library for parsing CLI options", + "homepage": "https://github.com/sebastianbergmann/cli-parser", + "support": { + "issues": "https://github.com/sebastianbergmann/cli-parser/issues", + "security": "https://github.com/sebastianbergmann/cli-parser/security/policy", + "source": "https://github.com/sebastianbergmann/cli-parser/tree/3.0.2" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-07-03T04:41:36+00:00" + }, + { + "name": "sebastian/code-unit", + "version": "3.0.1", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/code-unit.git", + "reference": "6bb7d09d6623567178cf54126afa9c2310114268" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/code-unit/zipball/6bb7d09d6623567178cf54126afa9c2310114268", + "reference": "6bb7d09d6623567178cf54126afa9c2310114268", + "shasum": "" + }, + "require": { + "php": ">=8.2" + }, + "require-dev": { + "phpunit/phpunit": "^11.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Collection of value objects that represent the PHP code units", + "homepage": "https://github.com/sebastianbergmann/code-unit", + "support": { + "issues": "https://github.com/sebastianbergmann/code-unit/issues", + "security": "https://github.com/sebastianbergmann/code-unit/security/policy", + "source": "https://github.com/sebastianbergmann/code-unit/tree/3.0.1" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-07-03T04:44:28+00:00" + }, + { + "name": "sebastian/code-unit-reverse-lookup", + "version": "4.0.1", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/code-unit-reverse-lookup.git", + "reference": "183a9b2632194febd219bb9246eee421dad8d45e" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/code-unit-reverse-lookup/zipball/183a9b2632194febd219bb9246eee421dad8d45e", + "reference": "183a9b2632194febd219bb9246eee421dad8d45e", + "shasum": "" + }, + "require": { + "php": ">=8.2" + }, + "require-dev": { + "phpunit/phpunit": "^11.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "4.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + } + ], + "description": "Looks up which function or method a line of code belongs to", + "homepage": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/", + "support": { + "issues": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/issues", + "security": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/security/policy", + "source": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/tree/4.0.1" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-07-03T04:45:54+00:00" + }, + { + "name": "sebastian/comparator", + "version": "6.2.1", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/comparator.git", + "reference": "43d129d6a0f81c78bee378b46688293eb7ea3739" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/comparator/zipball/43d129d6a0f81c78bee378b46688293eb7ea3739", + "reference": "43d129d6a0f81c78bee378b46688293eb7ea3739", + "shasum": "" + }, + "require": { + "ext-dom": "*", + "ext-mbstring": "*", + "php": ">=8.2", + "sebastian/diff": "^6.0", + "sebastian/exporter": "^6.0" + }, + "require-dev": { + "phpunit/phpunit": "^11.4" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "6.2-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + }, + { + "name": "Jeff Welch", + "email": "whatthejeff@gmail.com" + }, + { + "name": "Volker Dusch", + "email": "github@wallbash.com" + }, + { + "name": "Bernhard Schussek", + "email": "bschussek@2bepublished.at" + } + ], + "description": "Provides the functionality to compare PHP values for equality", + "homepage": "https://github.com/sebastianbergmann/comparator", + "keywords": [ + "comparator", + "compare", + "equality" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/comparator/issues", + "security": "https://github.com/sebastianbergmann/comparator/security/policy", + "source": "https://github.com/sebastianbergmann/comparator/tree/6.2.1" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-10-31T05:30:08+00:00" + }, + { + "name": "sebastian/complexity", + "version": "4.0.1", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/complexity.git", + "reference": "ee41d384ab1906c68852636b6de493846e13e5a0" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/complexity/zipball/ee41d384ab1906c68852636b6de493846e13e5a0", + "reference": "ee41d384ab1906c68852636b6de493846e13e5a0", + "shasum": "" + }, + "require": { + "nikic/php-parser": "^5.0", + "php": ">=8.2" + }, + "require-dev": { + "phpunit/phpunit": "^11.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "4.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Library for calculating the complexity of PHP code units", + "homepage": "https://github.com/sebastianbergmann/complexity", + "support": { + "issues": "https://github.com/sebastianbergmann/complexity/issues", + "security": "https://github.com/sebastianbergmann/complexity/security/policy", + "source": "https://github.com/sebastianbergmann/complexity/tree/4.0.1" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-07-03T04:49:50+00:00" + }, + { + "name": "sebastian/diff", + "version": "6.0.2", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/diff.git", + "reference": "b4ccd857127db5d41a5b676f24b51371d76d8544" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/diff/zipball/b4ccd857127db5d41a5b676f24b51371d76d8544", + "reference": "b4ccd857127db5d41a5b676f24b51371d76d8544", + "shasum": "" + }, + "require": { + "php": ">=8.2" + }, + "require-dev": { + "phpunit/phpunit": "^11.0", + "symfony/process": "^4.2 || ^5" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "6.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + }, + { + "name": "Kore Nordmann", + "email": "mail@kore-nordmann.de" + } + ], + "description": "Diff implementation", + "homepage": "https://github.com/sebastianbergmann/diff", + "keywords": [ + "diff", + "udiff", + "unidiff", + "unified diff" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/diff/issues", + "security": "https://github.com/sebastianbergmann/diff/security/policy", + "source": "https://github.com/sebastianbergmann/diff/tree/6.0.2" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-07-03T04:53:05+00:00" + }, + { + "name": "sebastian/environment", + "version": "7.2.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/environment.git", + "reference": "855f3ae0ab316bbafe1ba4e16e9f3c078d24a0c5" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/environment/zipball/855f3ae0ab316bbafe1ba4e16e9f3c078d24a0c5", + "reference": "855f3ae0ab316bbafe1ba4e16e9f3c078d24a0c5", + "shasum": "" + }, + "require": { + "php": ">=8.2" + }, + "require-dev": { + "phpunit/phpunit": "^11.0" + }, + "suggest": { + "ext-posix": "*" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "7.2-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + } + ], + "description": "Provides functionality to handle HHVM/PHP environments", + "homepage": "https://github.com/sebastianbergmann/environment", + "keywords": [ + "Xdebug", + "environment", + "hhvm" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/environment/issues", + "security": "https://github.com/sebastianbergmann/environment/security/policy", + "source": "https://github.com/sebastianbergmann/environment/tree/7.2.0" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-07-03T04:54:44+00:00" + }, + { + "name": "sebastian/exporter", + "version": "6.1.3", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/exporter.git", + "reference": "c414673eee9a8f9d51bbf8d61fc9e3ef1e85b20e" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/exporter/zipball/c414673eee9a8f9d51bbf8d61fc9e3ef1e85b20e", + "reference": "c414673eee9a8f9d51bbf8d61fc9e3ef1e85b20e", + "shasum": "" + }, + "require": { + "ext-mbstring": "*", + "php": ">=8.2", + "sebastian/recursion-context": "^6.0" + }, + "require-dev": { + "phpunit/phpunit": "^11.2" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "6.1-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + }, + { + "name": "Jeff Welch", + "email": "whatthejeff@gmail.com" + }, + { + "name": "Volker Dusch", + "email": "github@wallbash.com" + }, + { + "name": "Adam Harvey", + "email": "aharvey@php.net" + }, + { + "name": "Bernhard Schussek", + "email": "bschussek@gmail.com" + } + ], + "description": "Provides the functionality to export PHP variables for visualization", + "homepage": "https://www.github.com/sebastianbergmann/exporter", + "keywords": [ + "export", + "exporter" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/exporter/issues", + "security": "https://github.com/sebastianbergmann/exporter/security/policy", + "source": "https://github.com/sebastianbergmann/exporter/tree/6.1.3" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-07-03T04:56:19+00:00" + }, + { + "name": "sebastian/global-state", + "version": "7.0.2", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/global-state.git", + "reference": "3be331570a721f9a4b5917f4209773de17f747d7" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/global-state/zipball/3be331570a721f9a4b5917f4209773de17f747d7", + "reference": "3be331570a721f9a4b5917f4209773de17f747d7", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "sebastian/object-reflector": "^4.0", + "sebastian/recursion-context": "^6.0" + }, + "require-dev": { + "ext-dom": "*", + "phpunit/phpunit": "^11.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "7.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + } + ], + "description": "Snapshotting of global state", + "homepage": "https://www.github.com/sebastianbergmann/global-state", + "keywords": [ + "global state" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/global-state/issues", + "security": "https://github.com/sebastianbergmann/global-state/security/policy", + "source": "https://github.com/sebastianbergmann/global-state/tree/7.0.2" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-07-03T04:57:36+00:00" + }, + { + "name": "sebastian/lines-of-code", + "version": "3.0.1", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/lines-of-code.git", + "reference": "d36ad0d782e5756913e42ad87cb2890f4ffe467a" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/lines-of-code/zipball/d36ad0d782e5756913e42ad87cb2890f4ffe467a", + "reference": "d36ad0d782e5756913e42ad87cb2890f4ffe467a", + "shasum": "" + }, + "require": { + "nikic/php-parser": "^5.0", + "php": ">=8.2" + }, + "require-dev": { + "phpunit/phpunit": "^11.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Library for counting the lines of code in PHP source code", + "homepage": "https://github.com/sebastianbergmann/lines-of-code", + "support": { + "issues": "https://github.com/sebastianbergmann/lines-of-code/issues", + "security": "https://github.com/sebastianbergmann/lines-of-code/security/policy", + "source": "https://github.com/sebastianbergmann/lines-of-code/tree/3.0.1" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-07-03T04:58:38+00:00" + }, + { + "name": "sebastian/object-enumerator", + "version": "6.0.1", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/object-enumerator.git", + "reference": "f5b498e631a74204185071eb41f33f38d64608aa" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/object-enumerator/zipball/f5b498e631a74204185071eb41f33f38d64608aa", + "reference": "f5b498e631a74204185071eb41f33f38d64608aa", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "sebastian/object-reflector": "^4.0", + "sebastian/recursion-context": "^6.0" + }, + "require-dev": { + "phpunit/phpunit": "^11.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "6.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + } + ], + "description": "Traverses array structures and object graphs to enumerate all referenced objects", + "homepage": "https://github.com/sebastianbergmann/object-enumerator/", + "support": { + "issues": "https://github.com/sebastianbergmann/object-enumerator/issues", + "security": "https://github.com/sebastianbergmann/object-enumerator/security/policy", + "source": "https://github.com/sebastianbergmann/object-enumerator/tree/6.0.1" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-07-03T05:00:13+00:00" + }, + { + "name": "sebastian/object-reflector", + "version": "4.0.1", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/object-reflector.git", + "reference": "6e1a43b411b2ad34146dee7524cb13a068bb35f9" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/object-reflector/zipball/6e1a43b411b2ad34146dee7524cb13a068bb35f9", + "reference": "6e1a43b411b2ad34146dee7524cb13a068bb35f9", + "shasum": "" + }, + "require": { + "php": ">=8.2" + }, + "require-dev": { + "phpunit/phpunit": "^11.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "4.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + } + ], + "description": "Allows reflection of object attributes, including inherited and non-public ones", + "homepage": "https://github.com/sebastianbergmann/object-reflector/", + "support": { + "issues": "https://github.com/sebastianbergmann/object-reflector/issues", + "security": "https://github.com/sebastianbergmann/object-reflector/security/policy", + "source": "https://github.com/sebastianbergmann/object-reflector/tree/4.0.1" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-07-03T05:01:32+00:00" + }, + { + "name": "sebastian/recursion-context", + "version": "6.0.2", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/recursion-context.git", + "reference": "694d156164372abbd149a4b85ccda2e4670c0e16" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/recursion-context/zipball/694d156164372abbd149a4b85ccda2e4670c0e16", + "reference": "694d156164372abbd149a4b85ccda2e4670c0e16", + "shasum": "" + }, + "require": { + "php": ">=8.2" + }, + "require-dev": { + "phpunit/phpunit": "^11.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "6.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + }, + { + "name": "Jeff Welch", + "email": "whatthejeff@gmail.com" + }, + { + "name": "Adam Harvey", + "email": "aharvey@php.net" + } + ], + "description": "Provides functionality to recursively process PHP variables", + "homepage": "https://github.com/sebastianbergmann/recursion-context", + "support": { + "issues": "https://github.com/sebastianbergmann/recursion-context/issues", + "security": "https://github.com/sebastianbergmann/recursion-context/security/policy", + "source": "https://github.com/sebastianbergmann/recursion-context/tree/6.0.2" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-07-03T05:10:34+00:00" + }, + { + "name": "sebastian/type", + "version": "5.1.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/type.git", + "reference": "461b9c5da241511a2a0e8f240814fb23ce5c0aac" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/type/zipball/461b9c5da241511a2a0e8f240814fb23ce5c0aac", + "reference": "461b9c5da241511a2a0e8f240814fb23ce5c0aac", + "shasum": "" + }, + "require": { + "php": ">=8.2" + }, + "require-dev": { + "phpunit/phpunit": "^11.3" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "5.1-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Collection of value objects that represent the types of the PHP type system", + "homepage": "https://github.com/sebastianbergmann/type", + "support": { + "issues": "https://github.com/sebastianbergmann/type/issues", + "security": "https://github.com/sebastianbergmann/type/security/policy", + "source": "https://github.com/sebastianbergmann/type/tree/5.1.0" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-09-17T13:12:04+00:00" + }, + { + "name": "sebastian/version", + "version": "5.0.2", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/version.git", + "reference": "c687e3387b99f5b03b6caa64c74b63e2936ff874" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/version/zipball/c687e3387b99f5b03b6caa64c74b63e2936ff874", + "reference": "c687e3387b99f5b03b6caa64c74b63e2936ff874", + "shasum": "" + }, + "require": { + "php": ">=8.2" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "5.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Library that helps with managing the version number of Git-hosted PHP projects", + "homepage": "https://github.com/sebastianbergmann/version", + "support": { + "issues": "https://github.com/sebastianbergmann/version/issues", + "security": "https://github.com/sebastianbergmann/version/security/policy", + "source": "https://github.com/sebastianbergmann/version/tree/5.0.2" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-10-09T05:16:32+00:00" + }, + { + "name": "spatie/backtrace", + "version": "1.6.2", + "source": { + "type": "git", + "url": "https://github.com/spatie/backtrace.git", + "reference": "1a9a145b044677ae3424693f7b06479fc8c137a9" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/spatie/backtrace/zipball/1a9a145b044677ae3424693f7b06479fc8c137a9", + "reference": "1a9a145b044677ae3424693f7b06479fc8c137a9", + "shasum": "" + }, + "require": { + "php": "^7.3|^8.0" + }, + "require-dev": { + "ext-json": "*", + "laravel/serializable-closure": "^1.3", + "phpunit/phpunit": "^9.3", + "spatie/phpunit-snapshot-assertions": "^4.2", + "symfony/var-dumper": "^5.1" + }, + "type": "library", + "autoload": { + "psr-4": { + "Spatie\\Backtrace\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Freek Van de Herten", + "email": "freek@spatie.be", + "homepage": "https://spatie.be", + "role": "Developer" + } + ], + "description": "A better backtrace", + "homepage": "https://github.com/spatie/backtrace", + "keywords": [ + "Backtrace", + "spatie" + ], + "support": { + "source": "https://github.com/spatie/backtrace/tree/1.6.2" + }, + "funding": [ + { + "url": "https://github.com/sponsors/spatie", + "type": "github" + }, + { + "url": "https://spatie.be/open-source/support-us", + "type": "other" + } + ], + "time": "2024-07-22T08:21:24+00:00" + }, + { + "name": "spatie/error-solutions", + "version": "1.1.1", + "source": { + "type": "git", + "url": "https://github.com/spatie/error-solutions.git", + "reference": "ae7393122eda72eed7cc4f176d1e96ea444f2d67" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/spatie/error-solutions/zipball/ae7393122eda72eed7cc4f176d1e96ea444f2d67", + "reference": "ae7393122eda72eed7cc4f176d1e96ea444f2d67", + "shasum": "" + }, + "require": { + "php": "^8.0" + }, + "require-dev": { + "illuminate/broadcasting": "^10.0|^11.0", + "illuminate/cache": "^10.0|^11.0", + "illuminate/support": "^10.0|^11.0", + "livewire/livewire": "^2.11|^3.3.5", + "openai-php/client": "^0.10.1", + "orchestra/testbench": "^7.0|8.22.3|^9.0", + "pestphp/pest": "^2.20", + "phpstan/phpstan": "^1.11", + "psr/simple-cache": "^3.0", + "psr/simple-cache-implementation": "^3.0", + "spatie/ray": "^1.28", + "symfony/cache": "^5.4|^6.0|^7.0", + "symfony/process": "^5.4|^6.0|^7.0", + "vlucas/phpdotenv": "^5.5" + }, + "suggest": { + "openai-php/client": "Require get solutions from OpenAI", + "simple-cache-implementation": "To cache solutions from OpenAI" + }, + "type": "library", + "autoload": { + "psr-4": { + "Spatie\\Ignition\\": "legacy/ignition", + "Spatie\\ErrorSolutions\\": "src", + "Spatie\\LaravelIgnition\\": "legacy/laravel-ignition" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Ruben Van Assche", + "email": "ruben@spatie.be", + "role": "Developer" + } + ], + "description": "This is my package error-solutions", + "homepage": "https://github.com/spatie/error-solutions", + "keywords": [ + "error-solutions", + "spatie" + ], + "support": { + "issues": "https://github.com/spatie/error-solutions/issues", + "source": "https://github.com/spatie/error-solutions/tree/1.1.1" + }, + "funding": [ + { + "url": "https://github.com/Spatie", + "type": "github" + } + ], + "time": "2024-07-25T11:06:04+00:00" + }, + { + "name": "spatie/flare-client-php", + "version": "1.8.0", + "source": { + "type": "git", + "url": "https://github.com/spatie/flare-client-php.git", + "reference": "180f8ca4c0d0d6fc51477bd8c53ce37ab5a96122" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/spatie/flare-client-php/zipball/180f8ca4c0d0d6fc51477bd8c53ce37ab5a96122", + "reference": "180f8ca4c0d0d6fc51477bd8c53ce37ab5a96122", + "shasum": "" + }, + "require": { + "illuminate/pipeline": "^8.0|^9.0|^10.0|^11.0", + "php": "^8.0", + "spatie/backtrace": "^1.6.1", + "symfony/http-foundation": "^5.2|^6.0|^7.0", + "symfony/mime": "^5.2|^6.0|^7.0", + "symfony/process": "^5.2|^6.0|^7.0", + "symfony/var-dumper": "^5.2|^6.0|^7.0" + }, + "require-dev": { + "dms/phpunit-arraysubset-asserts": "^0.5.0", + "pestphp/pest": "^1.20|^2.0", + "phpstan/extension-installer": "^1.1", + "phpstan/phpstan-deprecation-rules": "^1.0", + "phpstan/phpstan-phpunit": "^1.0", + "spatie/pest-plugin-snapshots": "^1.0|^2.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "1.3.x-dev" + } + }, + "autoload": { + "files": [ + "src/helpers.php" + ], + "psr-4": { + "Spatie\\FlareClient\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "Send PHP errors to Flare", + "homepage": "https://github.com/spatie/flare-client-php", + "keywords": [ + "exception", + "flare", + "reporting", + "spatie" + ], + "support": { + "issues": "https://github.com/spatie/flare-client-php/issues", + "source": "https://github.com/spatie/flare-client-php/tree/1.8.0" + }, + "funding": [ + { + "url": "https://github.com/spatie", + "type": "github" + } + ], + "time": "2024-08-01T08:27:26+00:00" + }, + { + "name": "spatie/ignition", + "version": "1.15.0", + "source": { + "type": "git", + "url": "https://github.com/spatie/ignition.git", + "reference": "e3a68e137371e1eb9edc7f78ffa733f3b98991d2" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/spatie/ignition/zipball/e3a68e137371e1eb9edc7f78ffa733f3b98991d2", + "reference": "e3a68e137371e1eb9edc7f78ffa733f3b98991d2", + "shasum": "" + }, + "require": { + "ext-json": "*", + "ext-mbstring": "*", + "php": "^8.0", + "spatie/error-solutions": "^1.0", + "spatie/flare-client-php": "^1.7", + "symfony/console": "^5.4|^6.0|^7.0", + "symfony/var-dumper": "^5.4|^6.0|^7.0" + }, + "require-dev": { + "illuminate/cache": "^9.52|^10.0|^11.0", + "mockery/mockery": "^1.4", + "pestphp/pest": "^1.20|^2.0", + "phpstan/extension-installer": "^1.1", + "phpstan/phpstan-deprecation-rules": "^1.0", + "phpstan/phpstan-phpunit": "^1.0", + "psr/simple-cache-implementation": "*", + "symfony/cache": "^5.4|^6.0|^7.0", + "symfony/process": "^5.4|^6.0|^7.0", + "vlucas/phpdotenv": "^5.5" + }, + "suggest": { + "openai-php/client": "Require get solutions from OpenAI", + "simple-cache-implementation": "To cache solutions from OpenAI" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "1.5.x-dev" + } + }, + "autoload": { + "psr-4": { + "Spatie\\Ignition\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Spatie", + "email": "info@spatie.be", + "role": "Developer" + } + ], + "description": "A beautiful error page for PHP applications.", + "homepage": "https://flareapp.io/ignition", + "keywords": [ + "error", + "flare", + "laravel", + "page" + ], + "support": { + "docs": "https://flareapp.io/docs/ignition-for-laravel/introduction", + "forum": "https://twitter.com/flareappio", + "issues": "https://github.com/spatie/ignition/issues", + "source": "https://github.com/spatie/ignition" + }, + "funding": [ + { + "url": "https://github.com/spatie", + "type": "github" + } + ], + "time": "2024-06-12T14:55:22+00:00" + }, + { + "name": "spatie/laravel-ignition", + "version": "2.8.0", + "source": { + "type": "git", + "url": "https://github.com/spatie/laravel-ignition.git", + "reference": "3c067b75bfb50574db8f7e2c3978c65eed71126c" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/spatie/laravel-ignition/zipball/3c067b75bfb50574db8f7e2c3978c65eed71126c", + "reference": "3c067b75bfb50574db8f7e2c3978c65eed71126c", + "shasum": "" + }, + "require": { + "ext-curl": "*", + "ext-json": "*", + "ext-mbstring": "*", + "illuminate/support": "^10.0|^11.0", + "php": "^8.1", + "spatie/ignition": "^1.15", + "symfony/console": "^6.2.3|^7.0", + "symfony/var-dumper": "^6.2.3|^7.0" + }, + "require-dev": { + "livewire/livewire": "^2.11|^3.3.5", + "mockery/mockery": "^1.5.1", + "openai-php/client": "^0.8.1", + "orchestra/testbench": "8.22.3|^9.0", + "pestphp/pest": "^2.34", + "phpstan/extension-installer": "^1.3.1", + "phpstan/phpstan-deprecation-rules": "^1.1.1", + "phpstan/phpstan-phpunit": "^1.3.16", + "vlucas/phpdotenv": "^5.5" + }, + "suggest": { + "openai-php/client": "Require get solutions from OpenAI", + "psr/simple-cache-implementation": "Needed to cache solutions from OpenAI" + }, + "type": "library", + "extra": { + "laravel": { + "providers": [ + "Spatie\\LaravelIgnition\\IgnitionServiceProvider" + ], + "aliases": { + "Flare": "Spatie\\LaravelIgnition\\Facades\\Flare" + } + } + }, + "autoload": { + "files": [ + "src/helpers.php" + ], + "psr-4": { + "Spatie\\LaravelIgnition\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Spatie", + "email": "info@spatie.be", + "role": "Developer" + } + ], + "description": "A beautiful error page for Laravel applications.", + "homepage": "https://flareapp.io/ignition", + "keywords": [ + "error", + "flare", + "laravel", + "page" + ], + "support": { + "docs": "https://flareapp.io/docs/ignition-for-laravel/introduction", + "forum": "https://twitter.com/flareappio", + "issues": "https://github.com/spatie/laravel-ignition/issues", + "source": "https://github.com/spatie/laravel-ignition" + }, + "funding": [ + { + "url": "https://github.com/spatie", + "type": "github" + } + ], + "time": "2024-06-12T15:01:18+00:00" + }, + { + "name": "symfony/filesystem", + "version": "v7.1.6", + "source": { + "type": "git", + "url": "https://github.com/symfony/filesystem.git", + "reference": "c835867b3c62bb05c7fe3d637c871c7ae52024d4" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/filesystem/zipball/c835867b3c62bb05c7fe3d637c871c7ae52024d4", + "reference": "c835867b3c62bb05c7fe3d637c871c7ae52024d4", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "symfony/polyfill-ctype": "~1.8", + "symfony/polyfill-mbstring": "~1.8" + }, + "require-dev": { + "symfony/process": "^6.4|^7.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\Filesystem\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Provides basic utilities for the filesystem", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/filesystem/tree/v7.1.6" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-10-25T15:11:02+00:00" + }, + { + "name": "symfony/options-resolver", + "version": "v7.1.6", + "source": { + "type": "git", + "url": "https://github.com/symfony/options-resolver.git", + "reference": "85e95eeede2d41cd146146e98c9c81d9214cae85" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/options-resolver/zipball/85e95eeede2d41cd146146e98c9c81d9214cae85", + "reference": "85e95eeede2d41cd146146e98c9c81d9214cae85", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "symfony/deprecation-contracts": "^2.5|^3" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\OptionsResolver\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Provides an improved replacement for the array_replace PHP function", + "homepage": "https://symfony.com", + "keywords": [ + "config", + "configuration", + "options" + ], + "support": { + "source": "https://github.com/symfony/options-resolver/tree/v7.1.6" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-25T14:20:29+00:00" + }, + { + "name": "symfony/stopwatch", + "version": "v7.1.6", + "source": { + "type": "git", + "url": "https://github.com/symfony/stopwatch.git", + "reference": "8b4a434e6e7faf6adedffb48783a5c75409a1a05" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/stopwatch/zipball/8b4a434e6e7faf6adedffb48783a5c75409a1a05", + "reference": "8b4a434e6e7faf6adedffb48783a5c75409a1a05", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "symfony/service-contracts": "^2.5|^3" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\Stopwatch\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Provides a way to profile code", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/stopwatch/tree/v7.1.6" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-25T14:20:29+00:00" + }, + { + "name": "symfony/yaml", + "version": "v7.1.6", + "source": { + "type": "git", + "url": "https://github.com/symfony/yaml.git", + "reference": "3ced3f29e4f0d6bce2170ff26719f1fe9aacc671" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/yaml/zipball/3ced3f29e4f0d6bce2170ff26719f1fe9aacc671", + "reference": "3ced3f29e4f0d6bce2170ff26719f1fe9aacc671", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "symfony/polyfill-ctype": "^1.8" + }, + "conflict": { + "symfony/console": "<6.4" + }, + "require-dev": { + "symfony/console": "^6.4|^7.0" + }, + "bin": [ + "Resources/bin/yaml-lint" + ], + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\Yaml\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Loads and dumps YAML files", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/yaml/tree/v7.1.6" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-25T14:20:29+00:00" + }, + { + "name": "theseer/tokenizer", + "version": "1.2.3", + "source": { + "type": "git", + "url": "https://github.com/theseer/tokenizer.git", + "reference": "737eda637ed5e28c3413cb1ebe8bb52cbf1ca7a2" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/theseer/tokenizer/zipball/737eda637ed5e28c3413cb1ebe8bb52cbf1ca7a2", + "reference": "737eda637ed5e28c3413cb1ebe8bb52cbf1ca7a2", + "shasum": "" + }, + "require": { + "ext-dom": "*", + "ext-tokenizer": "*", + "ext-xmlwriter": "*", + "php": "^7.2 || ^8.0" + }, + "type": "library", + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Arne Blankerts", + "email": "arne@blankerts.de", + "role": "Developer" + } + ], + "description": "A small library for converting tokenized PHP source code into XML and potentially other formats", + "support": { + "issues": "https://github.com/theseer/tokenizer/issues", + "source": "https://github.com/theseer/tokenizer/tree/1.2.3" + }, + "funding": [ + { + "url": "https://github.com/theseer", + "type": "github" + } + ], + "time": "2024-03-03T12:36:25+00:00" + } + ], + "aliases": [], + "minimum-stability": "stable", + "stability-flags": [], + "prefer-stable": true, + "prefer-lowest": false, + "platform": { + "php": "^8.2" + }, + "platform-dev": [], + "plugin-api-version": "2.3.0" +} diff --git a/config/app.php b/config/app.php new file mode 100644 index 0000000..9eca5e2 --- /dev/null +++ b/config/app.php @@ -0,0 +1,128 @@ + env('APP_VERSION', 'unknown'), + + /* + |-------------------------------------------------------------------------- + | Application Name + |-------------------------------------------------------------------------- + | + | This value is the name of your application, which will be used when the + | framework needs to place the application's name in a notification or + | other UI elements where an application name needs to be displayed. + | + */ + + 'name' => env('APP_NAME', 'Laravel'), + + /* + |-------------------------------------------------------------------------- + | Application Environment + |-------------------------------------------------------------------------- + | + | This value determines the "environment" your application is currently + | running in. This may determine how you prefer to configure various + | services the application utilizes. Set this in your ".env" file. + | + */ + + 'env' => env('APP_ENV', 'production'), + + /* + |-------------------------------------------------------------------------- + | Application Debug Mode + |-------------------------------------------------------------------------- + | + | When your application is in debug mode, detailed error messages with + | stack traces will be shown on every error that occurs within your + | application. If disabled, a simple generic error page is shown. + | + */ + + 'debug' => (bool) env('APP_DEBUG', false), + + /* + |-------------------------------------------------------------------------- + | Application URL + |-------------------------------------------------------------------------- + | + | This URL is used by the console to properly generate URLs when using + | the Artisan command line tool. You should set this to the root of + | the application so that it's available within Artisan commands. + | + */ + + 'url' => env('APP_URL', 'http://localhost'), + + /* + |-------------------------------------------------------------------------- + | Application Timezone + |-------------------------------------------------------------------------- + | + | Here you may specify the default timezone for your application, which + | will be used by the PHP date and date-time functions. The timezone + | is set to "UTC" by default as it is suitable for most use cases. + | + */ + + 'timezone' => env('APP_TIMEZONE', 'UTC'), + + /* + |-------------------------------------------------------------------------- + | Application Locale Configuration + |-------------------------------------------------------------------------- + | + | The application locale determines the default locale that will be used + | by Laravel's translation / localization methods. This option can be + | set to any locale for which you plan to have translation strings. + | + */ + + 'locale' => env('APP_LOCALE', 'en'), + + 'fallback_locale' => env('APP_FALLBACK_LOCALE', 'en'), + + 'faker_locale' => env('APP_FAKER_LOCALE', 'en_US'), + + /* + |-------------------------------------------------------------------------- + | Encryption Key + |-------------------------------------------------------------------------- + | + | This key is utilized by Laravel's encryption services and should be set + | to a random, 32 character string to ensure that all encrypted values + | are secure. You should do this prior to deploying the application. + | + */ + + 'cipher' => 'AES-256-CBC', + + 'key' => env('APP_KEY'), + + 'previous_keys' => [ + ...array_filter( + explode(',', env('APP_PREVIOUS_KEYS', '')) + ), + ], + + /* + |-------------------------------------------------------------------------- + | Maintenance Mode Driver + |-------------------------------------------------------------------------- + | + | These configuration options determine the driver used to determine and + | manage Laravel's "maintenance mode" status. The "cache" driver will + | allow maintenance mode to be controlled across multiple machines. + | + | Supported drivers: "file", "cache" + | + */ + + 'maintenance' => [ + 'driver' => env('APP_MAINTENANCE_DRIVER', 'file'), + 'store' => env('APP_MAINTENANCE_STORE', 'database'), + ], + +]; diff --git a/config/auth.php b/config/auth.php new file mode 100644 index 0000000..2d4a51f --- /dev/null +++ b/config/auth.php @@ -0,0 +1,104 @@ + [ + 'guard' => env('AUTH_GUARD', 'web'), + 'passwords' => env('AUTH_PASSWORD_BROKER', 'users'), + ], + + /* + |-------------------------------------------------------------------------- + | Authentication Guards + |-------------------------------------------------------------------------- + | + | Next, you may define every authentication guard for your application. + | Of course, a great default configuration has been defined for you + | which utilizes session storage plus the Eloquent user provider. + | + | All authentication guards have a user provider, which defines how the + | users are actually retrieved out of your database or other storage + | system used by the application. Typically, Eloquent is utilized. + | + | Supported: "session" + | + */ + + 'guards' => [ + 'web' => ['driver' => 'session', 'provider' => 'users'], + ], + + /* + |-------------------------------------------------------------------------- + | User Providers + |-------------------------------------------------------------------------- + | + | All authentication guards have a user provider, which defines how the + | users are actually retrieved out of your database or other storage + | system used by the application. Typically, Eloquent is utilized. + | + | If you have multiple user tables or models you may configure multiple + | providers to represent the model / table. These providers may then + | be assigned to any extra authentication guards you have defined. + | + | Supported: "database", "eloquent" + | + */ + + 'providers' => [ + 'users' => ['driver' => 'eloquent', 'model' => env('AUTH_MODEL', App\Models\User::class)], + ], + + /* + |-------------------------------------------------------------------------- + | Resetting Passwords + |-------------------------------------------------------------------------- + | + | These configuration options specify the behavior of Laravel's password + | reset functionality, including the table utilized for token storage + | and the user provider that is invoked to actually retrieve users. + | + | The expiry time is the number of minutes that each reset token will be + | considered valid. This security feature keeps tokens short-lived so + | they have less time to be guessed. You may change this as needed. + | + | The throttle setting is the number of seconds a user must wait before + | generating more password reset tokens. This prevents the user from + | quickly generating a very large amount of password reset tokens. + | + */ + + 'passwords' => [ + 'users' => [ + 'provider' => 'users', + 'table' => env('AUTH_PASSWORD_RESET_TOKEN_TABLE', 'app_password_reset_tokens'), + 'expire' => 60, + 'throttle' => 60, + ], + ], + + /* + |-------------------------------------------------------------------------- + | Password Confirmation Timeout + |-------------------------------------------------------------------------- + | + | Here you may define the amount of seconds before a password confirmation + | window expires and users are asked to re-enter their password via the + | confirmation screen. By default, the timeout lasts for three hours. + | + */ + + 'password_timeout' => env('AUTH_PASSWORD_TIMEOUT', 10800), + +]; diff --git a/config/cache.php b/config/cache.php new file mode 100644 index 0000000..be38489 --- /dev/null +++ b/config/cache.php @@ -0,0 +1,108 @@ + env('CACHE_STORE', 'database'), + + /* + |-------------------------------------------------------------------------- + | Cache Stores + |-------------------------------------------------------------------------- + | + | Here you may define all of the cache "stores" for your application as + | well as their drivers. You may even define multiple stores for the + | same cache driver to group types of items stored in your caches. + | + | Supported drivers: "array", "database", "file", "memcached", + | "redis", "dynamodb", "octane", "null" + | + */ + + 'stores' => [ + + 'array' => [ + 'driver' => 'array', + 'serialize' => false, + ], + + 'database' => [ + 'driver' => 'database', + 'connection' => env('DB_CACHE_CONNECTION'), + 'table' => env('DB_CACHE_TABLE', 'app_cache'), + 'lock_connection' => env('DB_CACHE_LOCK_CONNECTION'), + 'lock_table' => env('DB_CACHE_LOCK_TABLE'), + ], + + 'file' => [ + 'driver' => 'file', + 'path' => storage_path('framework/cache/data'), + 'lock_path' => storage_path('framework/cache/data'), + ], + + 'memcached' => [ + 'driver' => 'memcached', + 'persistent_id' => env('MEMCACHED_PERSISTENT_ID'), + 'sasl' => [ + env('MEMCACHED_USERNAME'), + env('MEMCACHED_PASSWORD'), + ], + 'options' => [ + // Memcached::OPT_CONNECT_TIMEOUT => 2000, + ], + 'servers' => [ + [ + 'host' => env('MEMCACHED_HOST', '127.0.0.1'), + 'port' => env('MEMCACHED_PORT', 11211), + 'weight' => 100, + ], + ], + ], + + 'redis' => [ + 'driver' => 'redis', + 'connection' => env('REDIS_CACHE_CONNECTION', 'cache'), + 'lock_connection' => env('REDIS_CACHE_LOCK_CONNECTION', 'default'), + ], + + 'dynamodb' => [ + 'driver' => 'dynamodb', + 'key' => env('AWS_ACCESS_KEY_ID'), + 'secret' => env('AWS_SECRET_ACCESS_KEY'), + 'region' => env('AWS_DEFAULT_REGION', 'us-east-1'), + 'table' => env('DYNAMODB_CACHE_TABLE', 'cache'), + 'endpoint' => env('DYNAMODB_ENDPOINT'), + ], + + 'octane' => [ + 'driver' => 'octane', + ], + + ], + + /* + |-------------------------------------------------------------------------- + | Cache Key Prefix + |-------------------------------------------------------------------------- + | + | When utilizing the APC, database, memcached, Redis, and DynamoDB cache + | stores, there might be other applications using the same cache. For + | that reason, you may prefix every cache key to avoid collisions. + | + */ + + 'prefix' => env('CACHE_PREFIX', Str::slug(env('APP_NAME', 'laravel'), '_').'_cache_'), + +]; diff --git a/config/database.php b/config/database.php new file mode 100644 index 0000000..125949e --- /dev/null +++ b/config/database.php @@ -0,0 +1,173 @@ + env('DB_CONNECTION', 'sqlite'), + + /* + |-------------------------------------------------------------------------- + | Database Connections + |-------------------------------------------------------------------------- + | + | Below are all of the database connections defined for your application. + | An example configuration is provided for each database system which + | is supported by Laravel. You're free to add / remove connections. + | + */ + + 'connections' => [ + + 'sqlite' => [ + 'driver' => 'sqlite', + 'url' => env('DB_URL'), + 'database' => env('DB_DATABASE', database_path('database.sqlite')), + 'prefix' => '', + 'foreign_key_constraints' => env('DB_FOREIGN_KEYS', true), + 'busy_timeout' => null, + 'journal_mode' => null, + 'synchronous' => null, + ], + + 'mysql' => [ + 'driver' => 'mysql', + 'url' => env('DB_URL'), + 'host' => env('DB_HOST', '127.0.0.1'), + 'port' => env('DB_PORT', '3306'), + 'database' => env('DB_DATABASE', 'laravel'), + 'username' => env('DB_USERNAME', 'root'), + 'password' => env('DB_PASSWORD', ''), + 'unix_socket' => env('DB_SOCKET', ''), + 'charset' => env('DB_CHARSET', 'utf8mb4'), + 'collation' => env('DB_COLLATION', 'utf8mb4_unicode_ci'), + 'prefix' => '', + 'prefix_indexes' => true, + 'strict' => true, + 'engine' => null, + 'options' => extension_loaded('pdo_mysql') ? array_filter([ + PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'), + ]) : [], + ], + + 'mariadb' => [ + 'driver' => 'mariadb', + 'url' => env('DB_URL'), + 'host' => env('DB_HOST', '127.0.0.1'), + 'port' => env('DB_PORT', '3306'), + 'database' => env('DB_DATABASE', 'laravel'), + 'username' => env('DB_USERNAME', 'root'), + 'password' => env('DB_PASSWORD', ''), + 'unix_socket' => env('DB_SOCKET', ''), + 'charset' => env('DB_CHARSET', 'utf8mb4'), + 'collation' => env('DB_COLLATION', 'utf8mb4_unicode_ci'), + 'prefix' => '', + 'prefix_indexes' => true, + 'strict' => true, + 'engine' => null, + 'options' => extension_loaded('pdo_mysql') ? array_filter([ + PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'), + ]) : [], + ], + + 'pgsql' => [ + 'driver' => 'pgsql', + 'url' => env('DB_URL'), + 'host' => env('DB_HOST', '127.0.0.1'), + 'port' => env('DB_PORT', '5432'), + 'database' => env('DB_DATABASE', 'laravel'), + 'username' => env('DB_USERNAME', 'root'), + 'password' => env('DB_PASSWORD', ''), + 'charset' => env('DB_CHARSET', 'utf8'), + 'prefix' => '', + 'prefix_indexes' => true, + 'search_path' => 'public', + 'sslmode' => 'prefer', + ], + + 'sqlsrv' => [ + 'driver' => 'sqlsrv', + 'url' => env('DB_URL'), + 'host' => env('DB_HOST', 'localhost'), + 'port' => env('DB_PORT', '1433'), + 'database' => env('DB_DATABASE', 'laravel'), + 'username' => env('DB_USERNAME', 'root'), + 'password' => env('DB_PASSWORD', ''), + 'charset' => env('DB_CHARSET', 'utf8'), + 'prefix' => '', + 'prefix_indexes' => true, + // 'encrypt' => env('DB_ENCRYPT', 'yes'), + // 'trust_server_certificate' => env('DB_TRUST_SERVER_CERTIFICATE', 'false'), + ], + + ], + + /* + |-------------------------------------------------------------------------- + | Migration Repository Table + |-------------------------------------------------------------------------- + | + | This table keeps track of all the migrations that have already run for + | your application. Using this information, we can determine which of + | the migrations on disk haven't actually been run on the database. + | + */ + + 'migrations' => [ + 'table' => 'migrations', + 'update_date_on_publish' => true, + ], + + /* + |-------------------------------------------------------------------------- + | Redis Databases + |-------------------------------------------------------------------------- + | + | Redis is an open source, fast, and advanced key-value store that also + | provides a richer body of commands than a typical key-value system + | such as Memcached. You may define your connection settings here. + | + */ + + 'redis' => [ + + 'client' => env('REDIS_CLIENT', 'phpredis'), + + 'options' => [ + 'cluster' => env('REDIS_CLUSTER', 'redis'), + 'prefix' => env('REDIS_PREFIX', Str::slug(env('APP_NAME', 'laravel'), '_').'_database_'), + ], + + 'default' => [ + 'url' => env('REDIS_URL'), + 'host' => env('REDIS_HOST', '127.0.0.1'), + 'username' => env('REDIS_USERNAME'), + 'password' => env('REDIS_PASSWORD'), + 'port' => env('REDIS_PORT', '6379'), + 'database' => env('REDIS_DB', '0'), + ], + + 'cache' => [ + 'url' => env('REDIS_URL'), + 'host' => env('REDIS_HOST', '127.0.0.1'), + 'username' => env('REDIS_USERNAME'), + 'password' => env('REDIS_PASSWORD'), + 'port' => env('REDIS_PORT', '6379'), + 'database' => env('REDIS_CACHE_DB', '1'), + ], + + ], + +]; diff --git a/config/eloquent-sortable.php b/config/eloquent-sortable.php new file mode 100644 index 0000000..0cfadaf --- /dev/null +++ b/config/eloquent-sortable.php @@ -0,0 +1,6 @@ + 'sort', + 'sort_when_creating' => true, +]; diff --git a/config/filesystems.php b/config/filesystems.php new file mode 100644 index 0000000..c5f244d --- /dev/null +++ b/config/filesystems.php @@ -0,0 +1,76 @@ + env('FILESYSTEM_DISK', 'local'), + + /* + |-------------------------------------------------------------------------- + | Filesystem Disks + |-------------------------------------------------------------------------- + | + | Below you may configure as many filesystem disks as necessary, and you + | may even configure multiple disks for the same driver. Examples for + | most supported storage drivers are configured here for reference. + | + | Supported drivers: "local", "ftp", "sftp", "s3" + | + */ + + 'disks' => [ + + 'local' => [ + 'driver' => 'local', + 'root' => storage_path('app'), + 'throw' => false, + ], + + 'public' => [ + 'driver' => 'local', + 'root' => storage_path('app/public'), + 'url' => env('APP_URL').'/storage', + 'visibility' => 'public', + 'throw' => false, + ], + + 's3' => [ + 'driver' => 's3', + 'key' => env('AWS_ACCESS_KEY_ID'), + 'secret' => env('AWS_SECRET_ACCESS_KEY'), + 'region' => env('AWS_DEFAULT_REGION'), + 'bucket' => env('AWS_BUCKET'), + 'url' => env('AWS_URL'), + 'endpoint' => env('AWS_ENDPOINT'), + 'use_path_style_endpoint' => env('AWS_USE_PATH_STYLE_ENDPOINT', false), + 'throw' => false, + ], + + ], + + /* + |-------------------------------------------------------------------------- + | Symbolic Links + |-------------------------------------------------------------------------- + | + | Here you may configure the symbolic links that will be created when the + | `storage:link` Artisan command is executed. The array keys should be + | the locations of the links and the values should be their targets. + | + */ + + 'links' => [ + public_path('storage') => storage_path('app/public'), + ], + +]; diff --git a/config/logging.php b/config/logging.php new file mode 100644 index 0000000..bb739dc --- /dev/null +++ b/config/logging.php @@ -0,0 +1,139 @@ + env('LOG_CHANNEL', 'stack'), + + /* + |-------------------------------------------------------------------------- + | Deprecations Log Channel + |-------------------------------------------------------------------------- + | + | This option controls the log channel that should be used to log warnings + | regarding deprecated PHP and library features. This allows you to get + | your application ready for upcoming major versions of dependencies. + | + */ + + 'deprecations' => [ + 'channel' => env('LOG_DEPRECATIONS_CHANNEL', 'null'), + 'trace' => env('LOG_DEPRECATIONS_TRACE', false), + ], + + /* + |-------------------------------------------------------------------------- + | Log Channels + |-------------------------------------------------------------------------- + | + | Here you may configure the log channels for your application. Laravel + | utilizes the Monolog PHP logging library, which includes a variety + | of powerful log handlers and formatters that you're free to use. + | + | Available drivers: "single", "daily", "slack", "syslog", + | "errorlog", "monolog", "custom", "stack" + | + */ + + 'channels' => [ + + 'stack' => [ + 'driver' => 'stack', + 'channels' => explode(',', env('LOG_STACK', 'single')), + 'ignore_exceptions' => false, + ], + + 'alipay' => [ + 'driver' => 'single', + 'path' => storage_path('logs/alipay.log'), + 'level' => env('LOG_LEVEL', 'debug'), + 'replace_placeholders' => true, + ], + + 'single' => [ + 'driver' => 'single', + 'path' => storage_path('logs/laravel.log'), + 'level' => env('LOG_LEVEL', 'debug'), + 'replace_placeholders' => true, + ], + + 'daily' => [ + 'driver' => 'daily', + 'path' => storage_path('logs/laravel.log'), + 'level' => env('LOG_LEVEL', 'debug'), + 'days' => env('LOG_DAILY_DAYS', 14), + 'replace_placeholders' => true, + ], + + 'slack' => [ + 'driver' => 'slack', + 'url' => env('LOG_SLACK_WEBHOOK_URL'), + 'username' => env('LOG_SLACK_USERNAME', 'Laravel Log'), + 'emoji' => env('LOG_SLACK_EMOJI', ':boom:'), + 'level' => env('LOG_LEVEL', 'critical'), + 'replace_placeholders' => true, + ], + + 'papertrail' => [ + 'driver' => 'monolog', + 'level' => env('LOG_LEVEL', 'debug'), + 'handler' => env('LOG_PAPERTRAIL_HANDLER', SyslogUdpHandler::class), + 'handler_with' => [ + 'host' => env('PAPERTRAIL_URL'), + 'port' => env('PAPERTRAIL_PORT'), + 'connectionString' => 'tls://'.env('PAPERTRAIL_URL').':'.env('PAPERTRAIL_PORT'), + ], + 'processors' => [PsrLogMessageProcessor::class], + ], + + 'stderr' => [ + 'driver' => 'monolog', + 'level' => env('LOG_LEVEL', 'debug'), + 'handler' => StreamHandler::class, + 'formatter' => env('LOG_STDERR_FORMATTER'), + 'with' => [ + 'stream' => 'php://stderr', + ], + 'processors' => [PsrLogMessageProcessor::class], + ], + + 'syslog' => [ + 'driver' => 'syslog', + 'level' => env('LOG_LEVEL', 'debug'), + 'facility' => env('LOG_SYSLOG_FACILITY', LOG_USER), + 'replace_placeholders' => true, + ], + + 'errorlog' => [ + 'driver' => 'errorlog', + 'level' => env('LOG_LEVEL', 'debug'), + 'replace_placeholders' => true, + ], + + 'null' => [ + 'driver' => 'monolog', + 'handler' => NullHandler::class, + ], + + 'emergency' => [ + 'path' => storage_path('logs/laravel.log'), + ], + + ], + +]; diff --git a/config/mail.php b/config/mail.php new file mode 100644 index 0000000..df13d3d --- /dev/null +++ b/config/mail.php @@ -0,0 +1,116 @@ + env('MAIL_MAILER', 'log'), + + /* + |-------------------------------------------------------------------------- + | Mailer Configurations + |-------------------------------------------------------------------------- + | + | Here you may configure all of the mailers used by your application plus + | their respective settings. Several examples have been configured for + | you and you are free to add your own as your application requires. + | + | Laravel supports a variety of mail "transport" drivers that can be used + | when delivering an email. You may specify which one you're using for + | your mailers below. You may also add additional mailers if needed. + | + | Supported: "smtp", "sendmail", "mailgun", "ses", "ses-v2", + | "postmark", "resend", "log", "array", + | "failover", "roundrobin" + | + */ + + 'mailers' => [ + + 'smtp' => [ + 'transport' => 'smtp', + 'url' => env('MAIL_URL'), + 'host' => env('MAIL_HOST', '127.0.0.1'), + 'port' => env('MAIL_PORT', 2525), + 'encryption' => env('MAIL_ENCRYPTION', 'tls'), + 'username' => env('MAIL_USERNAME'), + 'password' => env('MAIL_PASSWORD'), + 'timeout' => null, + 'local_domain' => env('MAIL_EHLO_DOMAIN', parse_url(env('APP_URL', 'http://localhost'), PHP_URL_HOST)), + ], + + 'ses' => [ + 'transport' => 'ses', + ], + + 'postmark' => [ + 'transport' => 'postmark', + // 'message_stream_id' => env('POSTMARK_MESSAGE_STREAM_ID'), + // 'client' => [ + // 'timeout' => 5, + // ], + ], + + 'resend' => [ + 'transport' => 'resend', + ], + + 'sendmail' => [ + 'transport' => 'sendmail', + 'path' => env('MAIL_SENDMAIL_PATH', '/usr/sbin/sendmail -bs -i'), + ], + + 'log' => [ + 'transport' => 'log', + 'channel' => env('MAIL_LOG_CHANNEL'), + ], + + 'array' => [ + 'transport' => 'array', + ], + + 'failover' => [ + 'transport' => 'failover', + 'mailers' => [ + 'smtp', + 'log', + ], + ], + + 'roundrobin' => [ + 'transport' => 'roundrobin', + 'mailers' => [ + 'ses', + 'postmark', + ], + ], + + ], + + /* + |-------------------------------------------------------------------------- + | Global "From" Address + |-------------------------------------------------------------------------- + | + | You may wish for all emails sent by your application to be sent from + | the same address. Here you may specify a name and address that is + | used globally for all emails that are sent by your application. + | + */ + + 'from' => [ + 'address' => env('MAIL_FROM_ADDRESS', 'hello@example.com'), + 'name' => env('MAIL_FROM_NAME', 'Example'), + ], + +]; diff --git a/config/media-library.php b/config/media-library.php new file mode 100644 index 0000000..64ad8cc --- /dev/null +++ b/config/media-library.php @@ -0,0 +1,8 @@ + Media::class, + 'custom_path_generators' => [] +]; diff --git a/config/permission.php b/config/permission.php new file mode 100644 index 0000000..0f096c2 --- /dev/null +++ b/config/permission.php @@ -0,0 +1,186 @@ + [ + + /* + * When using the "HasPermissions" trait from this package, we need to know which + * Eloquent model should be used to retrieve your permissions. Of course, it + * is often just the "Permission" model but you may use whatever you like. + * + * The model you want to use as a Permission model needs to implement the + * `Spatie\Permission\Contracts\Permission` contract. + */ + + 'permission' => Spatie\Permission\Models\Permission::class, + + /* + * When using the "HasRoles" trait from this package, we need to know which + * Eloquent model should be used to retrieve your roles. Of course, it + * is often just the "Role" model but you may use whatever you like. + * + * The model you want to use as a Role model needs to implement the + * `Spatie\Permission\Contracts\Role` contract. + */ + + 'role' => Spatie\Permission\Models\Role::class, + + ], + + 'table_names' => [ + + /* + * When using the "HasRoles" trait from this package, we need to know which + * table should be used to retrieve your roles. We have chosen a basic + * default value but you may easily change it to any table you like. + */ + + 'roles' => 'hub_roles', + + /* + * When using the "HasPermissions" trait from this package, we need to know which + * table should be used to retrieve your permissions. We have chosen a basic + * default value but you may easily change it to any table you like. + */ + + 'permissions' => 'hub_permissions', + + /* + * When using the "HasPermissions" trait from this package, we need to know which + * table should be used to retrieve your models permissions. We have chosen a + * basic default value but you may easily change it to any table you like. + */ + + 'model_has_permissions' => 'hub_model_has_permissions', + + /* + * When using the "HasRoles" trait from this package, we need to know which + * table should be used to retrieve your models roles. We have chosen a + * basic default value but you may easily change it to any table you like. + */ + + 'model_has_roles' => 'hub_model_has_roles', + + /* + * When using the "HasRoles" trait from this package, we need to know which + * table should be used to retrieve your roles permissions. We have chosen a + * basic default value but you may easily change it to any table you like. + */ + + 'role_has_permissions' => 'hub_role_has_permissions', + ], + + 'column_names' => [ + /* + * Change this if you want to name the related pivots other than defaults + */ + 'role_pivot_key' => null, //default 'role_id', + 'permission_pivot_key' => null, //default 'permission_id', + + /* + * Change this if you want to name the related model primary key other than + * `model_id`. + * + * For example, this would be nice if your primary keys are all UUIDs. In + * that case, name this `model_uuid`. + */ + + 'model_morph_key' => 'model_id', + + /* + * Change this if you want to use the teams feature and your related model's + * foreign key is other than `team_id`. + */ + + 'team_foreign_key' => 'team_id', + ], + + /* + * When set to true, the method for checking permissions will be registered on the gate. + * Set this to false if you want to implement custom logic for checking permissions. + */ + + 'register_permission_check_method' => true, + + /* + * When set to true, Laravel\Octane\Events\OperationTerminated event listener will be registered + * this will refresh permissions on every TickTerminated, TaskTerminated and RequestTerminated + * NOTE: This should not be needed in most cases, but an Octane/Vapor combination benefited from it. + */ + 'register_octane_reset_listener' => false, + + /* + * Teams Feature. + * When set to true the package implements teams using the 'team_foreign_key'. + * If you want the migrations to register the 'team_foreign_key', you must + * set this to true before doing the migration. + * If you already did the migration then you must make a new migration to also + * add 'team_foreign_key' to 'roles', 'model_has_roles', and 'model_has_permissions' + * (view the latest version of this package's migration file) + */ + + 'teams' => false, + + /* + * Passport Client Credentials Grant + * When set to true the package will use Passports Client to check permissions + */ + + 'use_passport_client_credentials' => false, + + /* + * When set to true, the required permission names are added to exception messages. + * This could be considered an information leak in some contexts, so the default + * setting is false here for optimum safety. + */ + + 'display_permission_in_exception' => false, + + /* + * When set to true, the required role names are added to exception messages. + * This could be considered an information leak in some contexts, so the default + * setting is false here for optimum safety. + */ + + 'display_role_in_exception' => false, + + /* + * By default wildcard permission lookups are disabled. + * See documentation to understand supported syntax. + */ + + 'enable_wildcard_permission' => false, + + /* + * The class to use for interpreting wildcard permissions. + * If you need to modify delimiters, override the class and specify its name here. + */ + // 'permission.wildcard_permission' => Spatie\Permission\WildcardPermission::class, + + /* Cache-specific settings */ + + 'cache' => [ + + /* + * By default all permissions are cached for 24 hours to speed up performance. + * When permissions or roles are updated the cache is flushed automatically. + */ + + 'expiration_time' => \DateInterval::createFromDateString('24 hours'), + + /* + * The cache key used to store all permissions. + */ + + 'key' => 'spatie.permission.cache', + + /* + * You may optionally indicate a specific cache driver to use for permission and + * role caching using any of the `store` drivers listed in the cache.php config + * file. Using 'default' here means to use the `default` set in cache.php. + */ + + 'store' => 'default', + ], +]; diff --git a/config/queue.php b/config/queue.php new file mode 100644 index 0000000..a92267f --- /dev/null +++ b/config/queue.php @@ -0,0 +1,112 @@ + env('QUEUE_CONNECTION', 'database'), + + /* + |-------------------------------------------------------------------------- + | Queue Connections + |-------------------------------------------------------------------------- + | + | Here you may configure the connection options for every queue backend + | used by your application. An example configuration is provided for + | each backend supported by Laravel. You're also free to add more. + | + | Drivers: "sync", "database", "beanstalkd", "sqs", "redis", "null" + | + */ + + 'connections' => [ + + 'sync' => [ + 'driver' => 'sync', + ], + + 'database' => [ + 'driver' => 'database', + 'connection' => env('DB_QUEUE_CONNECTION'), + 'table' => env('DB_QUEUE_TABLE', 'app_jobs'), + 'queue' => env('DB_QUEUE', 'default'), + 'retry_after' => (int) env('DB_QUEUE_RETRY_AFTER', 90), + 'after_commit' => false, + ], + + 'beanstalkd' => [ + 'driver' => 'beanstalkd', + 'host' => env('BEANSTALKD_QUEUE_HOST', 'localhost'), + 'queue' => env('BEANSTALKD_QUEUE', 'default'), + 'retry_after' => (int) env('BEANSTALKD_QUEUE_RETRY_AFTER', 90), + 'block_for' => 0, + 'after_commit' => false, + ], + + 'sqs' => [ + 'driver' => 'sqs', + 'key' => env('AWS_ACCESS_KEY_ID'), + 'secret' => env('AWS_SECRET_ACCESS_KEY'), + 'prefix' => env('SQS_PREFIX', 'https://sqs.us-east-1.amazonaws.com/your-account-id'), + 'queue' => env('SQS_QUEUE', 'default'), + 'suffix' => env('SQS_SUFFIX'), + 'region' => env('AWS_DEFAULT_REGION', 'us-east-1'), + 'after_commit' => false, + ], + + 'redis' => [ + 'driver' => 'redis', + 'connection' => env('REDIS_QUEUE_CONNECTION', 'default'), + 'queue' => env('REDIS_QUEUE', 'default'), + 'retry_after' => (int) env('REDIS_QUEUE_RETRY_AFTER', 90), + 'block_for' => null, + 'after_commit' => false, + ], + + ], + + /* + |-------------------------------------------------------------------------- + | Job Batching + |-------------------------------------------------------------------------- + | + | The following options configure the database and table that store job + | batching information. These options can be updated to any database + | connection and table which has been defined by your application. + | + */ + + 'batching' => [ + 'database' => env('DB_CONNECTION', 'sqlite'), + 'table' => 'app_job_batches', + ], + + /* + |-------------------------------------------------------------------------- + | Failed Queue Jobs + |-------------------------------------------------------------------------- + | + | These options configure the behavior of failed queue job logging so you + | can control how and where failed jobs are stored. Laravel ships with + | support for storing failed jobs in a simple file or in a database. + | + | Supported drivers: "database-uuids", "dynamodb", "file", "null" + | + */ + + 'failed' => [ + 'driver' => env('QUEUE_FAILED_DRIVER', 'database-uuids'), + 'database' => env('DB_CONNECTION', 'sqlite'), + 'table' => 'app_failed_jobs', + ], + +]; diff --git a/config/sanctum.php b/config/sanctum.php new file mode 100644 index 0000000..764a82f --- /dev/null +++ b/config/sanctum.php @@ -0,0 +1,83 @@ + explode(',', env('SANCTUM_STATEFUL_DOMAINS', sprintf( + '%s%s', + 'localhost,localhost:3000,127.0.0.1,127.0.0.1:8000,::1', + Sanctum::currentApplicationUrlWithPort() + ))), + + /* + |-------------------------------------------------------------------------- + | Sanctum Guards + |-------------------------------------------------------------------------- + | + | This array contains the authentication guards that will be checked when + | Sanctum is trying to authenticate a request. If none of these guards + | are able to authenticate the request, Sanctum will use the bearer + | token that's present on an incoming request for authentication. + | + */ + + 'guard' => ['web'], + + /* + |-------------------------------------------------------------------------- + | Expiration Minutes + |-------------------------------------------------------------------------- + | + | This value controls the number of minutes until an issued token will be + | considered expired. This will override any values set in the token's + | "expires_at" attribute, but first-party sessions are not affected. + | + */ + + 'expiration' => null, + + /* + |-------------------------------------------------------------------------- + | Token Prefix + |-------------------------------------------------------------------------- + | + | Sanctum can prefix new tokens in order to take advantage of numerous + | security scanning initiatives maintained by open source platforms + | that notify developers if they commit tokens into repositories. + | + | See: https://docs.github.com/en/code-security/secret-scanning/about-secret-scanning + | + */ + + 'token_prefix' => env('SANCTUM_TOKEN_PREFIX', ''), + + /* + |-------------------------------------------------------------------------- + | Sanctum Middleware + |-------------------------------------------------------------------------- + | + | When authenticating your first-party SPA with Sanctum you may need to + | customize some of the middleware Sanctum uses while processing the + | request. You may change the middleware listed below as required. + | + */ + + 'middleware' => [ + 'authenticate_session' => Laravel\Sanctum\Http\Middleware\AuthenticateSession::class, + 'encrypt_cookies' => Illuminate\Cookie\Middleware\EncryptCookies::class, + 'validate_csrf_token' => Illuminate\Foundation\Http\Middleware\ValidateCsrfToken::class, + ], + +]; diff --git a/config/services.php b/config/services.php new file mode 100644 index 0000000..b793438 --- /dev/null +++ b/config/services.php @@ -0,0 +1,42 @@ + [ + 'token' => env('POSTMARK_TOKEN'), + ], + + 'ses' => [ + 'key' => env('AWS_ACCESS_KEY_ID'), + 'secret' => env('AWS_SECRET_ACCESS_KEY'), + 'region' => env('AWS_DEFAULT_REGION', 'us-east-1'), + ], + + 'resend' => [ + 'key' => env('RESEND_KEY'), + ], + + 'slack' => [ + 'notifications' => [ + 'bot_user_oauth_token' => env('SLACK_BOT_USER_OAUTH_TOKEN'), + 'channel' => env('SLACK_BOT_USER_DEFAULT_CHANNEL'), + ], + ], + + 'baidulbs' => [ + 'ak' => env('BAIDU_LBS_AK'), + ], + +]; diff --git a/config/session.php b/config/session.php new file mode 100644 index 0000000..96827e8 --- /dev/null +++ b/config/session.php @@ -0,0 +1,217 @@ + env('SESSION_DRIVER', 'database'), + + /* + |-------------------------------------------------------------------------- + | Session Lifetime + |-------------------------------------------------------------------------- + | + | Here you may specify the number of minutes that you wish the session + | to be allowed to remain idle before it expires. If you want them + | to expire immediately when the browser is closed then you may + | indicate that via the expire_on_close configuration option. + | + */ + + 'lifetime' => env('SESSION_LIFETIME', 120), + + 'expire_on_close' => env('SESSION_EXPIRE_ON_CLOSE', false), + + /* + |-------------------------------------------------------------------------- + | Session Encryption + |-------------------------------------------------------------------------- + | + | This option allows you to easily specify that all of your session data + | should be encrypted before it's stored. All encryption is performed + | automatically by Laravel and you may use the session like normal. + | + */ + + 'encrypt' => env('SESSION_ENCRYPT', false), + + /* + |-------------------------------------------------------------------------- + | Session File Location + |-------------------------------------------------------------------------- + | + | When utilizing the "file" session driver, the session files are placed + | on disk. The default storage location is defined here; however, you + | are free to provide another location where they should be stored. + | + */ + + 'files' => storage_path('framework/sessions'), + + /* + |-------------------------------------------------------------------------- + | Session Database Connection + |-------------------------------------------------------------------------- + | + | When using the "database" or "redis" session drivers, you may specify a + | connection that should be used to manage these sessions. This should + | correspond to a connection in your database configuration options. + | + */ + + 'connection' => env('SESSION_CONNECTION'), + + /* + |-------------------------------------------------------------------------- + | Session Database Table + |-------------------------------------------------------------------------- + | + | When using the "database" session driver, you may specify the table to + | be used to store sessions. Of course, a sensible default is defined + | for you; however, you're welcome to change this to another table. + | + */ + + 'table' => env('SESSION_TABLE', 'app_sessions'), + + /* + |-------------------------------------------------------------------------- + | Session Cache Store + |-------------------------------------------------------------------------- + | + | When using one of the framework's cache driven session backends, you may + | define the cache store which should be used to store the session data + | between requests. This must match one of your defined cache stores. + | + | Affects: "apc", "dynamodb", "memcached", "redis" + | + */ + + 'store' => env('SESSION_STORE'), + + /* + |-------------------------------------------------------------------------- + | Session Sweeping Lottery + |-------------------------------------------------------------------------- + | + | Some session drivers must manually sweep their storage location to get + | rid of old sessions from storage. Here are the chances that it will + | happen on a given request. By default, the odds are 2 out of 100. + | + */ + + 'lottery' => [2, 100], + + /* + |-------------------------------------------------------------------------- + | Session Cookie Name + |-------------------------------------------------------------------------- + | + | Here you may change the name of the session cookie that is created by + | the framework. Typically, you should not need to change this value + | since doing so does not grant a meaningful security improvement. + | + */ + + 'cookie' => env( + 'SESSION_COOKIE', + Str::slug(env('APP_NAME', 'laravel'), '_').'_session' + ), + + /* + |-------------------------------------------------------------------------- + | Session Cookie Path + |-------------------------------------------------------------------------- + | + | The session cookie path determines the path for which the cookie will + | be regarded as available. Typically, this will be the root path of + | your application, but you're free to change this when necessary. + | + */ + + 'path' => env('SESSION_PATH', '/'), + + /* + |-------------------------------------------------------------------------- + | Session Cookie Domain + |-------------------------------------------------------------------------- + | + | This value determines the domain and subdomains the session cookie is + | available to. By default, the cookie will be available to the root + | domain and all subdomains. Typically, this shouldn't be changed. + | + */ + + 'domain' => env('SESSION_DOMAIN'), + + /* + |-------------------------------------------------------------------------- + | HTTPS Only Cookies + |-------------------------------------------------------------------------- + | + | By setting this option to true, session cookies will only be sent back + | to the server if the browser has a HTTPS connection. This will keep + | the cookie from being sent to you when it can't be done securely. + | + */ + + 'secure' => env('SESSION_SECURE_COOKIE'), + + /* + |-------------------------------------------------------------------------- + | HTTP Access Only + |-------------------------------------------------------------------------- + | + | Setting this value to true will prevent JavaScript from accessing the + | value of the cookie and the cookie will only be accessible through + | the HTTP protocol. It's unlikely you should disable this option. + | + */ + + 'http_only' => env('SESSION_HTTP_ONLY', true), + + /* + |-------------------------------------------------------------------------- + | Same-Site Cookies + |-------------------------------------------------------------------------- + | + | This option determines how your cookies behave when cross-site requests + | take place, and can be used to mitigate CSRF attacks. By default, we + | will set this value to "lax" to permit secure cross-site requests. + | + | See: https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Set-Cookie#samesitesamesite-value + | + | Supported: "lax", "strict", "none", null + | + */ + + 'same_site' => env('SESSION_SAME_SITE', 'lax'), + + /* + |-------------------------------------------------------------------------- + | Partitioned Cookies + |-------------------------------------------------------------------------- + | + | Setting this value to true will tie the cookie to the top-level site for + | a cross-site context. Partitioned cookies are accepted by the browser + | when flagged "secure" and the Same-Site attribute is set to "none". + | + */ + + 'partitioned' => env('SESSION_PARTITIONED_COOKIE', false), + +]; diff --git a/database/.gitignore b/database/.gitignore new file mode 100644 index 0000000..9b19b93 --- /dev/null +++ b/database/.gitignore @@ -0,0 +1 @@ +*.sqlite* diff --git a/database/factories/UserFactory.php b/database/factories/UserFactory.php new file mode 100644 index 0000000..584104c --- /dev/null +++ b/database/factories/UserFactory.php @@ -0,0 +1,44 @@ + + */ +class UserFactory extends Factory +{ + /** + * The current password being used by the factory. + */ + protected static ?string $password; + + /** + * Define the model's default state. + * + * @return array + */ + public function definition(): array + { + return [ + 'name' => fake()->name(), + 'email' => fake()->unique()->safeEmail(), + 'email_verified_at' => now(), + 'password' => static::$password ??= Hash::make('password'), + 'remember_token' => Str::random(10), + ]; + } + + /** + * Indicate that the model's email address should be unverified. + */ + public function unverified(): static + { + return $this->state(fn (array $attributes) => [ + 'email_verified_at' => null, + ]); + } +} diff --git a/database/migrations/0001_01_01_000000_create_users_table.php b/database/migrations/0001_01_01_000000_create_users_table.php new file mode 100644 index 0000000..061b0ca --- /dev/null +++ b/database/migrations/0001_01_01_000000_create_users_table.php @@ -0,0 +1,49 @@ +id(); + $table->string('name'); + $table->string('email')->unique(); + $table->timestamp('email_verified_at')->nullable(); + $table->string('password'); + $table->rememberToken(); + $table->timestamps(); + }); + + Schema::create('app_password_reset_tokens', function (Blueprint $table) { + $table->string('email')->primary(); + $table->string('token'); + $table->timestamp('created_at')->nullable(); + }); + + Schema::create('app_sessions', function (Blueprint $table) { + $table->string('id')->primary(); + $table->foreignId('user_id')->nullable()->index(); + $table->string('ip_address', 45)->nullable(); + $table->text('user_agent')->nullable(); + $table->longText('payload'); + $table->integer('last_activity')->index(); + }); + } + + /** + * Reverse the migrations. + */ + public function down(): void + { + Schema::dropIfExists('app_users'); + Schema::dropIfExists('app_password_reset_tokens'); + Schema::dropIfExists('app_sessions'); + } +}; diff --git a/database/migrations/0001_01_01_000001_create_cache_table.php b/database/migrations/0001_01_01_000001_create_cache_table.php new file mode 100644 index 0000000..1a443a1 --- /dev/null +++ b/database/migrations/0001_01_01_000001_create_cache_table.php @@ -0,0 +1,35 @@ +string('key')->primary(); + $table->mediumText('value'); + $table->integer('expiration'); + }); + + Schema::create('app_cache_locks', function (Blueprint $table) { + $table->string('key')->primary(); + $table->string('owner'); + $table->integer('expiration'); + }); + } + + /** + * Reverse the migrations. + */ + public function down(): void + { + Schema::dropIfExists('app_cache'); + Schema::dropIfExists('app_cache_locks'); + } +}; diff --git a/database/migrations/0001_01_01_000002_create_jobs_table.php b/database/migrations/0001_01_01_000002_create_jobs_table.php new file mode 100644 index 0000000..91ae0e1 --- /dev/null +++ b/database/migrations/0001_01_01_000002_create_jobs_table.php @@ -0,0 +1,57 @@ +id(); + $table->string('queue')->index(); + $table->longText('payload'); + $table->unsignedTinyInteger('attempts'); + $table->unsignedInteger('reserved_at')->nullable(); + $table->unsignedInteger('available_at'); + $table->unsignedInteger('created_at'); + }); + + Schema::create('app_job_batches', function (Blueprint $table) { + $table->string('id')->primary(); + $table->string('name'); + $table->integer('total_jobs'); + $table->integer('pending_jobs'); + $table->integer('failed_jobs'); + $table->longText('failed_job_ids'); + $table->mediumText('options')->nullable(); + $table->integer('cancelled_at')->nullable(); + $table->integer('created_at'); + $table->integer('finished_at')->nullable(); + }); + + Schema::create('app_failed_jobs', function (Blueprint $table) { + $table->id(); + $table->string('uuid')->unique(); + $table->text('connection'); + $table->text('queue'); + $table->longText('payload'); + $table->longText('exception'); + $table->timestamp('failed_at')->useCurrent(); + }); + } + + /** + * Reverse the migrations. + */ + public function down(): void + { + Schema::dropIfExists('app_jobs'); + Schema::dropIfExists('app_job_batches'); + Schema::dropIfExists('app_failed_jobs'); + } +}; diff --git a/database/migrations/2024_08_15_165744_create_personal_access_tokens_table.php b/database/migrations/2024_08_15_165744_create_personal_access_tokens_table.php new file mode 100644 index 0000000..b40bbfa --- /dev/null +++ b/database/migrations/2024_08_15_165744_create_personal_access_tokens_table.php @@ -0,0 +1,34 @@ +id(); + $table->morphs('tokenable'); + $table->string('name'); + $table->string('token', 64)->unique(); + $table->text('abilities')->nullable(); + $table->jsonb('meta')->nullable(); + $table->timestamp('last_used_at')->nullable(); + $table->timestamp('expires_at')->nullable(); + $table->timestamps(); + }); + } + + /** + * Reverse the migrations. + */ + public function down(): void + { + Schema::dropIfExists('app_personal_access_tokens'); + } +}; diff --git a/database/migrations/2024_08_15_165944_create_media_table.php b/database/migrations/2024_08_15_165944_create_media_table.php new file mode 100644 index 0000000..93926f2 --- /dev/null +++ b/database/migrations/2024_08_15_165944_create_media_table.php @@ -0,0 +1,31 @@ +id(); + + $table->morphs('model'); + $table->uuid()->nullable()->unique(); + $table->string('collection_name'); + $table->string('name'); + $table->string('file_name'); + $table->string('mime_type')->nullable(); + $table->string('disk'); + $table->string('conversions_disk')->nullable(); + $table->unsignedBigInteger('size'); + $table->json('manipulations'); + $table->json('custom_properties'); + $table->json('generated_conversions'); + $table->json('responsive_images'); + $table->unsignedInteger('order_column')->nullable()->index(); + $table->nullableTimestamps(); + }); + } +}; diff --git a/database/seeders/DatabaseSeeder.php b/database/seeders/DatabaseSeeder.php new file mode 100644 index 0000000..d01a0ef --- /dev/null +++ b/database/seeders/DatabaseSeeder.php @@ -0,0 +1,23 @@ +create(); + + User::factory()->create([ + 'name' => 'Test User', + 'email' => 'test@example.com', + ]); + } +} diff --git a/package.json b/package.json new file mode 100644 index 0000000..4e934ca --- /dev/null +++ b/package.json @@ -0,0 +1,13 @@ +{ + "private": true, + "type": "module", + "scripts": { + "dev": "vite", + "build": "vite build" + }, + "devDependencies": { + "axios": "^1.6.4", + "laravel-vite-plugin": "^1.0", + "vite": "^5.0" + } +} diff --git a/packages/README.md b/packages/README.md new file mode 100644 index 0000000..2a88037 --- /dev/null +++ b/packages/README.md @@ -0,0 +1 @@ +# some packages diff --git a/packages/bydauto/README.md b/packages/bydauto/README.md new file mode 100644 index 0000000..afe6eeb --- /dev/null +++ b/packages/bydauto/README.md @@ -0,0 +1 @@ +# some api service diff --git a/packages/bydauto/cluepackage-send.sh b/packages/bydauto/cluepackage-send.sh new file mode 100644 index 0000000..fc6af5e --- /dev/null +++ b/packages/bydauto/cluepackage-send.sh @@ -0,0 +1,14 @@ +#!/bin/bash + +sign="xxxxxx" +now=$(date +%s) + +curl -X POST "https://dev.energytrust.com.cn/pkg/dataservice/cluepackage?sign=${sign}&method=spi.alipay.data.dataservice.ad.cluepackage.send&charset=UTF-8&version=1.0&utc_timestamp=${now}&sign_type=RSA2" \ + --header "Content-Type: application/x-www-form-urlencoded;charset=UTF-8" \ + --data-urlencode "id=123456" \ + --data-urlencode "user_name=黄丫" \ + --data-urlencode "user_mobile_no=18000000000" \ + --data-urlencode "user_province=浙江省" \ + --data-urlencode "user_city=杭州市" \ + --data-urlencode "clue_time=2024-07-24 11:44:16" \ + --data-urlencode "extend_info=行业拓展字段" diff --git a/packages/bydauto/composer.json b/packages/bydauto/composer.json new file mode 100644 index 0000000..13d6bea --- /dev/null +++ b/packages/bydauto/composer.json @@ -0,0 +1,9 @@ +{ + "name": "pkg/bydauto", + "type": "metapackage", + "autoload": { + "psr-4": { + "BYDAuto\\": "src/" + } + } +} diff --git a/packages/bydauto/config/bydauto.php b/packages/bydauto/config/bydauto.php new file mode 100644 index 0000000..b625128 --- /dev/null +++ b/packages/bydauto/config/bydauto.php @@ -0,0 +1,4 @@ +id(); + $table->timestamp('date_created'); + $table->timestamp('date_updated'); + $table->string('status')->nullable(); + $table->string('email')->nullable(); + $table->string('remark')->nullable(); + }); + + Schema::create('bydauto_testdrive', function (Blueprint $table) { + $table->id(); + $table->timestamp('date_created'); + $table->timestamp('date_updated'); + $table->string('status')->nullable(); + $table->string('name')->nullable(); + $table->string('mobile')->nullable(); + $table->string('platform')->nullable(); + $table->string('source')->nullable(); + $table->string('request_id')->nullable(); + $table->jsonb('meta')->nullable(); + $table->jsonb('rawdata')->nullable(); + }); + } + + public function down(): void + { + Schema::dropIfExists('bydauto_testdrive'); + } +}; diff --git a/packages/bydauto/routes/api.php b/packages/bydauto/routes/api.php new file mode 100644 index 0000000..15252be --- /dev/null +++ b/packages/bydauto/routes/api.php @@ -0,0 +1,14 @@ + $prefix, 'middleware' => ['api']], function () { + Route::get('vehicle', [BYDAutoController::class, 'vehicle']); + Route::get('dealer', [BYDAutoController::class, 'dealer']); + Route::get('province', [BYDAutoController::class, 'province']); + Route::get('city', [BYDAutoController::class, 'city']); + Route::post('testdrive', [BYDAutoController::class, 'testdrive']); +}); diff --git a/packages/bydauto/src/Actions/TestdriveCreateAction.php b/packages/bydauto/src/Actions/TestdriveCreateAction.php new file mode 100644 index 0000000..4bb9fbb --- /dev/null +++ b/packages/bydauto/src/Actions/TestdriveCreateAction.php @@ -0,0 +1,23 @@ +all(); + $data['request_id'] = $request->request_id; + return $this->createTestdrive($data); + } + + public function createTestdrive($data) + { + $model = new Testdrive($data); + $model->save(); + return $model; + } +} diff --git a/packages/bydauto/src/BYDAutoServiceProvider.php b/packages/bydauto/src/BYDAutoServiceProvider.php new file mode 100644 index 0000000..e131141 --- /dev/null +++ b/packages/bydauto/src/BYDAutoServiceProvider.php @@ -0,0 +1,40 @@ +loadMigrationsFrom($root . '/migrations'); + + $this->commands([ + CheryTransferCommand::class, + BYDAutoCommand::class, + GeocodingCommand::class, + BYDAutoNoticeCommand::class, + ]); + + $this->mergeConfigFrom($root . '/config/bydauto.php', 'bydauto'); + $this->loadRoutesFrom($root . '/routes/api.php'); + $this->loadViewsFrom($root . '/views', 'bydauto'); + } + + public function boot() + { + $this->app->booted(function () { + $schedule = $this->app->make(Schedule::class); + $schedule->command('BYDAuto:notice')->dailyAt('09:00'); + }); + } +} diff --git a/packages/bydauto/src/CheryClueApi.php b/packages/bydauto/src/CheryClueApi.php new file mode 100644 index 0000000..d394238 --- /dev/null +++ b/packages/bydauto/src/CheryClueApi.php @@ -0,0 +1,71 @@ +appId = config('chery-crm.scrm.app_id'); + $this->appSecret = config('chery-crm.scrm.secret'); + $this->endpoint = config('chery-crm.scrm.endpoint'); + $this->httpClient = new Client(['base_uri' => $this->endpoint, 'timeout' => 10]); + } + + public static function getInstance(): self + { + if (!self::$instance) { + self::$instance = new self(); + } + return self::$instance; + } + + /** + * 线索推送 + * + * @param array $data + * @return CheryResult + */ + public function cluePush($data) + { + $token = $this->getToken(); + $response = $this->httpClient->post('/api/app/chery-clue/api/clue/push/channel', ['json' => $data, 'headers' => ['x-csrf-token' => $token]]); + $content = json_decode($response->getBody()->getContents(), true); + $result = new CheryResult($content); + if ($result->code !== '0') { + $message = $result->get('msg', '推送线索失败'); + throw new \Exception($message); + } + return $result; + } + + public function getToken($force = false) + { + $token = cache('pkg:chery-scrm-token'); + if ($force || !$token) { + $response = $this->httpClient->get('/api/app/chery-clue/api/clue/channel/getToken', ['query' => ['appId' => $this->appId, 'appSecret' => $this->appSecret]]); + $json = json_decode($response->getBody()->getContents(), true); + if ($json['code'] === '0') { + $token = $json['data']; + // 有效期4小时,提前10分钟刷新 + cache(['pkg:chery-scrm-token' => $token], now()->addSeconds(4 * 3600 - 600)); + } else { + $message = $json['msg'] ?? 'pkg:chery-scrm-token 获取失败'; + throw new \Exception($message); + } + } + return $token; + } +} diff --git a/packages/bydauto/src/CheryResult.php b/packages/bydauto/src/CheryResult.php new file mode 100644 index 0000000..481cbad --- /dev/null +++ b/packages/bydauto/src/CheryResult.php @@ -0,0 +1,26 @@ +code = Arr::get($attributes, 'code'); + $this->msg = Arr::get($attributes, 'msg'); + $this->data = Arr::get($attributes, 'data'); + $this->reqId = Arr::get($attributes, 'reqId'); + $this->attributes = $attributes; + } +} diff --git a/packages/bydauto/src/Commands/BYDAutoCommand.php b/packages/bydauto/src/Commands/BYDAutoCommand.php new file mode 100644 index 0000000..1e4f22b --- /dev/null +++ b/packages/bydauto/src/Commands/BYDAutoCommand.php @@ -0,0 +1,59 @@ +argument('action'); + $method = "action_{$action}"; + if (method_exists($this, $method)) { + $this->{$method}(); + } else { + $this->error("不支持的操作 {$action}"); + } + } + + public function action_init() + { + $this->call('db:wipe'); + $this->call('migrate'); + } + + public function action_testdrive() + { + $items = Testdrive::query()->orderBy('id', 'desc')->get(); + $this->table(['id', 'date_created', 'status', 'name', 'mobile'], $items->map(function (Testdrive $v) { + return [$v->id, $v->date_created, $v->status, $v->name, $v->mobile]; + })); + } + + public function action_contact() + { + $items = Contact::all(); + $this->table(['id', 'email', 'remark', 'status'], $items->map(function (Contact $v) { + return [$v->id, $v->email, $v->remark, $v->status]; + })); + } + + public function action_contact_add() + { + $data['email'] = $this->ask('Email'); + $data['remark'] = $this->ask('Remark'); + $data['status'] = Contact::STATUS_PUBLISHED; + + $contact = new Contact($data); + $contact->save(); + + $this->info('Contact added'); + } +} diff --git a/packages/bydauto/src/Commands/BYDAutoNoticeCommand.php b/packages/bydauto/src/Commands/BYDAutoNoticeCommand.php new file mode 100644 index 0000000..8889ee2 --- /dev/null +++ b/packages/bydauto/src/Commands/BYDAutoNoticeCommand.php @@ -0,0 +1,61 @@ +argument('date') ?: Carbon::yesterday()->toDateString(); + $table = (new Testdrive())->getTable(); + + $items = DB::table($table) + ->selectRaw('source, COUNT(*) AS total') + ->groupByRaw('source') + ->whereDate('date_created', $date) + ->get(); + $count = $items->sum('total'); + $sourceMap = [ + 'alipromote:99800024' => '自建站99800024', + 'alipromote:100000006' => '自建站100000006', + 'alipromote:cluepackage' => '车生活推送', + 'alipromote:isaas' => '小程序', + ]; + + $users = config('chery-crm.daily_mail_users'); + $users = explode(',', $users); + $html = \View::make('chery-crm::notice.salesleads-day', compact('items', 'date', 'sourceMap', 'count'))->render(); + Mail::html($html, function ($message) use ($date, $users) { + $message->subject('线索日报 ' . $date)->to($users); + }); + } + + public function sourceGroup() + { + $table = (new Testdrive())->getTable(); + + $items = DB::table($table) + ->selectRaw('DATE(date_created) AS day, source, COUNT(*) AS total') + ->groupByRaw('DATE(date_created), source') + ->orderByRaw('DATE(date_created), source') + ->get(); + + $sourceGroup = $items->groupBy('source'); + $html = \View::make('chery-crm::notice.salesleads', compact('sourceGroup'))->render(); + Mail::html($html, function ($message) { + $message + ->subject('销售线索每日通知') + ->to('ifme.in@gmail.com'); + }); + } +} diff --git a/packages/bydauto/src/Commands/CheryTransferCommand.php b/packages/bydauto/src/Commands/CheryTransferCommand.php new file mode 100644 index 0000000..d3259cb --- /dev/null +++ b/packages/bydauto/src/Commands/CheryTransferCommand.php @@ -0,0 +1,80 @@ +argument('action'); + $this->{'action_' . $action}(); + } + + public function action_dispatch_all_draft() + { + $items = Testdrive::query() + ->where('status', Testdrive::STATUS_DRAFT) + ->get(); + $this->showTable($items); + + $confirm = $this->confirm('是否确认推送?', true); + if (!$confirm) { + return Command::SUCCESS; + } + foreach ($items as $model) { + TestdrivePushJob::dispatch($model); + } + return Command::SUCCESS; + } + + public function action_vehicle_alias_update() + { + $items = Vehicle::query()->get(); + $items->each(function ($item) { + $cleanName = preg_replace('/\s+/', '', $item->name); + $alias = [$item->name]; + if ($item->name !== $cleanName) { + $alias[] = $cleanName; + } + $item->update(['alias' => $alias]); + }); + } + + public function action_dispatch_by_mobile() + { + $mobiles = $this->ask('请输入手机号码,多个用逗号分隔'); + $mobiles = explode(',', $mobiles); + + $items = Testdrive::query() + ->whereIn('mobile', $mobiles) + ->get(); + $this->showTable($items); + + $confirm = $this->confirm('是否确认推送?', true); + if (!$confirm) { + return Command::SUCCESS; + } + foreach ($items as $model) { + TestdrivePushJob::dispatch($model); + } + return Command::SUCCESS; + } + + protected function showTable($items) + { + $columns = ['id', 'status', 'name', 'mobile']; + $this->table($columns, $items->map(fn($item) => $item->only($columns))); + } +} diff --git a/packages/bydauto/src/Commands/GeocodingCommand.php b/packages/bydauto/src/Commands/GeocodingCommand.php new file mode 100644 index 0000000..f0622e1 --- /dev/null +++ b/packages/bydauto/src/Commands/GeocodingCommand.php @@ -0,0 +1,206 @@ +argument('action'); + if (method_exists($this, 'action_' . $action)) { + $this->{'action_' . $action}(); + } else { + $this->error('Action not found'); + } + } + + public function action_update() + { + $items = Dealer::query()->orderBy('id')->get(); + dump($items[0]); + } + + public function xlsx($chunk, $index) + { + $spreadsheet = new Spreadsheet(); + $sheet = $spreadsheet->getActiveSheet(); + $sheet->setCellValue('A1', '门店名称(必填)'); + $sheet->setCellValue('B1', '门店编码'); + $sheet->setCellValue('C1', '省份名称(必填)'); + $sheet->setCellValue('D1', '城市名称(必填)'); + $sheet->setCellValue('E1', '描述'); + $sheet->setCellValue('F1', '地址(必填)'); + $sheet->setCellValue('G1', '经度(必填)'); + $sheet->setCellValue('H1', '纬度(必填)'); + $sheet->setCellValue('I1', '电话(必填)'); + $sheet->setCellValue('J1', '营业时间(必填)'); + $sheet->setCellValue('K1', '标签'); + $sheet->setCellValue('L1', '业务扩展字段'); + + $sn = 2; + foreach ($chunk as $dealer) { + $except1 = ['北京', '上海', '天津', '重庆']; // 直辖市 + $except2 = ['内蒙古', '内蒙古(蒙东)', '内蒙古(蒙西)']; // 内蒙古自治区 + $except3 = ['新疆']; // 新疆维吾尔自治区 + $except4 = ['西藏']; // 西藏自治区 + $except5 = ['广西']; // 广西壮族自治区 + $except6 = ['宁夏']; // 宁夏回族自治区 + $except7 = ['香港', '澳门']; // 香港特别行政区、澳门特别行政区 + + $province = $dealer->province; + if (in_array($province, $except1)) { + $province .= '市'; + } elseif (in_array($province, $except2)) { + $province = '内蒙古自治区'; + } elseif (in_array($province, $except3)) { + $province = '新疆维吾尔自治区'; + } elseif (in_array($province, $except4)) { + $province = '西藏自治区'; + } elseif (in_array($province, $except5)) { + $province = '广西壮族自治区'; + } elseif (in_array($province, $except6)) { + $province = '宁夏回族自治区'; + } elseif (in_array($province, $except7)) { + $province .= '特别行政区'; + } else { + $province .= '省'; + } + + $lng = $dealer->lng ? number_format($dealer->lng, 6) : ''; + $lat = $dealer->lat ? number_format($dealer->lat, 6) : ''; + + $sheet->setCellValue('A' . $sn, $dealer->name); + $sheet->setCellValue('B' . $sn, $dealer->erp); + $sheet->setCellValue('C' . $sn, $province); + $sheet->setCellValue('D' . $sn, $dealer->city); + $sheet->setCellValue('E' . $sn, $dealer->alias); + $sheet->setCellValue('F' . $sn, $dealer->address); + $sheet->setCellValue('G' . $sn, $lng); + $sheet->setCellValue('H' . $sn, $lat); + $sheet->setCellValue('I' . $sn, '13000000000'); + $sheet->setCellValue('J' . $sn, '09:00-18:00'); + $sheet->setCellValue('K' . $sn, ''); + + $vehicles = $dealer->vehicles->map(fn($v) => $v->extra_code)->join(','); + $vehicles = trim($vehicles, ','); + $sheet->setCellValue('L' . $sn, $vehicles); + + ++$sn; + } + $writer = new Xlsx($spreadsheet); + $writer->save(storage_path('app/dealers-' . $index . '.xlsx')); + } + + public function csv($chunk, $index) + { + $headers = ['门店名称(必填)', '门店编码', '省份名称(必填)', '城市名称(必填)', '描述', '地址(必填)', '经度(必填)', '纬度(必填)', '电话(必填)', '营业时间(必填)', '标签', '业务扩展字段']; + $file = fopen(storage_path('app/dealers-' . $index . '.csv'), 'w'); + fputcsv($file, $headers); + $chunk->each(function (Dealer $dealer) use ($file) { + $except1 = ['北京', '上海', '天津', '重庆']; // 直辖市 + $except2 = ['内蒙古', '内蒙古(蒙东)', '内蒙古(蒙西)']; // 内蒙古自治区 + $except3 = ['新疆']; // 新疆维吾尔自治区 + $except4 = ['西藏']; // 西藏自治区 + $except5 = ['广西']; // 广西壮族自治区 + $except6 = ['宁夏']; // 宁夏回族自治区 + $except7 = ['香港', '澳门']; // 香港特别行政区、澳门特别行政区 + + $province = $dealer->province; + if (in_array($province, $except1)) { + $province .= '市'; + } elseif (in_array($province, $except2)) { + $province = '内蒙古自治区'; + } elseif (in_array($province, $except3)) { + $province = '新疆维吾尔自治区'; + } elseif (in_array($province, $except4)) { + $province = '西藏自治区'; + } elseif (in_array($province, $except5)) { + $province = '广西壮族自治区'; + } elseif (in_array($province, $except6)) { + $province = '宁夏回族自治区'; + } elseif (in_array($province, $except7)) { + $province .= '特别行政区'; + } else { + $province .= '省'; + } + + $lng = $dealer->lng ? number_format($dealer->lng, 6) : ''; + $lat = $dealer->lat ? number_format($dealer->lat, 6) : ''; + + fputcsv($file, [ + $dealer->name, + $dealer->erp, + $province, + $dealer->city, + $dealer->alias, + $dealer->address, + $lng, + $lat, + '13000000000', + '09:00-18:00', + '', + $dealer->region, + ]); + }); + fclose($file); + } + + public function action_csv() + { + $items = Dealer::query()->orderBy('id')->get(); + $chunks = $items->chunk(200); + $chunks->each(fn($chunk, $index) => $this->xlsx($chunk, $index)); + } + + public function action_xlsx() + { + $items = Dealer::query()->orderBy('id')->get(); + $chunks = $items->chunk(200); + $chunks->each(fn($chunk, $index) => $this->xlsx($chunk, $index)); + } + + public function action_dump() + { + $address = $this->ask('请输入地址'); + $response = $this->getGeocoding($address); + dump($response); + } + + public function action_show() + { + $items = Dealer::query()->take(4)->get(); + $this->table(['CODE', '经销商名称', '在售车型'], $items->map(fn(Dealer $d) => [$d->erp, $d->alias, $d->vehicles->map(fn($v) => $v->spec_id)->join(',')])); + } + + public function action_fix() + { + $dealers = Dealer::query()->orderBy('id')->whereNull('lat')->get(); + $dealers->each(function (Dealer $dealer) { + $endpoint = 'https://api.map.baidu.com/geocoding/v3/'; + $address = str_replace("\n", " ", $dealer->address); + $this->info($dealer->id . ':' . $address); + $response = Http::get($endpoint, ['address' => $address, 'output' => 'json', 'ak' => config('services.baidulbs.ak')]); + if ($response->json('status') === 0) { + $location = $response->json('result.location'); + $dealer->update(['address' => $address, 'lat' => $location['lat'], 'lng' => $location['lng']]); + } + }); + } + + public function getGeocoding($address) + { + $endpoint = 'https://api.map.baidu.com/geocoding/v3/'; + $response = Http::get($endpoint, ['address' => $address, 'output' => 'json', 'ak' => config('services.baidulbs.ak')]); + return $response->json(); + } +} diff --git a/packages/bydauto/src/Controllers/BYDAutoController.php b/packages/bydauto/src/Controllers/BYDAutoController.php new file mode 100644 index 0000000..c47a382 --- /dev/null +++ b/packages/bydauto/src/Controllers/BYDAutoController.php @@ -0,0 +1,67 @@ +validate($request, $rules); + $requestId = Str::uuid(); + $request->merge(['request_id' => $requestId]); + (new TestdriveCreateAction())->execute($request); + + return response()->json(['code' => 0, 'message' => '提交成功', 'request_id' => $requestId]); + } + + public function vehicle(Request $request) + { + $items = Vehicle::cachedItems(); + return response()->json($items); + } + + public function province(Request $request) + { + $vehicle = Vehicle::query()->firstWhere('name', $request->vehicle); + $dealers = $vehicle->dealers; + $province = $dealers->groupBy('province')->keys(); + $data = $province->map(fn($item) => ['name' => $item]); + return response()->json($data); + } + + public function city(Request $request) + { + $vehicle = Vehicle::query()->firstWhere('name', $request->vehicle); + if (!$vehicle) { + throw ValidationException::withMessages(['vehicle' => '车型不存在']); + } + $dealers = $vehicle->dealers; + $city = $dealers->where('province', $request->province)->groupBy('city')->keys(); + $data = $city->map(fn($item) => ['name' => $item]); + return response()->json($data); + } + + public function dealer(Request $request) + { + $vehicle = Vehicle::query()->firstWhere('name', $request->vehicle); + if (!$vehicle) { + throw ValidationException::withMessages(['vehicle' => '车型不存在']); + } + $dealer = Dealer::query()->where('province', $request->province)->where('city', $request->city)->get(); + $data = $dealer->map(fn($item) => ['name' => $item->name, 'address' => $item->address, 'erp' => $item->erp]); + return response()->json($data); + } +} diff --git a/packages/bydauto/src/Foundation/AlipayAES.php b/packages/bydauto/src/Foundation/AlipayAES.php new file mode 100644 index 0000000..ea7d4db --- /dev/null +++ b/packages/bydauto/src/Foundation/AlipayAES.php @@ -0,0 +1,83 @@ +addPKCS7Padding($str); + $iv = str_repeat("\0", 16); + $encrypt_str = openssl_encrypt($str, 'AES-128-CBC', $screct_key, OPENSSL_NO_PADDING, $iv); + return base64_encode($encrypt_str); + } catch (\Exception $e) { + throw new \Exception("AES加密失败,plainText=" . $plainText . ",keySize=" . strlen($key) . "。" . $e->getMessage()); + } + } + + /** + * AES解密. + * + * @param $cipherText String 密文 + * @param $key String 对称密钥 + * @return false|string + * @throws \Exception + */ + public function decrypt($cipherText, $key) + { + try { + // AES, 128 模式加密数据 CBC + $str = base64_decode($cipherText); + $screct_key = base64_decode($key); + $iv = str_repeat("\0", 16); + $decrypt_str = openssl_decrypt($str, 'AES-128-CBC', $screct_key, OPENSSL_NO_PADDING, $iv); + return $this->stripPKSC7Padding($decrypt_str); + } catch (\Exception $e) { + throw new \Exception("AES解密失败,cipherText=" . $cipherText . ",keySize=" . strlen($key) . "。" . $e->getMessage()); + } + } + + /** + * 填充算法. + * @param string $source + * @return string + */ + private function addPKCS7Padding($source) + { + $source = trim($source); + $block = 16; + $pad = $block - (strlen($source) % $block); + if ($pad <= $block) { + $char = chr($pad); + $source .= str_repeat($char, $pad); + } + return $source; + } + + /** + * 移去填充算法. + * @param string $source + * @return string + */ + private function stripPKSC7Padding($source) + { + $char = substr($source, -1); + $num = ord($char); + if ($num == 62) { + return $source; + } + return substr($source, 0, -$num); + } +} diff --git a/packages/bydauto/src/Foundation/AlipayEasySDKFactory.php b/packages/bydauto/src/Foundation/AlipayEasySDKFactory.php new file mode 100644 index 0000000..1004d9a --- /dev/null +++ b/packages/bydauto/src/Foundation/AlipayEasySDKFactory.php @@ -0,0 +1,33 @@ +getOptions()); + } + + public function execute($method, $textParams, $bizParams) + { + return Factory::util()->generic()->execute($method, $textParams, $bizParams); + } + + protected function getOptions() + { + $options = new Config(); + $options->protocol = 'https'; + $options->gatewayHost = 'openapi.alipay.com'; + $options->signType = 'RSA2'; + $options->appId = config('chery-crm.alipay.app_id'); + $merchantPrivateKey = file_get_contents(storage_path(config('chery-crm.alipay.merchant_private_key'))); + $options->merchantPrivateKey = $merchantPrivateKey; + $alipayPublicKey = file_get_contents(storage_path(config('chery-crm.alipay.alipay_public_key'))); + $options->alipayPublicKey = $alipayPublicKey; + return $options; + } +} diff --git a/packages/bydauto/src/Foundation/DBLog.php b/packages/bydauto/src/Foundation/DBLog.php new file mode 100644 index 0000000..cc0a31e --- /dev/null +++ b/packages/bydauto/src/Foundation/DBLog.php @@ -0,0 +1,15 @@ +insert(['message' => $message, 'content' => $content, 'channel' => $channel, 'created_at' => now(), 'updated_at' => now()]); + } +} diff --git a/packages/bydauto/src/Foundation/DataTransfer.php b/packages/bydauto/src/Foundation/DataTransfer.php new file mode 100644 index 0000000..f64524b --- /dev/null +++ b/packages/bydauto/src/Foundation/DataTransfer.php @@ -0,0 +1,53 @@ +attributes = $attributes; + } + + public function toArray() + { + return $this->attributes; + } + + public function offsetExists($offset): bool + { + return isset($this->attributes[$offset]); + } + + public function offsetGet($offset): mixed + { + return $this->attributes[$offset] ?? null; + } + + public function offsetSet($offset, $value): void + { + $this->attributes[$offset] = $value; + } + + public function offsetUnset($offset): void + { + unset($this->attributes[$offset]); + } + + public function toJson($options = 0): string + { + return json_encode($this->jsonSerialize(), $options); + } + + public function jsonSerialize(): mixed + { + return $this->toArray(); + } + + public function get($key, $default = null) + { + return \Arr::get($this->attributes, $key, $default); + } +} diff --git a/packages/bydauto/src/Foundation/Encryption.php b/packages/bydauto/src/Foundation/Encryption.php new file mode 100644 index 0000000..90cfd58 --- /dev/null +++ b/packages/bydauto/src/Foundation/Encryption.php @@ -0,0 +1,31 @@ +pubkey)) { + $data = base64_encode($encrypted); + } else { + throw new \Exception('Unable to encrypt data. Perhaps it is bigger than the key size?'); + } + return $data; + } + + public function decrypt($data) + { + if (openssl_private_decrypt(base64_decode($data), $decrypted, $this->privkey)) { + $data = $decrypted; + } else { + $data = ''; + } + return $data; + } +} diff --git a/packages/bydauto/src/Jobs/TestdrivePushJob.php b/packages/bydauto/src/Jobs/TestdrivePushJob.php new file mode 100644 index 0000000..1de46b1 --- /dev/null +++ b/packages/bydauto/src/Jobs/TestdrivePushJob.php @@ -0,0 +1,37 @@ +sendNotification(); + $this->model->update(['status' => Testdrive::STATUS_PUBLISHED]); + } catch (\Exception $e) { + info('===== TestdrivePushJob::handle exception', ['message' => $e->getMessage()]); + } + } + + public function sendNotification() + { + $message = new TestdirveNotification($this->model); + $contacts = Contact::query()->where('status', Contact::STATUS_PUBLISHED)->get(); + $contacts->each(fn(Contact $contact) => $contact->notify($message)); + } +} diff --git a/packages/bydauto/src/Models/Contact.php b/packages/bydauto/src/Models/Contact.php new file mode 100644 index 0000000..8ac4c66 --- /dev/null +++ b/packages/bydauto/src/Models/Contact.php @@ -0,0 +1,18 @@ +belongsToMany(Vehicle::class, 'bydauto_dealer_vehicles', 'dealer_id', 'vehicle_id'); + } + + public static function cachedItems() + { + return Cache::remember('BYDAuto:dealers', 120, fn() => static::query()->get()); + } + + public static function findByAlias($alias) + { + $items = self::cachedItems(); + return $items->first(fn($d) => $d->alias === $alias); + } + + public static function findByName($name) + { + $items = self::cachedItems(); + return $items->first(fn($d) => $d->name === $name); + } +} diff --git a/packages/bydauto/src/Models/Testdrive.php b/packages/bydauto/src/Models/Testdrive.php new file mode 100644 index 0000000..52b13ab --- /dev/null +++ b/packages/bydauto/src/Models/Testdrive.php @@ -0,0 +1,37 @@ + 'json', 'rawdata' => 'json']; +} diff --git a/packages/bydauto/src/Models/Vehicle.php b/packages/bydauto/src/Models/Vehicle.php new file mode 100644 index 0000000..32c7200 --- /dev/null +++ b/packages/bydauto/src/Models/Vehicle.php @@ -0,0 +1,44 @@ + 'array']; + + public function dealers() + { + return $this->belongsToMany(Dealer::class, 'bydauto_dealer_vehicles', 'vehicle_id', 'dealer_id'); + } + + public static function cachedItems() + { + return Cache::remember('BYDAuto:vechicle', 3600, function () { + return Vehicle::query()->get()->map(fn($d) => ['id' => $d->id, 'name' => $d->name, 'alias' => $d->alias, 'spec_id' => $d->spec_id]); + }); + } + + public static function specId($name) + { + $items = self::cachedItems(); + $item = $items->first(fn($d) => in_array($name, $d['alias']) || $d['name'] === $name); + return $item ? $item['spec_id'] : null; + } +} diff --git a/packages/bydauto/src/Notifications/TestdirveNotification.php b/packages/bydauto/src/Notifications/TestdirveNotification.php new file mode 100644 index 0000000..b1b0c25 --- /dev/null +++ b/packages/bydauto/src/Notifications/TestdirveNotification.php @@ -0,0 +1,41 @@ +subject("预约试驾线索通知") + ->line("收到了一条新的试驾预约信息,请及时处理") + ->line("姓名:" . $this->model->name . " \n电话:" . $this->model->mobile) + ->line("=====") + ->line("祝,工作愉快!"); + } + + public function toArray(object $notifiable): array + { + return [ + // + ]; + } +} diff --git a/packages/bydauto/src/Observers/TestdriveObserver.php b/packages/bydauto/src/Observers/TestdriveObserver.php new file mode 100644 index 0000000..5896af4 --- /dev/null +++ b/packages/bydauto/src/Observers/TestdriveObserver.php @@ -0,0 +1,25 @@ +status === null) { + $model->status = Testdrive::STATUS_DRAFT; + } + } + + public function created(Testdrive $model) + { + if ($model->status === Testdrive::STATUS_DRAFT) { + TestdrivePushJob::dispatch($model); + } else { + info('===== TestdriveObserver::created not a draft', ['id' => $model->id, 'status' => $model->status]); + } + } +} diff --git a/packages/bydauto/views/notice/salesleads-day.blade.php b/packages/bydauto/views/notice/salesleads-day.blade.php new file mode 100644 index 0000000..aa96b5e --- /dev/null +++ b/packages/bydauto/views/notice/salesleads-day.blade.php @@ -0,0 +1,16 @@ +
+

{{ $date }}

+@if ($items->isEmpty()) +
无数据
+@else +
    +@foreach ($items as $item) +
  • + {{ $sourceMap[$item->source] ?? $item->source }} + {{ $item->total }} +
  • +@endforeach +
+

总数:{{ $count }}

+@endif +
diff --git a/packages/bydauto/views/notice/salesleads.blade.php b/packages/bydauto/views/notice/salesleads.blade.php new file mode 100644 index 0000000..7f0d67b --- /dev/null +++ b/packages/bydauto/views/notice/salesleads.blade.php @@ -0,0 +1,8 @@ +
+ @foreach ($sourceGroup as $source => $items) +

渠道: {{ $source }}

+ @foreach ($items as $item) +
{{ $item->day }} {{ $item->total }}
+ @endforeach + @endforeach +
diff --git a/phpunit.xml b/phpunit.xml new file mode 100644 index 0000000..506b9a3 --- /dev/null +++ b/phpunit.xml @@ -0,0 +1,33 @@ + + + + + tests/Unit + + + tests/Feature + + + + + app + + + + + + + + + + + + + + + + diff --git a/public/.htaccess b/public/.htaccess new file mode 100644 index 0000000..3aec5e2 --- /dev/null +++ b/public/.htaccess @@ -0,0 +1,21 @@ + + + Options -MultiViews -Indexes + + + RewriteEngine On + + # Handle Authorization Header + RewriteCond %{HTTP:Authorization} . + RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}] + + # Redirect Trailing Slashes If Not A Folder... + RewriteCond %{REQUEST_FILENAME} !-d + RewriteCond %{REQUEST_URI} (.+)/$ + RewriteRule ^ %1 [L,R=301] + + # Send Requests To Front Controller... + RewriteCond %{REQUEST_FILENAME} !-d + RewriteCond %{REQUEST_FILENAME} !-f + RewriteRule ^ index.php [L] + diff --git a/public/favicon.ico b/public/favicon.ico new file mode 100644 index 0000000..e69de29 diff --git a/public/index.php b/public/index.php new file mode 100644 index 0000000..947d989 --- /dev/null +++ b/public/index.php @@ -0,0 +1,17 @@ +handleRequest(Request::capture()); diff --git a/public/robots.txt b/public/robots.txt new file mode 100644 index 0000000..eb05362 --- /dev/null +++ b/public/robots.txt @@ -0,0 +1,2 @@ +User-agent: * +Disallow: diff --git a/public/static/1731484241.jpg b/public/static/1731484241.jpg new file mode 100644 index 0000000000000000000000000000000000000000..dffed774d63babc3126ab4b98adb336ed8289579 GIT binary patch literal 241009 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

Wj8yg#9FV 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 literal 0 HcmV?d00001 diff --git a/public/static/libs/element-ui/CHANGELOG.en-US.md b/public/static/libs/element-ui/CHANGELOG.en-US.md new file mode 100644 index 0000000..b8b32a2 --- /dev/null +++ b/public/static/libs/element-ui/CHANGELOG.en-US.md @@ -0,0 +1,2085 @@ +## Changelog + +### 2.15.14 + +*2023-08-24* + +#### Bug fixes +- Img + - Delete referrerpolicy prop (#22651 by @xinguanhua) +#### Optimization +- Docs + - Update readme and website example links (#22642 by @lyfeyaj) + - Update popper links (#22539 by @brizer) +- I18n + - Update translation of Spanish (#22430 by @jcardus) + - Add sr-Latn translation (#22567 by @N-M) + - Update Uzbek translation (#22390 by @akahon) +- Statistics + - Fix doc; Optimized code (#22384 by @webvs2) +- Table + - Add highlight selection row (#22382 by @wangdaodao) + +### 2.15.13 + +*2023-02-12* + +#### Bug fixes +- Docs + - Fix Statistic docs (#22383 by @JUST-Limbo) + - Fix Input docs (#22093 by @lm312) + - Fix en-US docs (#22268 #22269 #22270 by @Hazel-Lin) + - Fix Pagination docs (#22288 by @xujintai123) + - Fix: Links docs (#22370 by @itmier) +- Statistics + - fix slot display bug (#22375 by @webvs2) +- Chore + - missing web-type after publishing (#22271 by @loosheng) +#### Optimization +- InputNumber + - Fix touch one click trigger twice on the window touch pad (#22185 by @mrsai) +- Image + - Add initialIndex prop (#22346 by @inkroom) +- Statistics + - Updated countdown feature to localize lodash Closes (#22260 by @webvs2) + - Update code and doc (#22276 by @webvs2) +- Other + - fix web-types type props (#22281 by @whzxc) + +### 2.15.12 + +*2022-11-16* + +#### Bug fixes +- Statistic: + - Fixed the thousandth bit bug (#22252 by @webvs2) +- Other + - Fix 2.15.11 element-theme-chalk publish fail bug + +### 2.15.11 + +*2022-11-15* + +#### Bug fixes +- Docs + - Fix Radio docs (#22178 by @bchen1029) + - Fix Progress docs +#### Optimization +- I18n + - Update translation of Malaysian (#22185 by @z4q) + - Update translation of Norwegian (#22145 by @Barsnes) +- Progress + - Add defineBackColor and textColor prop (#22089 by @lm312) +- Statistics + - Add new component Statistics (#22159 by @webvs2) +- Other + - Add Web Types to improve code assistance in WebStorm IDE and other JetBrains IDEs (#22135 by @piotrtomiak) + +### 2.15.10 + +*2022-09-13* + +#### Bug fixes + +- DatePicker + - Fix props placement error (#21908 by @lqzhgood) +- Loading + - Fix sticky DOM error (#22087 by @zzjjhh001) +- Docs + - Fix Popover docs (#22083 by @lm312) + - Fix Skeleton docs (#22092 by @lm312) + - Fix DatePicker docs (#21970 by @guojiongwei) +- Tree: + - fix lazy-load default check problem (#21934 by @kiss-yu) + +#### Optimization + +- I18n + - Add translation of Sinhalese (#21936 by @sayuri-gi) + - Update translation of Spanish (#21924 by @jcardus) + - Add translation of Malaysian (#22028 by @iorange0411) + - Update translation of Swahili (#21904 by @Cholowao) +- Utils + - update date-util.js (#22099 by @Due07) +- DatePicker + - add months And years type (#21918 by @akiko123456) + +### 2.15.9 + +*2022-06-02* + +#### Bug fixes + +- Table + - Fix Tabl-header shake bug (#21863 by @bofeng) + - Fix when partial import show `el-checkbox not imported` error (#21828 by @bobohuochai) +- FormItem + - Fix change rules verification not reset bug (#21892 by @bofeng) +- Cascader + - Fix change options unexpect error (#21759 by @louiebb) +- Docs + - Fix Popover docs (#21843 by @lod61) + - Fix Calendar docs (#21814 by @GoJam11) + - Fix TimePicker docs (#21803 by @Alanscut) + - Fix DatePicker docs (#21877 by @Nirvanaiu) +- Other + - Fix codepen display bug (#21863 by @bofeng) + +#### Optimization + +- I18n + - Add translation of Swahili (#21895 by @quilltouch) +- Chore + - Use launch-editor-middleware in dev environment (#21633 by @polemices) +- DatePicker & Cascader + - Optimize the dropdown animation direction (#21806 by @XivLaw) +- Tooltip + - Optimize `getFirstElement` code (#21886 by @zhankang) +- Input + - Optimize scss code (#21558 by @cheese-git) + +### 2.15.8 + +*2022-04-12* + +#### Bug fixes + +- Drawer + - Fix appendToBody failure problem (#21264 by @cs1707) +- Switch + - Fix toggling value problem(#19473 by @EdwinBetanc0urt) +- Docs + - Fix input docs (#21723 by @justforuse) + - Fix DatePicker docs (#21663 by @justforuse) + - Fix Skeleton docs (#21601 by @yanwydxf) +- Others + - Fix vue version (#21736 by @ckvv) + +#### Optimization + +- I18n + - add translation of Azerbaijani (#21012 by @ricardotondello) + - update translation of Slovenian (#21729 by @patik123) + - update translation of Slovak (#21711 by @sjaustirni ) + - add translation of Icelandic (#21709 by @aronhr) + - add translation of Bengali (#21485 by @llwwtt) + +#### Others + +- Due to compatibility considerations, the PR on node-sass (#21019 by @linxsbox) of 2.15.7 release has been withdrawn and will be published in an appropriate version after re-evaluation. + +### 2.15.7 + +*2021-11-18* + +#### Bug fixes + +- Select + - fix click icon triggering dropdown (#21314 by @dennyak47) + - fix keydown event when composition (#21336 by @bchen1029) +- Badge + - fix type class when is-dot (#21308 by @adaex) +- Form + - validate method reject error info (#21374 by @cs1707) +- Table + - fix resizeObserver loop limit exceeded (#21255 by @tomieric) + - fix toggleAllSelection bug when table is empty (#21456 by @cs1707) + - optimize performance (#21330 by @cs1707) +- Button + - fix disabled priority (#21375 by @cs1707) +- Descriptions + - fix label slot bug (#21462 by @cs1707) +- SASS + - replace node-sass with dart-sass (#21019 by @linxsbox) +- Docs + - fix skeleton typos (#21408 by @zhhbstudio) + +### 2.15.6 + +*2021-09-02* + +#### Bug fixes + +- Cascader + - fix a bug that makes the browser jitter in zoom mode (#21207 by @cs1707) + - optimize performance (#21231 by @cs1707) +- Select + - fix long text overflow in multiple mode (#21237 by @cs1707) +- Dropdown + - add disabled property (#21235 by @mshioda) +- Radio + - fix checked state when browser go back (#21250 by @cs1707) +- Descriptions + - fix type declaration (#21265 by @adaex) + - avoid table style conflict (#21254 by @adaex) +- Drawer + - fix append to body (#21264 by @cs1707) +- Local + - fix italian mistake (#21012 by @ricardotondello) + +### 2.15.5 + +*2021-08-04* + +#### Bug fixes + +- Select + - fix resetInputHeight (#21201 by @cs1707) + +### 2.15.4 + +*2021-08-03* + +#### New features + +- Descriptions + - add description component (#21129 by @cs1707) +- Result + - add result component (#21171 by @cs1707) + +#### Bug fixes + +- Utils + - fix isScroll (#21098 by @canvascat) +- Translation + - update it.js (#21133 by @bliberi) +- RadioGroup + - fix RadioGroup used in component causes exception #17908 (#20783 by @lceric) +- Message + - fix message[type] (#21088 by @cs1707) +- Carousel + - reset the timer when setActiveItem method is called (#20846 by @Nekojita1) +- Cascader + - fix emitPath (#21185 by @cs1707) +- Select + - fix select filterable bug (#17494 by @profore) + - fix a bug that makes the browser jitter in zoom mode (#21197 by @cs1707) +- Tree + - fix insertChild (#21194 by @cs1707) + +### 2.15.3 + +*2021-06-29* + +#### New features + +- Skeleton + - add skeleton component (#21038 by @cs1707) +- Empty + - add empty component (#21080 by @cs1707) + +#### Bug fixes + +- Local + - fix week translations for hr locale (#21040 by @cs1707) +- Table + - fix lazy load data (#21041 by @cs1707) +- Docs + - fix form hide-required-asterisk description (#21045 by @cs1707) +- Drawer: + - fix destroy (#20715 by @zj9495) +- Row + - fix align top (#20963 by @cs1707) +- Select + - fix the bug when the value is Boolean (#21052 by @cs1707) +- Calendar + - fix first-day-of-week (#21057 by @cs1707) +- Utils + - fix isScroll (#21065 by @cs1707) + - fix(utils.dom by @fw6) +- TypeScript + - add CascaderPanel export type (#21070 by @qige2016) + - add spinner.d.ts (#21090 by @qige2016) + +### 2.15.2 + +*2021-05-28* + +#### Bug fixes + +- Image + - fix z-index and keydown event add stopPropagation (#20859 by @cs1707) +- Input + - fix show password cursor (#20870 by @cs1707) + - fix show password icon in edge (#20902 by @cs1707) +- Carousel + - fix interval and scale bug (#20931 by @cs1707) +- Cascader + - fix delete tag bug (#20939 by @cs1707) +- Drawer + - add overflow auto (#20948 by @cs1707) +- Others + - fix isFunction (#20912 by @cs1707) + +### 2.15.1 + +*2021-02-23* + +#### Bug fixes + +- Drawer + - bugfix (by @cs1707) +- Image + - fix incorrect image object fit ratio in IE (#19583 by @charlie0228) +- Cascader + - fix cascader panel active path (#20730 by @cs1707) +- Calendar + - fix calendar component i18n bug (#20758 by @iamkun) +- ColorPicker + - fix bugs (by @UxieVerity) + +#### Optimization + +- Doc + - update Axure resource v2.1.0 (by @iamkun) + +### 2.15.0 + +*2021-01-15* + +#### Bug fixes + +- Select + - Fix placeholder i18n bug (#17644 by @nzh63) +- Popconfirm + - Popconfirm i18n bug by @iamkun) +- Drawer + - Fix focus bug (#20626 by @cs1707) +- Image + - Preview optimization (#20652 by @cs1707) + +#### Optimization + +- Doc + - Fix typo in french translation of datetime-picker.md (#20543 by @lonk) + - Add format attribute description to the progress component (#20641 by @cs1707) + +### 2.14.1 + +*2020-11-11* + +#### Bug fixes + +- Popover + - Compatible with Vue 2.6 new v-slot syntax (#20424 by @iamkun) + +#### Optimization + +- I18n + - Update Arabic translation (#20202 by @elkattan) + - Update Uighur translation (#20177 by @IlhamTahir) + +### 2.14.0 + +*2020-10-29* + +#### Breaking changes + +- Popconfirm + - Rename event name to `confirm`, `cancel` (#20240 by @hugiron) + +#### Bug fixes + +- Progress + - Fix attribute error (#19985 by @Caaalabash) + +#### Optimization + +- I18n + - Update Russian translation (#19451 by @yangirov) + - Update Khmer translation (#20077 by @Sovai) + - Update Ukrainian translation (#20344 by @MammutAlex) + +### 2.13.2 + +*2020-05-18* + +#### Bug fixes + +- Autocomplete + - Fix change event bug (#19200 by @sxzz) +- Image + - Update error status (#19194 by @lhx6538665) + +#### Optimization + +- I18n + - Update ru-RU popconfirm translation (#19220 by @Opppex) + - Update vi translation (#19244 by @quangln2810) + - Update Catalan and Spanish translations (#19296 by @Ismaaa) + - Update Indonesia translation (#19320) by @therour) + - Update Brazilian Portuguese translation (#19374 by @diegomengarda) + +### 2.13.1 + +*2020-04-13* + +#### New features +- Autocomplete + - Add change event (#17913 by @sxzz) + +#### Bug fixes + +- Autocomplete + - Fix suggestion error when textarea (#18478 by @Roojay) +- Carousel + - Fix console typo bug (#18264 by @IceFox) +- Image + - Fix preview dose not show when preview list not contain src issue (#18975) (#19130 by @luckyCao) + - Fix shortcut key not work at second time issue (#18983) (#19156 by @luckyCao) + - Don't show image-viewer when preview is false (#18967 by @inooNgt) +- Transfer + - Fix incorrect line-height of el-transfer's first list item when it was used with el-form-item (#18917 by @Hanx) +- InputNumber + - Correctly compute inputNumberDisabled (#18439 by @ashuser-pendo) +- Chore + - Remove index intro (#19155 by @iamkun) +- Doc + - Popconfirm doc update (#18324 by @iamkun) + - Fix step-strictly docs typo (#18705 by @dream2023) + - Fix a type error in document of steps component (#17555 by @haoranyu) + +### 2.13.0 + +*2019-11-26* + +#### New features + +- Popconfirm + - Add popconfirm component (#17548 by @iamkun) + +#### Bug fixes + +- BackTop + - Use cubic bezier scrolling (by @lon) +- DatePicker + - Fix bug of only select min date of date range problem (#17191 by @smk0621) +- Select + - Fix select test cases by (@msidolphin) +- Tree + - Add font-size for the style of tree empty-text (#17094 by @spengjie) +- Table + - Column header can be costumed (#17291 by @ziyoung) + - Update table header cell style (#17284 by @ziyoung) + - Fix table header height after filter (#17348 by @ziyoung) + - Fixed row-style with display not work (#17002 by @a631807682) + - Fix header table not display (#17341 by @ziyoung) +- Calendar + - Import el-button and el-button-group (#17376 by @masongzhi) +- MessageBox + - Fix icon position error (#17410 by @nullptru) +- TimePicker + - Set the selection range after scrolling up or down (#16868 by @mattheyan) +- Message + - Fix close instace offsetHeight(#17564) (#17852 by @gzwgq222) +- Form + - Callback of validateField should be optional (#17314 by @CarterLi) +- Cascader + - Fix TypeScript 3.7 compatibility (#17881 by @CarterLi) +- Menu + - Fix router NavigationDuplicated error when using vue-router@^3.1.0 (#17269 by @iamkun) +- Dropdown + - Update type file (#17550 by @iamkun) +- Progress + - Add strokeLinecap prop (#17552 by @iamkun) +- InfiniteScroll + - Skip trigger event on invisible element (#17553 by @iamkun) +- Image + - Perfect picture preview behavior (#16985 by @luckyCao) + - Fix shield the page when preview big image (#16796 by @luckyCao) +- Drawer + - Bugfix drawer-append-to-body-not-working (#16953 by @JeremyWuuuuu) +- Select + - Fix tag show value or empty issue (17199 by @luckyCao) +- Scrollbar + - Fix FireFox scroll bar width (#18091 by @iamkun) + +#### Optimization + +- I18n + - Update sv-SE.js (#17926 by @FOLLGAD) + - Update avatar component fr doc (#17762 by @blombard) +- Docs + - Fix time-select typo (#17250 by @wacky6) + - Fix Drawer attribute accepted value typo in es (#17122 by @haoranyu) + - Update Spanish changelog 2.12.0 (#17364 by @Gonzalo2310) + - Fix Changelog typo (#17874 by @renlixin) + - Fix Loading demo (#17862 by @MBearo) + - Add input event in input Events Table (#18061 by @zhouxinyong) + - Delete Input repeat change event (#18085 by @zhouxinyong) + +### 2.12.0 + +*2019-08-29* + +#### New features + +- Popover + - Add close-delay prop (#16671 by @LachlanStuart) +- Theme + - Add Chrome Extension: Element Theme Extension (#16686 by @iamkun) +- Icon + - Add font-display to @font-face declaration (#16805 by @iamfaizalandyka) + +#### Bug fixes + +- Carousel + - Fix onChange emit value (#16705 by @iamkun) +- Notification + - Fix modifying incoming option object (#16704 by @iamkun) +- DatePicker + - Add className for picker option (#16632 by @iamkun) +- DateTimePicker + - Fix time-spinner not scroll to right position (#16854 by @jesse-li) +- Table + - Prevent click handler after drag (#16850 by @ziyoung) + - Fix chrome crash when set thead css display to none (#16956 by @luckyCao) + - Fix wrong empty block height (#16861 by @ziyoung) + - Not throw error when calling toggleExpansion (#16304 by @yyjjqq94) + - Not trigger sort-change event when mounted (#17113 by @a631807682) + - Fix setCurrentRow unable to clear highlight row (#16879 by @ziyoung) + - Fix expand-row-keys not work when data is loaded asynchronously (#16899 by @ziyoung) + - set toggleAllSelection as instance property (#17137 by @ziyoung) +- Tree + - Fix distance between label and checkbox (#16799 by @Hazlank) +- Tabs + - Fix incorrect TabItem's position (#16520 by @victorting) + - Fix activated tab is out of visual range bug (#17033 by @nullptru) +- Calendar + - Fix weekdays i18n issue (#16772 by @ubitoffee) + - fix locale error (#17208 by @iamkun) +- Cascader + - Fix CascaderPanel display error (#16716 by @zhangHongEn) + - Fix disable status and close button issue (#16224 by @yyjjqq94) +- Input + - Fix Korean composition event (#15069 by @MoonHyuk) + - Fix click event of clear button not trigger when using v-loading (#16576 by @a631807682) +- Select + - Not toggle dropdown when filtering (#17205 by @luckyCao) +- Transfer + - Fix style error (#17206 by @iamkun) +- Dialog + - update sass var (#16365 by @haoranyu) +- RadioGroup + - Not produce invalid HTML in table if "is" attribute is specify (#17070 by @nullptru) +- Divider + - Support custom classes (#17078 by @island205) + +#### Optimization + +- Checkbox + - Improve screen reader experience (#16575 by @tylertrotter) +- Docs + - Update changelog (#16773 by @SimonaliaChen) + - Update contributing guide (#14800 by @sinchang) + - Fix typo in Drawer docs (#16848 by @winkay) + - Update custom theme (#16983 by @iamkun) + - Add Esperanto translation (#16955 by @maxkoryukov) + - Update input-number document about change event (#16316 by @luckyCao) + - Update spanish doc 2.11.1 (#16961 by @Gonzalo2310) +- I18n + - Remove translation of 'year' in catalan language as in the other languages (#14722 by @oscaralbareda) + - Update spanish changelog 2.10.0 and 2.10.1 (#16548 by @Gonzalo2310) + - Update ar.js (#16653 by @l3op) +- Test + - Correct spelling error (#16672 by @boomler) + - Refactor unit test to use data-uri (#16847 by @a631807682) +- Types + - Fix httprequest type (#16633 by @luckyCao) + +### 2.11.1 + +*2019-07-26* + +#### Bug fixes + +- Image + - Fix Image component SSR compatibility (#16737 by @luckyCao) +- Chore + - Update dart-sass compatibility (#16744 by @LewisChennnnn) + +### 2.11.0 + +*2019-07-25* + +#### New features + +- Drawer + - Add drawer component (#16577 by @JeremyWuuuuu) + +#### Bug fixes + +- Checkbox + - Enhance css selector (#16006 by @Hazlank) +- Tree + - Make el-tree generic (#15934 by @JeremyWuuuuu) + - Set isCurrent prop to False (#15870 by @kkkisme) +- Dropdown + - Fix split-button caret default color (#15931 by @JuniorTour) +- Cascader + - Fix level 1 children is empty update problem (#16399 by @luckyCao) + - Add sets default values when lazy is true (#16420 by @luckyCao) + - Fix display errors when node value is duplicate (#15935 by @junyiz) + - Expose getCheckedNodes and fix options change bug (#16709 by @SimonaliaChen) +- Calendar + - Display correct header when range is specified (#16354 by @ziyoung) +- Submenu + - Fix prop append-to-body (#16289 by @a631807682) +- Table + - Fix tree table when updating data (#16481 by @island205) +- Select + - Fix memory leak issue (#16463 by @island205) +- InfiniteScroll + - Update naming & doc (#16698 by @iamkun) +- Avatar + - Fix image not center vertically issue (#16489 by @luckyCao) +- Dialog + - Add destroyOnClose attribute (#16455 by @ziyoung) +- Image + - Add big Image preview feature (#16333 by @luckyCao) + +#### Optimization + +- Docs + - Fix dropdown demo (#16193 by @webxmsj) + - Fix typo in table documents (#15971 by @howiefh) +- I18n + - Update translation of Thai language (#16689 by @ponkrit) +- Chore + - Update theme base api (#16607 by @iamkun) + - Add form theme token (#16699 by @iamkun) + - Mark ali inner user's access (#16609 by @iamkun) + - Fix doc anchor bug (#16692 by @iamkun) + +### 2.10.1 + +*2019-07-02* + +#### Bug fixes + +- Table + - Fix sort icon (#15439 by @bezany) + - Fix layout breaks when append slot exists (#16332 by @ziyoung) + - Fix showOverflowTooltip not reactive (#16295 by @a631807682) + - Register scrollbar in filter-panel (#16246 by @ziyoung) +- Chore + - Fix 2.9 docs (#16233 by @ziyoung) + - Fix index page theme intro english css style issue (#16254 by @iamkun) + +#### Optimization + +- Tag + - Compatible with IE (#16334 by @ziyoung) +- Chore + - Update Dingtalk Group QR image (#16236 by @iamkun) +- Doc + - Update online theme roller doc (#16244 by @iamkun) + +### 2.10.0 + +*2019-06-25* + +#### New features + +- I18n + - Added Uzbek language (#15796 by @ogabek96) +- Calendar + - Add first-day-of-week attribute (#16047 by @ziyoung) +- Avatar + - Add avatar component (#16144 by @luckyCao) +- Upload: + - Add capability to customize thumbnail template (#13192 by @victorzhuk) + +#### Bug fixes + +- Tree + - Not highlight tree node when currentKey is null (#15668 by @yyjjqq94) + - Fix issue #15538 caused by two Tree sharing the same data (#15615 by @VanMess) +- Upload + - Update the parameter `fileList` type (#15716 by @underfin) +- Table + - Fix loading icon not display (#15868 by @ziyoung) + - Fix background color of complex table when hovering (#15504 by @cnlon) + - Fix current-row-key and select event bug (#15983 by @ziyoung) + - Height accepts more units (#16013 by @ziyoung) + - Fix reserve-selection not work (#16135 by @ziyoung) +- Docs + - Fix Divider attribute type in zh-cn (#15889 by @haoranyu) +- Menu + - Fixed submenu hidden bug after adding popper-append-to-body (#15391 by @PanJiaChen) +- Select + - Fix initialInputHeight (#15989 by @yyjjqq94) + - Fix default-first-option behavior when typing Chinese (#15431 by @VanMess) + - fix double import problem (#16215 by @lengband) +- Message + - Add type def for offset option (#16027 by @matjaz) +- Timeline + - Fix reverse broken (#16091 by @ziyoung) +- Slider + - Fix #15545 by adding explains about "input" event in Chinese (#15588 by @VanMess) +- InfiniteScroll + - Update package name (#16125 by @iamkun) +- MessageBox + - Fix  distinguishCancelAndClose action not same as docs bug (#15438 by @qingdengyue) +- PopupManager + - Fix z-index cannot be rewritten at first using (#15738 by @luckyCao) +- Docs + - Delete an incorrect closing html tag and empty block code (#16194 by @Alexeykhr) +- Chore + - Update test api host (#15807 by @iamkun) + +#### Optimization + +- Tree + - Modify loop conditions to improve performance (#15699 by @KingJeason) +- Theme + - Refine GA track & Update footer link forward to online theme roller (#16007 by @island205) +- Badge + - Update badge prop check (#16198 by @iamkun) +- Avatar + - Update theme config var (#16202 by @luckyCao) +- I18n + - Update pt-br.js (#15776 by @gigioSouza) + - Update Farsi translation (#15881 by @pamenary) +- Docs + - Add missing components in quickstart (#16063 by @pape2016) + - Update french translation (#16208 by @blombard) + - Add description $slots.default (#15444 by @Alexeykhr) + - Update Spanish Doc 2.9.1 (#15840 by @Gonzalo2310) + - Fix spelling mistakes in fr (#15837 by @blombard) + - Update changelog 2.9.2 Spanish (#16185 by @Gonzalo2310) + +#### Breaking changes + +- Form + - Remove success status (#16159 by @ziyoung) + +### 2.9.2 + +*2019-06-21* + +#### Bug fixes + +- Chore + - Fix TS definitions file (#15805 by @NateScarlet) + +### 2.9.1 + +*2019-05-30* + +#### New features + +- Table + - default-expand-all, expand-row-keys, toggle-row-expansion method and expand-change event are supported in Tree Table (#15709 by @ziyoung) + +#### Bug fixes + +- Table + - Fix some bugs (#15709 by @ziyoung) +- Theme + - Update api host (#15784 by @iamkun) + +#### Optimization + +- Chore + - Update InfiniteScroll type (#15794 by @iamkun) + +### 2.9.0 + +*2019-05-30* + +#### New features + +- Backtop + - Add Backtop component (#15541 by @iamkun) +- PageHeader + - Add PageHeader component (#15714 by @ziyoung) +- InfiniteScroll + - Add InfiniteScroll directive (#15567 by @iamkun) +- Cascader + - Add multiple mode and filter-method (#15611 by @SimonaliaChen) +- Message + - Display in stack mode (#15639 by @island205) +- Tag + - Add prop effect (#15725 by @SimonaliaChen) +- Tabs + - Left align title when type is card (#15695 by @luckyCao) +- DatePicker + - Support literal strings (#15525 by island205) +- Image + - Add support for transmit attrs and listeners (#15578 by @VanMess) +- Theme + - Add popup background (#15412 by @iamkun) +- Chore + - Update new 2.9.0 index page (#15682 by @iamkun) + +#### Bug fixes + +- Table + - Fix sort-change behaviour when sort condition is null (#15012 by @joelxr) +- Image + - Fix ssr and object-fit compatibility (#15346 by @SimonaliaChen) +- Input + - Fix show-word-count style in el-form (#15359 by @lvjiaxuan) + - Fix clear icon is not centered (#15354 by @YiiGuxing) +- Calendar + - Fix not correct day of week when the day is Sunday (#15399 by @qingdengyue) + - Fix October disappear bug (#15394 by @qingdengyue) +- Tabs + - Fix basic tab nested in card tab padding error (#15461 by @SimonaliaChen) +- Tag + - Fix stop propagation problem (#15150 by @infjer) +- Form + - Fix input-group within form-item height error (#15457 by @SimonaliaChen) + - Fix resetFields issue (15181 by @luckyCao) +- Tooltip + - Fix custom tabindex not work (#15619 by @SimonaliaChen ) +- Link + - Fix link icon style class (#15752 by @iamkun) +- Select + - Revert set value to null when cleared (#15447 by @iamkun) +- Loading + - Fix dom not change when loading state change quickly (#15123 by @FAKER-A) +- Switch + - Label with el-switch repeating event (#15178 by @FAKER-A) +- Slider + - Fix style problem when clicking slider bar(#15561 by @luckyCao) +- Radio + - Fix issue 14808 (#14809 by @OverTree) +- Form + - Fix resetFields issue (15181 by @luckyCao) +- Chore + - Upgrade dependencies and fix demo bug (#15324 by ziyoung) +- Type + - Fix loading type definition (#15635 by @iamkun) + - Fix Icon type (#15634 by @iamkun) + - Fix Link type definition (#15402 by @iamkun) + +#### Optimization + +- Cascader + - Refactor (#15611 by @SimonaliaChen) +- Chore + - Update make new component logic (by @iamkun) +- Docs + - Rename variable in docs (#15185 by @liupl) + - Fix image attribute type and default value (#15423 by @haoranyu) + - Fix form doc bug (#15228 by @SHERlocked93) + +### 2.8.2 + +*2019-04-25* + +#### Bug fixes + +- Icon + - Update icon (#15272 by @iamkun) +- Docs + - Fix Form and Input doc style (#15273 by @ziyoung) + +### 2.8.1 + +*2019-04-25* + +#### Bug fixes + +- Icon + - Update icon of cascader and select (#15264 by @SimonaliaChen) + - Update icon (#15258 #15268 by @iamkun) + +#### Optimization + +- Chore + - Update build script (#15267 by @ziyoung) +- Docs + - Fix link underline color (#15265 by @iamkun) +- Other + - Fix migrating config not compatible with camel case props and events (#15260 by @SimonaliaChen) + +### 2.8.0 + +*2019-04-25* + +#### New features + +- Divider + - Add divider component (#15055 by @island205) +- Rate + - Add custom colors and icon-classes by passing a object (#15051 by @SimonaliaChen) +- Link + - Add link component (#15052 by @iamkun) +- Calendar + - Add calendar component (#14908 by @ziyoung) +- Icon + - Add icon (#15214 by @iamkun) +- Alert + - Add dark theme (#15041 by @island205) +- Image + - Add image component (#15117 by @SimonaliaChen) +- Collapse + - CollapseItem can be disabled (#15076 by @ziyoung) +- Carousel + - Add direction attribute and support vertical direction (#15122 by @ziyoung) +- Pagination + - Add hide-on-single-page attribute (#15096 by @ziyoung) +- Slider + - Add marks attribute (#15133 by @luckyCao) +- Input + - Add show-word-count attribute (#15075 by @luckyCao) +- InputNumber + - Add step-strictly attribute (#15050 by @luckyCao) +- Tooltip, Dropdown, Popover + - Support tabindex attribute (#15167 by @ziyoung) + +#### Bug fixes + +- Notification + - Fix title word break (#15008 by @iamkun) +- Form + - Fix switching the rules in el-form not work (#14985 by @luckyCao) + - Fix label style (#14969 by @ziyoung) + - Required FormItem displays asterisk when label is auto (#15144 by @ziyoung) +- Pagination + - Fix slot not updated (#14711 by @lucyhao) +- Table + - Fix load bug in lazy mode (#15101 by @ziyoung) + - Fix cell width when colspan is grater than 1 (#15196 by @ziyoung) + - Improve performance (#14868 by @ziyoung) + - Don't emit triggers sort-change during initialization (#14625 by @PeanutWatson) + - Equal behaviour for height and max-height (#14660 by @arthurdenner) +- Dialog + - Fix dialog body correctly break long words (#15027 by @iamkun) +- Alert + - update type definition (#15186 by @ziyoung) +- Tabs + - Fix issue where Promise rejection was hitting application (#14816 by @ffxsam) + - Rerender when slot changes (#15238 by @ziyoung) +- Message + - Fix type definition (#14968 by @agoni1212) +- Select + - Fix error when value is undefined or null (#15022 by @luckyCao) +- Tree + - Delete current node after it removed (#14604 by @sinchang) + - Improve performance (#14881 by @ChenZhuoSteve) +- Dropdown + - Fix style (#14907 by @doing123) +- Slider + - Fix broken keyboard a11y bug (#14792 by @erezsob) +- Menu + - ActiveIndex value shall be null if defaultIndex does not exist(#14074 by @hoythan) +- Directive + - RepeatClick: use Date.now() instead of new Date() (#14776 by @pavelmash) +- Upload + - Fix Upload transparent picture display style (#15039 by @iamkun) +- Theme + - Add zero border (#15256 by @iamkun) + +#### Optimization + +- Chore + - Update changelog zh-cn (#14965 by @iamkun) + - Hide demo description when it's empty (#15014 by @ziyoung) + - Display dev server info by default by @iamkun) + - Fix 2.6.0 changelog error (#15026 by @iamkun) + - Update build config (#14821 by @abc3660170) + - Add hmr (#15221 by @SimonaliaChen) + - Use sourcemap in dev environment (#15087 by @ibufu) +Docs + - Rename variable in docs (#14602 #15003 #15094 #15105 by @liupl) + - Fix upload doc error (#15023 by @iamkun) + - Update Form custom validator doc (#15040 by @iamkun) + - Update Tabs docs to display vertical tabs (#15053 by @iamkun) + - Use eleme.cn as domain (#15139 by @ziyoung) + - Fix Image route name (#15194 by @iamkun) + - Remove duplicated fr translation (#15207 by @iamkun) + +#### Breaking changes + +- Rate + - Fix decimal display support in disabled mode (#15089 by @haoranyu) +- Select + - Use placeholder option label to set placeholder in filter mode (#14989 by @ibufu) + +### 2.7.2 + +*2019-04-03* + +#### Bug fixes + +- Form + - Fix auto `label-width` style (#14955 by @ziyoung) + +#### Optimization +- Docs + - Fix doc img link error (#14957 by @iamkun) +- Chore + - Fix deploy mkdir error (#14952 by @iamkun) + +### 2.7.1 + +*2019-04-03* + +#### Bug fixes + +- Select + - Set value to null when cleared (#14322 by @aaronfulkerson) +- Input + - Update DOM dependent values on type change (#14889 by @wacky6) +- Table + - Make `defaultExpandAll` works when expanded column exists (#14935 by @ziyoung) +- Dialog + - Background color can be configured (#14939 by @ziyoung) +- Form + - `label-width` supports auto width (#14944 by @ziyoung) + +#### Optimization +- Docs + - Update Spanish docs (#14913 by @Gonzalo2310) + - Add French doc for new component (#14924 by @ziyoung) + - Optimize Tabs docs (#14938 by @ziyoung) + +### 2.7.0 + +*2019-03-28* + +#### New features + +- Table + - Add support tree structure data (#14632 by @ziyoung) + +#### Bug fixes + +- Tabs + - Use primary color as boxShadow color (#14558 by @Richard-Choooou) + - Rerender when label changes (#14496 by @akki-jat) +- Table + - Footer follows body cell align (#14730 by @ziyoung) +- NavMenu + - Fix click el-submenu trigger childMenu pop again bug (#14443 by @PanJiaChen) +- Dropdown + - Make compatible with 2.6 new v-slot syntax (#14832 by @ziyoung) +- ColorPicker + - Fix handle error hex color string (#14793 by @iamkun) +- Tree + - Revert pr #13349 (#14847 by @ziyoung) +- Tooltip + - Display when initial value is true (#14826 by @ziyoung) +- Docs + - Update cascader docs (#14442 by @panhezeng) +- Style + - Fix media query in sm-only, md-only, lg-only (#14611 by @sinchang) + +#### Optimization + +- Chore + - Add webpage description (#14802 by @iamkun) + +### 2.6.3 + +*2019-03-21* + +#### Bug fixes + +- Fix Cascader demo style (#14789 by @ziyoung) +- Remove unnecessary DOM operation (#14788 by @ziyoung) +- Fix DatePicker default-value DST (#14562 by @wacky6) + +### 2.6.2 + +*2019-03-21* + +#### New features + +- DatePicker + - Add monthrange for type attribute (#14487 by @zxyRealm) +- i18n + - Add Croatian locale (#14360 by @danijelh) + +#### Bug fixes + +- Input + - Fix regression (#14572 by @wacky6) +- DatePicker + - Fix first-day-of-week computation (#14523 by @sinchang) + - Fix week picker's value-format (#13754 by @wacky6) +- Steps + - Fix issue #14502 (#14596 by @sinchang) + - Fix style with simple theme (#14610 by @sinchang) +- Docs + - Update french doc for 2.6.1 and fix typos (#14555 by @smalesys) + - Rename variable in Table docs (#14587 by @likwotsing) + - Add french search index (#14565 by @iamkun) + - Fix TimePicker page style (#14579 by @ziyoung) + - Rename variable in Upload docs (#14593 by @liupl) + - French translation update (#14643 by @smalesys) + - Update Form async validator docs (#14694 by @iamkun) + - Fix tooltip doc error (#14748 by @iamkun) + - Fix typo (#14751 by @2bj) + - Fix highlighting control elements for Webkit touch (#14703 by @VladG0r) + +#### Optimization + +- Chore + - Update ci build script (#14600 by @ziyoung) + - Update ga tracking (#14560 by @iamkun) + - Add more ga event (#14633 by @iamkun) + - Update discusion group (#14741 by @iamkun) + - Update test deps and conf (#14735 by @wacky6) + - Upgrade gulp (#14745 by @ziyoung) + - Use codepen to display demo & fix doc error (#14747 by @ziyoung) + +### 2.6.1 + +*2019-03-03* + +#### Bug fixes + +- **Don't specify node version** (by @iamkun in #14546) +- Fix doc directory in `deloy-faas.sh` (by @ziyoung in #14553) +- Fix date style issue in changelog for 2.6.0 (by @island205 in #14547) +- Fix doc typo (by @wack6 in #14552) + +### 2.6.0 + +*2019-03-01* + +#### New features +- Timeline + - Add timeline component (by @jikkai in #14248) +- DropdownItem + - Add icon prop to `el-dropdown-item` (by @gabrielboliveira in #14088) +- Input + - Add show-password props (by @phshy0607 in #13966) +- Select + - Add slot `empty` (by @elfman in #13785) +- Autocomplete + - Add highlight-first-item prop (by @YamenSharaf in #14269) +- I18n + - Created Armenian locale (by @hamletbarsamyan in #14214) +- Docs + - French translation (by @smalesys in #12153, #14418, #14434) + +#### Optimization +- Alert + - Update alert description default slot class (by @iamkun in #14488) +- Input + - Update input password (by @iamkun in #14480) +- InputNumber + - Remove unnecessary parseFloat (by @JuniorTour in #14172) +- Menu + - Add support for `el-menu-item` without index (by @georgyfarniev in #13298) +- Table + - Remove some html DOM operations (by @elfman in #13643) +- Upload + - Optimize code (by @elfman in #13973) +- Popup + - Optimize code (by @KAionro in #14413) +- Docs + - Add more detail about how to run play mode for contribution (by @island205 in #14355) + - Warn input as a controlled component (by @wacky6 in #14463) + - Update Table doc (by @luguokong in #14329) + - Update input doc (by @iamkun in #14437) + - Update custom-theme docs (by @wangguohao in #14297) + - Make the icon style change when hover on it (by @tuxinghuan in #14295) +- Build + - Minimizing css and js for Element doc site (by @iamkun in #14430) + - Speeding up webpack (by @hetech in #14484) + - Use cli to select release version (by @hetech in #14354) +- Install stale for issue handling (by @island205 in #14392) + +#### Bug fixes +- Menu + - Fix subMenu focus bug when switch browser tab (by @liupl in #13976) +- MessageBox + - Fix type definition (by @NateScarlet in #14278) +- ScrollBar + - Prevent right button click on thumb (by @xifeiwu in #14196) +- Switch + - Trigger form validation if value changes (by @hetech in #14426) +- Table + - Make toggleAllSelection method an instance method (by @letanure in #14075) +- Tabs & Dropdown + - Fix style (by @hetech in #14452) +- Tree + - Empty-text tips are different from tables (by @ColinCll in #14331) +- Docs + - Fix DatetimePicker format doc error (by @iamkun in #14290) + - Spelling issue in datepicker documentation (by @helmut in #14481) + - Fix pagination doc style (by @liuchuzhang in #14451) + +#### Breaking changes +- Table + - Fix params order of row events (by @jikkai in #12086) + +### 2.5.4 + +*2019-02-01* + +#### Bug fixes + +- Build: Fix babel config issue which lead to collapse transition broken (by @island205 in #14282) + +### 2.5.3 + +*2019-01-31* + +#### Optimization + +- Optimize code of Message (by @vok123 in #14029) +- Retire gh-pages (by @ziyoung in #14266) +- Add IssueHunt link (by @island205 in #14261) + +#### Bug fixes + +- Fix UMD module error on server side (by @island205 in #14242) +- Fix active TabBar style (by @iamkun in #14240) +- Fix Table demo code error (by @xunmeng in #14253) + +### 2.5.2 + +*2019-01-27* + +#### Optimization +- Docs: + - Update ChangeLog ES 2.5.1 (by @Gonzalo2310 in #14231) + +#### Bug fixes +- Build: + - Delete unremoved comments in umd module `lib/index.js` (by @island205 in #14233) + - Fix export error fired in commonjs module used in nuxt.js (by @island205 in #14232) + - Fix 2.5.1 build issues (by @iamkun in #14228) + +### 2.5.1 + +*2019-01-26* + +#### Optimization +- DatePicker: highlight current month and year (by @Debiancc in #14211) +- Update 2.5.0 changelog (by @wacky6 in #14217) + +#### Bug fixes +- Fix export issue generate by webpack upgrading (by @island205 in #14220) +- Keep 2.4.11 docs && new sub folder for 2.5+ (by @iamkun in #14222) + +### 2.5.0 + +*2019-01-25* + +#### New features +- DatePicker + - Add `validate-event` attribute (by @ziyoung in #13531) +- DateTimePicker + - `pickerOptions` support `selectableRange` option (by @eeeeeeeason) +- Tag + - Add `click` event (by @licdream in #14106) +- I18n + - support Kyrgyz language (by @zzjframework in #14174) + +#### Optimization +- Upgrade to webpack@4 (by @jikkai in #14173) +- Input + - Simplify implementation, follow one-way data flow. Fix several related bugs (by @wacky6 in #13471) +- Update Axure file,add new components (by @ziyoung in #13773) + +#### Bug fixes +- Autocomplete + - Fix dropdown's last line beging clipped (by @ziyoung in #13597) + - Fix missing popper arrow (by @liuchuzhang in #13762) +- Carousel + - Cleanup timer when component is destroyed (by @elfman in #13820) +- Cascader + - Remove deprecated property of computed props (by @iamkun in #13737) + - Fix CascaderOption's type definition in TypeScript (by @NateScarlet in #13613) + - Fix icon covering the text (by @ziyoung in #13596) +- Checkbox + - Refine style (by @PanJiaChen) +- DatePicker + - Add missing v-for `key` in TimeSpinner (by @Ende93 in #13547) + - Fix week highlight on year boundary (by @suyi91 in #13883) +- Input + - Fix textarea DOM node reference (by @laomu1988 @island205 in #13803) +- Pagination + - Input value won't be less than 1 (by @elfman in #13727) +- Popover + - Fix popover issues with hover trigger (by @goldengecko in #13104) + - Fix popper instance memory leak (by @qpxtWhite in #13988) +- Radio + - Refine style (by @ohhoney1) +- Table + - Enhanced table sorting when clicking on the sorting arrow (by @ohhoney1 in #12890) + - Fix empty text vertical alignment issue on IE10+ (by @imzjy in #13638) + - Fix index type documentation (by @ilovefafa in #13628) + - Fix `show-summary` display issue when multilevel header has fixed attr (by @luckyCao in #13914) +- Tabs + - Fix auto scroll bug (by @iamkun in #13696) + - Get the correct tab through tab name (by @iamkun in #13705) + - Use paneName instead of name to determine pane style (by @iamkun in #13733) +- Tree + - Fix `showCheckbox` prop on `Tree` can not affect their children `tree-node` (by @KidneyFlower) + - Update doc and definition file (by @ziyoung in #13540) +- Upload + - Add `url` prop to upload file when `list-type` changed (by @elfman in #13771) +- Slider + - Fix source code indentation (by @wacky6 in #13955) +- I18n + - Add missing Catalan translations (by @jaumesala) + - Add missing ru translation (by @justlp in #13658) + - Fix Finnish translations (by @jenkrisu in #14137) +- Doc + - Update Spanish doc 2.4.11 (by @Gonzalo2310 in #13522) +- Others + - Remove unnecessary script (by @ziyoung) + - Fix error anchor link (by @iamkun in #13753) + - Fix inconsistent capitalization in documentation (by @wonderjar) + - Add DingDing chat group qr code to readme (by @iamkun in #13957) + - Add yarn logs to .gitignore (by @mimimi in #13922) + - Remove sponsor duotai (by @island205 in #14156) + - Update readme qr code src (by @iamkun in #13960) + - Update CDN link, fix typo (by @ziyoung) + +### 2.4.11 + +*2018-11-21* + +- Revert pr #13296. Fixed clicking on Menu external causing Submenu collapsed, #13478 +- Adjust small screen (xs) media query breakpoints, #13468 (by @alekoshen712) + +### 2.4.10 + +*2018-11-16* + +- Fixed multiple clicks on Select to display the drop-down list, #13268 +- The clear icon for input is not displayed when Form is disabled, #13208 +- Adjust the style of Select, Progress, Autocomplete, Tooltip, Collaspe, TimePicker, #13188 (by @porcelainHeart) #13210 #13266 #13257 #13290 #13347 (by @PanJiaChen) +- Carousel component added `loop` attribute, #13217 +- When the data of Table changes, the highlighted line will remain, #13200 +- Table header scoped slot can receive parameters, #13263 +- Table's `clearFilter` method supports arguments, #13176 +- Tooltip is no longer created when there is no content in the Table cell, #13152 (by @rongxingsun) +- The input box contents of the ColorPicker panel can be displayed correctly, #13278 +- ColorPicker no longer triggers form validation when dragging, #13299 +- InputNumber added `select `method, #13286 (by @st-sloth) +- Autocomplete added `clear` event, #12171(by arthurdenner) #13326 +- You can close Menu by clicking on Menu outside, #13296 +- Form's `validateField` method can receive arguments, #13319 +- Cascader added `visible-change` event, #13415 +- DatePicker added range-separator slot, #13272 (by @milworm) +- Tree adds `iconClass` and `currentNodeKey` properties, #13337 #13197 (by @isnifer) +- Progress's` status` added text #13198 (by @ali-master) +- Fixing tree's `defaultCheckedKeys` caused an error, #13349 (by @dive2Pro) + +### 2.4.9 + +*2018-10-26* + +- The parameter of Form's `clearValidate` supports string, #12990 (by @codinglobster) +- Added type attribute for Badge, #12991 +- Users can use scoped-slot to customize table column header #13012 (by @ivanseidel) +- Fixed the input box of Select unable to type text under IE, #13034 (by @GaliMU) +- Select option does not wrap when space is enough, #12329 (by @akki-jat) +- When dropdown list of Select is expanded, the arrow icon will also display correctly, #12353 (by @firesh) +- Fixed that the size attribute of Select does not work, #13070 +- Select multiple values can be cleared, #13049 (by @ZSkycat) +- Fixed the last TabNav unable be deleted, #13039 +- Fixed that TabNav label is not displayed correctly, #13178 +- Added title slot for Alert, #13082 (by @Kingwl) +- Fixed an issue where the tooltip content in Table was incorrect, #13159 (by @elfman) +- Optimize the animation of Upload when file is deleted, #12987 +- Adjusted style of InputNumber when control button is not displayed, #13052 + +### 2.4.8 + +- Not displaying outline when Switch is focused, #12771 +- Fixed Dropdown's style in ButtonGroup, #12819 (by @bluejfox) +- Added opened event for Dialog, #12828 +- Fixed the incorrect display order of TabNav, #12846 +- Fixed the problem that Tabs did not scroll to the selected tab, #12948 +- Fixed the problem that the identifier does not display when the Tree node is dragged, #12854 +- The validate event parameter of Form contains the validation message, #12860 (by @YamenSharaf) +- Fixed DatePicker not to verify the validity of user input time, #12898 +- Fixed the problem that `render-header` attribute of Table header doesn't work, #12914 + +### 2.4.7 + +*2018-09-14* + +- Fixed DatePicker not triggering form validation, #12328 #12348 +- Fixed DatePicker throwing errors in multiple mode, #12347 +- Fixed incorrect position of DatePicker spinner, #12415 (by @rang-ali) +- Fixed automatic filling of DatePicker input box, #12521 (by @abdallanayer) +- Fixed Input not highlighted in Cascader, #12341 +- Fixed wrong order of Tabpane, #12346 +- Fixed incorrect position of ColorPicker cursor, #12376 (by @cnwhy) +- Fixed the style of Submenu, #2457 +- Fixed not highlighted after Submenu is selected, #12479 +- Fixed incorrect values selected by Cascader, #12508 (by @huangjinqiang) +- Fixed incorrect value of Pagination input box, #12525 +- Fixed order that Pagination triggers events, #12530 +- Fixed Table Filter not displayed, #12539 +- Fixed Tree unable to delete nodes, #12684 +- Fixed height of Select Input changing in single mode, #12719 +- Fixed style of FormItem label in nested Form, #12748 +- Added `autocomplete` attribute for Input, deprecated `auto-complete`, #12514 (by @axetroy) +- Added slots-scope for Form to display validation information, #12715 (by @YamenSharaf) + +### 2.4.6 + +*2018-08-09* + +- Fixed Table not showing filter icon when `filters` is assigned empty array, #12165 +- Fixed Menu not saving active state when `collapse` is changed, #12178 (by @elfman) +- Fixed Cascader not escaping special characters for Regexp, #12248 +- Fixed disabled RadioButton showing box-shadow when clicked, #12262 +- Fixed arrow key not effect when default value is `undefined`,#12322 +- Fixed query function of Select not debounced in multi mode, #12181 +- Fixed query keyword of Select disappearing in multi mode, #12304 +- Fixed incorrect width of Dialog when it is displayed in full screen, #12203 +- Fixed incorrect display of Main on IE, #12237 +- Fixed Input triggering two form validations, #12260 +- Fixed adding new Tree node causing nodes to disappear, #12256 +- Fixed Tree node not deleted after dragging, #12279 +- Fixed Popover not visible when InputNumber focuses, #12284 +- Added `popper-append-to-body` attribute for Autocomplete, #12241 +- Added `sync` modifier support for Pagination's `page-size` attribute, #12281 + +### 2.4.5 + +*2018-07-26* + +- Fixed Table setting `class-name` does not work for `expand` column, #12006 +- Added `toggleAllSelection` method for Table, #12047 +- Fixed wrong position of suffix slot when Input contains Select, #12108 +- Fixed `line-height` of Option unable to set, #12120 +- Fixed TimeSelect with default value of `null` could not be assigned after executing `resetField`, #12010 +- Fixed keydown event which is not arrow key does not work in Tree, #12008 +- Fixed parent node checked in lazy mode, #12106 +- Added `includeHalfChecked` parameter for getCheckedNodes of Tree, #12014 + +### 2.4.4 + +*2018-07-13* + +- Fixed triggering Select validation after Form resetting, #11837 +- Fixed wrong position of Input `suffix` slot when `suffix` slot with `append` slot, #11951 +- Fixed clearable Input still displaying the clear icon when readonly, #11967 +- Fixed Tree node checked when it's disabled, #11847 +- Fixed Tree's `default-checked-keys` not working, #11971 +- Fixed `empty-text` not visible when Tree node filtered, #11971 +- Fixed the position of oversized `empty-text` in Table, #11965 +- Fixed Table row not be unhighlighted when `current-row-key` is assigned to `null`, #11866 +- Fixed showing filter dropdown when `filters` is an empty array, #11864 +- Fixed Radio's label does not stop event propagation, #11912 + +### 2.4.3 + +*2018-07-03* + +- Fixed `allow-drop` not working properly when Tree nodes have a custom height, #11797 +- Now you can pass a parameter to the `clearValidate` method of Form, specifying which FormItems' validation results need to be cleared, #11821 +- Added `distinguishCancelAndClose` attribute for MessageBox, #11831 + +### 2.4.2 + +*2018-06-26* + +- Now `class-name` and `label-class-name` of Table are reactive, #11626 +- Fixed Table still highlighting clicked row when `highlight-current-row` is `false`, #11646 +- Fixed a style bug of ButtonGroup when it has only one `round` or `circle` Button, #11605 +- Fixed style of page size Select of Pagination, #11622 +- Fixed Menu's `open` method error when `collapse` is dynamically changed, #11646 +- Added `activeName` and `oldActiveName` parameters to the before-leave hook of Tabs, #11713 +- Fixed Cascader focused after outside clicked, #11588 +- Fixed Cascader not closing when option is clicked when `change-on-select` is true, #11623 +- Now updating Select's value programmatically will trigger form validation, #11672 + +### 2.4.1 + +*2018-06-08* + +- Removed Autocomplete's duplicate type declaration, #11388 +- Fixed Select's dropdown arrow style in FireFox when nested in Form, #11427 +- Fixed clear icon of Select still showing when the initial value is `null`, #11460 +- Fixed disabled radio showing box-shadow when clicked, #11462 +- Added `iconClass` attribute for MessageBox, #11499 +- Added `stretch` attribute for Tabs, #11476 +- Fixed rendering order issue of TabPane when Tabs is `lazy`, #11461 +- Fixed Table not retaining current highlight row when expanded, #11464 +- Fixed focusing state when `before-leave` returns a resolved promise, #11386 +- Fixed disabled Popover still creating poppers, #11426 +- Fixed Tree's endless loop when a new node is added in lazy mode, #11430 (by @wangjingf) +- Added `closed` event for Dialog, #11490 + +### 2.4.0 Fullerene + +*2018-05-28* + +#### New features +- General + - Dev tool and bundler is switched to native webpack, #11216 + - Now you can globally set the initial z-index of popups, #11257 +- Autocomplete + - Added `hide-loading` attribute, #11260 +- Button + - Now you can use the `size` attribute on circle buttons to control their sizes, #11275 +- InputNumber + - Added `precision` attribute, #11281 +- Tabs + - Added `before-leave` attribute, #11259 + - Added `lazy` attribute, #11167(by @Kingwl) +- Table + - Added `sort` method to manually sort the table, #11311 + +#### Bug fixes +- Input + - Fixed an issue that causes a re-render when using the Chinese IME to quickly input text, #11235 (by @STLighter) +- Popover + - Fixed the console error when the triggering element is Radio or Checkbox, #11265 +- Breadcrumb + - Fixed the `to` attribute not supporting dynamic update, #11286 +- Upload + - Fixed the console error when a File is resolved in the returned Promise of the `beforeUpload` method, #11297 (by @qusiba) +- Tooltip + - Fixed arrow not positioned correctly when content is empty, #11335 +- Autocomplete + - Fixed incorrect input suggestions after deleting keyword quickly, #11323 +- ColorPicker + - Fixed `active-change` event incorrectly triggering when picker dropdown is closed, #11304 +- Table + - Fixed style error of oversized filter panel, #11314 + - Fixed currently selected row not retained when the table is sorted, #11348 +- Checkbox + - Fixed single checkbox not supporting validation, #11271 +- Radio + - Fixed disabled Radio still being selected when pressing space key, #11303 +- MessageBox + - Fixed the `el-popup-parent--hidden` class not removed when opening MessageBox in succession, #11371 + +### 2.3.9 + +*2018-05-18* + +- Fixed when the source data does not have the field specified by a TableColumn's `prop` attribute, an error would occur when the mouse moves into that column's cells, #11137 +- The `lockScroll` attribute of pop up components no longer adds an inline style to the parent element, but instead adds a class name, #11114 +- Fixed the icon of Progress not displaying when its `status` is exception, #11172 +- Fixed options' `disabled` attribute not working in filterable Cascader's filter result list, #11185 +- Fixed an issue where Table's expanded row cannot be collapsed if the data source is updated after its expansion, #11186 +- `setCurrentKey` of Tree now accepts `null` as its param to cancel the currently highlighted node, #11205 + +### 2.3.8 + +*2018-05-11* + +- Fixed DatePicker panel jumping to the current month after picking a date in a non-current month when `type` is dates, #10973 +- Fixed clearable Input still displaying the clear icon when readonly, #10912 +- Fixed closing the DatePicker panel without changing the value incorrectly triggering the `change` event, #11017 +- Fixed keyboard navigation not working properly when Select has grouped options, #11058 +- Added `prefix` named slot for Select, #11063 +- Added `clearValidate` method for FormItem, #11076 +- Added `checkOnClickNode` attribute for Tree, #11111 + +### 2.3.7 + +*2018-04-29* + +- Fixed Table not updating its header widths when the scroll bar disappears due to filtering, #10834 +- Fixed clearable Input still showing the clear icon when its initial value is `null`, #10912 +- Fixed incorrect trigger of the `active-change` event after changing ColorPicker's binding value programatically, #10903 (by @zhangbobell) +- Fixed filterable Select causing an infinite loop when navigating options using keyboard if all options are disabled, #10945 + +### 2.3.6 + +*2018-04-21* + +- Fixed wrong behavior of Tree's `allow-drop` callback when `type` parameter is used, #10821 +- Now you can properly enter keywords in filterable single Select in IE11, #10822 +- Fixed single Select incorrectly triggering `blur` event after clicking an option, #10822 + +### 2.3.5 + +*2018-04-20* + +- Fixed incorrect highlights in DatePicker panel when `type` is week, #10712 +- Fixed InputNumber being empty when its initial value is 0, #10714 +- Added `automatic-dropdown` attribute for Select, #10042 (by @Seebiscuit) +- Fixed disabled Rate's value still being updated by navigation keys, #10726 (by @Richard-Choooou) +- Now DatePicker's `type` attribute can be `'dates'`, where you can pick multiple dates in one picker, #10650 (by @Mini256) +- Added `prev-click` and `next-click` events for Pagination, #10755 +- Added `pager-count` attribute for Pagination, #10493 (by @chongjohn716) +- Added `type` as the 3rd param of Tree's `allow-drop` attribute callback, #10792 +- Now we use ResizeObserver to detect DOM element resizing, #10779 + +### 2.3.4 + +*2018-04-12* + +- Deleted duplicate `showTimeout` attribute in SubMenu's TypeScript declaration, #10566 (by @kimond) +- Now you can customize Transfer's data item using scoped slot, #10577 +- Fixed clicking disabled prev and next button of Pagination still triggers `current-change` event, #10628 +- Fixed Textarea displaying `undefined` in SSR when its value is not set, #10630 +- Fixed disabled TabItem style when `type` is border-card, #10640 +- Added `$index` as `formatter`'s fourth param of Table, #10645 +- Fixed CheckboxButton not exported in TypeScript declaration, #10666 + +### 2.3.3 + +*2018-04-04* + +- Added `shadow` attribute for Card, #10418 (by @YunYouJun) +- Fixed Badge being hidden when `value` is `0`, #10470 +- Fixed some bugs of draggable Tree, #10474 #10494 +- Added `placement` for Autocomplete, #10475 +- Now `default-time` attribute also works in non-range DateTimePicker, #10321 (by @RickMacTurk) +- Removed the blue outline of TabItem after the browser blurs or is minimized, #10503 +- Added `popper-append-to-body` attribute for SubMenu, #10515 +- Removed visual feedback when hovering on non-link BreadcrumbItem, #10551 +- Fixed InputNumber's `change` event to ensure the component's binding value is updated in the event handler, #10553 + +### 2.3.2 + +*2018-03-29* + +- Fixed an Autocomplete regression, #10442 + +### 2.3.1 + +*2018-03-29* + +- Fixed a regression that `type` of Input is not passed down to the native input element, #10415 +- Added `blur` method for Select, #10416 + +### 2.3.0 Diamond + +*2018-03-28* + +#### New features +- Table + - Now `formatter` of TableColumn can be dynamically updated, #10184 (by @elfman) + - Added `select-on-indeterminate` attribute, #9924 (by @syn-zeta) +- Menu + - Added `collapse-transition` attribute, #8809 (by @limichange) +- Input + - Added `select` method, #10229 + - Added `blur` method, #10356 +- ColorPicker + - Added `predefine` attribute, #10170 (by @elfman) +- Tree + - Added `draggable`, `allow-drop` and `allow-drag` attributes, and `node-drag-start`, `node-drag-enter`, `node-drag-leave`, `node-drag-over`, `node-drag-end` and `node-drop` events, #9251 #10372 (by @elfman) +- Form + - `validate` method now has a second parameter, containing information of form items that failed the validation, #10279 + - Added `validate` event, #10351 +- Progress + - Added `color` attribute, #10352 (by @YunYouJun) +- Button + - Added `circle` attribute, #10359 (by @YunYouJun) + +#### Bug fixes +- Form + - Fixed label of FormItem not align with mixed Input, #10189 +- Menu + - Now collapsed Menu will only show the Tooltip when the `title` slot of MenuItem is set, #10193 (by @PanJiaChen) +- Pagination + - Fixed `current-change` event wrongly triggering without user interaction, #10247 +- DatePicker + - Now the date and time value in the dropdown panel are correctly formatted based on the `format` attribute, #10174(by @remizovvv) +- Upload + - Fixed `accept` attribute not working when `drag` is true, #10278 + +### 2.2.2 + +*2018-03-14* + +- Added `clear` event for Input, #9988 (by @blackmiaool) +- Now manual input of ColorPicker supports `hsl`, `hsv` and `rgb` modes, #9991 +- Fixed DatePicker not triggering `change` event when its initial value is cleared, #9986 +- Now icon class related attributes of Rate support dynamic updates, #10003 +- Fixed Table with fixed columns not updating its height correctly if `max-height` is set, #10034 +- Now DatePicker's range mode supports reverse selection (clicking the end date, then clicking the start date), #8156 (by @earlymeme) +- Added `disabled` attribute for Pagination, #10006 +- Added `after-enter` and ` after-leave` events for Popover, #10047 +- Fixed Select not triggering validation when user selects an option after executing `resetFields` of Form, #10105 +- Fixed incorrect widths of fixed columns of Table in some cases, #10130 +- Fixed MessageBox inheriting the `title` attribute of its previous instance when called without `title`, #10126 (by @Pochodaydayup) +- Added `input-size` attribute for Slider, #10154 +- Added `left-check-change` and `right-check-change` events for Transfer, #10156 + +### 2.2.1 + +*2018-03-02* + +- Fixed Aside, Header and Footer shrinking in some layout, #9812 +- Fixed Table with a `height` attribute not rendering in SSR, #9876 +- Fixed expandable Table not calculating its height when a row is expanded, #9848 +- Fixed `change` event not trigger when manually typing date in DateTimePicker, #9913 +- Fixed Select showing its options when the input box is right-clicked, #9894 (by @openks) +- Added `tooltip-class` attribute for Slider, #9957 +- Now Select will stay focused after selection, #9857 (by @Seebiscuit) +- Added `target-order` attribute for Transfer, #9960 + +### 2.2.0 Graphite + +*2018-02-12* + +#### New features +- Menu + - Added `popper-class` and `disabled` attributes for SubMenu, #9604 #9771 + - Horizontal Menu now supports multi-layered SubMenu, #9741 +- Tree + - Added `node-contextmenu` event, #9678 + - Now you can customize node template using scoped slot, #9686 + - Added `getNode`, `remove`, `append`, `insertBefore`, `insertAfter`, `getCheckedKeys`, `getHalfCheckedNodes`, `getHalfCheckedKeys` methods and `check` event, #9718 #9730 +- Transfer + - Added `clearQuery` method, #9753 +- Select + - Added `popper-append-to-body` attribute, #9782 + +#### Bug fixes +- Table + - Fixed clicking expanding icon of an expandable row triggers `row-click` event, #9654 + - Fixed layout not update when column width is changed by user dragging, #9668 + - Fixed style issue when summary row co-exists with fixed columns, #9667 +- Container + - Fixed container components not stretching in IE11, #9655 +- Loading + - Fixed Loading not showing when the value of `v-loading` is changed to true in the `mounted` hook, #9722 +- Switch + - Fixed two native click events are triggered when Switch is clicked, #9760 + +### 2.1.0 Charcoal + +*2018-01-31* + +#### New features +- Cascader + - Added `focus` and `blur` events, #9184 (by @viewweiwu) +- Table + - The `filter-method` now has a third param `column`, #9196 (by @liyanlong) +- DatePicker + - Added `prefix-icon` and `clear-icon` attributes, #9237 (by @AdamSGit) + - Added `default-time` attribute, #9094 (by @nighca) + - `value-format` now supports `timestamp`, #9319 (by @wacky6) +- InputNumber + - Now the binding value can be `undefined`, #9361 +- Select + - Added `auto-complete` attribute, #9388 +- Form + - Added `disabled` attribute, #9529 + - Added `validateOnRuleChange` attribute, #8141 +- Notificaition + - Added `closeAll` method, #9514 + +#### Bug fixes +- InputNumber + - Fixed value resetting when typing decimal point, #9116 +- Dropdown + - Fixed dropdown menu incorrect positioning when the page only has a horizontal scrollbar in some browsers, #9138 (by @banzhuanmei) +- Table + - Fixed an error in calculating number of fixed columns after the column data changes, #9188(by @kolesoffac) + - Fixed the border of the last column of the grouped header not properly displayed, #9326 + - Fixed incorrect positioning of table header in Safari, #9327 + - Fixed expanded row collapsing when the table data changes, #9462 + - Fixed unnecessary multiple renders in some conditions, #9426 + - Fixed column width calculation error when `width` of TableColumn changes, #9426 +- Loading + - Fixed Loading not hiding correctly in some conditions, #9313 +- DatePicker + - Fixed `focus` method not working in range mode, #9437 + - Fixed clicking the "now" button still selecting the current date even if it is disabled, #9470 (by @wacky6) + - Fixed date clamping when navigating, #9577 (by @wacky6) +- Steps + - Fixed style error in IE 11, #9454 + +#### Breaking changes +- Menu + - The popup menu in `collapse` mode now appends directly to `body`, so that it is visible when nested in Aside, #9263 +- Table + - Now checking the checkboxes in multi-selection Table doesn't trigger `row-click` event, #9467 +- Loading + - The `z-index` of non-fullscreen loading mask is changed to 2000. The `z-index` of fullscreen loading mask will update dynamically with the popup components, #9522 +- Dropdown + - `show-timeout` and `hide-timeout` attributes now only works when trigger is `hover`, #9573 + +### 2.0.11 + +*2018-01-08* + +- Fixed border color issue of Select when in `prepend` or `append` slot of Input, #9089 +- Fixed `remove-tag` event's parameter of Select, #9090 +- Added `show-timeout` and `hide-timeout` attributes for SubMenu, #8934 (by @HugoLew) +- Fixed missing Tooltip style of `show-overflow-tooltip` when Table is imported on demand, #9130 +- Fixed Table column's sorting malfunctioning after `clearSort` is executed on that column, #9100 (by @zEmily) +- i18n config file for Czech is renamed from `cz` to `cs-CZ`, #9164 + +### 2.0.10 + +*2017-12-29* + +- Fixed wrong max height calculation of Table when fixed column and summary row co-exist, #9026 +- Fixed uncompiled color style of empty text in Table, #9028 +- Now DatePicker only emits `change` event when value is truly changed, #9029 (by @remizovvv) +- Added `tabindex` attribute for Input, #9041 (by @dicklwm) + +### 2.0.9🎄 + +*2017-12-24* + +- Added `before-remove` hook function for Upload, #8788 (by @firesh) +- Fixed initial value of `error` not working for FormItem, #8840 +- Now Loading directive supports custom class name by assigning `element-loading-custom-class` attribute, #8826 (by @earlymeme) +- Fixed CarouselItem becoming invisible when data is asynchronously updated, #8921 +- Added `renderAfterExpand` attribute for Tree, #8972 + +### 2.0.8 + +*2017-12-12* + +- Added Spanish documentation +- Fixed `show-timeout` of Dropdown not working when trigger is click, #8734 (by @presidenten) +- Fixed Form validation timing for rules whose trigger is blur, #8776 +- Fixed blur event of ranged DatePicker, #8784 +- `format` of TimePicker now supports AM/PM, #8620 (by @firesh) + +### 2.0.7 + +*2017-11-29* + +- Fixed disabled text button style, #8570 + +### 2.0.6 + +*2017-11-29* + +- Fixed style bug of Table's sorting icons, #8405 +- Fixed trigger mechanism for Popover when its `trigger` is manual, #8467 +- Added `prefix-icon` and `suffix-icon` attributes for Autocomplete, #8446 (by @liyanlong) +- Added `separator` attribute for Cascader, #8501 +- Added `clearable` attribute for Input, #8509 (by @lbogdan) +- Added `background` attribute for Pagination, #8553 + +### 2.0.5 + +*2017-11-17* + +- Fixed Popover, Tree, Breadcrumb and Cascader regression in 2.0.4, #8188 #8217 #8283 +- Fixed memory leak of clickoutside directive, #8168 #8225 (by @badpunman @STLighter) +- Fixed multiple Select height when its value is cleared, #8317 (by @luciy) +- Added `collapse-tags` attribute for multiple Select to replace tags with one line of text, #8190 +- Fixed high CPU consumption caused by hidden Table, #8351 +- Now you can use `doLayout` method of Table to update its layout, #8351 + +### 2.0.4 + +*2017-11-10* + +- Improved accessibility for Cascader, Dropdown, Message, Notification, Popover, Tooltip and Tree +- Fixed Container resize when the width of viewport decreases, #8042 +- Fixed Tree's `updateKeyChildren` incorrectly deleting child nodes, #8100 +- Fixed bordered CheckboxButton's height when nested in a Form, #8100 +- Fixed Menu's parsing error for custom colors, #8153 (by @zhouyixiang) + +### 2.0.3 + +*2017-11-03* + +- Fixed `editable` and `readonly` attributes for ranged DatePicker, #7922 +- Fixed style error of nested Tabs, #7941 +- Fixed style error of the last Step of vertical Steps, #7980 +- Fixed trigger timing of `current-change` event for Pagination, #7995 +- Fixed unregistered Tooltip in Menu, #7995 + +### 2.0.2 + +*2017-10-31* + +- Now right-clicking the buttons of InputNumber won't change its value, #7817 +- `validate` method of Form can now wait for asynchronous validations before executing its callback, #7774 (by @Allenice) +- Fixed range selection of DatePicker not working in Chromium 53-57 browsers, #7838 +- Fixed missing preview and delete icons of Upload when its `list-type` is picture-card, #7857 +- Added `sort-by` attribute for TableColumn, #7828 (by @wangfengming) +- Fixed DatePicker sometimes displaying wrong year number when selecting the first week in week mode, #7860 (by @hh23485) +- Fixed icon style error of vertical Steps, #7891 +- The hot area for node arrows in Tree is expanded, #7891 + +### 2.0.1 + +*2017-10-28* + +- Fixed style error of RadioButton and CheckboxButton, #7793 +- Fixed TimePicker not respond to mouse scroll in some conditions, #7811 +- Fixed incomplete styles of some components when imported on demand, #7811 + +### 2.0.0 Carbon + +*2017-10-27* + +#### New features +- General + - A new theme: `theme-chalk` + - Accessibility of the following components are improved: Alert, AutoComplete, Breadcrumb, Button, Checkbox, Collapse, Input, InputNumber, Menu, Progress, Radio, Rate, Slider, Switch, Upload + - Added TypeScript typings + - All existing icons are redesigned. Some new icons are added + - Added a series of breakpoint-based utility classes that hide elements when the viewport size meets certain conditions + - Added layout components: Container, Header, Aside, Main, Footer + - Now you can configure component sizes globally. When importing Element, you can add a global config object with a `size` prop to configure default sizes for all components. +- Button + - Added `round` attribute. It's used for round-cornered Buttons #6643 +- TimeSelect + - Now can be navigated by `Up` and `Down`, and hitting `Enter` selects the time #6023 +- TimePicker + - Now can be navigated by arrow keys, and hitting `Enter` selects the time #6050 + - Added `start-placeholder` and `end-placeholder`. They're placeholders for the two input boxes in range mode #7169 + - Added `arrow-control` attribute to spin the time with arrows #7438 +- Tree + - Now child nodes don't render before the first expand #6257 + - Added `check-descendants` attribute. It determines if child nodes are checked when checking their parent node in `lazy` mode #6235 +- Tag + - Added `size` attribute #7203 +- Datepicker + - Now `timeFormat` can format the TimePicker when type is set to `datetimerange` #6052 + - Added `start-placeholder` and `end-placeholder`. They're placeholders for the two input boxes in range mode #7169 + - Added `value-format` attribute to customize the format of the binding value, #7367 + - Added `unlink-panels` attribute to unlink the two date panels when selecting a date range +- MessageBox + - Added `closeOnHashChange` attribute #6043 + - Added `center` attribute so that the content can be centered #7029 + - Added `roundButton` attribute to display round Buttons #7029 + - Added `dangerouslyUseHTMLString` attribute. When set to `true`, `message` will be parsed as HTML string* #6043 + - Added `inputType` attribute to assign type for the inner input box, #7651 +- Dialog + - Added `width`、`fullscreen`、`append-to-body` attributes. Now Dialog can be nested + - Added `center` attribute so that the content can be centered #7042 + - Added `focus-after-closed`、`focus-after-open` to improve accessibility #6511 +- ColorPicker + - Now you can type colors in the input box #6167 + - Added `size` and `disabled` attributes #7026 + - Added `popper-class` attribute #7351 +- Message + - Now color of the icons can be overridden by CSS #6207 + - Added `dangerouslyUseHTMLString` attribute. When set to `true`, `message` will be parsed as HTML string* #6207 + - Added `center` attribute so that the content can be centered #6875 +- Notification + - Added `position` attribute to configure where Notification pops up #6231 + - Added `dangerouslyUseHTMLString` attribute. When set to `true`, `message` will be parsed as HTML string* #6231 + - Added `showClose` attribute to hide the close button #6402 +- Rate + - Added `show-score` attribute to determine if current score is displayed #6295 +- Tabs + - Added `tab-position` attribute #6096 +- Radio + - Added `border` and `size` attributes #6690 +- Checkbox + - Added `border` and `size` attributes #6690 +- Alert + - Added `center` attribute so that the content can be centered #6876 +- Menu + - Added `background-color`, `text-color` and `active-text-color` attributes #7064 + - Added `open` and `close` methods to open and close SubMenu programmatically, #7412 +- Form + - Added `inline-message` attribute to determine if the validation message is displayed in inline style #7032 + - Added `status-icon` attribute to display a feedback icon when validated #7032 + - Form and FormItem now have a `size` attribute. Inner components will inherit this size if not specified on themselves, #7428 + - `validate` method will now return a promise if the callback is omitted, #7405 + - Added `clearValidate` method for clearing validating results for all form items, #7623 +- Input + - Added `suffix` and `prefix` named slots, `suffixIcon` and `prefixIcon` attributes to add contents inside the input box #7032 +- Breadcrumb + - Added `separator-class` attribute to support icons as item separators #7203 +- Steps + - Added `simple` attribute to activate simple-styled Steps #7274 +- Pagination + - Added `prev-text` and `next-text` attributes to customize texts of previous page and next page #7005 +- Loading + - Now you can customize spinner icon and background color with `spinner` and `background` prop, #7390 +- Autocomplete + - Added `debounce` attribute, #7413 +- Upload + - Added `limit` and `on-exceed` attributes to limit the amount of files, #7405 +- DateTimePicker + - Added `time-arrow-control` attribute to activate `arrow-control` of the nesting TimePicker, #7438 +- Layout + - Added a new breakpoint `xl` for viewport wider than 1920px +- Table + - Added `span-method` attribute for merging cells + - Added `clearSort` method to clear sorting programmatically + - Added `clearFilter` method to clear filter programmatically + - For expandable rows, when a row is expanded, a `.expanded` class will be added to its class list, so that you can customize its style + - Added `size` attribute + - Added `toggleRowExpansion` method to expand or collapse expandable rows programmatically + - Added `cell-class-name` attribute to assign class name for cells + - Added `cell-style` attribute to style cells + - Added `header-row-class-name` attribute to assign class name for header rows + - Added `header-row-style` attribute to style header rows + - Added `header-cell-class-name` attribute to assign class name for header cells + - Added `header-cell-style` attribute to style header cells + - TableColumn's `prop` attribute now accepts `object[key]` notations + - Added `index` attribute for TableColumn to customize row indices +- Select + - Added `reserve-keyword` attribute for reserving current search keyword after selecting an option + +#### Bug fixes +- DatePicker + - Fixed `v-model` returning the second day of the selected week in week mode #6038 + - Fixed the first input being cleared in `daterange` type #6021 +- DateTimePicker + - Fixed DateTimePicker and TimePicker affecting each other when picked #6090 + - Fixed hour and second can be beyond limit when selecting time #6076 +- TimePicker + - Fixed `v-model` not update correctly when blurred #6023 +- Dialog + - Fixed texts having blurry edges when opening and closing nesting dropdowns #6088 +- Select + - Improved performance. Now Vue dev-tool won't crash when a large number of Selects are destroyed #6151 +- Table + - Fixed a bug that Table remains hiding when its parent element appears from `display: none` + - Fixed Table expanding its width when its parent element has `display: flex` + - Fixed a bug that fixed columns of a Table with `append` slot would disappear when data is dynamically fetched + - Fixed `expand-row-keys` attribute not working with initial value + - Fixed filter failing when `data` updates + - Fixed a calculation error of fixed columns layout with grouped headers + - Fixed a dynamic `max-height` bug + - Fixed some style calculation errors + +#### Breaking changes +- General + - Removed `theme-default` + - Compatible with Vue 2.5.2+ and IE 10+ + - `change` event of form components and `current-change` event of Pagination now only trigger on user interaction + - `size` attribute of Button and form components now accept `medium`, `small` and `mini` + - To facilitate the use of third-party icons, `icon` attribute of Button and Steps, `prefix-icon` and `suffix-icon` attributes of Input now require a full class name +- Dialog + - Removed `size` attribute. Now the size of Dialog can be configured by `width` and `fullscreen` + - Now the visibility of Dialog cannot be controlled by `v-model` +- Rate + - `text-template` is renamed to `score-template` +- Dropdown + - `menu-align` is renamed to `placement`. Now it supports more positions +- Transfer + - `footer-format` is renamed to `format` +- Switch + - Attributes starting with `on-*` will be parsed to events in JSX, making all `on-*` attributes of Switch not + able to work in JSX. So `on-*` attributes are renamed to `active-*`, and accordingly `off-*` attributes are renamed to `inactive-*`. This change affects the following attributes: `on-icon-class`, `off-icon-class`, `on-text`, `off-text`, `on-color`, `off-color`, `on-value`, `off-value` + - `active-text` and `inactive-text` attributes now don't have default values +- Tag + - `type` attribute now accepts `success`, `info`, `warning` and `danger` +- Menu + - Removed `theme` attribute. The color of Menu can be configured using `background-color`, `text-color` and `active-text-color` +- Input + - Removed `icon` attribute. Now the suffix icon can be configured using `suffix-icon` attribute or `suffix` named slot + - Removed `on-icon-click` attribute and `click` event. Now to add click handler on icons, please use named slots + - `change` event now behaves like the native input element, which triggers only on blur or pressing enter. If you need to respond to user input in real time, you can use `input` event. +- Autocomplete + - Removed `custom-item` attribute. Now the template of input suggestions can be customized using `scoped slot` + - Removed `props` attribute. Now you can use `value-key` attribute to designate key name of the input suggestion object for display +- Steps + - Removed `center` attribute + - Now the Steps will fill its parent container by default +- DatePicker + - The params of DatePicker's `change` event is now the binding value itself. Its format is controlled by `value-format` +- Table + - Removed support for customizing column template using `inline-template` + - `sort-method` now aligns with `Array.sort`. It should return a number instead of a boolean + - `append` slot is moved outside the `tbody` element to avoid multiple rendering + - `expand` event is renamed to `expand-change` + - The params of `row-class-name` and `row-style` method is now an object + +## +* Dynamically rendering arbitrary HTML on your website can be very dangerous because it can easily lead to [XSS attacks](https://en.wikipedia.org/wiki/Cross-site_scripting). So when `dangerouslyUseHTMLString` is on, please make sure the content of `message` is trusted, and **never** assign `message` to user-provided content. diff --git a/public/static/libs/element-ui/CHANGELOG.es.md b/public/static/libs/element-ui/CHANGELOG.es.md new file mode 100644 index 0000000..b3b5112 --- /dev/null +++ b/public/static/libs/element-ui/CHANGELOG.es.md @@ -0,0 +1,2093 @@ +## Changelog + +### 2.15.14 + +*2023-08-24* + +#### Bug fixes +- Img + - Delete referrerpolicy prop (#22651 by @xinguanhua) +#### Optimization +- Docs + - Update readme and website example links (#22642 by @lyfeyaj) + - Update popper links (#22539 by @brizer) +- I18n + - Update translation of Spanish (#22430 by @jcardus) + - Add sr-Latn translation (#22567 by @N-M) + - Update Uzbek translation (#22390 by @akahon) +- Statistics + - Fix doc; Optimized code (#22384 by @webvs2) +- Table + - Add highlight selection row (#22382 by @wangdaodao) + +### 2.15.13 + +*2023-02-12* + +#### Bug fixes +- Docs + - Fix Statistic docs (#22383 by @JUST-Limbo) + - Fix Input docs (#22093 by @lm312) + - Fix en-US docs (#22268 #22269 #22270 by @Hazel-Lin) + - Fix Pagination docs (#22288 by @xujintai123) + - Fix: Links docs (#22370 by @itmier) +- Statistics + - fix slot display bug (#22375 by @webvs2) +- Chore + - missing web-type after publishing (#22271 by @loosheng) +#### Optimization +- InputNumber + - Fix touch one click trigger twice on the window touch pad (#22185 by @mrsai) +- Image + - Add initialIndex prop (#22346 by @inkroom) +- Statistics + - Updated countdown feature to localize lodash Closes (#22260 by @webvs2) + - Update code and doc (#22276 by @webvs2) +- Other + - fix web-types type props (#22281 by @whzxc) + +### 2.15.12 + +*2022-11-16* + +#### Bug fixes +- Statistic: + - Fixed the thousandth bit bug (#22252 by @webvs2) +- Other + - Fix 2.15.11 element-theme-chalk publish fail bug + +### 2.15.11 + +*2022-11-15* + +#### Bug fixes +- Docs + - Fix Radio docs (#22178 by @bchen1029) + - Fix Progress docs +#### Optimization +- I18n + - Update translation of Malaysian (#22185 by @z4q) + - Update translation of Norwegian (#22145 by @Barsnes) +- Progress + - Add defineBackColor and textColor prop (#22089 by @lm312) +- Statistics + - Add new component Statistics (#22159 by @webvs2) +- Other + - Add Web Types to improve code assistance in WebStorm IDE and other JetBrains IDEs (#22135 by @piotrtomiak) + +### 2.15.10 + +*2022-09-13* + +#### Bug fixes + +- DatePicker + - Fix props placement error (#21908 by @lqzhgood) +- Loading + - Fix sticky DOM error (#22087 by @zzjjhh001) +- Docs + - Fix Popover docs (#22083 by @lm312) + - Fix Skeleton docs (#22092 by @lm312) + - Fix DatePicker docs (#21970 by @guojiongwei) +- Tree: + - fix lazy-load default check problem (#21934 by @kiss-yu) + +#### Optimization + +- I18n + - Add translation of Sinhalese (#21936 by @sayuri-gi) + - Update translation of Spanish (#21924 by @jcardus) + - Add translation of Malaysian (#22028 by @iorange0411) + - Update translation of Swahili (#21904 by @Cholowao) +- Utils + - update date-util.js (#22099 by @Due07) +- DatePicker + - add months And years type (#21918 by @akiko123456) + +### 2.15.9 + +*2022-06-02* + +#### Bug fixes + +- Table + - Fix Tabl-header shake bug (#21863 by @bofeng) + - Fix when partial import show `el-checkbox not imported` error (#21828 by @bobohuochai) +- FormItem + - Fix change rules verification not reset bug (#21892 by @bofeng) +- Cascader + - Fix change options unexpect error (#21759 by @louiebb) +- Docs + - Fix Popover docs (#21843 by @lod61) + - Fix Calendar docs (#21814 by @GoJam11) + - Fix TimePicker docs (#21803 by @Alanscut) + - Fix DatePicker docs (#21877 by @Nirvanaiu) +- Other + - Fix codepen display bug (#21863 by @bofeng) + +#### Optimization + +- I18n + - Add translation of Swahili (#21895 by @quilltouch) +- Chore + - Use launch-editor-middleware in dev environment (#21633 by @polemices) +- DatePicker & Cascader + - Optimize the dropdown animation direction (#21806 by @XivLaw) +- Tooltip + - Optimize `getFirstElement` code (#21886 by @zhankang) +- Input + - Optimize scss code (#21558 by @cheese-git) + +### 2.15.8 + +*2022-04-12* + +#### Bug fixes + +- Drawer + - Fix appendToBody failure problem (#21264 by @cs1707) +- Switch + - Fix toggling value problem(#19473 by @EdwinBetanc0urt) +- Docs + - Fix input docs (#21723 by @justforuse) + - Fix DatePicker docs (#21663 by @justforuse) + - Fix Skeleton docs (#21601 by @yanwydxf) +- Others + - Fix vue version (#21736 by @ckvv) + +#### Optimization + +- I18n + - add translation of Azerbaijani (#21012 by @ricardotondello) + - update translation of Slovenian (#21729 by @patik123) + - update translation of Slovak (#21711 by @sjaustirni ) + - add translation of Icelandic (#21709 by @aronhr) + - add translation of Bengali (#21485 by @llwwtt) + +#### Others + +- Due to compatibility considerations, the PR on node-sass (#21019 by @linxsbox) of 2.15.7 release has been withdrawn and will be published in an appropriate version after re-evaluation. + +### 2.15.7 + +*2021-11-18* + +#### Bug fixes + +- Select + - fix click icon triggering dropdown (#21314 by @dennyak47) + - fix keydown event when composition (#21336 by @bchen1029) +- Badge + - fix type class when is-dot (#21308 by @adaex) +- Form + - validate method reject error info (#21374 by @cs1707) +- Table + - fix resizeObserver loop limit exceeded (#21255 by @tomieric) + - fix toggleAllSelection bug when table is empty (#21456 by @cs1707) + - optimize performance (#21330 by @cs1707) +- Button + - fix disabled priority (#21375 by @cs1707) +- Descriptions + - fix label slot bug (#21462 by @cs1707) +- SASS + - replace node-sass with dart-sass (#21019 by @linxsbox) +- Docs + - fix skeleton typos (#21408 by @zhhbstudio) + +### 2.15.6 + +*2021-09-02* + +#### Bug fixes + +- Cascader + - fix a bug that makes the browser jitter in zoom mode (#21207 by @cs1707) + - optimize performance (#21231 by @cs1707) +- Select + - fix long text overflow in multiple mode (#21237 by @cs1707) +- Dropdown + - add disabled property (#21235 by @mshioda) +- Radio + - fix checked state when browser go back (#21250 by @cs1707) +- Descriptions + - fix type declaration (#21265 by @adaex) + - avoid table style conflict (#21254 by @adaex) +- Drawer + - fix append to body (#21264 by @cs1707) +- Local + - fix italian mistake (#21012 by @ricardotondello) + +### 2.15.5 + +*2021-08-04* + +#### Bug fixes + +- Select + - fix resetInputHeight (#21201 by @cs1707) + +### 2.15.4 + +*2021-08-03* + +#### New features + +- Descriptions + - add description component (#21129 by @cs1707) +- Result + - add result component (#21171 by @cs1707) + +#### Bug fixes + +- Utils + - fix isScroll (#21098 by @canvascat) +- Translation + - update it.js (#21133 by @bliberi) +- RadioGroup + - fix RadioGroup used in component causes exception #17908 (#20783 by @lceric) +- Message + - fix message[type] (#21088 by @cs1707) +- Carousel + - reset the timer when setActiveItem method is called (#20846 by @Nekojita1) +- Cascader + - fix emitPath (#21185 by @cs1707) +- Select + - fix select filterable bug (#17494 by @profore) + - fix a bug that makes the browser jitter in zoom mode (#21197 by @cs1707) +- Tree + - fix insertChild (#21194 by @cs1707) + +### 2.15.3 + +*2021-06-29* + +#### New features + +- Skeleton + - add skeleton component (#21038 by @cs1707) +- Empty + - add empty component (#21080 by @cs1707) + +#### Bug fixes + +- Local + - fix week translations for hr locale (#21040 by @cs1707) +- Table + - fix lazy load data (#21041 by @cs1707) +- Docs + - fix form hide-required-asterisk description (#21045 by @cs1707) +- Drawer: + - fix destroy (#20715 by @zj9495) +- Row + - fix align top (#20963 by @cs1707) +- Select + - fix the bug when the value is Boolean (#21052 by @cs1707) +- Calendar + - fix first-day-of-week (#21057 by @cs1707) +- Utils + - fix isScroll (#21065 by @cs1707) + - fix(utils.dom by @fw6) +- TypeScript + - add CascaderPanel export type (#21070 by @qige2016) + - add spinner.d.ts (#21090 by @qige2016) + +### 2.15.2 + +*2021-05-28* + +#### Bug fixes + +- Image + - fix z-index and keydown event add stopPropagation (#20859 by @cs1707) +- Input + - fix show password cursor (#20870 by @cs1707) + - fix show password icon in edge (#20902 by @cs1707) +- Carousel + - fix interval and scale bug (#20931 by @cs1707) +- Cascader + - fix delete tag bug (#20939 by @cs1707) +- Drawer + - add overflow auto (#20948 by @cs1707) +- Others + - fix isFunction (#20912 by @cs1707) + +### 2.15.1 + +*2021-02-23* + +#### Bug fixes + +- Drawer + - bugfix (by @cs1707) +- Image + - fix incorrect image object fit ratio in IE (#19583 by @charlie0228) +- Cascader + - fix cascader panel active path (#20730 by @cs1707) +- Calendar + - fix calendar component i18n bug (#20758 by @iamkun) +- ColorPicker + - fix bugs (by @UxieVerity) + +#### Optimization + +- Doc + - update Axure resource v2.1.0 (by @iamkun) +### 2.15.0 + +*2021-01-15* + +#### Bug fixes + +- Select + - Fix placeholder i18n bug (#17644 by @nzh63) +- Popconfirm + - Popconfirm i18n bug by @iamkun +- Drawer + - Fix focus bug (#20626 by @cs1707) +- Image + - Preview optimization (#20652 by @cs1707) + +#### Optimization + +- Doc + - Fix typo in french translation of datetime-picker.md (#20543 by @lonk) + - Add format attribute description to the progress component (#20641 by @cs1707) + +### 2.14.1 + +*2020-11-11* + +#### Bug fixes + +- Popover + - Compatible with Vue 2.6 new v-slot syntax (#20424 by @iamkun) + +#### Optimization + +- I18n + - Update Arabic translation (#20202 by @elkattan) + - Update Uighur translation (#20177 by @IlhamTahir) + +### 2.14.0 + +*2020-10-29* + +#### Breaking changes + +- Popconfirm + - Rename event name to `confirm`, `cancel` (#20240 by @hugiron) + +#### Bug fixes + +- Progress + - Fix attribute error (#19985 by @Caaalabash) + +#### Optimization + +- I18n + - Update Russian translation (#19451 by @yangirov) + - Update Khmer translation (#20077 by @Sovai) + - Update Ukrainian translation (#20344 by @MammutAlex) + +### 2.13.2 + +*2020-05-18* + +#### Corrección de errores + +- Autocomplete + - Arreglado el error cuando se daba el evento change (#19200 by @sxzz) +- Image + - Actualizado el estado de error (#19194 by @lhx6538665) + +#### Optimización + +- I18n + - Actualización de la traducción del popconfirm al Ruso (#19220 by @Opppex) + - Actualización de la traducción al vi (#19244 by @quangln2810) + - Actualización de la traducción al Catalán y al Español (#19296 by @Ismaaa) + - Actualización de la traducción al Indonesio (#19320) by @therour) + - Actualización de la traducción al Portugués Brasileño (#19374 by @diegomengarda) + + +### 2.13.1 + +*2020-04-13* + +#### Nuevas características +- Autocomplete + - Agregado el evento change (#17913 by @sxzz) + +#### Corrección de errores + +- Autocomplete + - Solucionado el error de la sugerencia en textarea (#18478 by @Roojay) +- Carousel + - Arreglado el error de escritura de la consola (#18264 by @IceFox) +- Image + - Solucionado el error de que no se mostraba el preview si no existía el src (#18975) (#19130 by @luckyCao) + - Arreglado el problema de que el shortcut key no funcionaba la segunda vez (#18983) (#19156 by @luckyCao) + - No muestra la imagen cuando preview es falso (#18967 by @inooNgt) +- Transfer + - Corregida la altura (line-height) incorrecta del primer elemento del el-transfer cuando era usado con el-form-item (#18917 by @Hanx) +- InputNumber + - Calculo correcto de inputNumberDisabled (#18439 by @ashuser-pendo) +- Tarea + - Se quito la introducción del index (#19155 by @iamkun) +- Documentación + - Actualización de la documentación de Popconfirm (#18324 by @iamkun) + - Arreglado el error tipográfico de la documentación de Fix step-strictly (#18705 by @dream2023) + - Corregido un type error en la documentación de steps component (#17555 by @haoranyu) + +### 2.13.0 + +*2019-11-26* + +#### Nuevas características + +- Popconfirm + - Agregado componente popconfirm (#17548 by @iamkun) + +#### Corrección de errores + +- BackTop + - Se usa cubic bezier para el scroll (by @lon) +- DatePicker + - Arreglado el fallo cuando solo se elegía fecha mínima en un rango de fechas (#17191 by @smk0621) +- Select + - Arreglado los casos de test del select (by @msidolphin) +- Tree + - Agregado font-size para el estilo del texto cuando esta vacío el tree (#17094 by @spengjie) +- Table + - La cabecera de la columna puede modificarse (#17291 by @ziyoung) + - Se actualizo el estilo de la cabecera de la tabla de la celda (#17284 by @ziyoung) + - Se soluciono el problema de height de la cabecera de la tabla después de un filtro (#17348 by @ziyoung) + - Corregido el estilo de la fila que con display no funcionaba (#17002 by @a631807682) + - Arreglado que la cabecera de la tabla no se mostraba (#17341 by @ziyoung) +- Calendar + - La importación de el-button y el-button-group (#17376 by @masongzhi) +- MessageBox + - Corregido el error de posición del icono (#17410 by @nullptru) +- TimePicker + - Establecido el rango de selección después de hacer scroll (#16868 by @mattheyan) +- Message + - Corregido el offsetHeight al cerrar la instancia(#17564) (#17852 by @gzwgq222) +- Form + - La función de llamada de validateField es opcional (#17314 by @CarterLi) +- Cascader + - Corregida la compatibilidad con TypeScript 3.7 (#17881 by @CarterLi) +- Menu + - Corregido el error de la ruta de navegación duplicada cuando se usaba vue-router@^3.1.0 (#17269 by @iamkun) +- Dropdown + - Actualización del tipo de archivo (#17550 by @iamkun) +- Progress + - Agregada la prop strokeLinecap (#17552 by @iamkun) +- InfiniteScroll + - Salto del disparo de evento en elementos invisibles (#17553 by @iamkun) +- Image + - Comportamiento perfecto de personalización de imágenes (#16985 by @luckyCao) + - Corregida la pagina cuando se hace preview de imágenes grandes (#16796 by @luckyCao) +- Drawer + - Corregido el fallo del append-to-body del drawer que no funcionaba (#16953 by @JeremyWuuuuu) +- Select + - Corregido: ahora muestra el tag o el valor vacío (17199 by @luckyCao) +- Scrollbar + - Arreglado el ancho del scroll en FireFox (#18091 by @iamkun) + +#### Optimización + +- I18n + - Actualizado sv-SE.js (#17926 by @FOLLGAD) + - Actualizada la documentación para francés para el componente avatar (#17762 by @blombard) +- Docs + - Arreglada la typografia de time-select (#17250 by @wacky6) + - Arreglado en Drawer, ahora el atributo value acepta tipografías en español (#17122 by @haoranyu) + - Actualización del Changelog 2.12.0 al español (#17364 by @Gonzalo2310) + - Arreglo de la tipografía del Changelog (#17874 by @renlixin) + - Arreglada la demo de Loading (#17862 by @MBearo) + - Agregado el evento input en los inputs de Table (#18061 by @zhouxinyong) + - Eliminado el evento repetitivo change de los input (#18085 by @zhouxinyong) + +### 2.12.0 + +*2019-08-29* + +#### Nuevas características + +- Popover + - Agregada la prop close-delay (#16671 by @LachlanStuart) +- Theme + - Añadida la extensión Chrome: Element Theme Extensión (#16686 by @iamkun) +- Icon + - Añadido font-display a la declaración @font-face (#16805 by @iamfaizalandyka) + +#### Corrección de errores + +- Carousel + - Corregido el valor emitido por onChange (#16705 by @iamkun) +- Notification + - Corrección de la modificación del objeto de opción entrante (#16704 by @iamkun) +- DatePicker + - Agregado el className para la opción picker (#16632 by @iamkun) +- DateTimePicker + - Corrección del time-spinner que no se desplazaba a la posición correcta (#16854 by @jesse-li) +- Table + - Evitar la propagación del click después del arrastre (#16850 by @ziyoung) + - Corregido una error en chrome que se producía cuando el css de thead tenia display: none (#16956 by @luckyCao) + - Corregida la altura incorrecta de los bloques vacíos (#16861 by @ziyoung) + - No hay lanzamiento de error cuando se llama a toggleExpansion (#16304 by @yyjjqq94) + - No se lanza el evento sort-change cuando esta montado (#17113 by @a631807682) + - Corregido que el setCurrentRow no borraba la linea resaltada (#16879 by @ziyoung) + - Corregido que expand-row-keys no funcionaba cuando los datos eran cargados asincrónicamente (#16899 by @ziyoung) + - Establecido toggleAllSelection como propiedad instanciada (#17137 by @ziyoung) +- Tree + - Corregida la distancia entre label y checkbox (#16799 by @Hazlank) +- Tabs + - Corregida la posición incorrecta de los item's del Tab (#16520 by @victorting) + - Corregido el error de que la pestaña activada estaba fuera del rango visual (#17033 by @nullptru) +- Calendar + - Arreglado el problema de los días de la semana con i18n (#16772 by @ubitoffee) + - Corregido el error de localización (#17208 by @iamkun) +- Cascader + - Corregido un error de visualización del CascaderPanel (#16716 by @zhangHongEn) + - Corregido el problema de disable status y close button (#16224 by @yyjjqq94) +- Input + - Arreglado el evento de composición coreana (#15069 by @MoonHyuk) + - Arreglado el evento click del botón clear que no se lanzaba cuando se usaba v-loading (#16576 by @a631807682) +- Select + - No cambiaba el dropdown cuando se filtraba (#17205 by @luckyCao) +- Transfer + - Arreglado un error de estilo (#17206 by @iamkun) +- Dialog + - Actualizada las variables Sass (#16365 by @haoranyu) +- RadioGroup + - No produce HTML invalido en la tabla si el atributo 'is' es especificado (#17070 by @nullptru) +- Divider + - Soporta clases personalizadas (#17078 by @island205) + +#### Optimización + +- Checkbox + - Mejorada la experiencia del lector de pantalla (#16575 by @tylertrotter) +- Docs + - Actualizado changelog (#16773 by @SimonaliaChen) + - Actualizada la guía de contribución (#14800 by @sinchang) + - Arreglado typo en la documentación de Drawer (#16848 by @winkay) + - Actualizado el tema personalizado (#16983 by @iamkun) + - Agregada traducción en Esperanto (#16955 by @maxkoryukov) + - Actualizada la documentación de input-number sobre el evento change (#16316 by @luckyCao) + - Actualizada la documentación en Español 2.11.1 (#16961 by @Gonzalo2310) +- I18n + - Eliminada la traducción de 'year' en idioma Catalán como en otros idiomas (#14722 by @oscaralbareda) + - Actualizado el changelog de las versiones 2.10.0 y 2.10.1 en Español (#16548 by @Gonzalo2310) + - Actualizado ar.js (#16653 by @l3op) +- Test + - Corregir error ortográfico (#16672 by @boomler) + - Refractorizacion del unit test para usar data-uri (#16847 by @a631807682) +- Types + - Corrección del tipo httprequest (#16633 by @luckyCao) + +### 2.11.1 + +*2019-07-26* + +#### Corrección de errores + +- Image + - Corregido el componente Image para compatibilidad SSR (#16737 by @luckyCao) +- Tarea + - Actualizado para compatibilidad con dart-sass by @LewisChennnnn) + +### 2.11.0 + +*2019-07-25* + +#### Nuevas características + +- Drawer + - Agregado componente drawer (#16577 by @JeremyWuuuuu) + +#### Corrección de errores + +- Checkbox + - Mejora del selector css (#16006 by @Hazlank) +- Tree + - Establecido el el-tree como genérico (#15934 by @JeremyWuuuuu) + - Establecido la prop isCurrent como False (#15870 by @kkkisme) +- Dropdown + - Corregido el color predeterminado de los split-button (#15931 by @JuniorTour) +- Cascader + - Corregido un problema de actualización cuando el nivel 1 de children estaba vació (#16399 by @luckyCao) + - Ahora se muestra correctamente header cuando range esta especificado (#16354 by @ziyoung) + - Agregados valores por defecto cuando lazy es true (#16420 by @luckyCao) + - Solucionado problemas de visualización (#15935 by @junyiz) + - Expuestos los getCheckedNodes y corrección de errores en el cambio de opciones (#16709 by @SimonaliaChen) +- Submenu + - Corregida la prop append-to-body (#16289 by @a631807682) +- Table + - Arreglado un fallo en la actualizacion de los datos de tree table (#16481 by @island205) +- Select + - Arreglado un problema de fuga de memoria (#16463 by @island205) +- InfiniteScroll + - Actualizada la nomenclatura y la documentacion (#16698 by @iamkun) +- Avatar + - Arreglado que la imagen no se centraba verticalmente (#16489 by @luckyCao) +- Dialog + - Agregado el atributo destroyOnClosee (#16455 by @ziyoung) +- Image + - Agregada la función de vista previa grande de imágenes (#16333 by @luckyCao) + +#### Optimización + +- Documentación + - Arreglada la demo de dropdown (#16193 by @webxmsj) + - Corrección de errores tipográficos en las tablas de documentos (#15971 by @howiefh) +- I18n + - Actualizada la traduccion del lenguage Thai (#16689 by @ponkrit) +- Tareas + - Actualizada la api base del tema (#16607 by @iamkun) + - Añadido token del formulario del tema (#16699 by @iamkun) + - Marcar todos los accesos internos del usuario (#16609 by @iamkun) + - Corrección del error de anclaje del documento (#16692 by @iamkun) + +### 2.10.1 + +*2019-07-02* + +#### Corrección de errores + + +- Table + - Corregido el icono de ordenación (#15439 by @bezany) + - Corregidas las rupturas del layout cuando existía un slot (#16332 by @ziyoung) + - Corregido showOverflowTooltip no era reactivo (#16295 by @a631807682) + - Registrada la scrollbar en el panel de filtro (#16246 by @ziyoung) +- Tareas + - Arreglada la documentación 2.9 (#16233 by @ziyoung) + - Corregido el índice de la página de introducción del tema en inglés que tenia un error en los estilos css (#16254 by @iamkun) + +#### Optimización + +- Tag + - Compatible con IE (#16334 by @ziyoung) +- Tarea + - Actualizada la imagen QR de Dingtalk Group (#16236 by @iamkun) +- Doc + - Actualizada la documentación online del theme roller (#16244 by @iamkun) + +### 2.10.0 + +*2019-06-25* + +#### Nuevas características + +- I18n + - Añadido idioma Uzbeko (#15796 by @ogabek96) +- Calendar + - Añadido el atributo del primer día de la semana (#16047 by @ziyoung) +- Avatar + - Agregado componente Avatar (#16144 by @luckyCao) +- Upload: + - Añade capacidad para personalizar la plantilla de miniaturas (#13192 by @victorzhuk) + +#### Corrección de errores + +- Tree + - No resaltar el nodo de árbol cuando currentKey es nulo (#15668 by @yyjjqq94) + - Solucionado el problema #15538 causado por dos Tree que compartian los mismos datos.(#15615 by @VanMess) +- Upload + - Actualizado el tipo del parámetro `fileList` (#15716 by @underfin) +- Table + - Solucionado que el icono de loading no se mostraba (#15868 by @ziyoung) + - Corregido el color de fondo de una tabla compleja cuando se desplaza el cursor (#15504 by @cnlon) + - Corregido current-row-key y el bug del evento select (#15983 by @ziyoung) + - Height acepta más unidades (#16013 by @ziyoung) + - Solucionado reserve-selection no funcionaba (#16135 by @ziyoung) +- Docs + - Corregido el tipo de atributo Divider en zh-cn (#15889 by @haoranyu) + - Se elimina una etiqueta html de cierre incorrecta y el código de bloque vacío (#16194 por @Alexeykhr) +- Menu + - Corregido un error oculto en el submenú después de añadir popper-append-to-body (#15391 by @PanJiaChen) +- Select + - Arreglado initialInputHeight (#15989 by @yyjjqq94) + - Corregido el comportamiento de default-first-option cuando se escribe chino (#15431 by @VanMess) + - Corregido el problema de importación doble (#16215 by @lengband) +- Message + - Añadida la opción type def para offset (#16027 by @matjaz) +- Timeline + - Arreglado reverso roto (#16091 by @ziyoung) +- Slider + - Corregido #15545 agregando explicaciones sobre el evento "input" en chino (#15588 by @VanMess) +- InfiniteScroll + - Actualización del nombre del paquete (#16125 by @iamkun) +- MessageBox + - Arreglado el bug de distinguishCancelAndClose, la acción no era la misma que la documentada (#15438 by @qingdengyue) +- PopupManager + - Arreglado que el z-index no podía ser reescrito la primera vez que se usaba (#15738 by @luckyCao) +- Tarea + - Actualizado el test del api host (#15807 by @iamkun) + +#### Optimizacion + +- Tree + - Modificar las condiciones del bucle para mejorar el rendimiento (#15699 by @KingJeason) +- Theme + - Refinado GA track & actualizado el link del pie que lleva al theme roller online (#16007 by @island205) +- Badge + - Actualizado el check del prop badge (#16198 by @iamkun) +- Avatar + - Actualizado el var del config del theme (#16202 by @luckyCao) +- I18n + - Actualizada la traducción del portugués (#15776 by @gigioSouza) + - Actualizada la traducción del idioma Farsi (#15881 by @pamenary) +- Docs + - Agregado componentes faltantes en el quick start (#16063 by @pape2016) + - Actualizada la traducción al francés (#16208 by @blombard) + - Agregada descripción $slots.default (#15444 by @Alexeykhr) + - Actualizada la Doc en Español 2.9.1 (#15840 by @Gonzalo2310) + - Corrección de errores ortográficos en fr (#15837 by @blombard) + - Actualizado el changelog 2.9.2 en español (#16185 by @Gonzalo2310) + +#### Breaking changes + +- Form + - Eliminado el estado success (#16159 by @ziyoung) + +### 2.9.2 + +*2019-06-21* + +#### Corrección de errores + +- Tareas + - Solucionadas las definiciones de archivos TS (#15805 by @NateScarlet) + +### 2.9.1 + +*2019-05-30* + +#### Nuevas características + +- Table + - Los metodos tree-props,default-expand-all, expand-row-keys, toggle-row-expansion y el evento expand-change son compatibles con Tree Table (#15709 by @ziyoung) + +#### Corrección de errores + +- Table + - Corrección de algunos errores (#15709 by @ziyoung) +- Theme + - Actualización del host de la api (#15784 by @iamkun) + +#### Optimización + +- Tarea + - Una actualización del tipo InfiniteScroll (#15794 by @iamkun) + +### 2.9.0 + +*2019-05-30* + +#### Nuevas características + +- Backtop + - Añadido componente Backtop (#15541 by @iamkun) +- PageHeader + - Añadido el componente PageHeader (#15714 by @ziyoung) +- InfiniteScroll + - Añadida la directiva InfiniteScroll (#15567 by @iamkun) +- Cascader + - Agregado modo múltiple y método de filtro (#15611 by @SimonaliaChen) +- Message + - Visualización en modo stack (#15639 by @island205) +- Tag + - Añadido prop effect (#15725 by @SimonaliaChen) +- Tabs + - Alinea el título a la izquierda cuando el tipo es card (#15695 by @luckyCao) +- DatePicker + - Soporta cadenas literales (#15525 by island205) +- Image + - Añadido soporte para transmitir attrs y listeners (#15578 by @VanMess) +- Theme + - Añadido fondo al popup (#15412 by @iamkun) +- Tarea + - Actualizada la nueva página de índice 2.9.0 (#15682 by @iamkun) + +#### Corrección de errores + +- Table + - Corregido el comportamiento de cambio de orden cuando la condición de orden es nula (#15012 by @joelxr) +- Image + - Corregido ssr y compatibilidad de ajuste de objetos (#15346 by @SimonaliaChen) +- Input + - Corregido estilo show-word-count en el-form (#15359 by @lvjiaxuan) + - Corregido el icono de borrar que no estaba centrado (#15354 by @YiiGuxing) +- Calendar + - Corregido día de la semana no correcto cuando el día es domingo (#15399 by @qingdengyue) + - Corregido error de desaparición de octubre (#15394 by @qingdengyue) +- Tabs + - Corrección de la pestaña básica anidada en el error de relleno de la pestaña de la tarjeta (#15461 by @SimonaliaChen) +- Tag + - Corregido problema de propagación de stop (#15150 by @infjer) +- Form + - Corregido el error de grupo de entrada dentro de la altura del elemento de formulario (#15457 by @SimonaliaChen) + - Solucionado el problema de resetFields (15181 by @luckyCao) +- Tooltip + - Corregido tabindex personalizado no funcionaba (#15619 by @SimonaliaChen ) +- Link + - Arreglada la clase de estilo del icono de enlace (#15752 by @iamkun) +- Select + - Revertir el valor establecido a nulo cuando se borra (#15447 by @iamkun) +- Loading + - Corregido dom no cambia cuando el estado de carga cambia rápidamente (#15123 by @FAKER-A) +- Switch + - Etiqueta con el evento de repetición del interruptor (#15178 by @FAKER-A) +- Slider + - Arreglado el problema de estilo al hacer clic en la barra deslizante (#15561 by @luckyCao) +- Radio + - Solucionado el problema 14808 (#14809 by @OverTree) +- Form + - Solucionado el problema de resetFields (15181 by @luckyCao) +- Tarea + - Se actualizaron las dependencias y se corrigió el error de demostración (#15324 by ziyoung) + - Type + - Corregida la definición del tipo de carga (#15635 by @iamkun) + - Corregido tipo Icono (#15634 by @iamkun) + - Corregida la definición del tipo de enlace (#15402 by @iamkun) + +#### Optimización + +- Cascader + - Refractorización (#15611 by @SimonaliaChen) +- Tarea + - Actualización hacer nueva lógica de componentes (by @iamkun) +- Documentación + - Renombrar variable en docs (#15185 by @liupl) + - Corregido el atributo type de imagen y el valor por defecto (#15423 by @haoranyu) + - Corregido error en la doc de form (#15228 by @SHERlocked93) + +### 2.8.2 + +*2019-04-25* + +#### Corrección de errores + +- Icon + - Actualizado icon (#15272 by @iamkun) +- Docs + - Arreglada la documentacion de Form e Input (#15273 by @ziyoung) + +### 2.8.1 + +*2019-04-25* + +#### Corrección de errores + +- Icon + - Actualizado el icono de cascader y select (#15264 by @SimonaliaChen) + - Actualizado icon (#15258 #15268 by @iamkun) + +#### Optimización + +- Chore + - Actualizado build script (#15267 by @ziyoung) +- Docs + - Arreglado el color underline de link (#15265 by @iamkun) +- Other + - Arreglada la migracion de la configuracion no compatible con camel case props y eventos (#15260 by @SimonaliaChen) + +### 2.8.0 + +*2019-04-25* + +#### Nuevas características + +- Divider + - Agregado el componente Divider (#15055 by @island205) +- Rate + - Agregados colores personalizados y clases de iconos pasando un objeto (#15051 by @SimonaliaChen) +- Link + - Agregado componente Link (#15052 by @iamkun) +- Calendar + - Agregado el componente Calendar (#14908 by @ziyoung) +- Icon + - Agregado Icon (#15214 by @iamkun) +- Alert + - Agregado tema dark (#15041 by @island205) +- Image + - Agregado componente image (#15117 by @SimonaliaChen) +- Collapse + - CollapseItem puede ser disabled (#15076 by @ziyoung) +- Carousel + - Agregado atributo direction y soporte para la direccion vertical (#15122 by @ziyoung) +- Pagination + - Agregado atributo hide-on-single-page (#15096 by @ziyoung) +- Slider + - Agregado atributo marks (#15133 by @luckyCao) +- Input + - Agregado attributo show-word-count (#15075 by @luckyCao) +- InputNumber + - Agregado atributo step-strictly (#15050 by @luckyCao) +- Tooltip, Dropdown, Popover + - Soporte para el atributo tabindex (#15167 by @ziyoung) + +#### Corrección de errores + +- Notification + - Arreglado el word break del titulo (#15008 by @iamkun) +- Form + - Arreglado que cuando se cambiaban las reglas en el-form no funcionaba (#14985 by @luckyCao) + - Arreglado el estilo del label (#14969 by @ziyoung) + - Los FormItem requeridos muestran astericos cuando el label es auto (#15144 by @ziyoung) +- Pagination + - Arreglado que el slot no se actualizaba (#14711 by @lucyhao) +- Table + - Arreglado un bug del load en el modo lazy (#15101 by @ziyoung) + - Arreglado el ancho de la celda cuando colspan es mayor que 1 (#15196 by @ziyoung) + - Mejora en el rendimiento (#14868 by @ziyoung) + - No se emiten disparadores del evento sort-change durante la inicializacion (#14625 by @PeanutWatson) + - Igual comportamiento para height y max-height (#14660 by @arthurdenner) +- Dialog + - Arreglado que el cuerpo del dialog quiebre las palabras correctamente en las palabras largas (#15027 by @iamkun) +- Alert + - Actualizada la definicion de type (#15186 by @ziyoung) +- Tabs + - Solucionado el problema por el que el rechazo de la promesa estaba afectando a la aplicación (#14816 by @ffxsam) + - Rerender cuando hay cambios en el slot (#15238 by @ziyoung) +- Message + - Actualizada la definicion de type (#14968 by @agoni1212) +- Select + - Solucionado el error cuando value es undefined o null (#15022 by @luckyCao) +- Tree + - Eliminar el nodo actual despues de removido (#14604 by @sinchang) + - Mejora en el rendimiento (#14881 by @ChenZhuoSteve) +- Dropdown + - Estilo arreglado (#14907 by @doing123) +- Slider + - Corrección de un fallo en el teclado a11y (#14792 by @erezsob) +- Menu + - El valor de ActiveIndex será nulo si el defaultIndex no existe (#14074 by @hoythan) +- Directive + - RepeatClick: usa Date.now() en lugar de new Date() (#14776 by @pavelmash) +- Upload + - Arreglado el estilo para mostrar imagenes transparentes (#15039 by @iamkun) +- Theme + - Agregado zero border (#15256 by @iamkun) + +#### Optimización + +- Tareas + - Actualizado changelog zh-cn (#14965 by @iamkun) + + - Ocultar la descripcion de la demo cuando esta vacia (#15014 by @ziyoung) + + - Muestra la info dev del server por defecto @iamkun) + + - Arreglado un error del changelog v2.6.0 (#15026 by @iamkun) + + - Actualizado build config (#14821 by @abc3660170) + + - Agregado hmr (#15221 by @SimonaliaChen) + + - Uso de sourcemap en entorno dev (#15087 by @ibufu) Docs + + - Cambio de nombre de variable en docs (#14602 #15003 #15094 #15105 by @liupl) + + - Arreglado un error en la documentacion de upload (#15023 by @iamkun) + + - Actualizada la documentacion del custom validator del Form (#15040 by @iamkun) + + - Actualizada la documentacion de Tabs de como mostrar tabs verticales (#15053 by @iamkun) + + - Uso del dominio eleme.cn (#15139 by @ziyoung) + + - Arreglado el nombre de la ruta de imágenes (#15194 by @iamkun) + + - Eliminada la traducción duplicada en francés (#15207 by @iamkun) + + + +#### Breaking changes + +- Rate + - Arreglado Fix decimal display support in disabled mode (#15089 by @haoranyu) +- Select + - Se usa la opcion placeholder del label para poner el placeholder en el modo filter (#14989 by @ibufu) + +### 2.7.2 + +*2019-04-03* + +#### Corrección de errores + +- Form + - Arreglado el estilo auto `label-width` (#14955 by @ziyoung) + +#### Optimización +- Docs + - Arreglado un error de link de una imagen (#14957 by @iamkun) +- Chore + - Arreglado un error de mkdir en el deploy (#14952 by @iamkun) + +### 2.7.1 + +*2019-04-03* + +#### Corrección de errores + +- Select + - Se asigna null a value cuando se limpia (#14322 by @aaronfulkerson) +- Input + - Actualiza los valores dependientes en el DOM cuando el tipo cambia (#14889 by @wacky6) +- Table + - Hacer que defaultExpandAll funcione cuando exista una columna expandida (#14935 by @ziyoung) +- Dialog + - El color de fondo puede ser configurado (#14939 by @ziyoung) +- Form + - `label-width` soporta auto width (#14944 by @ziyoung) + +#### Optimización +- Docs + - Actualización de la documentación en español (#14913 by @Gonzalo2310) + - Agregada documentación en francés para el nuevo componente (#14924 by @ziyoung) + - Documentación de los Tabs optimizada (#14938 by @ziyoung) + +### 2.7.0 + +*2019-03-28* + +#### Nuevas características + +- Table + - Agregado soporte de datos con estructura tree (#14632 by @ziyoung) + +#### Corrección de errores + +- Tabs + - Uso de color primario como boxShadow color (#14558 by @Richard-Choooou) + - Renderización cuando cambia la etiqueta (#14496 by @akki-jat) +- Table + - El pie de página sigue la alineación de las celdas del body (#14730 by @ziyoung) +- NavMenu + - Se ha corregido que al hacer click en el el-submenu se disparaba childMenu nuevamente (#14443 by @PanJiaChen) +- Dropdown + - Compatible con la nueva sintaxis de v-slot en V 2.6 (#14832 by @ziyoung) +- ColorPicker + - Corregido el manejo de error de string en hex color (#14793 by @iamkun) +- Tree + - Revertido pr #13349 (#14847 by @ziyoung) +- Tooltip + - Muestra cuando el valor inicial es verdadero (#14826 by @ziyoung) +- Docs + - Actualización de documentos de cascader (#14442 by @panhezeng) +- Style + - Corrección de la media query en sm-only, md-only, lg-only (#14611 by @sinchang) + +#### Optimización + +- Chore + - Añadido descripción de la página web (#14802 by @iamkun) + +### 2.6.3 + +*2019-03-21* + +#### Corrección de errores + +- Corrección del estilo de demostración de Cascader (#14789 by @ziyoung) +- Eliminación de la operación DOM innecesaria (#14788 by @ziyoung) +- Corrección del valor predeterminado del DST de DatePicker (#14562 by @wacky6) + +### 2.6.2 + +*2019-03-21* + +#### Nuevas características + +- DatePicker + - Añadido monthrange para el atributo type (#14487 by @zxyRealm) +- i18n + - Añadido Locale Croata (#14360 by @danijelh) +- Docs + - Actualización del documento en francés para 2.6.1 y corrección de errores tipográficos (#14555 by @smalesys) + - Actualización de la traducción al francés (#14643 by @smalesys) + +#### Corrección de errores + +- Input + - Corregida regresión (#14572 by @wacky6) +- DatePicker + - Corrección del cálculo del primer día de la semana (#14523 by @sinchang) + - Corregido el formato de valor del selector de semana (#13754 by @wacky6) +- Steps + - Corregida issue #14502 (#14596 by @sinchang) + - Arreglado estilo con tema simple (#14610 by @sinchang) +- Docs + - Renombrada variable en documentos de Table (#14587 by @likwotsing) + - Añadido índice de búsqueda en francés (#14565 by @iamkun) + - Corrección del estilo de página TimePicker (#14579 by @ziyoung) + - Renombrada variable en Upload docs (#14593 by @liupl) + - Actualización de los documentos del Form async validator (#14694 by @iamkun) + - Solucionado el error de tooltip doc (#14748 by @iamkun) + - Corregido error tipográfico (#14751 by @2bj) + - Corregido los elementos de control de resaltado para Webkit touch (#14703 by @VladG0r) + + +#### Optimización + +- Chore + - Actualización del script de construcción de ci (#14600 by @ziyoung) + - Actualización ga tracking (#14560 por @iamkun) + - Añadido más evento ga (#14633 by @iamkun) + - Actualización del grupo de discusión (#14741 por @iamkun) + - Actualización de los deps y conf de las pruebas (#14735 by @wacky6) + - Actualización gulp (#14745 by @ziyoung) + - Uso de codepen para mostrar la demo y corregir el error doc (#14747 por @ziyoung) + +### 2.6.1 + +*2019-03-03* + +#### Corrección de errores + +- **Don't specify node version** (by @iamkun in #14546) +- Corrección del directorio doc en `deloy-faas.sh` (by @ziyoung in #14553) +- Arreglado el estilo de date en changelog para 2.6.0 (by @island205 in #14547) +- Corregido error tipográfico en doc (by @wack6 in #14552) + +### 2.6.0 + +*2019-03-01* + +#### Nuevas características +- Timeline + - Agregado componente timeline (by @jikkai in #14248) +- DropdownItem + - Añadida la prop icon a `el-dropdown-item` (by @gabrielboliveira in #14088) +- Input + - Añadida la prop show-password (by @phshy0607 in #13966) +- Select + - Añadido el slot `empty` (by @elfman in #13785) +- Autocomplete + - Añadida la prop highlight-first-item (by @YamenSharaf in #14269) +- I18n + - Locale Armenio creado (by @hamletbarsamyan in #14214) +- Docs + - Traducción al francés (by @smalesys in #12153, #14418, #14434) + +#### Optimización +- Alert + - Actualizada la descripción de Alert (by @iamkun in #14488) +- Input + - Actualizado input password (by @iamkun in #14480) +- InputNumber + - Removido parseFloat innecesario (by @JuniorTour in #14172) +- Menu + - Añadido soporte para `el-menu-item` sin índice (by @georgyfarniev in #13298) +- Table + - Eliminadas algunas operaciones DOM html (by @elfman in #13643) +- Upload + - Optimizado el código (by @elfman in #13973) +- Popup + - Optimizado el código (by @KAionro in #14413) +- Docs + - Se han agregado más detalles sobre cómo ejecutar el modo de play para contribuir (by @island205 in #14355) + - Warn input como componente de control. (by @wacky6 in #14463) + - Actualizacion de la documentacion de Table (by @luguokong in #14329) + - Actualizacion de la documentacion de input (by @iamkun in #14437) + - Actualizacion de la documentacion de custom-theme (by @wangguohao in #14297) + - Se ha hecho que el icono cambie de estilo en hover (by @tuxinghuan in #14295) +- Build + - Minimización de css y js para la doc del sitio de Element (by @iamkun in #14430) + - Aceleración de webpack (by @hetech in #14484) + - Uso de cli para seleccionar la versión de lanzamiento (by @hetech in #14354) +- Instalación de stale para el manejo de issues (by @island205 in #14392) + +#### Corrección de errores +- Menu + - Corregido el error de focus del submenú cuando se cambiaba la pestaña del navegador (by @liupl in #13976) +- MessageBox + - Corregida la definicion de type (by @NateScarlet in #14278) +- ScrollBar + - Prevenido el clic del botón derecho en la miniatura (by @xifeiwu in #14196) +- Switch + - Activación de la validación de formularios si el valor cambia (by @hetech in #14426) +- Table + - Se ha convertido el método toggleAllSelection en un método de instancia (by @letanure in #14075) +- Tabs & Dropdown + - Estilo arreglado (by @hetech in #14452) +- Tree + - Los tips de texto vacío son diferentes de las tablas (by @ColinCll in #14331) +- Docs + - Corregido el error de formato de la documentacion de DatetimePicker (by @iamkun in #14290) + - Problema de ortografía en la documentación de datepicker (by @helmut in #14481) + - Arreglado estilo doc de paginación (by @liuchuzhang in #14451) + +#### Breaking changes +- Table + - Cambiar el orden de los parámetros enviados en los eventos de las filas (by @jikkai in #12086) + +### 2.5.4 + +*2019-02-01* + +#### Corrección de errores + +- Build: Se ha solucionado el problema de configuración de babel que provocaba que el efecto de transicion de collpase se rompiera (por @island205 en #14282) + +### 2.5.3 + +*2019-01-31* + +#### Optimización + +- Optimización del código de Message (por @vok123 en #14029) +- Retirada de gh-pages (por @ziyoung en #14266) +- Añadido enlace IssueHunt (por @island205 en #14261) + +#### Corrección de errores + +- Corregido el error del módulo UMD en el lado del servidor (por @island205 en #14242) +- Corregido el estilo activo de TabBar (por @iamkun en #14240) +- Corregido el error de código de demo de la tabla (por @xunmeng en #14253) + + +### 2.5.2 + +*2019-01-27* + +#### Optimización +- Docs: + - Actualizacion ChangeLog ES 2.5.1 (by @Gonzalo2310 in #14231) + +#### Corrección de errores +- Build: + - Eliminar comentarios no borrados en el módulo umd `lib/index.js` (por @island205 en #14233) + - Corregido el error de exportación disparado en el módulo commonjs usado en nuxt.js (por @island205 en #14232) + - Corrección de problemas de compilación de 2.5.1 (por @iamkun en #14228) + +### 2.5.1 + +*2019-01-26* + +#### Optimización +- DatePicker: resalta el mes y año actual (por @Debiancc en #14211) +- Actualizacion del changelog 2.5.0 (por @wacky6 en #14217) + +#### Corrección de errores +- Arreglado el problema de exportación generado por la actualización de webpack (por @island205 en #14220) +- Guardados los documentos 2.4.11 y la nueva subcarpeta para 2.5+ (por @iamkun en #14222) + +### 2.5.0 + +*2019-01-25* + +#### Corrección de errores +- Autocompletar + - Corregida la última línea del menú desplegable que comenzaba recortada (#13597) (por @ziyoung) + - Arreglada la popper arrow que faltaba (#13762) (por @liuchuzhang) +- Carrusel + - Contador de limpieza cuando el componente es destruido (#13820) (por @elfman) +- Cascader + - Retirada de los props computados obsoletos (#13737) (por @iamkun) + - Se corrigió la definición de tipo de las opciónes de Cascader en TypeScript (#13613) (por @NateScarlet) + - Corregido icono que cubre el texto (#13596) (por @ziyoung) +- Checkbox + - Refinado el estilo (por @PanJiaChen) +- DatePicker + - Añade el `key` en v-for de TimeSpinner (#13547) (por @Ende93) + - Corregido el resaltado de la semana en el límite del año (#13883) (por @suyi91) +- Input + - Corregida la referencia del nodo DOM del textarea (#13803) (por @laomu1988 @island205) +- Pagination + - El valor de entrada no será menor que 1 (#13727) (por @elfman) +- Popover + - Corrección de problemas de popover con el disparador de hover (#13104) (por @goldengecko) + - Corregido el fallo de memoria de instancia de popper (#13988) (por @qpxtWhite) +- Radio + - Refinado el estilo (por @ohhoney1) +- Table + - Mejorada la ordenación de tablas al hacer clic en la flecha de ordenación (#12890) (por @ohhoney1) + - Solucionado el problema de alineación vertical de texto vacío en IE10+ (#13638) (por @imzjjy) + - Corregida la documentación del tipo de índice (#13628) (por @ilovefafa) + - Corrección del problema de visualización de `show-summary` cuando el encabezado multinivel tiene el attr fixed (#13914) (por @luckyCao) +- Tabs + - Corregido error de autodesplazamiento (#13696) (por @iamkun) + - Obtener la tab correcta a través del nombre de tab (#13705) (por @iamkun) + - Uso de paneName en lugar de name para determinar el estilo del panel (#13733) (por @iamkun) +- Tree + - Corregido que `showCheckbox` prop en `Tree` no puede afectar a los hijos `tree-node` (por @KidneyFlower) + - Actualizado documento y archivo de definición (#13540) (por @ziyoung) +- Upload + - Agregada la prop `url` para subir el archivo cuando `list-type` cambia (#13771) (por @elfman) +- Slider + - Corrección de la sangría del código fuente (#13955) (por @wacky6) +- I18n + - Añadidas las traducciones de catalán que faltaban (por @jaumesala) + - Añadidas las traducciónes de ruso que faltaban (#13658) (por @justlp) + - Corrección de las traducciones al finés (#14137) (por @jenkrisu) +- Doc + - Actualización del documento 2.4.11 (#13522) (por @Gonzalo2310) +- Otros + - Eliminar scripts innecesarios (por @ziyoung) + - Corregido el error de anchor link (#13753) (por @iamkun) + - Corrección de la capitalización inconsistente en la documentación (por @wonderjar) + - Añadido código qr del grupo de chat DingDing al readme (by @iamkun in #13957) + - Añadido logs de hilo a .gitignore (#13922) (por @mimimi) + - Eliminada la cuota de patrocinadores (#14156) (por @island205) + - Actualizado readme qr code src (#13960) (por @iamkun) + - Actualizado enlace CDN, corregido error tipográfico (por @ziyoung) + +### 2.4.11 + +*2018-11-21* + +- Revertido pr #13296. Arreglado que al hacer clic fuera del Menú causaba que el Submenú colapsara, #13478 +- Ajustados los media query breakpoints de las pantallas pequeñas (xs), #13468 (por @alekoshen712) + +### 2.4.10 + +*2018-11-16* + +- Se corrigio que se necesitaban varios clics en Select para mostrar la lista desplegable, #13268 +- El icono de limpiado para el input no se muestraba cuando Form estaba deshabilitado, #13208 +- Ajustados los estilos de Select, Progress, Autocomplete, Tooltip, Collaspe, TimePicker, #13188 (by @porcelainHeart) #13210 #13266 #13257 #13290 #13347 (by @PanJiaChen) +- Se agregó el atributo `loop` al componente carrusel, #13217 +- Cuando los datos de Table cambian, la línea resaltada permanecerá, #13200 +- Table header scoped slot puede recibir parámetros, #13263 +- El método `clearFilter` de la tabla soporta argumentos, #13176 +- El tooltip ya no se crea cuando no hay contenido en la celda de Table, #13152 (por @rongxingsun) +- El contenido del input del panel ColorPicker se muestra correctamente, #13278 +- ColorPicker ya no activa la validación de formularios al arrastrar, #13299 +- InputNumber se le ha añadido el método `select`, #13286 (por @st-sloth) +- Autocompletar agregó el evento `clear`, #12171(by arthurdenner) #13326 +- Puede cerrar Menú haciendo clic fuera del Menú, #13296 +- El método `validateField` de Form puede recibir argumentos, #13319 +- Cascader añadió el evento `visible-change`, #13415 +- DatePicker agregó slot para separador de rango, #13272 (por @milworm) +- Tree añade las propiedades `iconClass` y `currentNodeKey`, #13337 #13197 (por @isnifer) +- Progress permite texto en el atributo `status` #13198 (por @ali-master) +- Corregidas las `defaultCheckedKeys` de Tree que causaba un error, #13349 (por @dive2Pro) + + +### 2.4.9 + +*2018-10-26* + +- El parámetro de Form's `clearValidate` soporta cadenas, #12990 (by @codinglobster) +- Se agregó el atributo `type` para Badge, #12991 +- Ser puede usar scoped-slot para personalizar el encabezado de la columna de Table #13012 (por @ivanseidel) +- Arreglado que el input box de Select no se podia escrbir en IE, #13034 (by @GaliMU) +- La opción Seleccionar no se cerraba cuando el espacio era insuficiente, #12329 (by @akki-jat) +- Cuando se expande la lista desplegable de Seleccionar, el icono de flecha también se mostrará correctamente, #12353 (by @firesh) +- Arreglado que el atributo size de Select no funcionaba, #13070 +- Select multiple values pueden ser limpiado en lote, #13049 (by @ZSkycat) +- Arreglado el último TabNav que no se podía borrar, #13039 +- Arreglado que la etiqueta del TabNav no se mostraba correctamente, #13178 +- Añadido title slot para Alert, #13082 (by @Kingwl) +- Corregido un problema por el cual el contenido del tooltip en Table era incorrecto, #13159 (by @elfman) +- Optimizada la animación de Upload cuando el archivo es eliminado, #12987 +- Ajustado el estilo de InputNumber cuando no se muestra el botón de control, #13052 + +### 2.4.8 + +- No se muestra el contorno cuando Switch está enfocado, #12771 +- Arreglado el estilo del Dropdown en ButtonGroup, #12819 (por @bluejfox) +- Añadido evento opened para Dialog, #12828 +- Corregido el orden incorrecto de visualización de TabNav, #12846 +- Corregido el problema de que Tabs no se desplazaba a la pestaña seleccionada, #12948 +- Corregido el problema de que el identificador no se mostraba cuando se arrastraba el Tree node, #12854 +- El parámetro validar evento de Form contiene el mensaje de validación, #12860 (por @YamenSharaf) +- Se ha corregido el DatePicker que no verificaba la validez de la hora de entrada del usuario, #12898 +- Arreglado el problema de que el atributo `render-header` del encabezado de Table no funcionaba, #12914 + +### 2.4.7 + +*2018-09-14* + +- Corregido que DatePicker no activaba la validación del Form, #12328 #12348 +- Corregidos el lanzamiento de errores del DatePicker en modo múltiple, #12347 +- Corregida la posición incorrecta del spinner del DatePicker, #12415 (por @rang-ali) +- Se ha corregido el llenado automático del input del DatePicker, #12521 (por @abdallanayer) +- Corregida el input no resaltada en Cascader, #12341 +- Corregido el orden incorrecto de Tabpane, #12346 +- Corregida la posición incorrecta del cursor de ColorPicker, #12376 (por @cnwhy) +- Corregido el estilo del Submenú, #2457 +- Corregido el resaltado después de seleccionar el Submenú, #12479 +- Corregidos los valores incorrectos seleccionados por Cascader, #12508 (por @huangjinqiang) +- Corregido el valor incorrecto del input de Paginación, #12525 +- Se ha corregido el orden en que la paginación desencadena los eventos, #12530 +- Corregido que no se mostraba el Table Filter, #12539 +- Corregido Tree que era incapaz de borrar nodos, #12684 +- Corregida la altura de los Select Input que cambiaba en modo simple, #12719 +- Arreglado el estilo de la etiqueta FormItem en Form anidado, #12748 +- Añadido el atributo `autocomplete` para Input, obsoleto `auto-complete`, #12514 (por @axetroy) +- Añadido el slots-scope de Form para mostrar la información de validación, #12715 (por @YamenSharaf) + +### 2.4.6 + +*2018-08-09* + +- Arreglada la tabla que no mostraba el ícono del filtro cuando a `filter` se les asignaba un array vacío, #12165 +- Arreglado Menu que no guardaba el estado activo cuando cambiaba `collapse` #12178 (por @elfman) +- Se ha corregido que Cascader no escapaba a los caracteres especiales para Regexp, #12248 +- Se ha corregido que el RadioBotón deshabilitado mostraba la sombra de la caja cuando se hacía clic, #12262 +- Arreglado el efecto de la tecla de flecha en Select cuando el valor por defecto es `undefined`,#12322 +- Corregida la función de consulta de Select not debounced en modo multi, #12181 +- Corregida que la palabra clave de consulta de Select desaparecía en modo multi, #12304 +- Corregido el ancho incorrecto de Dialog cuando se muestra a pantalla completa, #12203 +- Corregida la visualización incorrecta de Main en IE, #12237 +- Corregido el trigger de Input con dos validaciones de Form, #12260 +- Arreglado el añadir un nuevo nodo de árbol que causaba que los nodos desaparecieran, #12256 +- Arreglado el nodo Tree no se borraba después de arrastrar, #12279 +- Popover corregido porque no era visible cuando InputNumber no enfocaba, #12284 +- Añadido el atributo `popper-append-to-body` para Autocompletar, #12241 +- Añadido el modificador `sync` para el atributo `page-size` de Pagination, #12281 + +### 2.4.5 + +*2018-07-26* + +- Se ha corregido en Table que `class-name` no funcionaba para las columnas `expand`, #12006 +- Se ha añadido el método `toggleAllSelection` para Table, #12047 +- Corregida la posición incorrecta del `suffix slot` cuando Input contiene Select, #12108 +- Corregido que el `line-height` de Option no se establecia, #12120 +- Corregido que TimeSelect con valor por defecto `null` no podia ser asignado después de ejecutar `resetField`, #12010 +- Arreglado el evento `keydown` que cuando no era una tecla de flecha no funciona en Tree, #12008 +- Corregido nodo padre checked en modo lazy, #12106 +- Añadido el parámetro `includeHalfChecked` para getCheckedNodes de Tree, #12014 + +### 2.4.4 + +*2018-07-13* + +- Corregido que se disparaba la validacion del Select después de reajustar el formulario, #11837 +- Corregida la posición incorrecta del slot Input `suffix` cuando se usaba el slot `suffix` con el slot `append` , #11951 +- Corregido el clearable Input que muestraba el icono de borrado cuando era readonly, #11967 +- Arreglado el nodo Tree checked cuando estaba disabled, #11847 +- Corregido que `default-checked-keys` no funcionaba en Tree, #11971 +- Corregido que el `empty-text` no era visible cuando el nodo Tree se filtraba, #11971 +- Arreglada la posición de texto vacío sobredimensionado en Table, #11965 +- Corregido que la fila de la tabla no se modificado el resaltado cuando `current-row-key` era asignada a null, #11866 +- Arreglado que mostraba el filtro del dropdown cuando los filtros eran un array vacío, #11864 +- Corregido que el cambio de label de Radio no detenia propagacion de eventos, #11912 + +### 2.4.3 + +*2018-07-03* + +- Corregido `allow-drop` que no funcionaba correctamente cuando los nodos de árbol tenian una altura personalizada, #11797 +- Ahora puede pasar un parámetro al método `clearValidate` de Form, especificando qué resultados de validación de `FormItems` necesita borrar, #11821 +- Añadido el atributo `distinguishCancelAndClose` para MessageBox, #11831 + +### 2.4.2 + +*2018-06-26* + +- Ahora el `class-name` y el `label-class-name` de la tabla son reactivos, #11626 +- Arreglado que Table seguia resaltando la fila en la que se había hecho clic cuando `highlight-current-row` era `false`, #11646 +- Corregido un error de estilo de ButtonGroup cuando sólo habia un botón `round` o `circle`, #11605 +- Arreglado estilo del tamaño de página del Select de Pagination, #11622 +- Corregido un error del método `open` de los Menús cuando se cambiaba dinámicamente `collapse`, #11646 +- Añadidos los parámetros `activeName` y `oldActiveName` al gancho before-leave de Tabs, #11713 +- Arreglado el focus en Cascader después de hacer clic fuera, #11588 +- Arreglado que Cascader no se cerraba cuando se hacia clic en la opción estando `change-on-select` como `true`, #11623 +- Ahora la actualización del valor de Select programáticamente activará la validación de formulario, #11672 + +### 2.4.1 + +*2018-06-08* + +- Removida la declaración duplicada de type en Autocompletar, #11388 +- Corregido el estilo de flecha en el dropdown de Select en FireFox cuando se anidaba en el formulario, #11427 +- Corregido que el ícono `clear` de Select seguia apareciendo cuando el valor inicial era `null`, #11460 +- Arreglado que cuando el radio estaba `disabled` mostraba el box-shadow al hacer click, #11462 +- Añadido el atributo `iconClass` para MessageBox, #11499 +- Añadido el atributo `stretch` para Tabs, #11476 +- Arreglado el problema de orden de renderizado de TabPane cuando Tabs es `lazy`, #11461 +- Arreglado que Table no retenia la fila actual de resaltados cuando se expandia, #11464 +- Arreglado que focusing state cuando `before-leave` devolvia una promesa resuelta, #11386 +- Arreglado que Popover deshabilitado seguia creando poppers, #11426 +- Arreglado el bucle sin fin de Tree cuando se añadia un nuevo nodo en modo `lazy`, #11430 (por @wangjingf) +- Añadido el evento `closed` para Dialog, #11490 + +### 2.4.0 Fullerene + +*2018-05-28* + +#### Nuevas características +- Generalidades + - La herramienta de desarrollo y el empaquetador se cambiaron a webpack nativo, #11216 + - Ahora puede configurar globalmente el z-index inicial de los popups, #11257 +- Autocomplete + - Añadido el atributo `hide-loading`, #11260 +- Button + - Ahora se puede usar el atributo `size` en los botones circulares para controlar sus tamaños, #11275 +- InputNumber + - Añadido el atributo `precision`, #11281 +- Tabs + - Añadido el atributo `before-leave`, #11259 + - Añadido el atributo `lazy`, #11167(by @Kingwl) +- Table + - Añadido el método `sort` para ordenar manualmente la tabla, #11311 + +#### Corrección de errores +- Input + - Se ha corregido un problema que provocaba que se volviera a procesar al utilizar el IME chino para introducir texto rápidamente, #11235 (por @STLighter). +- Popover + - Corregido el error de la consola cuando el elemento disparador es Radio o Checkbox, #11265 +- Breadcrumb + - Arreglado el atributo `to` que no soportaba la actualización dinámica, #11286 +- Upload + - Corregido el error de la consola cuando se resolvia el Archivo en la Promesa devuelta del método `beforeUpload`, #11297 (por @qusiba) +- Tooltip + - Solucionado que la flecha no se posicionaba correctamente cuando el contenido estaba vacío, #11335 +- Autocompletar + - Corregido que las sugerencias de entrada eran incorrectas después de eliminar la palabra clave rápidamente, #11323 +- ColorPicker + - Corregido el evento `active-change` que se disparaba incorrectamente cuando el menú desplegable del picker estaba cerrado, #11304 +- Table + - Corregido el error de estilo del panel de filtro cuando se sobredimensionaba, #11314 + - Corregida que la fila seleccionada actualmente no se retenia cuando se ordenaba la tabla, #11348 +- CheckBox + - Arreglado que cuando el checkbox era único no soportaba validación, #11271 +- Radio + - Arreglado que el Radio desactivado seguia estando seleccionada cuando se pulsaba la tecla espaciadora, #11303 +- MessageBox + - Corregida la clase `el-popup-parent--hidden` que no se eliminaba al abrir MessageBox sucesivamente, #11371 + +### 2.3.9 + +*2018-05-18* + +- Corregido que cuando los datos de origen no tenian el campo especificado por el atributo `prop` de una TableColumn, se producía un error al moverse el ratón dentro de las celdas de esa columna, #11137. +- El atributo `lockScroll` de los componentes pop-up ya no añade un inline style al elemento padre, sino que añade un nombre de clase, #1111114. +- Arreglado el icono de Progreso que no se mostraba cuando su `status` era `exception`, #11172 +- El atributo `disabled` no funcionaba en la lista de resultados del filtro de Cascader, #11185 +- Se ha corregido un problema por el que la fila expandida de la Tabla no se podía contraer si los datos de origen se actualizaban después de su expansión, #11186. +- `setCurrentKey` de Tree ahora acepta `null` como parámetro para cancelar el nodo actualmente resaltado, #11205 + +### 2.3.8 + +*2018-05-11* + +- Corregido que el panel DatePicker saltaba al mes actual después de escoger una fecha en un mes diferente cuando el tipo era `dates`, #10973 +- Arreglado que el `clearable Input` seguía mostrando el icono de borrado cuando era sólo de lectura, #10912 +- Arreglado que al cerrar el panel DatePicker sin modificar el valor se desencadenaba incorrectamente el evento `change`, #11017 +- Arreglado que la navegación por el teclado no funcionaba correctamente cuando Select tenia opciones agrupadas, #11058 +- Agregado el `slot named` `prefix` para Select, #11063 +- Agregado el metodo `clearValidate` para FormItem, #11076 +- Agregado el atributo `checkOnClickNode` para Tree, #11111 + +### 2.3.7 + +*2018-04-29* + +- Corregido que Table no actualizaba el ancho de encabezado cuando la barra de desplazamiento desaparecia debido al filtrado, #10834 +- Corregido input borrable que mostraba el icono de borrado cuando su valor inicial era `nulo`, #10912 +- Corregido el disparador incorrecto del evento `active-change` después de cambiar el valor enlazado de ColorPicker programáticamente, #10903 (por @zhangbobell) +- Corregido filterable Select que causaba un bucle infinito al navegar por las opciones usando el teclado si todas las opciones estában deshabilitadas, #10945 + +### 2.3.6 + +*2018-04-21* + +- Corregido el comportamiento incorrecto del callback `allow-drop` de Tree cuando se usaba el parámetro `type`, #10821 +- Ahora puede introducir correctamente las palabras clave en filterable Single Select en IE11, #10822 +- Corregido Single Select activaba incorrectamente el evento `blur` después de hacer clic en una opción, #10822 + +### 2.3.5 + +*2018-04-20* + +- Arreglado los incorrectos realces en el panel de DatePicker cuando `type` es week, #10712 +- Arreglado que InputNumber comenzaba vacio cuando el valor inicial era 0, #10714 +- Agregado el atributo `automatic-dropdown` para Select, #10042 (by @Seebiscuit) +- Arreglado que el valor del Rate pasaba a `disabled` cuando se comenzaba a actualizar con las teclas de navegacion, #10726 (by @Richard-Choooou) +- Ahora el atributo `type` de DatePicker's puede ser `'dates'`, donde puede elegir varias fechas en un solo picker, #10650 (by @Mini256) +- Agregados los eventos `prev-click` y `next-click` para Pagination, #10755 +- Agregado el atributo `pager-count` para Pagination, #10493 (by @chongjohn716) +- Agregado `type` como 3rd parametro del atributo `allow-drop` de Tree, #10792 +- Ahora usamos ResizeObserver para detectar el redimensionamiento de elementos DOM, #10779 + +### 2.3.4 + +*2018-04-12* + +- Eliminado el atributo duplicado `showTimeout` en SubMenu's en la declaracion TypeScript, #10566 (by @kimond) +- Ahora se puede personalizar los datos de los items de Transfer usando scoped slot, #10577 +- Arreglado que los click de los botones `next` y `prev` en Pagination se deshabilitaban cuando se disparaba el evento `current-change`, #10628 +- Arreglado que Textarea mostraba `undefined` en SSR cuando el valor no era asignado, #10630 +- Arreglado que se deshabilitaba el estilo del TabItem cuando `type` era border-card, #10640 +- Agregado `$index` como cuarto parametro en el atributo de las columnas de Table `formatter` , #10645 +- Arreglado que CheckboxButton no se exportaba en la declaracion de TypeScript, #10666 + +### 2.3.3 + +*2018-04-04* + +- Agregar atributo `shadow` para Card, #10418 (by @YunYouJun) +- Se ha corregido el error de ocultar Badge cuando `value` es `0`, #10470 +- Arreglados algunos bugs del draggable Tree, #10474 #10494 +- Agregado `placement` para Autocomplete, #10475 +- Ahora el atributo `default-time` también funciona en un rango que no es el rango DateTimePicker, #10321 (by @RickMacTurk) +- Eliminado el contorno azul de TabItem después de que el navegador se desdibuja o se minimiza, #10503 +- Agregado el atributo `popper-append-to-body` para SubMenu, #10515 +- Eliminado el feedback visual cuando se desplaza sobre non-link BreadcrumbItem, #10551 +- Se ha corregido el evento `change` de InputNumber para garantizar que el valor de ligado del componente se actualiza en el control de eventos, #10553 + +### 2.3.2 + +*2018-03-29* + +- Arreglada una regresión de Autocompletar, #10442 + +### 2.3.1 + +*2018-03-29* + +- Se ha corregido una regresión por la que el `type` de input no se transmitia al elemento de entrada nativo, #10415 +- Agregado el metodo `blur` para Select, #10416 + +### 2.3.0 Diamond + +*2018-03-28* + +#### Nuevas características +- Table + - Ahora `formatter` de TableColumn puede ser actualizado dinámicamente, #10184 (by @elfman) + - Agregado el atributo `select-on-indeterminate`, #9924 (by @syn-zeta) +- Menu + - Agregado el atributo `collapse-transition`, #8809 (by @limichange) +- Input + - Agregado el metodo `select` , #10229 + - Agregado el metodo `blur`, #10356 +- ColorPicker + - Agregado el atributo `predefine`, #10170 (by @elfman) +- Tree + - Agregados los atributos `draggable`, `allow-drop` y `allow-drag`, y los eventos `node-drag-start`, `node-drag-enter`, `node-drag-leave`, `node-drag-over`, `node-drag-end` y `node-drop`, #9251 #10372 (by @elfman) +- Form + - El metodo `validate` ahora acepta un segundo parametro, que contiene información de los ítems del formulario que no superaron la validación, #10279 + - Agregado el evento `validate`, #10351 +- Progress + - Agregado el atributo `color`, #10352 (by @YunYouJun) +- Button + - Agregado el atributo `circle`, #10359 (by @YunYouJun) + +#### Bug's arreglados +- Form + - Solucionado: Label del FormItem no se alineaba adecuadamente con Input mixto, #10189 +- Menu + - Ahora collapsed Menu sólo mostrará el Tooltip cuando el slot `title` de MenuItem esté configurado, #10193 (by @PanJiaChen) +- Pagination + - Corregido el evento `current-change` que se disparaba erróneamente sin interacción del usuario, #10247 +- DatePicker + - Ahora la fecha y la hora en el panel desplegable están correctamente formateadas según el atributo `format`, #10174(by @remizovvv) +- Upload + - Solucionado el atributo `accept` no trabajaba cuando `drag` era true, #10278 + +### 2.2.2 + +*2018-03-14* + +- Agregado el evento `clear` para Input, #9988 (by @blackmiaool) +- Ahora la entrada manual de ColorPicker soporta los modos `hsl`, `hsv` y `rgb`, #9991 +- Arreglado DatePicker no desencadenaba el evento `change` cuando se borraba su valor inicial, #9986 +- Ahora la clase de iconos relacionadas con los atributos de Rate soporta actualizaciones dinamicas, #10003 +- Arreglado Table que con columnas `fixed` no actualizaban correctamente su altura si se fijaba `max-height`, #10034 +- Ahora DatePicker en modo rango admite la selección inversa (haciendo clic en la fecha final y, a continuación, haciendo clic en la fecha de inicio), #8156 (by @earlymeme) +- Agregado el atributo `disabled` para Pagination, #10006 +- Agregados los eventos `after-enter` y ` after-leave` para Popover, #10047 +- Arreglado Select no disparaba validación cuando el usuario seleccionaba una opción después de ejecutar `resetFields` de Form, #10105 +- Arreglado anchos incorrectos de columnas fijas de Table en algunos casos, #10130 +- Corregido MessageBox heredaba el atributo `title` de su instancia anterior cuando se llamaba sin `title`, #10126 (by @Pochodaydayup) +- Agregado el atributo `input-size` para Slider, #10154 +- Agregados los eventos `left-check-change` y `right-check-change` para Transfer, #10156 + +### 2.2.1 + +*2018-03-02* + +- Corregido Aside, Header y Footer que se contraia en algunos layout, #9812 +- Corregido Table con un atributo `height` no renderizaba en SSR, #9876 +- Corregido Table con fila expandible no calculaba la altura cuando la fila era expandida, #9484 +- Corregido que cuando se escribia la fecha de forma manual en DateTimePicker no se disparaba el evento `change`, #9913 +- Corregido que Select mostraba sus opciones cuando se hacia click con el botón derecho del mouse en el Input, #9894 (by @openks) +- Agregado el atributo `tooltip-class` para Slider, #9957 +- Ahora Select permanecera enfocado despues de la selección, #9857 (by @Seebiscuit) +- Agregado el atributo `target-order` para Transfer, #9960 + +### 2.2.0 Graphite + +*2018-02-12* + +#### New features +- Menu + - Agregados los atributos `popper-class` y `disabled` para SubMenu, #9604 #9771 + - Menu Horizontal ahora soporta SubMenu multi-capas, #9741 +- Tree + - Agregado el evento `node-contextmenu`, #9678 + - Ahora se puede personalizar el template del nodo usando scoped slot, #9686 + - Agregados los metodos `getNode`, `remove`, `append`, `insertBefore`, `insertAfter`, `getCheckedKeys`, `getHalfCheckedNodes`, `getHalfCheckedKeys` y el evento `check`, #9718 #9730 +- Transfer + - Agregado el metodo `clearQuery`, #9753 +- Select + - Agregado el atributo `popper-append-to-body`, #9782 + +#### Bug fixes +- Table + - Corregido el icono de expansión de una fila expandible que al hacer click activaba el evento `row-click`, #9654 + - Corregido el layout que no se actualizaba cuando el ancho de columna era cambiado por el usuario arrastrando, #9668 + - Corregido problema de estilo cuando la fila de resumen coexistia con columnas fijas, #9667 +- Container + + - Corregido componentes del Container que no se estiraban en IE11, #9655 +- Loading + + - Corregido Loading no se mostraba cuando el valor de `v-loading` era cambiado a true en el `hook` `mounted`, #9722 +- Switch + - Corregido se disparaban los dos eventos nativos de click cuando se hacia click en el Switch, #9760 + + + +### 2.1.0 Charcoal + +*2018-01-31* + +#### New features +- Cascader + - Agregados los eventos `focus` y `blur`, #9184 (by @viewweiwu) +- Table + - El `filter-method` ahora tiene un tercer parámetro `column`, #9196 (by @liyanlong) +- DatePicker + - Agregados los atributos `prefix-icon` y `clear-icon`, #9237 (by @AdamSGit) + - Agregado el atributo `default-time`, #9094 (by @nighca) + - `value-format` ahora soporta `timestamp`, #9319 (by @wacky6) +- InputNumber + - Ahora el valor vinculado puede ser `undefined`, #9361 +- Select + - Agregado el atributo `auto-complete`, #9388 +- Form + - Agregado el atributo `disabled`, #9529 + - Agregado el atributo `validateOnRuleChange`, #8141 +- Notification + - Agregado el metodo `closeAll`, #9514 + +#### Bug fixes +- InputNumber + - Arreglado el reseteo del valor cuando tiene punto decimal, #9116 +- Dropdown + - Arreglado el dropdown menu que tenia un posicionamiento incorrecto cuando la página sólo tiene una barra de desplazamiento horizontal en algunos navegadores, #9138 (by @banzhuanmei) +- Table + - Corregido un error en el cálculo del número de columnas fijas después de que los datos de la columna cambian, #9188(by @kolesoffac) + - Corregido el borde de la última columna de la cabecera agrupada que no se visualizaba correctamente., #9326 + - Corregido el posicionamiento incorrecto del header de la tabla en Safari, #9327 + - Corregido fila expandida colapsaba cuando cambiaban los datos de la tabla, #9462 + - Corregido renders múltiples innecesarios en algunas condiciones, #9426 + - Corregido un error de calculo en el ancho de la columna cuando `width` cambiaba en TableColumn, #9426 +- Loading + - Corregido que en algunas ocasiones el loading no se ocultaba correctamente, #9313 +- DatePicker + - Corregido el metodo `focus` que no funcionaba en modo `range`, #9437 + - Corregido si se hacia clic en el botón "now" seguia seleccionando la fecha actual aunque estuviera desactivado, #9470 (by @wacky6) + - Corregido fijación de fechas al navegar, #9577 (by @wacky6) +- Steps + - Corregido error de estilos en IE 11, #9454 + +#### Breaking changes +- Menu + - El menú desplegable en modo `collapse` ahora se agrega directamente al `body`, de modo que es visible cuando está anidado en Aside, #9263 +- Table + - Ahora, al marcar los checkboxes en la Tabla de selección múltiple no se activa el evento `row-click`, #9467 +- Loading + - El `z-index` de la máscara de carga non-fullscreen se cambia a 2000. El `z-index` de la máscara de carga fullscreen se actualiza dinámicamente con los componentes emergentes, #9522 +- Dropdown + - Los atributos `show-timeout` y `hide-timeout` ahora solo trabajan si se dispara `hover`, #9573 + +### 2.0.11 + +*2018-01-08* + +- Corregido el problema de color del borde del Select cuando está el slot `prepend` o `append` del Input, #9089 +- Corregido el parámetro `remove-tag` de Select, #9090 +- Añadido los atributos `show-timeout` y `hide-timeout` para SubMenu, #8934 (por @HugoLew) +- Corregido el estilo de Tooltip de `show-overflow-tooltip` que faltaba cuando Table era importada bajo demanda, #9130 +- Se ha corregido el mal funcionamiento de ordenación de la columna de Table despues que `clearSort` era ejecutado en esa columna, #9100 (por @zEmily) +- El fichero de configuración i18n para el checo se renombra de `cz` a `cs-CZ`, #9164 + +### 2.0.10 + +*2017-12-29* + +- Corregido el calculo incorrecto de la altura máxima de Table cuando fixed column y summary row coexisten, #9026 +- Solucionado el estilo de color que no lo compilaba para textos vacíos en Table, #9028 +- Ahora DatePicker sólo emite el evento `change` cuando el valor cambia verdaderamente, #9029 (by @remizovvv) +- Añadido atributo `tabindex` para Input, #9041 (by @dicklwm) + +### 2.0.9🎄 + +*2017-12-24* + +- Añadida la función de enganche (hook) `before-remove` para Upload, #8788 (by @firesh) +- Arreglado el valor inicial de error que no funcionaba para FormItem, #8840 +- Ahora la directiva Loading soporta nombre de clase personalizado asignando el atributo `element-loading-custom-class`, #8826 (por @earlymeme) +- Arreglado CarouselItem que se ponía invisible cuando los datos eran actualizados asincrónicamente, #8921 +- Añadido el atributo `renderAfterExpand` para Tree, #8972 + +### 2.0.8 + +*2017-12-12* + +- Agregada la documentacion en español +- Arreglado `show-timeout` de Dropdown que no funcionaba cuando se disparaba el click, #8734 (por @presidenten) +- Arreglado el tiempo de validacion del Form cuando se disparaba el blur, #8776 +- Arreglado el evento de perdida de foco (blur) del DatePicker por rangos, #8784 +- `format` de TimePicker ahora soporta AM/PM, #8620 (por @firesh) + +### 2.0.7 + +*2017-11-29* + +- Solucionado el estilo disabled en el texto de button, #8570 + +### 2.0.6 + +*2017-11-29* + +- Corregido error de estilo de los iconos de ordenación de Table, #8405 +- Corregido activacion para Popover cuando `trigger` es manual, #8467 +- Añadidos los atributos `prefix-icon` y `suffix-icon` para Autocomplete, #8446 (por @liyanlong) +- Añadido el atributo `separator` para Cascader, #8501 +- Añadido atributo `clearable` para Input, #8509 (por @lbogdan) +- Añadido atributo `background` para Pagination, #8553 + +### 2.0.5 + +*2017-11-17* + +- Solucionado regresion en 2.0.4 de Popover, Tree, Breadcrumb and Cascader, #8188 #8217 #8283 +- Solucionado Fuga de memoria de la directiva clickoutside, #8168 #8225 (por @badpunman @STLighter) +- Solucionada la altura en multiple Select cuando se borra su valor, #8317 (por @luciy) +- Añadido el atributo `collapse-tags` para multiple Select para reemplazar las tags con una línea de texto, #8190 +- Solucionado el alto consumo de CPU causado por Table cuando esta oculta, #8351 +- Ahora puede usar el método `doLayout` de Table para actualizar su diseño, #8351 + +### 2.0.4 + +*2017-11-10* + +- Accesibilidad mejorada para Cascader, Dropdown, Message, Notification, Popover, Tooltip y Tree +- Arreglado el cambio de tamaño del Container cuando el ancho de la vista disminuye, #8042 +- Arreglado Tree's `updateKeyChildren` borraba incorrectamente los nodos hijos, #8100 +- Arreglado la altura de los bordes de CheckboxBotón's cuando esta anidado en un Form, #8100 +- Arreglado error de análisis de los Menu's para los colores personalizados, #8153 (por @zhouyixiang) + +### 2.0.3 + +*2017-11-03* + +- Solucionado atributos `editable` and `readonly` de DatePicker de los rangos, #7922 +- Corregido error de estilo de los Tabs anidados, #7941 +- Corregido error de estilo del último Step de Steps verticales, #7980 +- Corregido el tiempo de activación del evento `current-change` para Pagination, #7995 +- Corregido Tooltip no registrado en el Menu, #7995 + +### 2.0.2 + +*2017-10-31* + +- Ahora haciendo clic con el botón derecho del ratón en los botones de InputNumber no cambiará su valor, #7817 +- El metodo `validate` de Form ahora puede esperar por validaciones asíncronas antes de ejecutar su devolución de llamada, #7774 (por @Allenice) +- Corregido la selección de rango de DatePicker no funcionaba en los navegadores Chromium 53-57, #7838 +- Corregido la perdida de previsualización e iconos de eliminar de Upload cuando su `list-type` es picture-card, #7857 +- Añadido el atributo `sort-by` para TableColumn, #7828 (por @wangfengming) +- Corregido que a veces DatePicker muestra un número de año incorrecto al seleccionar la primera semana en modo week, #7860 (por @hh23485) +- Corregido error de estilo de icono de Step vertical, #7891 +- El área hot para las flechas de nodo en Tree se expandia, #7891 + +### 2.0.1 + +*2017-10-28* + +- Corregido error de estilo de RadioButton y CheckboxButton, #7793 +- Corregido TimePicker no responde al desplazamiento del ratón en algunas condiciones, #7811 +- Corregido estilos incompletos de algunos componentes cuando se importan bajo demanda, #7811 + +### 2.0.0 Carbon + +*2017-10-27* + +#### New features + +- General + - Un nuevo tema: `theme-chalk` + - Se ha mejorado la accesibilidad de los siguientes componentes: Alert, AutoComplete, Breadcrumb, Button, Checkbox, Collapse, Input, InputNumber, Menu, Progress, Radio, Rate, Slider, Switch, Upload + - Añadido tipografías TypeScript + - Todos los iconos existentes son rediseñados. Se han añadido algunos iconos nuevos + - Añadida una serie de clases de utilidades basadas en puntos de ruptura que ocultan elementos cuando el tamaño del viewport cumple ciertas condiciones + - Componentes de diseño añadidos: Container, Header, Aside, Main, Footer. + - Ahora puede configurar los tamaños de componentes a nivel global. Al importar Element, puede añadir un objeto de configuración global con un prop `size` para configurar tamaños predeterminados para todos los componentes. +- Button + - Atributo `round` añadido. Se usa para botones de esquinas redondas #6643 +- TimeSelect + - Ahora puede ser navegado por `Up` y `Down`, y presionando `Enter` selecciona la hora #6023 +- TimePicker + - Ahora puede ser navegado por `Up` y `Down`, y presionando `Enter` selecciona la hora #6050 + - Añadido `start-placeholder` y `end-placeholder`. Son placeholder's para las dos casillas de input en modo range #7169 + - Añadido el atributo `arrow-control` para hacer girar el tiempo con las flechas #7438 +- Tree + - Ahora los nodos hijo no se renderizan antes de la primera expansión #6257 + - Añadido el atributo `check-descendants`. Determina si los nodos hijo se seleccionan al seleccionar su nodo padre en modo `lazy` #6235 +- Tag + - Atributo `size` añadido #7203 +- Datepicker + - Ahora `timeFormat` puede dar formato al TimePicker cuando type está configurado en `datetimerange` #6052 + - Añadido `start-placeholder` y `end-placeholder`. Son placeholder's para las dos casillas de input en modo range #7169 + - Atributo `value-format` añadido para personalizar el formato del valor enlazado, #7367 + - Añadido el atributo `unlink-panels` para desacoplar los dos paneles de fechas al seleccionar un rango. +- MessageBox + - Añadido el atributo `closeOnHashChange` #6043 + - Atributo `center` agregado para que el contenido pueda ser centrado #7029 + - Añadido atributo `roundButton` para mostrar Botones redondeados #7029 + - Añadido atributo `dangerouslyUseHTMLString`. Cuando está configurado en true, el mensaje será analizado como cadena HTML* #6043 + - Añadido atributo `inputType` para asignar el tipo para el input interno, #7651 +- Dialog + - Añadidos los atributos `width`, `fullscreen`, `append-to-body`. Ahora Dialog puede ser anidado + - Atributo `center` agregado para que el contenido pueda ser centrado #7042 + - Añadidos `focus-after-closed`, `focus-after-open` para mejorar la accesibilidad #6511 +- ColorPicker + - Ahora puede escribir colores en el input #6167 + - Añadidos atributos `size` y `disabled` #7026 + - Añadido atributo `popper-class` #7351 +- Message + - Ahora el color de los iconos puede ser sustituido por CSS #6207 + - Añadido atributo `dangerouslyUseHTMLString`. Cuando está configurado en true, el mensaje será analizado como cadena HTML* #6207 + - Atributo `center` agregado para que el contenido pueda ser centrado #6875 +- Notification + - Añadido atributo `position` para configurar donde aparece Notification #6231 + - Añadido atributo `dangerouslyUseHTMLString` . Cuando está configurado en true, el mensaje será analizado como cadena HTML* #6231 + - Añadido el atributo `showClose` para ocultar el botón de cierre #6402 +- Rate + - Añadido el atributo `show-score` para determinar si la puntuación actual se muestra #6295 +- Tabs + - Añadido el atributo `tab-position` #6096 +- Radio + - Añadidos los atributos `border` y `size` #6690 +- Checkbox + - Añadidos los atributos `border` y `size` #6690 +- Alert + - Atributo `center` agregado para que el contenido pueda ser centrado #6876 +- Menu + - Añadidos los atributos `background-color`, `text-color` y `active-text-color` #7064 + - Añadidos los methods `open` and `close` para abrir y cerrar los SubMenu con programación, #7412 +- Form + - Añadido el atributo `inline-message` para determinar si el mensaje de validación se muestra inline #7032 + - Añadido el atributo `status-icon` para mostrar un icono de retroalimentación cuando se valida #7032 + - Form y FormItem ahora tienen un atributo `size`. Los componentes internos heredarán este tamaño si no se especifica en ellos mismos, #7428 + - Método `validate` devolverá ahora una promesa si se omite la llamada de retorno, #7405 + - Añadido método `clearValidate` para limpiar los resultados de las validaciones de todos los form items, #7623 +- Input + - Añadido slots con nombres `suffix` y `prefix` y atributos `suffixIcon` y `prefixIcon` para añadir contenido dentro del input #7032 +- Breadcrumb + - Añadido el atributo `separator-class` para dar soporte a los iconos como separadores de items #7203 +- Steps + - Añadido atributo `simple` para activar Steps de estilo sencillo #7274 +- Pagination + - Añadidos los atributos `prev-text` y `next-text` para personalizar los textos de la página anterior y de la página siguiente #7005 +- Loading + - Ahora usted puede personalizar el ícono del spinner y el color de fondo con los props `spinner` y `background` , #7390 +- Autocomplete + - Añadido atributo `debounce`, #7413 +- Upload + - Añadidos los atributos `limit` and `on-exceed` para limitar la cantidad de archivos, #7405 +- DateTimePicker + - Añadido el atributo `time-arrow-control` para activar `arrow-control` del TimePicker anidado, #7438 +- Layout + - Añadido un nuevo breakpoint `xl` para viewport más ancho que 1920px +- Table + - Añadido el atributo `span-method` para combinar celdas + - Añadido el método `clearSort` para borrar la clasificación programáticamente + - Añadido el método `clearFilter` para limpiar el filtro de forma programática + - Para las filas ampliables, cuando se amplía una fila, se añadirá una clase `.expanded` a su lista de clases, para que pueda personalizar su estilo. + - Atributo de `size` añadido + - Añadido el método `toggleRowExpansion` para expandir o contraer filas expandibles programáticamente. + - Añadido el atributo `cell-class-name` para asignar el nombre de la clase para las celdas + - Añadido atributo `cell-style` para dar estilo a las celdas + - Añadido atributo `header-row-class-name` para asignar el nombre de clase para las filas de encabezado. + - Añadido un atributo `header-row-style` para el estilo de encabezado + - Añadido el atributo `header-cell-class-name` para asignar el nombre de la clase para las celdas de encabezado. + - Añadido el atributo `header-cell-style` a las celdas de encabezado de estilo + - El atributo prop de TableColumn ahora acepta las notaciones `object[key]` + - Atributo de `index` añadido para TableColumn para personalizar índices de filas +- Select + - Añadido el atributo `reserve-keyword` para reservar la palabra clave de búsqueda actual después de seleccionar una opción. + +#### Bug fixes + +- DatePicker + - Arreglado `v-model` que devolvia el segundo día de la semana seleccionada en modo week #6038 + - Arreglado el primer input comenzaba borrado con el type `daterange` #6021 +- DateTimePicker + - Arreglado DateTimePicker y TimePicker que se afectaban entre sí cuando se seleccionaban #6090 + - Arreglado la hora y el segundo podian estar más allá del límite al seleccionar el tiempo #6076 +- TimePicker + - Arreglado `v-model` que no se actualizaba correctamente cuando no tenia el foco #6023 +- Dialog + - Arreglado textos que tenian bordes borrosos al abrir y cerrar dropdowns anidados #6088 +- Select + - Rendimiento mejorado. Ahora Vue dev-tool no se bloqueará cuando un gran número de Selects sean destruidos #6151 +- Table + - Corregido un bug de Table permanecía oculto cuando su elemento padre tenia el atributo `display: none` + - Arreglado Table ahora amplia su ancho cuando el elemento padre tiene `display: flex` + - Arreglado un bug que corregía las columnas de una tabla con slot con nombre `append` que desaparecia cuando los datos eran recuperados dinámicamente. + - Arreglado el atributo `expand-row-keys` que no funcionan con el valor inicial + - Fallo del filtro corregido al actualizar los datos + - Se ha corregido un error de cálculo de la disposición de columnas fijas con cabeceras agrupadas. + - Corregido un error de `max-height` dinámico + - Corregidos algunos errores de cálculo de estilo + +#### Breaking changes + +- General + - Eliminado `theme-default` + - Compatible con Vue 2.5.2+ e IE 10+ + - Evento `change` de componentes del formulario y evento `current-change` de Pagination ahora sólo se activa en la interacción del usuario. + - El atributo `size` del botón y los componentes del formulario aceptan ahora los tamaños `medium`, `small` y `mini`. + - Para facilitar el uso de iconos de terceros, los atributos `icon` de Button y Steps y los atributos `prefix-icon` y `suffix-icon` del input ahora requieren un nombre de clase completo. +- Dialog + - Atributo `size` eliminado. Ahora el tamaño de Dialog se puede configurar con `width` y `fullscreen` + - Ahora la visibilidad del Diálogo no puede ser controlada por `v-model` +- Rate + - `text-template` a sido renombrado a `score-template` +- Dropdown + - `menu-align` a sido renombrado a `placement`. Ahora soporta más posiciones +- Transfer + - `footer-format` a sido renombrado a `format` +- Switch + - Los atributos que comienzan con `on*` serán analizados en eventos en JSX, haciendo que todos los atributos `on*` de Switch no puedan trabajar en JSX. Por lo tanto, los atributos `on*` se renombran a `active-*`, y por consiguiente los atributos `off-*` se renombran a `inactivado-*`. Este cambio afecta a los siguientes atributos: `on-icon-class`, `off-icon-class`, `on-text`, `off-text`, `on-color`, `off-color`, `on-value`, `off-value`. + - Los atributos `active-text` y `inactive-text` ahora no tienen valores por defecto. +- Tag + - El atributo type acepta ahora `success`, `info`, `warning` y `danger` +- Menu + - Atributo `theme` eliminado. El color de Menu se puede configurar utilizando `background-color`, `text-color` y `active-text-color` +- Input + - Atributo `icon` eliminado. Ahora el icono del sufijo puede configurarse usando el atributo `suffix-icon` o el slot con nombre `suffix`. + - Eliminado el atributo `on-icon-click` y el evento `click`. Ahora para añadir el manejador de clics en los iconos, por favor use los slots con nombre. + - El evento `change` se comporta ahora como el nativo, que se activa sólo en la perdida del foco o presionando enter. Si necesita responder a las entradas de usuario en tiempo real, puede utilizar el evento `input`. +- Autocomplete + - Atributo `custom-item` eliminado. Ahora la plantilla de sugerencias del input se puede personalizar utilizando `scoped slot` + - Atributo `props` eliminado. Ahora puede utilizar el atributo `value-key` para designar el nombre de la clave del objeto de sugerencia del input para su visualización. +- Steps + - Atributo `center` eliminado + - Ahora Steps llenara su contenedor padre por defecto +- DatePicker + - Los parámetros del evento `change` de DatePicker son ahora el valor vinculante en sí mismo. Su formato es controlado por `value-format` +- Table + - Soporte eliminado para personalizar la plantilla de columnas mediante `inline-template` + - `sort-method` ahora se alinea con `Array.sort`. Debería devolver un número en lugar de un booleano + - El slot `append` se desplazo fuera del elemento `tbody` para evitar múltiples renderizados. + - Evento `expand` se renombro a `expand-change` + - Los parametros de los métodos `row-class-name` y `row-style` son ahora un objeto + +# # + +* El procesamiento dinámico de HTML arbitrario en su sitio web puede ser muy peligroso porque puede conducir fácilmente a [ataques XSS](https://en.wikipedia.org/wiki/Cross-site_scripting). Por lo tanto, cuando `dangerouslyUseHTMLString` está encendido, por favor asegúrese de que el contenido de `message` es confiable, y **nunca** asigne el `message` al contenido proporcionado por el usuario.`` \ No newline at end of file diff --git a/public/static/libs/element-ui/CHANGELOG.fr-FR.md b/public/static/libs/element-ui/CHANGELOG.fr-FR.md new file mode 100644 index 0000000..cbf4198 --- /dev/null +++ b/public/static/libs/element-ui/CHANGELOG.fr-FR.md @@ -0,0 +1,2085 @@ +## Changelog + +### 2.15.14 + +*2023-08-24* + +#### Bug fixes +- Img + - Delete referrerpolicy prop (#22651 by @xinguanhua) +#### Optimization +- Docs + - Update readme and website example links (#22642 by @lyfeyaj) + - Update popper links (#22539 by @brizer) +- I18n + - Update translation of Spanish (#22430 by @jcardus) + - Add sr-Latn translation (#22567 by @N-M) + - Update Uzbek translation (#22390 by @akahon) +- Statistics + - Fix doc; Optimized code (#22384 by @webvs2) +- Table + - Add highlight selection row (#22382 by @wangdaodao) + +### 2.15.13 + +*2023-02-12* + +#### Bug fixes +- Docs + - Fix Statistic docs (#22383 by @JUST-Limbo) + - Fix Input docs (#22093 by @lm312) + - Fix en-US docs (#22268 #22269 #22270 by @Hazel-Lin) + - Fix Pagination docs (#22288 by @xujintai123) + - Fix: Links docs (#22370 by @itmier) +- Statistics + - fix slot display bug (#22375 by @webvs2) +- Chore + - missing web-type after publishing (#22271 by @loosheng) +#### Optimization +- InputNumber + - Fix touch one click trigger twice on the window touch pad (#22185 by @mrsai) +- Image + - Add initialIndex prop (#22346 by @inkroom) +- Statistics + - Updated countdown feature to localize lodash Closes (#22260 by @webvs2) + - Update code and doc (#22276 by @webvs2) +- Other + - fix web-types type props (#22281 by @whzxc) + +### 2.15.12 + +*2022-11-16* + +#### Bug fixes +- Statistic: + - Fixed the thousandth bit bug (#22252 by @webvs2) +- Other + - Fix 2.15.11 element-theme-chalk publish fail bug + +### 2.15.11 + +*2022-11-15* + +#### Bug fixes +- Docs + - Fix Radio docs (#22178 by @bchen1029) + - Fix Progress docs +#### Optimization +- I18n + - Update translation of Malaysian (#22185 by @z4q) + - Update translation of Norwegian (#22145 by @Barsnes) +- Progress + - Add defineBackColor and textColor prop (#22089 by @lm312) +- Statistics + - Add new component Statistics (#22159 by @webvs2) +- Other + - Add Web Types to improve code assistance in WebStorm IDE and other JetBrains IDEs (#22135 by @piotrtomiak) + +### 2.15.10 + +*2022-09-13* + +#### Bug fixes + +- DatePicker + - Fix props placement error (#21908 by @lqzhgood) +- Loading + - Fix sticky DOM error (#22087 by @zzjjhh001) +- Docs + - Fix Popover docs (#22083 by @lm312) + - Fix Skeleton docs (#22092 by @lm312) + - Fix DatePicker docs (#21970 by @guojiongwei) +- Tree: + - fix lazy-load default check problem (#21934 by @kiss-yu) + +#### Optimization + +- I18n + - Add translation of Sinhalese (#21936 by @sayuri-gi) + - Update translation of Spanish (#21924 by @jcardus) + - Add translation of Malaysian (#22028 by @iorange0411) + - Update translation of Swahili (#21904 by @Cholowao) +- Utils + - update date-util.js (#22099 by @Due07) +- DatePicker + - add months And years type (#21918 by @akiko123456) + +### 2.15.9 + +*2022-06-02* + +#### Bug fixes + +- Table + - Fix Tabl-header shake bug (#21863 by @bofeng) + - Fix when partial import show `el-checkbox not imported` error (#21828 by @bobohuochai) +- FormItem + - Fix change rules verification not reset bug (#21892 by @bofeng) +- Cascader + - Fix change options unexpect error (#21759 by @louiebb) +- Docs + - Fix Popover docs (#21843 by @lod61) + - Fix Calendar docs (#21814 by @GoJam11) + - Fix TimePicker docs (#21803 by @Alanscut) + - Fix DatePicker docs (#21877 by @Nirvanaiu) +- Other + - Fix codepen display bug (#21863 by @bofeng) + +#### Optimization + +- I18n + - Add translation of Swahili (#21895 by @quilltouch) +- Chore + - Use launch-editor-middleware in dev environment (#21633 by @polemices) +- DatePicker & Cascader + - Optimize the dropdown animation direction (#21806 by @XivLaw) +- Tooltip + - Optimize `getFirstElement` code (#21886 by @zhankang) +- Input + - Optimize scss code (#21558 by @cheese-git) + +### 2.15.8 + +*2022-04-12* + +#### Bug fixes + +- Drawer + - Fix appendToBody failure problem (#21264 by @cs1707) +- Switch + - Fix toggling value problem(#19473 by @EdwinBetanc0urt) +- Docs + - Fix input docs (#21723 by @justforuse) + - Fix DatePicker docs (#21663 by @justforuse) + - Fix Skeleton docs (#21601 by @yanwydxf) +- Others + - Fix vue version (#21736 by @ckvv) + +#### Optimization + +- I18n + - add translation of Azerbaijani (#21012 by @ricardotondello) + - update translation of Slovenian (#21729 by @patik123) + - update translation of Slovak (#21711 by @sjaustirni ) + - add translation of Icelandic (#21709 by @aronhr) + - add translation of Bengali (#21485 by @llwwtt) + +#### Others + +- Due to compatibility considerations, the PR on node-sass (#21019 by @linxsbox) of 2.15.7 release has been withdrawn and will be published in an appropriate version after re-evaluation. + +### 2.15.7 + +*2021-11-18* + +#### Bug fixes + +- Select + - fix click icon triggering dropdown (#21314 by @dennyak47) + - fix keydown event when composition (#21336 by @bchen1029) +- Badge + - fix type class when is-dot (#21308 by @adaex) +- Form + - validate method reject error info (#21374 by @cs1707) +- Table + - fix resizeObserver loop limit exceeded (#21255 by @tomieric) + - fix toggleAllSelection bug when table is empty (#21456 by @cs1707) + - optimize performance (#21330 by @cs1707) +- Button + - fix disabled priority (#21375 by @cs1707) +- Descriptions + - fix label slot bug (#21462 by @cs1707) +- SASS + - replace node-sass with dart-sass (#21019 by @linxsbox) +- Docs + - fix skeleton typos (#21408 by @zhhbstudio) + +### 2.15.6 + +*2021-09-02* + +#### Bug fixes + +- Cascader + - fix a bug that makes the browser jitter in zoom mode (#21207 by @cs1707) + - optimize performance (#21231 by @cs1707) +- Select + - fix long text overflow in multiple mode (#21237 by @cs1707) +- Dropdown + - add disabled property (#21235 by @mshioda) +- Radio + - fix checked state when browser go back (#21250 by @cs1707) +- Descriptions + - fix type declaration (#21265 by @adaex) + - avoid table style conflict (#21254 by @adaex) +- Drawer + - fix append to body (#21264 by @cs1707) +- Local + - fix italian mistake (#21012 by @ricardotondello) + +### 2.15.5 + +*2021-08-04* + +#### Bug fixes + +- Select + - fix resetInputHeight (#21201 by @cs1707) + +### 2.15.4 + +*2021-08-03* + +#### New features + +- Descriptions + - add description component (#21129 by @cs1707) +- Result + - add result component (#21171 by @cs1707) + +#### Bug fixes + +- Utils + - fix isScroll (#21098 by @canvascat) +- Translation + - update it.js (#21133 by @bliberi) +- RadioGroup + - fix RadioGroup used in component causes exception #17908 (#20783 by @lceric) +- Message + - fix message[type] (#21088 by @cs1707) +- Carousel + - reset the timer when setActiveItem method is called (#20846 by @Nekojita1) +- Cascader + - fix emitPath (#21185 by @cs1707) +- Select + - fix select filterable bug (#17494 by @profore) + - fix a bug that makes the browser jitter in zoom mode (#21197 by @cs1707) +- Tree + - fix insertChild (#21194 by @cs1707) + +### 2.15.3 + +*2021-06-29* + +#### New features + +- Skeleton + - add skeleton component (#21038 by @cs1707) +- Empty + - add empty component (#21080 by @cs1707) + +#### Bug fixes + +- Local + - fix week translations for hr locale (#21040 by @cs1707) +- Table + - fix lazy load data (#21041 by @cs1707) +- Docs + - fix form hide-required-asterisk description (#21045 by @cs1707) +- Drawer: + - fix destroy (#20715 by @zj9495) +- Row + - fix align top (#20963 by @cs1707) +- Select + - fix the bug when the value is Boolean (#21052 by @cs1707) +- Calendar + - fix first-day-of-week (#21057 by @cs1707) +- Utils + - fix isScroll (#21065 by @cs1707) + - fix(utils.dom by @fw6) +- TypeScript + - add CascaderPanel export type (#21070 by @qige2016) + - add spinner.d.ts (#21090 by @qige2016) + +### 2.15.2 + +*2021-05-28* + +#### Bug fixes + +- Image + - fix z-index and keydown event add stopPropagation (#20859 by @cs1707) +- Input + - fix show password cursor (#20870 by @cs1707) + - fix show password icon in edge (#20902 by @cs1707) +- Carousel + - fix interval and scale bug (#20931 by @cs1707) +- Cascader + - fix delete tag bug (#20939 by @cs1707) +- Drawer + - add overflow auto (#20948 by @cs1707) +- Others + - fix isFunction (#20912 by @cs1707) + +### 2.15.1 + +*2021-02-23* + +#### Bug fixes + +- Drawer + - bugfix (by @cs1707) +- Image + - fix incorrect image object fit ratio in IE (#19583 by @charlie0228) +- Cascader + - fix cascader panel active path (#20730 by @cs1707) +- Calendar + - fix calendar component i18n bug (#20758 by @iamkun) +- ColorPicker + - fix bugs (by @UxieVerity) + +#### Optimization + +- Doc + - update Axure resource v2.1.0 (by @iamkun) + +### 2.15.0 + +*2021-01-15* + +#### Bug fixes + +- Select + - Fix placeholder i18n bug (#17644 by @nzh63) +- Popconfirm + - Popconfirm i18n bug by @iamkun +- Drawer + - Fix focus bug (#20626 by @cs1707) +- Image + - Preview optimization (#20652 by @cs1707) + +#### Optimization + +- Doc + - Fix typo in french translation of datetime-picker.md (#20543 by @lonk) + - Add format attribute description to the progress component (#20641 by @cs1707) + +### 2.14.1 + +*2020-11-11* + +#### Bug fixes + +- Popover + - Compatible with Vue 2.6 new v-slot syntax (#20424 by @iamkun) + +#### Optimization + +- I18n + - Update Arabic translation (#20202 by @elkattan) + - Update Uighur translation (#20177 by @IlhamTahir) + +### 2.14.0 + +*2020-10-29* + +#### Breaking changes + +- Popconfirm + - Rename event name to `confirm`, `cancel` (#20240 by @hugiron) + +#### Bug fixes + +- Progress + - Fix attribute error (#19985 by @Caaalabash) + +#### Optimization + +- I18n + - Update Russian translation (#19451 by @yangirov) + - Update Khmer translation (#20077 by @Sovai) + - Update Ukrainian translation (#20344 by @MammutAlex) + +### 2.13.2 + +*2020-05-18* + +#### Bug fixes + +- Autocomplete + - Fix change event bug (#19200 by @sxzz) +- Image + - Update error status (#19194 by @lhx6538665) + +#### Optimization + +- I18n + - Update ru-RU popconfirm translation (#19220 by @Opppex) + - Update vi translation (#19244 by @quangln2810) + - Update Catalan and Spanish translations (#19296 by @Ismaaa) + - Update Indonesia translation (#19320) by @therour) + - Update Brazilian Portuguese translation (#19374 by @diegomengarda) + + +### 2.13.1 + +*2020-04-13* + +#### New features +- Autocomplete + - Add change event (#17913 by @sxzz) + +#### Bug fixes + +- Autocomplete + - Fix suggestion error when textarea (#18478 by @Roojay) +- Carousel + - Fix console typo bug (#18264 by @IceFox) +- Image + - Fix preview dose not show when preview list not contain src issue (#18975) (#19130 by @luckyCao) + - Fix shortcut key not work at second time issue (#18983) (#19156 by @luckyCao) + - Don't show image-viewer when preview is false (#18967 by @inooNgt) +- Transfer + - Fix incorrect line-height of el-transfer's first list item when it was used with el-form-item (#18917 by @Hanx) +- InputNumber + - Correctly compute inputNumberDisabled (#18439 by @ashuser-pendo) +- Chore + - Remove index intro (#19155 by @iamkun) +- Doc + - Popconfirm doc update (#18324 by @iamkun) + - Fix step-strictly docs typo (#18705 by @dream2023) + - Fix a type error in document of steps component (#17555 by @haoranyu) + +### 2.13.0 + +*2019-11-26* + +#### New features + +- Popconfirm + - Add popconfirm component (#17548 by @iamkun) + +#### Bug fixes + +- BackTop + - Use cubic bezier scrolling (by @lon) +- DatePicker + - Fix bug of only select min date of date range problem (#17191 by @smk0621) +- Select + - Fix select test cases (by @msidolphin) +- Tree + - Add font-size for the style of tree empty-text (#17094 by @spengjie) +- Table + - Column header can be costumed (#17291 by @ziyoung) + - Update table header cell style (#17284 by @ziyoung) + - Fix table header height after filter (#17348 by @ziyoung) + - Fixed row-style with display not work (#17002 by @a631807682) + - Fix header table not display (#17341 by @ziyoung) +- Calendar + - Import el-button and el-button-group (#17376 by @masongzhi) +- MessageBox + - Fix icon position error (#17410 by @nullptru) +- TimePicker + - Set the selection range after scrolling up or down (#16868 by @mattheyan) +- Message + - Fix close instace offsetHeight(#17564) (#17852 by @gzwgq222) +- Form + - Callback of validateField should be optional (#17314 by @CarterLi) +- Cascader + - Fix TypeScript 3.7 compatibility (#17881 by @CarterLi) +- Menu + - Fix router NavigationDuplicated error when using vue-router@^3.1.0 (#17269 by @iamkun) +- Dropdown + - Update type file (#17550 by @iamkun) +- Progress + - Add strokeLinecap prop (#17552 by @iamkun) +- InfiniteScroll + - Skip trigger event on invisible element (#17553 by @iamkun) +- Image + - Perfect picture preview behavior (#16985 by @luckyCao) + - Fix shield the page when preview big image (#16796 by @luckyCao) +- Drawer + - Bugfix drawer-append-to-body-not-working (#16953 by @JeremyWuuuuu) +- Select + - Fix tag show value or empty issue (17199 by @luckyCao) +- Scrollbar + - Fix FireFox scroll bar width (#18091 by @iamkun) + +#### Optimization + +- I18n + - Update sv-SE.js (#17926 by @FOLLGAD) + - Update avatar component fr doc (#17762 by @blombard) +- Docs + - Fix time-select typo (#17250 by @wacky6) + - Fix Drawer attribute accepted value typo in es (#17122 by @haoranyu) + - Update Spanish changelog 2.12.0 (#17364 by @Gonzalo2310) + - Fix Changelog typo (#17874 by @renlixin) + - Fix Loading demo (#17862 by @MBearo) + - Add input event in input Events Table (#18061 by @zhouxinyong) + - Delete Input repeat change event (#18085 by @zhouxinyong) + +### 2.12.0 + +*2019-08-29* + +#### New features + +- Popover + - Add close-delay prop (#16671 by @LachlanStuart) +- Theme + - Add Chrome Extension: Element Theme Extension (#16686 by @iamkun) +- Icon + - Add font-display to @font-face declaration (#16805 by @iamfaizalandyka) + +#### Bug fixes + +- Carousel + - Fix onChange emit value (#16705 by @iamkun) +- Notification + - Fix modifying incoming option object (#16704 by @iamkun) +- DatePicker + - Add className for picker option (#16632 by @iamkun) +- DateTimePicker + - Fix time-spinner not scroll to right position (#16854 by @jesse-li) +- Table + - Prevent click handler after drag (#16850 by @ziyoung) + - Fix chrome crash when set thead css display to none (#16956 by @luckyCao) + - Fix wrong empty block height (#16861 by @ziyoung) + - Not throw error when calling toggleExpansion (#16304 by @yyjjqq94) + - Not trigger sort-change event when mounted (#17113 by @a631807682) + - Fix setCurrentRow unable to clear highlight row (#16879 by @ziyoung) + - Fix expand-row-keys not work when data is loaded asynchronously (#16899 by @ziyoung) + - set toggleAllSelection as instance property (#17137 by @ziyoung) +- Tree + - Fix distance between label and checkbox (#16799 by @Hazlank) +- Tabs + - Fix incorrect TabItem's position (#16520 by @victorting) + - Fix activated tab is out of visual range bug (#17033 by @nullptru) +- Calendar + - Fix weekdays i18n issue (#16772 by @ubitoffee) + - fix locale error by (#17208 by @iamkun) +- Cascader + - Fix CascaderPanel display error (#16716 by @zhangHongEn) + - Fix disable status and close button issue (#16224 by @yyjjqq94) +- Input + - Fix Korean composition event (#15069 by @MoonHyuk) + - Fix click event of clear button not trigger when using v-loading (#16576 by @a631807682) +- Select + - Not toggle dropdown when filtering (#17205 by @luckyCao) +- Transfer + - Fix style error (#17206 by @iamkun) +- Dialog + - update sass var (#16365 by @haoranyu) +- RadioGroup + - Not produce invalid HTML in table if "is" attribute is specify (#17070 by @nullptru) +- Divider + - Support custom classes (#17078 by @island205) + +#### Optimization + +- Checkbox + - Improve screen reader experience (#16575 by @tylertrotter) +- Docs + - Update changelog (#16773 by @SimonaliaChen) + - Update contributing guide (#14800 by @sinchang) + - Fix typo in Drawer docs (#16848 by @winkay) + - Update custom theme (#16983 by @iamkun) + - Add Esperanto translation (#16955 by @maxkoryukov) + - Update input-number document about change event (#16316 by @luckyCao) + - Update spanish doc 2.11.1 (#16961 by @Gonzalo2310) +- I18n + - Remove translation of 'year' in catalan language as in the other languages (#14722 by @oscaralbareda) + - Update spanish changelog 2.10.0 and 2.10.1 (#16548 by @Gonzalo2310) + - Update ar.js (#16653 by @l3op) +- Test + - Correct spelling error (#16672 by @boomler) + - Refactor unit test to use data-uri (#16847 by @a631807682) +- Types + - Fix httprequest type (#16633 by @luckyCao) + +### 2.11.1 + +*2019-07-26* + +#### Bug fixes + +- Image + - Fix Image component SSR compatibility (#16737 by @luckyCao) +- Chore + - Update dart-sass compatibility (#16744 by @LewisChennnnn) + +### 2.11.0 + +*2019-07-25* + +#### New features + +- Drawer + - Add drawer component (#16577 by @JeremyWuuuuu) + +#### Bug fixes + +- Checkbox + - Enhance css selector (#16006 by @Hazlank) +- Tree + - Make el-tree generic (#15934 by @JeremyWuuuuu) + - Set isCurrent prop to False (#15870 by @kkkisme) +- Dropdown + - Fix split-button caret default color (#15931 by @JuniorTour) +- Cascader + - Fix level 1 children is empty update problem (#16399 by @luckyCao) + - Add sets default values when lazy is true (#16420 by @luckyCao) + - Fix display errors when node value is duplicate (#15935 by @junyiz) + - Expose getCheckedNodes and fix options change bug (#16709 by @SimonaliaChen) +- Calendar + - Display correct header when range is specified (#16354 by @ziyoung) +- Submenu + - Fix prop append-to-body (#16289 by @a631807682) +- Table + - Fix tree table when updating data (#16481 by @island205) +- Select + - Fix memory leak issue (#16463 by @island205) +- InfiniteScroll + - Update naming & doc (#16698 by @iamkun) +- Avatar + - Fix image not center vertically issue (#16489 by @luckyCao) +- Dialog + - Add destroyOnClose attribute (#16455 by @ziyoung) +- Image + - Add big Image preview feature (#16333 by @luckyCao) + +#### Optimization + +- Docs + - Fix dropdown demo (#16193 by @webxmsj) + - Fix typo in table documents (#15971 by @howiefh) +- I18n + - Update translation of Thai language (#16689 by @ponkrit) +- Chore + - Update theme base api (#16607 by @iamkun) + - Add form theme token (#16699 by @iamkun) + - Mark ali inner user's access (#16609 by @iamkun) + - Fix doc anchor bug (#16692 by @iamkun) + +### 2.10.1 + +*2019-07-02* + +#### Bug fixes + +- Table + - Fix sort icon (#15439 by @bezany) + - Fix layout breaks when append slot exists (#16332 by @ziyoung) + - Fix showOverflowTooltip not reactive (#16295 by @a631807682) + - Register scrollbar in filter-panel (#16246 by @ziyoung) +- Chore + - Fix 2.9 docs (#16233 by @ziyoung) + - Fix index page theme intro english css style issue (#16254 by @iamkun) + +#### Optimization + +- Tag + - Compatible with IE (#16334 by @ziyoung) +- Chore + - Update Dingtalk Group QR image (#16236 by @iamkun) +- Doc + - Update online theme roller doc (#16244 by @iamkun) + +### 2.10.0 + +*2019-06-25* + +#### New features + +- I18n + - Added Uzbek language (#15796 by @ogabek96) +- Calendar + - Add first-day-of-week attribute (#16047 by @ziyoung) +- Avatar + - Add avatar component (#16144 by @luckyCao) +- Upload: + - Add capability to customize thumbnail template (#13192 by @victorzhuk) + +#### Bug fixes + +- Tree + - Not highlight tree node when currentKey is null (#15668 by @yyjjqq94) + - Fix issue #15538 caused by two Tree sharing the same data. (#15615 by @VanMess) +- Upload + - Update the parameter `fileList` type (#15716 by @underfin) +- Table + - Fix loading icon not display (#15868 by @ziyoung) + - Fix background color of complex table when hovering (#15504 by @cnlon) + - Fix current-row-key and select event bug (#15983 by @ziyoung) + - Height accepts more units (#16013 by @ziyoung) + - Fix reserve-selection not work (#16135 by @ziyoung) +- Docs + - Fix Divider attribute type in zh-cn (#15889 by @haoranyu) +- Menu + - Fixed submenu hidden bug after adding popper-append-to-body (#15391 by @PanJiaChen) +- Select + - Fix initialInputHeight (#15989 by @yyjjqq94) + - Fix default-first-option behavior when typing Chinese (#15431 by @VanMess) + - fix double import problem (#16215 by @lengband) +- Message + - Add type def for offset option (#16027 by @matjaz) +- Timeline + - Fix reverse broken (#16091 by @ziyoung) +- Slider + - Fix #15545 by adding explains about "input" event in Chinese (#15588 by @VanMess) +- InfiniteScroll + - Update package name (#16125 by @iamkun) +- MessageBox + - Fix  distinguishCancelAndClose action not same as docs bug (#15438 by @qingdengyue) +- PopupManager + - Fix z-index cannot be rewritten at first using (#15738 by @luckyCao) +- Docs + - Delete an incorrect closing html tag and empty block code (#16194 by @Alexeykhr) +- Chore + - Update test api host (#15807 by @iamkun) + +#### Optimization + +- Tree + - Modify loop conditions to improve performance (#15699 by @KingJeason) +- Theme + - Refine GA track & Update footer link forward to online theme roller (#16007 by @island205) +- Badge + - Update badge prop check (#16198 by @iamkun) +- Avatar + - Update theme config var (#16202 by @luckyCao) +- I18n + - Update pt-br.js (#15776 by @gigioSouza) + - Update Farsi translation (#15881 by @pamenary) +- Docs + - Add missing components in quickstart (#16063 by @pape2016) + - Update french translation (#16208 by @blombard) + - Add description $slots.default (#15444 by @Alexeykhr) + - Update Spanish Doc 2.9.1 (#15840 by @Gonzalo2310) + - Fix spelling mistakes in fr (#15837 by @blombard) + - Update changelog 2.9.2 Spanish (#16185 by @Gonzalo2310) + +#### Breaking changes + +- Form + - Remove success status (#16159 by @ziyoung) + +### 2.9.2 + +*2019-06-21* + +#### Correction de bugs + +- Chore + - Correction du fichier de définitions TS (#15805 by @NateScarlet) + +### 2.9.1 + +*2019-05-30* + +#### Nouvelles fonctionnalités + +- Table + - les événements tree-props,default-expand-all, expand-row-keys, toggle-row-expansion method and expand-change sont pris en charge dans Tree Table (#15709 by @ziyoung) + +#### Correction de bugs + +- Table + - Correction de quelques bugs (#15709 by @ziyoung) +- Theme + - Mise à jour de l'hôte api (#15784 by @iamkun) + +#### Optimisation + +- Chore + - Mise à jour de InfiniteScroll type (#15794 by @iamkun) + +### 2.9.0 + +*2019-05-30* + +#### Nouvelles fonctionnalités + +- Backtop + - Ajout du composant Backtop (#15541 by @iamkun) +- PageHeader + - Ajout du composant PageHeader (#15714 by @ziyoung) +- InfiniteScroll + - Ajout de la directive InfiniteScroll (#15567 by @iamkun) +- Cascader + - Ajouter plusieurs mode et filter-method (#15611 by @SimonaliaChen) +- Message + - Affichage en mode pile (#15639 by @island205) +- Tag + - Ajout d'un effet de prop (#15725 by @SimonaliaChen) +- Tabs + - Aligner le titre à gauche lorsque le type est carte (#15695 by @luckyCao) +- DatePicker + - Supporte les chaînes de caractères littérales (#15525 by island205) +- Image + - Ajout du support pour les attributs de transmission et listeners (#15578 by @VanMess) +- Theme + - Ajout d'un popup en arrière plan (#15412 by @iamkun) +- Chore + - Mise à jour de la nouvelle page d'index 2.9.0 (#15682 by @iamkun) + +#### Correction de bugs + +- Table + - Correction du comportement de sort-change lorsque la condition de tri est nulle (#15012 by @joelxr) +- Image + - Correction de la compatibilité ssr et object-fit (#15346 by @SimonaliaChen) +- Input + - Correction du style de show-word-count dans el-form (#15359 by @lvjiaxuan) + - Correction de l'icône d'erreur pas centrée (#15354 by @YiiGuxing) +- Calendar + - Correction du mauvais jour de la semaine quand le jour est dimanche (#15399 by @qingdengyue) + - Correction du bug de disparition d'octobre (#15394 by @qingdengyue) +- Tabs + - Correction de l'onglet de base imbriqué dans l'erreur de remplissage de card (#15461 by @SimonaliaChen) +- Tag + - Correction du problème de propagation d'arrêt (#15150 by @infjer) +- Form + - Correction de input-group dans l'erreur de hauteur de form-item (#15457 by @SimonaliaChen) + - Résolution de l'issue de resetFields (15181 by @luckyCao) +- Tooltip + - Correction de tabindex personnalisé ne fonctionnant pas (#15619 by @SimonaliaChen ) +- Link + - Correction de la classe de style d'icône (#15752 by @iamkun) +- Select + - Revert définit la valeur à null une fois effacée (#15447 by @iamkun) +- Loading + - Résolution du problème de mise à jour de dom lorsque l'état de chargement change rapidement (#15123 by @FAKER-A) +- Switch + - Label avec les événements récurrents el-switch (#15178 by @FAKER-A) +- Slider + - Correction d'un problème de style lorsque la barre de défilement est cliquée (#15561 by @luckyCao) +- Radio + - Résolution de l'issue 14808 (#14809 by @OverTree) +- Form + - Résolution du problème de resetFields (15181 by @luckyCao) +- Chore + - Mise à jour des dépendances et corrige le bug de démonstration (#15324 by ziyoung) +- Type + - Correction du type de chargement (#15635 by @iamkun) + - Correction du type d'icône (#15634 by @iamkun) + - Fixe la définition du type de lien (#15402 by @iamkun) + +#### Optimisation + +- Cascader + - Refactor (#15611 by @SimonaliaChen) +- Chore + - Mise à jour de la logique du nouveau composant (by @iamkun) +- Docs + - Renommage de variables dans la documentation (#15185 by @liupl) + - Correction du type d'attribut d'image et de la valeur par défaut (#15423 by @haoranyu) + - Correction d'un bug de formulaire (#15228 by @SHERlocked93) + +### 2.8.2 + +*2019-04-25* + +#### Corrections de bugs + +- Icon + - Mise à jour (#15272 par @iamkun) +- Docs + - Correction du style de Form et Input (#15273 par @ziyoung) + +### 2.8.1 + +*2019-04-25* + +#### Corrections de bugs + +- Icon + - Mise à jour de l'icône du cascadeur et du select (#15264 par @SimonaliaChen) + - Mise à jour (#15258 #15268 par @iamkun) + +#### Optimisation + +- Chore + - Mise à jour du script de build (#15267 par @ziyoung) +- Docs + - Correction de la couleur de souslignage d'un lien (#15265 par @iamkun) +- Autre + - Correction d'une configuration de migration non compatible avec les propriétés et évènements en camelCase (#15260 par @SimonaliaChen) + +### 2.8.0 + +*2019-04-25* + +#### Nouvelles fonctionnalités + +- Divider + - Ajout du composant divider (#15055 par @island205) +- Rate + - Ajout des couleurs et des classes d'icônes personnalisées en passant un objet (#15051 par @SimonaliaChen) +- Link + - Ajout du composant Link (#15052 par @iamkun) +- Calendar + - Ajout du composant calendar (#14908 by @ziyoung) +- Icon + - Ajout d'une icône (#15214 par @iamkun) +- Alert + - Ajout d'un thème sombre (#15041 par @island205) +- Image + - Ajout du composant image (#15117 par @SimonaliaChen) +- Collapse + - CollapseItem peut être désactivé (#15076 par @ziyoung) +- Carousel + - Ajout d'un attribut de direction et support de la direction verticale (#15122 by @ziyoung) +- Pagination + - Ajout d'un attribut caché sur une seule page (#15096 par @ziyoung) +- Slider + - Ajout des marqueurs (#15133 par @luckyCao) +- Input + - Ajout de l'attribut show-word-count (#15075 par @luckyCao) +- InputNumber + - Ajout de l'attribut step-strictly (#15050 par @luckyCao) +- Tooltip, Dropdown, Popover + - Support de l'attribut tabindex (#15167 by @ziyoung) + +#### Corrections de bugs + +- Notification + - Correction du word-break du titre (#15008 par @iamkun) +- Form + - Correction d'une erreur dans les règles de validation (#14985 par @luckyCao) + - Correction du style du label (#14969 par @ziyoung) + - Les FormItem requis affiche un astérisque lorsque le label est auto (#15144 by @ziyoung) +- Pagination + - Fix du slot non mis à jour (#14711 par @lucyhao) +- Table + - Correction d'un bug de chargement en mode lazy (#15101 by @ziyoung) + - Correction de la largeur des cellules lorsque colspan est supérieur à 1 (#15196 by @ziyoung) + - Amélioration des performances (#14868 by @ziyoung) + - Ne pas émettre de déclencheurs de changement de tri pendant l'initialisation (#14625 by @PeanutWatson) + - Comportement égal pour height et max-height (#14660 by @arthurdenner) +- Dialog + - Correction de la casse des longs mots (#15027 par @iamkun) +- Alert + - Mise à jour (#15186 par @ziyoung) +- Tabs + - Correction d'un problème où le rejet d'une promesse touchait l'application (#14816 par @ffxsam) + - Rerendu lors d'un changement de slots (#1523238 by @ziyoung) +- Message + - Mise à jour (#14968 par @agoni121212) +- Select + - Correction d'une erreur lorsque la valeur est indéfinie ou nulle (#15022 par @luckyCao) +- Tree + - Détruire le noeud courant après sa suppression (#14604 par @sinchang) + - Amélioration des performances (#14881 par @ChenZhuoSteve) +- Dropdown + - Correction de style (#14907 par @doing123) +- Slider + - Correction d'un bug clavier a11y cassé (#14792 by @erezsob) +- Menu + - La valeur ActiveIndex sera nulle si defaultIndex n'existe pas (#14074 par @hoythan) +- Directive + - RepeatClick : utilisation de Date.now() au lieu de Date() (#14776 par @pavelmash) +- Upload + - Correction du style d'affichage des images transparentes (#15039 par @iamkun) +- Thème + - Ajout d'une bordure (#1525256 par @iamkun) + +#### Optimisation + +- Chore + - Mise à jour du changelog zh-cn (#14965 par @iamkun) + - Masquer la description de la démo quand elle est vide (#15014 par @ziyoung) + - Afficher les informations du serveur de développement par défaut par @iamkun) + - Correction d'une erreur de changelog 2.6.0 (#15026 par @iamkun) + - Mise à jour de la configuration de compilation (#14821 par @abc3660170) + - Ajout d'hmr (#15221 par @SimonaliaChen) + - Utilisation de sourcemap dans l'environnement dev (#15087 par @ibufu) +Docs + - Renommage de la variable dans docs (#14602 #15003 #15094 #15105 par @liupl) + - Correction d'une erreur de téléchargement de doc (#15023 par @iamkun) + - Mise à jour du validateur de formulaire personnalisé doc (#15040 par @iamkun) + - Mise à jour des onglets docs pour afficher les onglets verticaux (#15053 par @iamkun) + - Utiliser eleme.cn comme domaine (#15139 par @ziyoung) + - Correction du nom de route Image (#15194 par @iamkun) + - Suppression de la traduction en double (#15207 par @iamkun) + +#### Breaking changes + +- Rate + - Correction du support de l'affichage décimal en mode désactivé (#15089 par @haoranyu) +- Select + - Utiliser le label de l'option pour régler le placeholder en mode filtre (#14989 par @ibufu) + +### 2.7.2 + +*2019-04-03* + +#### Corrections de bugs + +- Form + - Correction du style de `label-width` auto (#14955 par @ziyoung) + +#### Optimisation +- Docs + - Correction d'une erreur de lien img (#14957 par @iamkun) +- Chore + - Correction d'une erreur de déploiement mkdir (#14952 par @iamkun) + +### 2.7.1 + +*2019-04-03* + +#### Corrections de bugs + +- Select + - Définir la valeur à null lorsqu'elle est effacée (#14322 par @aaronfulkerson) +- Input + - Mise à jour des valeurs dépendantes du DOM lors d'un changement de type (#14889 par @wacky6) +- Table + - Faire fonctionner `defaultExpandAll' lorsqu'une colonne étendue existe (#14935 par @ziyoung) +- Dialog + - Couleur d'arrière-plan configurable (#14939 par @ziyoung) +- Form + - `label-width` supporte la largeur automatique (#14944 by @ziyoung) + +#### Optimisation +- Docs + - Mise à jour de la documentation en espagnol (#14913 par @Gonzalo2310) + - Ajout d'un document en français pour le nouveau composant (#14924 by @ziyoung) + - Optimiser la documentation des onglets (#14938 by @ziyoung) + +### 2.7.0 + +*2019-03-28* + +#### Nouvelles fonctionnalités + +- Table + - Ajout du support de l'arborescence des données (#14632 by @ziyoung) + +#### Corrections de bugs + +- Tabs + - Utilise la couleur primaire comme couleur de l'ombre (#14558 par @Richard-Choooou) + - Rerendu lorsque label change (#14496 par @akki-jat) +- Table + - Le pied de page suit l'alignement des cellules du corps (#14730 by @ziyoung) +- NavMenu + - Correction d'un bug de clic sur el-submenu (#14443 par @PanJiaChen) +- Dropdown + - Compatible avec la nouvelle syntaxe v-slot 2.6 (#14832 by @ziyoung) +- ColorPicker + - Correction d'une erreur de couleur hexadécimale (#14793 par @iamkun) +- Tree + - Revert pr #13349 (#14847 par @ziyoung) +- Tooltip + - Affichage lorsque la valeur initiale est vraie (#14826 by @ziyoung) +- Docs + - Mise à jour de la documentation du cascader (#14442 par @panhezeng) +- Style + - Correction des media queries dans sm-only, md-only, lg-only (#14611 by @sinchang) + +#### Optimisation + +- Chore + - Ajouter la description de la page web (#14802 par @iamkun) + +### 2.6.3 + +*2019-03-21* + +#### Corrections de bugs + +- Correction du style de la démo de Cascader (#14789 par @ziyoung) +- Suppression des opérations DOM inutiles (#14788 by @ziyoung) +- Correction DatePicker valeur par défaut DST (#14562 par @wacky6) + +### 2.6.2 + +*2019-03-21* + +##### Nouvelles fonctionnalités + +- DatePicker + - Ajout d'une plage de mois pour l'attribut type (#14487 par @zxyRealm) +- i18n + - Ajout de la locale croate (#14360 par @danijelh) + +##### Corrections de bugs + +- Input + - Correction d'un régression (#14572 par @wacky6) +- DatePicker + - Correction du calcul du premier jour de la semaine (#14523 par @sinchang) + - Correction du format de valeur du sélecteur de semaine (#13754 par @wacky6) +- Steps + - Correction du problème #14502 (#14596 par @sinchang) + - Correction du style avec le thème simple (#14610 par @sinchang) +- Docs + - Mise à jour de la doc française pour la 2.6.1 et correction de fautes de frappe (#1455555 par @smalesys) + - Renommage d'une variable dans la documentation de la table (#14587 par @likwotsing) + - Ajout de l'index de recherche en français (#14565 par @iamkun) + - Correction du style de la page TimePicker (#14579 par @ziyoung) + - Renommage d'une variable dans la page Upload (#14593 par @liupl) + - Mise à jour de la traduction française (#14643 par @smalesys) + - Mise à jour de la documentation du validateur de formulaire asynchrone (#14694 par @iamkun) + - Correction d'une erreur de doc tooltip (#14748 par @iamkun) + - Correction d'une coquille (#14751 par @2bj) + - Correction de la surbrillance pour Webkit touch (#14703 by @VladG0r) + +##### Optimisation + +- Tâche + - Mise à jour du script de build dans le ci (#14600 par @ziyoung) + - Mise à jour du tracking ga (#14560 par @iamkun) + - Ajout d'un événement ga supplémentaire (#14633 par @iamkun) + - Mise à jour du groupe de discussion (#14741 par @iamkun) + - Mise à jour des deps de test et conf (#14735 par @wacky6) + - Mise à jour de Gulp (#14745 by @ziyoung) + - Utilisez le codepen pour afficher les démos et correction d'une erreur de doc (#14747 by @ziyoung) + +### 2.6.1 + +*2019-03-03* + +#### Corrections de bugs + +- **Ne pas spécifier la version de node** (par @iamkun dans #14546) +- Correction du répertoire doc dans `deloy-faas.sh` (par @ziyoung dans #14553) +- Correction d'un problème de style de date dans le changelog de la 2.6.0 (par @island205 dans #14547) +- Correction d'une typo dans la doc (par @wack6 dans #14552) + +### 2.6.0 + +*2019-03-01* + +#### Nouvelles fonctionnalités +- Timeline + - Ajout d'un composant timeline (par @jikkai dans #14248) +- DropdownItem + - Ajout de la propriété `icon` à `el-dropdown-item` (par @gabrielboliveira dans #14088) +- Input + - Ajout de propriétés pour afficher les mots de passe (par @phshy0607 dans #13966) +- Select + - Ajout du slot `empty` (par @elfman au #13785) +- Autocomplete + - Ajout de la propriété `highlight-first-item` (par @YamenSharaf dans #14269) +- I18n + - Création de la locale Arménienne (par @hamletbarsamyan dans #14214) +- Docs + - Traduction française (par @smalesys dans #12153, #14418, #14434) + +#### Optimisation +- Alert + - Mise à jour de la classe du slot par défaut de la description de Alert (par @iamkun dans #14488) +- Input + - Mise à jour de l'input de type password (par @iamkun dans #14480) +- InputNumber + - Retrait d'un parseFloat inutile (par @JuniorTour au #14172) +- Menu + - Ajout du support de `el-menu-item` sans index (par @georgyfarniev dans #13298) +- Table + - Suppression de certaines opérations du DOM (par @elfman dans #13643) +- Upload + - Optimisation du code (par @elfman dans #13973) +- Popup + - Optimisation du code (par @KAionro dans #14413) +- Docs + - Ajout de détails sur la façon d'exécuter le mode play pour les contributeurs (par @island205 dans #14355) + - Ajout d'un avertissement concernant Input (par @wacky6 dans #14463) + - Mise à jour de la doc de Table (par @luguokong dans #14329) + - Mise à jour de la doc d'Input (par @iamkun dans #14437) + - Mise à jour de la doc sur le thème (par @wangguohaohao dans #14297) + - Le style de l'icône change lorsque vous passez dessus (par @tuxinghuan dans #14295) +- Build + - Minification du CSS et du JS pour le site d'Element (par @iamkun dans #14430) + - Accélération de webpack (par @hetech dans #14484) + - Utilisation du cli pour sélectionner la version de publication (par @hetech dans #14354) +- Installation de stale pour la gestion des issues (par @island205 dans #14392) + +#### Corrections de bugs +- Menu + - Correction d'un bug de focus des sous-menus lors du changement d'onglet du navigateur (par @liupl dans #13976) +- MessageBox + - Correction de la définition du type (par @NateScarlet dans #14278) +- ScrollBar + - Empêche le clic droit sur le bouton du pouce (par @xifeiwu dans #14196) +- Switch + - Déclenchement de la validation du formulaire si la valeur change (par @hetech dans #14426) +- Table + - La méthode toggleAllSelection est maintenant une méthode d'instance (par @letanure dans #14075) +- Tabs & Dropdown + - Correction du style (par @hetech dans #14452) +- Tree + - Les tips sont différents des tableaux (par @ColinCll dans #14331) +- Docs + - Correction d'une erreur de doc du DatetimePicker (par @iamkun dans #14290) + - Problème d'orthographe dans la documentation du DatePicker (par @helmut dans #14481) + - Correction du style de la doc de Pagination(par @liuchuzhang dans #14451) + +#### Breaking changes +- Table + - Fix params order of row events (by @jikkai in #12086) + +### 2.5.4 + +*2019-02-01* + +#### Corrections de bugs + +- Build: Correction d'un problème de configuration de babel qui cassait la transition collapse (par @island205 dans #14282) + +### 2.5.3 + +*2019-01-31* + +#### Optimisation + +- Optimisation du code de Message (par @vok123 dans #14029) +- Suppression des gh-pages (par @ziyoung dans #14266) +- Ajout du lien IssueHunt (par @island205 dans #14261) + +#### Corrections de bugs + +- Correction d'une erreur du module UMD côté serveur (par @island205 dans #14242) +- Correction du style du TabBar actif (par @iamkun dans #14240) +- Correction d'une erreur de code dans la démo de Table (par @xunmeng dans #14253) + +### 2.5.2 + +*2019-01-27* + +#### Optimisation +- Docs: + - Mise à jour du ChangeLog ES 2.5.1 (par @Gonzalo2310 dans #14231) + +#### Corrections de bugs +- Build: + - Suppression des commentaires non supprimés dans le module umd `lib/index.js` (par @island205 dans #14233) + - Correction d'une erreur d'exportation dans le module commonjs utilisé dans nuxt.js (par @island205 dans #14232) + - Correction des problèmes de build 2.5.1 (par @iamkun dans #14228) + +### 2.5.1 + +*2019-01-26* + +#### Optimisation +- DatePicker: surbrillance du mois et de l'année courants (par @Debiancc dans #14211) +- Mise à jour du changelog 2.5.0 (par @wacky6 dans #14217) + +#### Corrections de bugs +- Correction d'un problème d'exportation due par la mise à jour du webpack (par @island205 dans #14220) +- Conservation de la docs 2.4.11 && nouveau sous-dossier pour 2.5+ (par @iamkun dans #14222) + +### 2.5.0 + +*2019-01-25* + +#### Nouvelles fonctionnalités +- DatePicker + - Ajout de l'attribut `validate-event` (par @ziyoung dans #13531) +- DateTimePicker + - `pickerOptions` supporte l'option `selectableRange` (par @eeeeeeeeeeeason) +- Tag + - Ajout de l'événement `click` (par @licdream dans #14106) +- I18n + - Support de la langue kirghize (par @zzjframework dans #14174) + +#### Optimisation +- Mise à niveau vers webpack@4 (par @jikkai dans #14173) +- Input + - Simplification de l'implémentation, suivant un flux de données à sens unique. Correction de plusieurs bugs liés. (par @wacky6 dans #13471) +- Mise à jour du fichier Axure avec de nouveaux composants (par @ziyoung dans #13773) + +#### Corrections de bugs +- Autocomplete + - Correction de la dernière ligne du menu déroulant qui était coupée (#13597) (par @ziyoung) + - Correction d'une flèche de popper manquante (#13762) (par @liuchuzhang) +- Carrousel + - Nettoyage du timer lorsque le composant est détruit (#13820) (par @elfman) +- Cascader + - Suppression de la propriété obsolète des props calculées (#13737) (par @iamkun) + - Correction de la définition du type CascaderOption dans TypeScript (#13613) (par @NateScarlet) + - Correction de l'icône couvrant le texte (#13596) (par @ziyoung) +- Checkbox + - Refonte du style (par @PanJiaChen) +- DatePicker + - Ajout d'un `key` de v-for manquant dans TimeSpinner (#13547) (par @Ende93) + - Correction du surlignage de la semaine dans la bordure de l'année (#13883) (par @suyi91) +- Input + - Correction de la référence de textarea dans le DOM (#13803) (par @laomu1988 @island205) +- Pagination + - La valeur d'entrée ne sera pas inférieure à 1 (#13727) (par @elfman) +- Popover + - Correction d'un problème de popover avec le déclencheur de hover (#13104) (par @goldengecko) + - Correction d'une fuite de mémoire de l'instance popper (#13988) (par @qpxtWhite) +- Radio + - Refonte du style (par @ohhhoney1) +- Table + - Amélioration du tri des tables en cliquant sur la flèche de tri (#12890) (par @ohhoney1) + - Correction d'un problème d'alignement vertical du texte vide sur IE10+ (#13638) (par @imzjy) + - Correction de la documentation sur le type d'index (#13628) (par @ilovefafafa) + - Correction du problème d'affichage `show-summary` lorsque le header multi-niveaux est fixe (#13914) (par @luckyCao) +- Tabs + - Correction d'un bug de défilement automatique (#13696) (par @iamkun) + - Obtenir l'onglet correct par le nom de l'onglet (#13705) (par @iamkun) + - Utilisez paneName au lieu de name pour déterminer le style du panneau (#13733) (par @iamkun) +- Tree + - Correction de la propriété `showCheckbox` sur `Tree` qui ne pouvait pas affecter leurs `tree-node` enfants(par @KidneyFlower) + - Mise à jour des fichiers de doc et de définition (#13540) (par @ziyoung) +- Upload + - Ajout de le propriété `url` au fichier uploadé lorsque `list-type` est modifié (#13771) (par @elfman) +- Slider + - Correction de l'indentation du code source (#13955) (par @wacky6) +- I18n + - Ajout des traductions manquantes en catalan (par @jaumesala) + - Ajout de la traduction russe manquante (#13658) (par @justlp) + - Correction des traductions en finnois (#14137) (par @jenkrisu) +- Doc + - Mise à jour de la documentation espagnol depuis la 2.4.11 (#13522) (par @Gonzalo2310) +- Autres + - Suppression d'un script inutile (par @ziyoung) + - Correction des ancres (#13753) (par @iamkun) + - Correction de l'incohérence des majuscules dans la documentation (par @wonderjar) + - Ajout du QR code du chat DingDing au readme (#13957) (par @iamkun) + - Ajout des logs yarn au .gitignore (#13922) (par @mimimi) + - Suppression du sponsor duotai (#14156) (par @island205) + - Mise à jour du QR code dans le readme (#13960) (par @iamkun) + - Mise à jour du lien CDN, correction d'une typo (par @ziyoung) + +### 2.4.11 + +*2018-11-21* + +- Revert pr #13296. Correction d'un clic sur Menu externe causant l'effondrement du SubMenu, #13478 +- Ajustement des points de rupture media query sur petit écran (xs), #13468 (par @alekoshen712) + +### 2.4.10 + +*2018-11-16* + +- Correction des clics multiples sur Select pour afficher la liste déroulante, #13268 +- L'icône d'effacement des champs n'est pas affichée lorsque Form est désactivé, #13208 +- Ajustement des styles de Select, Progress, Autocomplete, Tooltip, Collaspe, TimePicker, #13188 (par @porcelainHeart) #13210 #13266 #13266 #13257 #13290 #13347 (par @PanJiaChen) +- Ajout de l'attribut `loop` dans le composant Carrousel, #13217 +- Lorsque les données de Table changent, la ligne en surbrillance reste, #13200 +- Le slot du header de Table peut recevoir des paramètres, #13263 +- La méthode `clearFilter` de Table peut recevoir des arguments, #13176 +- La bulle d'aide n'est plus créée lorsqu'il n'y a pas de contenu dans la cellule de Table, #13152 (par @rongxingsun) +- Le contenu de la zone de saisie du panneau ColorPicker peut être affiché correctement, #13278 +- ColorPicker ne déclenche plus la validation des formulaires lors du glisser-déposer, #13299 +- InputNumber: ajout de la méthode `select`, #13286 (par @st-sloth) +- AutoComplete: ajout de l'événement `clear`, #12171(par arthurdenner) #13326 +- Vous pouvez fermer Menu en cliquant à l'extérieur, #13296 +- La méthode `validateField` du formulaire peut recevoir des arguments, #13319 +- Cascader: ajout de l'événement `visible-change`, #13415 +- DatePicker: a ajout d'un slot pour les séparateurs d'intervalle, #13272 (par @milworm) +- Tree: ajout des propriétés `iconClass` et `currentNodeKey`, #13337 #13197 (par @isnifer) +- Progress: ajout du texte de statut #13198 (par @ali-master) +- Correction de `defaultCheckedKeys` de Tree, #13349 (par @dive2Pro) + +### 2.4.9 + +*2018-10-26* + +- Le paramètre `clearValidate` de Form supporte les strings #12990 (par @codinglobster) +- Ajout de l'attribut `type` pour Badge, #12991 +- Les utilisateurs peuvent utiliser scoped-slot pour personnaliser l'en-tête de colonne de Table #13012 (par @ivanseidel) +- Correction du champ de Select incapable d'entrer du texte sous IE, #13034 (par @GaliMU) +- Les options Select ne s'enroule pas lorsque l'espace est suffisant, #12329 (par @akki-jat) +- Lorsque la liste déroulante de Select est ouverte, l'icône de la flèche s'affichera également correctement, #12353 (par @firesh) +- Correction de l'attribut de taille de Select qui ne fonctionnait pas, #13070 +- La sélection de plusieurs valeurs peut aussi être effacée, #13049 (par @ZSkycat) +- Correction du dernier TabNav qui ne pouvait pas être supprimé, #13039 +- Correction d'un problème d'affichage du label TabNav, #13178 +- Ajout d'un slot de titre pour Alert, #13082 (par @Kingwl) +- Correction d'un problème où le contenu de l'infobulle de Table était incorrect, #13159 (par @elfman) +- Optimisation de l'animation de Upload lorsque le fichier est supprimé, #12987 +- Style ajusté pour InputNumber lorsque le bouton de commande n'est pas affiché, #13052 + +### 2.4.8 + +- Ne pas afficher le contour lorsque le Switch est focus, #12771 +- Correction du style de Dropdown dans ButtonGroup, #12819 (par @bluejfox) +- Ajout d'un événement d'ouverture pour Dialog, #12828 +- Correction de l'ordre d'affichage incorrect de TabNav, #12846 +- Correction d'un problème qui empêchait les Tabs de défiler jusqu'à l'onglet sélectionné, #12948 +- Correction d'un problème de l'identificateur qui ne s'affiche pas lorsque le noeud de Tree est glissé, #12854 +- Le paramètre de l'événement validation du formulaire contient le message de validation #12860 (par @YamenSharaf). +- Correction de DatePicker pour ne pas vérifier la validité du temps d'entrée de l'utilisateur, #12898 +- Correction d'un problème avec l'attribut `render-header` de l'en-tête de table qui ne fonctionnait pas, #12914 + +### 2.4.7 + +*2018-09-14* + +- Correction de DatePicker ne déclenchant pas la validation du formulaire, #12328 #12348 +- Correction des erreurs lancées par DatePicker en mode multiple, #12347 +- Correction d'une position incorrecte du spinner de DatePicker, #12415 (par @rang-ali) +- Correction du remplissage automatique de la zone de saisie de DatePicker, #12521 (par @abdallanayer) +- Correction du champ non-subrillant dans Cascader, #12341 +- Correction d'un mauvais ordre de Tabpane, #12346 +- Correction d'une position incorrecte du curseur ColorPicker, #12376 (par @cnwhy) +- Correction du style de SubMenu, #2457 +- Correction de la surbrillance après la sélection de SubMenu, #12479 +- Correction des valeurs incorrectes sélectionnées par Cascader, #12508 (par @huangjinqiang) +- Correction d'une valeur incorrecte dans le champ d'entrée Pagination, #12525 +- Correction de l'ordre dans lequel la Pagination déclenche les événements, #12530 +- Correction des filtres de table non-affichés, #12539 +- Correction de l'arbre incapable de supprimer des nœuds, #12684 +- Correction de la hauteur de Select Input changeant en mode simple, #12719 +- Correction d'un style du label de FormItem sous forme imbriquée, #12748 +- Ajout de l'attribut `autocomplete` pour Input, `auto-complete` devenant obsolète, #12514 (par @axetroy) +- Ajout des slots-scope pour Form pour afficher les informations de validation, #12715 (par @YamenSharaf) + +### 2.4.6 + +*2018-08-09* + +- Correction de Table n'affichant pas l'icône de filtre lorsque `filters` est un tableau vide, #12165 +- Correction de Menu ne sauvegardant pas l'état actif lorsque `collapse` change, #12178 (par @elfman) +- Correction du Cascader n'échappant pas les caractères spéciaux poue les Regexp, #12248 +- Correction d'un bouton Radio désactivé affichant l'ombre d'une case lorsqu'on clique dessus, #12262 +- Correction de arrow key qui n'a pas d'effet lorsque la valeur par défaut est `undefined`, #12322 +- Correction de la fonction de requête de Select non-stabilisée en mode multi, #12181 +- Correction du mot-clé de la requête Select disparaissant en mode multi, #12304 +- Correction d'une largeur incorrecte de Dialog lorsqu'il est affiché en plein écran, #12203 +- Correction de l'affichage incorrect de Main sur IE, #12237 +- Correction de Input déclenchant deux validations de formulaire, #12260 +- Correction de l'ajout d'un nouveau nœud d'arborescence provoquant la disparition des nœuds, #12256 +- Correction d'un nœud d'arborescence non supprimé après avoir glissé, #12279 +- Correction du Popover non-visible quand InputNumber a le focus, #12284 +- Ajout de l'attribut `popper-append-to-body` pour Autocomplete, #12241 +- Ajout du support du modificateur `sync` pour l'attribut `page-size` de Pagination, #12281 + +### 2.4.5 + +*2018-07-26* + +- Correction du réglage de Table `class-name` qui ne fonctionne pas pour les colonnes `expand`, #12006 +- Ajout de la méthode `toggleAllSelection` pour Table, #12047 +- Correction d'une mauvaise position du slot de suffixe lorsque Input contient Select, #12108 +- Correction de `line-height` de l'option impossible à régler, #12120 +- Correction de TimeSelect avec la valeur par défaut `null` ne pouvant être assigné après avoir exécuté `resetField`, #12010 +- Correction d'un événement keydown qui n'étant pas arrow key ne fonctionne pas dans Tree, #12008 +- Correction d'un nœud parent vérifié en mode lazy, #12106 +- Ajout du paramètre `includeHalfChecked` pour getCheckedNodes de Tree, #12014 + +### 2.4.4 + +*2018-07-13* + +- Correction du déclenchement de la validation de Select après la réinitialisation du formulaire, #11837 +- Correction d'une mauvaise position du slot `suffix` de Input lorsque le slot `suffixe` est avec le slot `append`, #11951 +- Correction de Input affichant toujours l'icône clear même en lecture seule, #11967 +- Correction d'un nœud d'arborescence coché lorsqu'il est désactivé, #11847 +- Correction des `default-checked-keys` qui ne fonctionnait pas, #11971 +- Correction de `empty-text` non visible lorsque le noeud de Tree est filtré, #11971 +- Correction de la position du `empty-text` surdimensionné dans Table, #11965 +- Correction de la surbrillance de la ligne de Table lorsque `current-row-key` est assignée à `null`, #11866 +- Correction de l'affichage de la liste déroulante des filtres lorsque `filters` est un tableau vide, #11864 +- Correction du label de Radio qui n'arrête pas la propagation des événements, #11912 + +### 2.4.3 + +*2018-07-03* + +- Correction de `allow-drop` qui ne fonctionnait pas correctement lorsque les nœuds de Tree avaient une hauteur personnalisée, #11797 +- Maintenant vous pouvez passer un paramètre à la méthode `clearValidate` du formulaire, en spécifiant quels résultats de validation FormItems doivent être effacés, #11821 +- Ajout de l'attribut `distinguishCancelAndClose` pour MessageBox, #11831 + +### 2.4.2 + +*2018-06-26* + +- Maintenant `class-name` et `label-class-name` de Table sont réactifs, #11626 +- Correction de Table qui mettait toujours en surbrillance la ligne cliquée lorsque `highlight-current-row` était `false`, #11646 +- Correction d'un bug de style de ButtonGroup lorsqu'il n'a qu'un seul bouton `round` ou `circle`, #11605 +- Correction du style du Select de Pagination, #11622 +- Correction de la méthode `open` du menu quand `collapse` est dynamiquement changé, #11646 +- Ajout des paramètres `activeName` et `oldActiveName` au hook before-leave de Tabs, #11713 +- Correction de Cascader ayant le focus après avoir cliqué à l'extérieur, #11588 +- Correction de Cascader ne se fermant pas quand l'option est cliquée quand `change-on-select` est `true`, #11623 +- La mise à jour programmatique de la valeur de Select déclenchera la validation du formulaire, #11672 + +### 2.4.1 + +*2018-06-08* + +- Suppression du duplicata de la déclaration de type pour Autocomplete, #11388 +- Correction du style de flèche déroulante de Select dans FireFox lorsqu'il est imbriqué dans Form, #11427 +- Correction de l'icône de l'option de Select qui s'affiche toujours lorsque la valeur initiale est `null`, #11460 +- Correction d'un Radio désactivé affichant l'ombre de la boîte quand on clique dessus, #11462 +- Ajout de l'attribut `iconClass` pour MessageBox, #11499 +- Ajout de l'attribut `stretch` pour Tabs, #11476 +- Correction d'un problème d'ordre de rendu de TabPane lorsque Tabs est `lazy`, #11461 +- Correction de Table ne conservant pas la surbrillance de la ligne actuelle lors de son ouverture, #11464 +- Correction de l'état de la mise au point lorsque `before-leave` renvoie une promesse résolue, #11386 +- Correction de la désactivation du Popover qui créait encore des poppers, #11426 +- Correction de la boucle sans fin de Tree lorsqu'un nouveau noeud est ajouté en mode lazy, #11430 (par @wangjingf) +- Ajout de l'événement `closed` pour Dialog, #11490 + +### 2.4.0 Fullerene + +*2018-05-28* + +#### Nouvelles fonctionnalités +- Général + - L'outil de développement et le bundler sont basculés vers le webpack natif, #11216 + - Vous pouvez maintenant définir globalement l'index z initial des popups, #11257 +- Autocomplete + - Ajout de l'attribut `hide-loading`, #11260 +- Button + - Vous pouvez maintenant utiliser l'attribut `size` sur les boutons circulaires pour contrôler leur taille, #11275 +- InputNumber + - Ajout de l'attribut `precision`, #11281 +- Tabs + - Ajout de l'attribut `before-leave`, #11259 + - Ajout de l'attribut `lazy`, #11167(by @Kingwl) +- Table + - Ajout de la méthode `sort` pour trier manuellement la table, #11311 + +#### Corrections de bugs +- Input + - Correction d'un problème qui provoquait un re-rendu lors de l'utilisation de l'IME chinois pour saisir rapidement du texte, #11235 (par @STLighter) +- Popover + - Correction de l'erreur de console lorsque l'élément déclencheur est Radio ou Checkbox, #11265 +- Breadcrumb + - Correction de l'attribut `to` ne supportant pas la mise à jour dynamique, #11286 +- Upload + - Correction de l'erreur de console lorsqu'un fichier est résolu dans la promesse retournée de la méthode `beforeUpload`, #11297 (par @qusiba) +- Infobulle + - Correction d'une flèche mal positionnée lorsque le contenu est vide, #11335 +- Autocomplete + - Correction de suggestions d'entrée incorrectes après la suppression rapide d'un mot-clé, #11323 +- ColorPicker + - Correction d'un événement `active-change` se déclenchant incorrectement lorsque le menu déroulant du picker est fermé, #11304 +- Table + - Correction d'une erreur de style du panneau de filtre surdimensionné, #11314 + - Correction de la ligne actuellement sélectionnée qui n'était pas conservée lors du tri de la table, #11348 +- Checkbox + - Correction d'une checkbox unique ne supportant pas la validation, #11271 +- Radio + - Correction du Radio désactivé quand même sélectionné en appuyant sur la touche espace, #11303 +- MessageBox + - Correction de la classe `el-popup-parent-hidden` qui n'était pas supprimée à l'ouverture successive de MessageBox, #11371 + +### 2.3.9 + +*2018-05-18* + +- Correction d'une erreur lorsque les données source n'ont pas le champ spécifié par l'attribut `prop` d'une TableColumn, lorsque la souris se déplace dans les cellules de cette colonne, #11137 +- L'attribut `lockScroll` des composants popup n'ajoute plus un style en ligne à l'élément parent, mais ajoute un nom de classe, #1111114 +- Correction de l'icône de Progression qui ne s'affichait pas quand son `status` était une exception, #11172 +- Correction de l'attribut `désactivé` qui ne fonctionnait pas dans la liste des résultats de filtrage du Cascader filtrable, #11185 +- Correction d'un problème où la ligne étendue de la table ne peut pas être réduite si la source de données est mise à jour après son extension, #11186 +- `setCurrentKey` de Tree accepte maintenant `null` comme paramètre pour annuler le noeud actuellement mis en surbrillance, #11205 + +### 2.3.8 + +*2018-05-11* + +- Correction du saut du panneau DatePicker au mois courant après avoir choisi une date dans un mois non courant quand `type` est dates, #10973 +- Correction de l'Input effaçable affichant toujours l'icône d'effacement en lecture seule, #10912 +- Correction de la fermeture du panneau DatePicker sans changer la valeur déclenchant incorrectement l'événement `change`, #11017 +- Correction d'un problème de navigation du clavier lorsque Select a regroupé les options, #11058 +- Ajout du slot nommé `préfixe` pour Select, #11063 +- Ajout de la méthode `clearValidate` pour FormItem, #11076 +- Ajout de l'attribut `checkOnClickNode` pour Tree, #1111111 + +### 2.3.7 + +*2018-04-29* + +- Correction d'une table qui ne mettait pas à jour ses largeurs de headers lorsque la barre de défilement disparaissait à cause du filtrage, #10834 +- Correction de l'Input effaçable affichant toujours l'icône d'effacement lorsque sa valeur initiale est `null`, #10912 +- Correction d'un déclencheur incorrect de l'événement `active-change` après avoir changé la valeur liée de ColorPicker par programmation, #10903 (par @zhangbobell) +- Correction du Select filtrable qui provoquait une boucle infinie lors de la navigation dans les options à l'aide du clavier si toutes les options sont désactivées, #10945 + +### 2.3.6 + +*2018-04-21* + +- Correction d'un comportement incorrect du callback `allow-drop` de Tree lorsque le paramètre `type` est utilisé, #10821 +- Maintenant vous pouvez entrer correctement les mots-clés dans le Select simple filtrable dans IE11, #10822 +- Correction d'un Select simple déclenchant incorrectement un événement `blur` après avoir cliqué sur une option, #10822 + +### 2.3.5 + +*2018-04-20* + +- Correction d'une surbrillance incorrecte dans le panneau DatePicker lorsque `type` est la semaine, #10712 +- Correction d'un InputNumber vide lorsque sa valeur initiale est 0, #10714 +- Ajout de l'attribut `automatic-dropdown` pour Select, #10042 (par @Seebiscuit) +- Correction de Rate désactivé quand même mis à jour par les touches de navigation, #10726 (par @Richard-Choooou) +- L'attribut `type` de DatePicker peut être `dates`, où vous pouvez choisir plusieurs dates dans un sélecteur, #10650 (par @Mini256) +- Ajout des événements `prev-click` et `next-click` pour Pagination, #10755 +- Ajout de l'attribut `pager-count` pour Pagination, #10493 (par @chongjohn716) +- Ajout de `type` comme 3ème paramètre de l'attribut `allow-drop` de Tree, #10792 +- Nous utilisons maintenant ResizeObserver pour détecter le redimensionnement des éléments DOM, #10779 + +### 2.3.4 + +*2018-04-12* + +- Suppression du double de l'attribut `showTimeout` dans la déclaration TypeScript de SubMenu, #10566 (par @kimond) +- Vous pouvez maintenant personnaliser les éléments de Transfert en utilisant le scoped slot, #10577 +- Correction d'un clic sur le bouton précédent désactivé et le bouton suivant de la pagination déclenchant toujours l'événement `current-current-change`, #10628 +- Correction de Textarea affichant `undefined` dans le SSR lorsque sa valeur n'est pas définie, #10630 +- Correction de la désactivation du style TabItem lorsque `type` est border-card, #10640 +- Ajout de `$index` comme quatrième paramètre du `formatter` de la Table, #10645 +- Correction de CheckboxButton non exporté dans la déclaration TypeScript, #10666 + +### 2.3.3 + +*2018-04-04* + +- Ajout de l'attribut `shadow` pour Card, #10418 (par @YunYouJun) +- Correction de Badge masqué lorsque `value` est `0`, #10470 +- Correction de quelques bugs de Tree, #10474 #10494 +- Ajout de `placement` pour Autocomplete, #10475 +- L'attribut `default-time` fonctionne également dans DateTimePicker, #10321 (par @RickMacTurk) +- Suppression du contour bleu de TabItem après que le navigateur n'ait plus le focus ou soit minimisé, #10503 +- Ajout de l'attribut `popper-append-to-body` pour SubMenu, #10515 +- Suppression du feedback visuel lors du survol d'un élément BreadcrumbItem non lié, #10551 +- Correction de l'événement `change` d'InputNumber pour s'assurer que la valeur liée du composant est mise à jour dans le gestionnaire d'événements, #10553 + +### 2.3.2 + +*2018-03-29* + +- Correction d'une régression d'Autocomplete, #10442 + +### 2.3.1 + +*2018-03-29* + +- Correction d'une régression de `type` d'Inputqui n'était pas transmis à l'élément natif, #10415 +- Ajout de la méthode `blur` pour Select, #10416 + +#### 2.3.0 Diamant + +*2018-03-28* + +#### Nouvelles fonctionnalités +- Table + - Maintenant le `formatter` de TableColumn peut être mis à jour dynamiquement, #10184 (par @elfman) + - Ajout de l'attribut `select-on-indeterminate`, #9924 (par @syn-zeta) +- Menu + - Ajout de l'attribut `collapse-transition`, #8809 (par @limichange) +- Input + - Ajout de la méthode `select`, #10229 + - Ajout de la méthode `blur`, #10356 +- ColorPicker + - Ajout de l'attribut `predefine`, #10170 (par @elfman) +- Tree + - Ajout des attributs `draggable`, `allow-drop` et `allow-drag`, et `node-drag-start`, `node-drag-enter`, `node-drag-leave`, `node-drag-leave`, `node-drag-over`, `node-drag-end` et `node-drop`, #9251 #10372 (par @elfman) +- Form + - La méthode `validate` a maintenant un deuxième paramètre, contenant l'information des éléments de formulaire qui ont échoué à la validation, #10279 + - Ajout de l'événement `validate`, #10351 +- Progress + - Ajout de l'attribut `color`, #10352 (par @YunYouJun) +- Button + - Ajout de l'attribut `circle`, #10359 (par @YunYouJun) + +#### Corrections de bugs +- Form + - Correction du label de FormItem non aligné avec l'Input mixte, #10189 +- Menu + - Désormais, le menu réduit n'affichera la bulle d'aide que lorsque le slot `title` de l'élément MenuItem est défini, #10193 (par @PanJiaChen). +- Pagination + - Correction d'un événement `current-current-change` qui se déclenchait incorrectement sans interaction de l'utilisateur, #10247 +- DatePicker + - Maintenant, la date et l'heure dans le panneau déroulant sont correctement formatées en fonction de l'attribut `format`, #10174(by @remizovvv) +- Upload + - Correction de l'attribut `accept` qui ne fonctionnait pas quand `drag` est vrai, #10278 + +### 2.2.2 + +*2018-03-14* + +- Ajout de l'événement `clear` pour Input, #9988 (par @blackmiaool) +- Maintenant la saisie manuelle de ColorPicker supporte les modes `hsl`, `hsv` et `rgb`, #9991 +- Correction de DatePicker ne déclenchant pas l'événement `change` lorsque sa valeur initiale est effacée, #9986 +- Maintenant les attributs liés à la classe d'icônes de Rate supportent les mises à jour dynamiques, #10003 +- Correction de Table avec des colonnes fixes dont la hauteur n'est pas mise à jour correctement si `max-height` est réglé, #10034 +- Maintenant le mode plage de DatePicker supporte la sélection inverse (en cliquant sur la date de fin, puis sur la date de début), #8156 (par @earlymeme) +- Ajout de l'attribut `désactivé` pour Pagination, #10006 +- Ajout des événements `after-enter` et `after-leave` pour Popover, #10047 +- Correction de Select ne déclenchant pas la validation lorsque l'utilisateur sélectionne une option après avoir exécuté `resetFields` du formulaire, #10105 +- Correction des largeurs incorrectes des colonnes fixes de Table dans certains cas, #10130 +- Correction de MessageBox héritant de l'attribut `title` de son instance précédente lorsqu'il était appelé sans `title`, #10126 (par @Pochodaydaydayup) +- Ajout de l'attribut `input-size` pour Slider, #10154 +- Ajout des événements `left-check-change` et `right-check-change` pour Transfer, #10156 + +### 2.2.1 + +*2018-03-02* + +- Correction d'un rétrécissement de Aside, Header et Footer dans certaines mises en page, #9812 +- Correction de Table avec un attribut `height` qui ne rendait pas dans SSR, #9876 +- Correction d'une Table extensible ne calculant pas sa hauteur lorsqu'une rangée est agrandie, #9848 +- Correction d'un événement `change` qui ne se déclenchait pas lors de la saisie manuelle de la date dans DateTimePicker, #9913 +- Correction de Select affichant ses options lorsque la boîte de saisie est cliquée avec le bouton droit de la souris, #9894 (par @openks) +- Ajout de l'attribut `tooltip-class` pour Slider, #9957 +- Maintenant Select garde le focus après la sélection, #9857 (par @Seebiscuit) +- Ajout de l'attribut `target-order` pour Transfer, #9960 + +### 2.2.0 Graphite + +*2018-02-12* + +#### Nouvelles fonctionnalités +- Menu + - Ajout des attributs `popper-class` et `disabled` pour le sous-menu, #9604 #9771 + - Le menu horizontal prend maintenant en charge le sous-menu multicouche, #9741 +- Tree + - Ajout de l'évènement `node-contextmenu`, #9678 + - Vous pouvez maintenant personnaliser le modèle de nœud en utilisant un slot avec portée, #9686 + - Ajout des méthodes `getNode`, `remove`, `remove`, `append`, `insertBefore`, `insertAfter`, `getCheckedKeys`, `getHalfCheckedNodes`, `getHalfCheckedNodes`, `getHalfCheckedKeys` et de l'événement `check`, #9718 #9730 +- Transfer + - Ajout de la méthode `clearQuery`, #9753 +- Select + - Ajout de l'attribut `popper-append-to-body`, #9782 + +#### Corrections de bugs +- Table + - Correction d'un clic sur l'icône d'expansion d'une ligne extensible qui déclenche l'événement `row-click`, #9654 + - Correction de la mise en page non mise à jour lorsque la largeur des colonnes est modifiée par glisser-déposer de l'utilisateur, #9668 + - Correction d'un problème de style lorsque la ligne de résumé coexiste avec des colonnes fixes, #9667 +- Container + - Les composants fixes de Container ne s'étirent pas dans IE11, #9655 +- Loading + - Correction du chargement n'apparaissant pas lorsque la valeur de `v-loading` est changée en true dans le hook `mounted`, #9722 +- Switch + - Correction de deux événements de clics natifs déclenchés lorsque Switch est cliqué, #9760 + +### 2.1.0 Charcoal + +*2018-01-31* + +#### Nouvelles fonctionnalités +- Cascader + - Ajout des événements `focus` et `blur`, #9184 (par @viewweiwu) +- Table + - La méthode `filter-method` a maintenant un troisième paramètre `column`, #9196 (par @liyanlong) +- DatePicker + - Ajout des attributs `prefix-icon` et `clear-icon`, #9237 (par @AdamSGit) + - Ajout de l'attribut `default-time`, #9094 (par @nighca) + - Le format `value-format` supporte maintenant `timestamp`, #9319 (par @wacky6) +- InputNumber + - Maintenant la valeur liée peut être `undefined`, #9361 +- Select + - Ajouté l'attribut `auto-complete`, #9388 +- Form + - Ajout de l'attribut `désactivé`, #9529 + - Ajout de l'attribut `validateOnRuleChange`, #8141 +- Notification + - Ajout de la méthode `closeAll`, #9514 + +#### Corrections de bugs +- InputNumber + - Correstion du reset lors de la saisie du point des nombres décimaux, #9116 +- Dropdown + - Correction du mauvais positionnement du menu déroulant lorsque la page n'a qu'une barre de défilement horizontale dans certains navigateurs, #9138 (par @banzhuanmei) +- Table + - Correction d'une erreur dans le calcul du nombre de colonnes fixes après les changements de données des colonnes, #9188(by @kolesoffac) + - Correction de la bordure de la dernière colonne de l'en-tête groupé qui n'était pas correctement affichée, #9326 + - Correction d'un positionnement incorrect de l'en-tête du tableau dans Safari, #9327 + - Correction de la réduction des lignes extensibles lorsque les données de la table changent, #9462 + - Correction de rendus multiples inutiles dans certaines conditions, #9426 + - Correction d'une erreur de calcul de la largeur de colonne lors de la modification de `width` de TableColumn, #9426 +- Loading + - Correction de Loading ne se cachant pas correctement dans certaines conditions, #9313 +- DatePicker + - Correction de la méthode `focus` qui ne fonctionnait pas en mode "range", #9437 + - Correction du clic sur le bouton "now" qui sélectionnait toujours la date actuelle même si elle était désactivée, #9470 (par @wacky6) + - Correction d'une date trop serrée lors de la navigation, #9577 (par @wacky6) +- Steps + - Correction d'une erreur de style dans IE 11, #9454 + +#### Changements +- Menu + - Le menu contextuel en mode `collapse` s'ajoute maintenant directement à `body`, de sorte qu'il est visible lorsqu'il est imbriqué dans Aside, #9263 +- Table + - Maintenant, cocher les cases dans la Table multi-sélection ne déclenche pas l'événement `row-click`, #9467 +- Loading + - Le `z-index` du masque de chargement non plein écran est changé à 2000. Le `z-index` du masque de chargement plein écran se mettra à jour dynamiquement avec les composants popup, #9522 +- Dropdown + - Les attributs `show-timeout` et `hide-timeout` ne fonctionnent maintenant que lorsque le déclencheur est `hover`, #9573 + +### 2.0.11 + +*2018-01-08* + +- Correction d'un problème de couleur de bordure de Select dans les slots `prepend` ou `append` de Input, #9089 +- Correction du paramètre `remove-tag` de l'événement Select, #909090 +- Ajout des attributs `show-timeout` et `hide-timeout` pour le sous-menu, #8934 (par @HugoLew) +- Correction d'un style Tooltip manquant de `show-overflow-tooltip` lors de l'importation de Table sur demande, #9130 +- Correction d'un dysfonctionnement du tri des colonnes de la table après l'exécution de `clearSort` sur cette colonne, #9100 (par @zEmily) +- Le fichier de configuration i18n pour le tchèque est renommé de `cz` en `cs-CZ`, #9164 + +### 2.0.10 + +*2017-12-29* + +- Calcul erroné de la hauteur du tableau lorsque la colonne fixe et la ligne de somme coexistent, #9026 +- Correction d'un style de couleur non compilé du texte vide dans le tableau, #9028 +- Maintenant, DatePicker n'émet que l'événement `change` quand la valeur est vraiment changée, #9029 (par @remizovvvv) +- Ajout de l'attribut `tabindex` pour Input, #9041 (par @dicklwm) + +### 2.0.9🎄 + +*2017-12-24* + +- Ajouté la fonction de hook "avant suppression" pour Upload, #8788 (par @firesh) +- Correction de la valeur initiale de `error` qui ne fonctionnait pas pour FormItem, #8840 +- La directive Loading prend maintenant en charge le nom de classe personnalisé grâce à l'attribut `element-loading-custom-class`, #8826 (par @earlymeme) +- Correction CarouselItem devenant invisible lorsque les données sont mises à jour de manière asynchrone, #8921 +- Ajout de l'attribut `renderAfterExpand` pour Tree, #8972 + +### 2.0.8 + +*2017-12-12* + +- Ajout de la documentation en espagnol +- Correction du `show-timeout` de Dropdown qui ne fonctionnait pas quand le déclencheur est click, #8734 (par @presidenten) +- Correction du temps de validation des formulaires pour les règles dont le déclencheur est blur, #8776 +- Correction d'un événement de blur de DatePicker avec intervalle, #8784 +- L'attribut `format` de TimePicker supporte maintenant AM/PM, #8620 (par @firesh) + +### 2.0.7 + +*2017-11-29* + +- Correction du style du bouton de type texte désactivé, #8570 + +### 2.0.6 + +*2017-11-29* + +- Correction d'un bug de style des icônes de tri de la table, #8405 +- Correction du mécanisme de déclenchement de Popover lorsque son `trigger` est manuel, #8467 +- Ajout des attributs `prefix-icon` et `suffix-icon` pour Autocomplete, #8446 (par @liyanlong) +- Ajout de l'attribut `separator` pour Cascader, #8501 +- Ajout de l'attribut `clearable` pour Input, #8509 (par @lbogdan) +- Ajout de l'attribut `background` pour Pagination, #8553 + +### 2.0.5 + +*2017-11-17* + +- Correction de la régression Popover, Tree, Breadcrumb et Cascader dans 2.0.4, #8188 #8217 #8283 +- Correction d'une fuite de mémoire de la directive `clickoutside`, #8168 #8225 (par @badpunman @STLighter) +- Correction de la hauteur du Select multiple lorsque sa valeur est effacée, #8317 (par @luciy) +- Ajout de l'attribut `collapse-tags` pour plusieurs Sélectionner pour remplacer les balises par une ligne de texte, #8190 +- Correction d'une consommation CPU élevée causée par la table cachée, #8351 +- Maintenant vous pouvez utiliser la méthode `doLayout` de la Table pour mettre à jour sa disposition, #8351 + +### 2.0.4 + +*2017-11-10* + +- Accessibilité améliorée pour Cascader, Dropdown, Message, Notification, Popover, Tooltip et Tree. +- Correction du redimensionnement de Container lorsque la largeur de la fenêtre d'affichage diminue, #8042 +- Correction de la suppression incorrecte de `updateKeyChildren` dans Tree, #8100 +- Correction de la hauteur de la CheckboxButton avec bordure lorsque le bouton est imbriqué dans un formulaire, #8100 +- Correction d'une erreur d'analyse du menu pour les couleurs personnalisées, #8153 (par @zhouyixiang) + +### 2.0.3 + +*2017-11-03* + +- Correction des attributs `éditable` et `readonly` pour DatePicker avec intervalle, #7922 +- Correction d'une erreur de style des Tabs imbriqués, #7941 +- Correction d'une erreur de style de la dernière étape des Steps verticales, #7980 +- Correction de la synchronisation du déclenchement de l'événement `current-current-change` pour Pagination, #7995 +- Correction d'une infobulle non enregistrée dans Menu, #7995 + +### 2.0.2 + +*2017-10-31* + +- Un clic droit sur les boutons de InputNumber ne changera pas sa valeur, #7817 +- La méthode `validate` de Form peut maintenant attendre des validations asynchrones avant d'exécuter son callback, #7774 (par @Allenice) +- Correction de la plage de sélection de DatePicker ne fonctionnant pas dans les navigateurs Chromium 53-57, #7838 +- Correction des icônes manquantes de prévisualisation et de suppression de Upload lorsque son `list-type` est picture-card, #7857 +- Ajout de l'attribut `sort-by` pour TableColumn, #7828 (par @wangfengming) +- Correction de DatePicker affichant parfois un mauvais numéro d'année lors de la sélection de la première semaine en mode semaine, #7860 (par @hhh23485) +- Correction d'une erreur de style d'icône des Steps verticales, #7891 +- La 'hot area' pour les flèches de nœud dans Tree est étendue, #7891 + +### 2.0.1 + +*2017-10-28* + +- Correction d'une erreur de style de RadioButton et CheckboxButton, #7793 +- Correction de TimePicker qui ne répondait pas au défilement de la souris dans certaines conditions, #7811 +- Correction des styles incomplets de certains composants lors de l'importation à la demande, #7811 + +### 2.0.0 Carbon + +*2017-10-27* + +#### Nouvelles fonctionnalités +- Général + - Un nouveau thème : `theme-chalk`. + - L'accessibilité des éléments suivants est améliorée : Alert, AutoComplete, Breadcrumb, Button, Checkbox, Collapse, Input, InputNumber, Menu, Progress, Radio, Rate, Slider, Switch, Upload + - Ajout du typage TypeScript + - Toutes les icônes existantes sont redessinées. De nouvelles icônes sont ajoutées + - Ajout d'une série de classes basées sur les breakpoints qui masquent les éléments lorsque la taille de la fenêtre remplit certaines conditions + - Ajout des composants de mise en page : Container, Header, Aside, Main, Footer + - Vous pouvez maintenant configurer la taille des composants de manière globale. Lors de l'importation d'un élément, vous pouvez ajouter un objet de configuration global avec une propriété `size` pour configurer les tailles par défaut pour tous les composants. +- Button + - Ajout de l'attribut `round`. Il est utilisé pour les boutons à coins ronds #6643 +- TimeSelect + - Vous pouvez maintenant naviguer en appuyant sur les touches `Up` et `Down`, et en appuyant sur `Enter` vous sélectionnez l'heure #6023. +- TimePicker + - Vous pouvez maintenant naviguer à l'aide des touches fléchées, et en appuyant sur `Entrée` vous sélectionnez l'heure #6050. + - Ajout de `start-placeholder` et de `end-placeholder`. Ce sont des placeholders pour les deux champs en mode intervalle #7169 + - Ajout de l'attribut `farrow-control` pour faire tourner le temps avec les flèches #7438 +- Tree + - Maintenant les noeuds enfants ne font pas de rendu avant la première ouverture #6257 + - Ajout de l'attribut `check-descendants`. Il détermine si les nœuds enfants sont vérifiés lors du contrôle de leur nœud parent en mode `lazy` #6235 +- Tag + - Ajouté l'attribut `size` #7203 +- Datepicker + - Maintenant `timeFormat` peut formater le TimePicker quand le type est réglé sur `datetimerange` #6052 + - Ajout de `start-placeholder` et de `end-placeholder`. Ce sont des placeholders pour les deux champs en mode intervalle #7169 + - Ajout de l'attribut `value-format` pour personnaliser le format de la valeur liée, #7367 + - Ajout de l'attribut `unlink-panels` pour dissocier les deux panneaux de date lors de la sélection d'une plage de dates +- MessageBox + - Ajout de l'attribut `closeOnHashChange` #6043 + - Ajout de l'attribut `center` pour que le contenu puisse être centré #7029 + - Ajout de l'attribut `roundButton` pour afficher les boutons ronds #7029 + - Ajout de l'attribut `dangerouslyUseHTMLString`. Lorsqu'il est réglé sur `true`, `message` sera interprété comme une chaîne HTML\* #6043 + - Ajout de l'attribut `inputType` pour assigner le type de l'input intérieur, #7651 +- Dialog + - Ajout des attributs `width`、`fullscreen`、`append-to-body`. La boîte de dialogue peut maintenant être imbriquée + - Ajout de l'attribut `center` pour que le contenu puisse être centré #7042 + - Ajout de `focus-after-closed`、`focus-after-open` pour améliorer l'accessibilité #6511 +- ColorPicker + - Maintenant vous pouvez taper les couleurs dans le champ de saisie #6167 + - Ajout des attributs `size` et `disabled` #7026 + - Ajout de l'attribut `popper-class` #7351 +- Message + - Maintenant la couleur des icônes peut être modifiée par CSS #6207 + - Ajout de l'attribut `dangerouslyUseHTMLString`. Lorsqu'il est réglé sur `true`, `message` sera interprété comme une chaîne HTML\* #6207 + - Ajout de l'attribut `center` pour que le contenu puisse être centré #6875 +- Notification + - Ajout de l'attribut `position` pour configurer où Notification apparaît #6231 + - Ajout de l'attribut `dangerouslyUseHTMLString`. Lorsqu'il est réglé sur `true`, `message` sera interprété comme une chaîne HTML\* #6231 + - Ajout de l'attribut `showClose` pour cacher le bouton de fermeture #6402 +- Rate + - Ajout de l'attribut `show-score` pour déterminer si le score actuel est affiché #6295 +- Tabs + - Ajout de l'attribut `tab-position` #6096 +- Radio + - Ajout des attributs `border` et `size` #6690 +- Checkbox + - Ajout des attributs `border` et `size` #6690 +- Alert + - Ajout de l'attribut `center` pour que le contenu puisse être centré #6876 +- Menu + - Ajout des attributs `background-color`, `text-color` et `active-text-color` #7064 + - Ajout des méthodes `open` et `close` pour ouvrir et fermer les sous-menus par programmation, #7412 +- Form + - Ajout de l'attribut `inline-message` pour déterminer si le message de validation est affiché en ligne #7032 + - Ajout de l'attribut `status-icon` pour afficher une icône de feedback après validation #7032 + - Form et FormItem ont maintenant un attribut `size`. Les composants internes hériteront de cette taille s'ils ne sont pas spécifiés sur eux-mêmes, #7428 + - La méthode `validate` retournera maintenant une promesse si le rappel est omis, #7405 + - Ajout de la méthode `clearValidate` pour la validation des résultats pour tous les éléments de formulaire, #7623 +- Input + - Ajout des attributs `suffixe` et `préfixe` des slots nommés, `suffixIcon` et `prefixIcon` pour ajouter du contenu dans la zone de saisie #7032 +- Breadcrumb + - Ajout de l'attribut `separator-class` pour supporter les icônes comme séparateurs d'éléments #7203 +- Steps + - Ajout de l'attribut `simple` pour activer les étapes de style simple #7274 +- Pagination + - Ajout des attributs `prev-text` et `next-text` pour personnaliser les textes des pages précédente et suivante #7005 +- Loading + - Maintenant vous pouvez personnaliser l'icône et la couleur de fond avec les propriétés `spinner` et `background` #7390 +- Autocomplete + - Ajout de l'attribut `debounce`, #7413 +- Upload + - Ajout des attributs `limit` et `on-exceed` pour limiter le nombre de fichiers, #7405 +- DateTimePicker + - Ajout de l'attribut `time-arrow-control` pour activer `arrow-control` du TimePicker imbriqué, #743838 +- Layout + - Ajout d'un nouveau point d'arrêt `xl` pour les fenêtres plus larges que 1920px +- Table + - Ajout de l'attribut `span-method` pour la fusion de cellules + - Ajout de la méthode `clearSort` pour effacer le tri par programmation + - Ajout de la méthode `clearFilter` pour effacer le filtre par programmation + - Pour les lignes extensibles, lorsqu'une ligne est étendue, une classe `.expanded` sera ajoutée à sa liste de classes, afin que vous puissiez personnaliser son style + - Ajout de l'attribut `size` + - Ajout de la méthode `toggleRowExpansionRowExpansion` pour ouvrir ou réduire les lignes extensibles par programmation + - Ajout de l'attribut `cell-class-name` pour assigner un nom de classe aux cellules + - Ajout de l'attribut `cell-style` pour le style des cellules + - Ajout de l'attribut `header-row-class-name` pour assigner un nom de classe aux lignes d'en-tête + - Ajout de l'attribut `header-row-style` pour le style d'en-tête + - Ajout de l'attribut `header-cell-class-name` pour assigner un nom de classe aux cellules d'en-tête + - Ajout de l'attribut `header-cell-style` pour le style des cellules d'en-tête + - L'attribut `prop` de la tableColumn accepte maintenant les notations `object[key]` + - Ajout de l'attribut `index` pour TableColumn pour personnaliser les index de lignes +- Select + - Ajout de l'attribut `reserve-keyword` pour réserver le mot-clé de la recherche courante après avoir sélectionné une option. + +#### Corrections de bugs +- DatePicker + - Correction de `v-model` retournant le deuxième jour de la semaine sélectionnée en mode semaine #6038 + - Correction de la première entrée effacée dans le type `daterange` #6021 +- DateTimePicker + - Correction de DateTimePicker et TimePicker s'affectant l'un l'autre lors de la sélection #6090 + - Correction de l'heure et de la seconde qui peuvent être au-delà de la limite en sélectionnant l'heure #6076 +- TimePicker + - Correction de `v-model` qui ne se mettait pas à jour correctement lors du blur #6023 +- Dialog + - Correction des textes ayant des bords flous lors de l'ouverture et de la fermeture des listes déroulantes imbriquées #6088 +- Select + - Performances améliorées. Maintenant Vue dev-tool ne crashera pas quand un grand nombre de Select sont détruits #6151 +- Table + - Correction d'un bug ou la table reste masquée lorsque son élément parent apparaît depuis `display : none` + - Correction de l'extension de la largeur de la table lorsque l'élément parent a `display : flex` + - Correction d'un bug qui corrigeait le fait que les colonnes d'une table avec l'emplacement `append` disparaissaient lorsque les données étaient récupérées dynamiquement + - Correction de l'attribut `expand-row-keys` qui ne fonctionnait pas avec la valeur initiale + - Correction d'une défaillance du filtre lors de la mise à jour de `data` + - Correction d'une erreur de calcul dans la mise en page des colonnes fixes avec en-têtes groupés + - Correction d'un bug dynamique de `max-height` + - Correction de quelques erreurs de calcul de style + +#### Breaking changes +- Général + - Suppression de `theme-default`. + - Compatible avec Vue 2.5.2+ et IE 10+ + - L'événement `change` des composants de formulaire et l'événement `current-current-change` de la pagination ne se déclenchent plus que lors de l'interaction de l'utilisateur + - L'attribut `size` de Button et les composants de formulaire acceptent maintenant `medium`, `small` et `mini` + - Pour faciliter l'utilisation d'icônes tierces, les attributs `icon` du bouton et des étapes, `prefix-icon` et `suffix-icon` d'Input nécessitent maintenant un nom de classe complet +- Dialog + - Suppression de l'attribut `taille`. Maintenant la taille de Dialog peut être configurée par `width` et `fullscreen` + - Maintenant la visibilité de Dialog ne peut plus être contrôlée par `v-model` +- Rate + - Le `text-template` est renommé `score-template` +- Dropdown + - `menu-align` est renommé en `placement`. Maintenant il supporte plus de positions +- Transfert + - le `footer-format` est renommé en `format` +- Switch + - Les attributs commençant par `on-**` seront analysés pour les événements dans JSX, ce qui rend tous les attributs `on-*` de Switch incapable de fonctionner en JSX. Ainsi, les attributs `on-**` sont renommés en `active-*`, et par conséquent les attributs `off-*` sont renommés en `inactive-*`. Cette modification affecte les attributs suivants: `on-icon-class`, `off-icon-class`, `on-text`, `off-text`, `off-text`, `on-color`, `off-color`, `on-value`, `off-value` + - Les attributs `active-text` et `inactive-text` n'ont plus de valeurs par défaut +- Tag + - L'attribut `type` accepte maintenant `success`, `info`, ` warning` et `danger` +- Menu + - Suppression de l'attribut `theme`. La couleur du menu peut être configurée en utilisant `background-color`, `text-color` et `active-text-color` +- Input + - Suppression de l'attribut `icon`. L'icône du suffixe peut maintenant être configurée à l'aide de l'attribut `suffix-icon` ou du slot `suffix-icon` + - Suppression de l'attribut `on-icon-click` et de l'événement `click`. Maintenant pour ajouter le gestionnaire de clic sur les icônes, veuillez utiliser les slots nommés + - L'événement `change` se comporte maintenant comme dans l'input natif, qui ne se déclenche qu'en cas de blur ou en appuyant sur Entrée. Si vous avez besoin de répondre à l'entrée de l'utilisateur en temps réel, vous pouvez utiliser l'événement `input` +- Autocomplete + - Suppression de l'attribut `custom-item`. Le template de suggestions d'entrée peut maintenant être personnalisé en utilisant `scoped slot`. + - Suppression de l'attribut `props`. Vous pouvez maintenant utiliser l'attribut `value-key` pour désigner le nom de clé de l'objet de suggestion d'entrée pour l'affichage. +- Steps + - Suppression de l'attribut `center` + - Maintenant le Steps va remplir son conteneur parent par défaut +- DatePicker + - Le paramètre de l'événement `change` de DatePicker est maintenant la valeur liée elle-même. Son format est contrôlé par `value-format` +- Table + - Suppression de la prise en charge de la personnalisation du modèle de colonne à l'aide de `inline-template` + - `sort-method` s'aligne maintenant avec `Array.sort`. Il devrait retourner un nombre au lieu d'un booléen + - L'emplacement `append` est déplacé à l'extérieur de l'élément `tbody` pour éviter les rendus multiples + - L'événement `expand` est renommé en `expand-change` + - Les paramètres de la méthode `row-class-name` et `row-style` sont maintenant un objet + +## +* Rendre du HTML arbitraire de façon dynamique sur votre site Web peut être très dangereux car cela peut facilement mener à[des attaques XSS](https://en.wikipedia.org/wiki/Cross-site_scripting). Donc quand `dangerouslyUseHTMLString' est activé, assurez-vous que le contenu du `message' est fiable, et **ne jamais** assigner `message` au contenu fourni par l'utilisateur.. diff --git a/public/static/libs/element-ui/CHANGELOG.zh-CN.md b/public/static/libs/element-ui/CHANGELOG.zh-CN.md new file mode 100644 index 0000000..337a3e8 --- /dev/null +++ b/public/static/libs/element-ui/CHANGELOG.zh-CN.md @@ -0,0 +1,2085 @@ +## 更新日志 + +### 2.15.14 + +*2023-08-24* + +#### Bug 修复 +- Img + - 删除 referrerpolicy 属性 (#22651 by @xinguanhua) +#### 优化 +- Docs + - 更新 readme and website example links (#22642 by @lyfeyaj) + - 更新 popper 官方文档链接 (#22539 by @brizer) +- I18n + - 更新 西班牙语 翻译 (#22430 by @jcardus) + - 新增 塞尔维亚语(拉丁) 翻译 (#22567 by @N-M) + - 更新 乌兹别克语 翻译 (#22390 by @akahon) +- Statistics + - 文档更新; 代码优化 (#22384 by @webvs2) +- Table + - 增加高亮选中行属性 (#22382 by @wangdaodao) + +### 2.15.13 + +*2023-02-12* + +#### Bug 修复 +- Docs + - 修复 Statistic 文案 (#22383 by @JUST-Limbo) + - 修复 Input 文案 (#22093 by @lm312) + - 修复 en-US 文案 (#22268 #22269 #22270 by @Hazel-Lin) + - 修复 Pagination 文案 (#22288 by @xujintai123) + - 修复 Links 文案 (#22370 by @itmier) +- Statistics + - 修复 slot 显示问题 (#22375 by @webvs2) +- Chore + - 修复 web-type 文件丢失问题 (#22271 by @loosheng) +#### 优化 +- InputNumber + - windows触摸屏响应优化 (#22185 by @mrsai) +- Image + - 新增 initialIndex 属性 (#22346 by @inkroom) +- Statistics + - countdown 特性更新 (#22260 by @webvs2) + - 代码优化及doc更新 (#22276 by @webvs2) +- 其他 + - web-type代码优化 (#22281 by @whzxc) + +### 2.15.12 + +*2022-11-16* + +#### Bug 修复 +- Statistics + - 修改 千分位 问题 (#22252 by @webvs2) +- 其他 + - 修复 2.15.11版本element-theme-chalk未成功发布 问题 + +### 2.15.11 + +*2022-11-15* + +#### Bug 修复 +- Docs + - 修复 Radio 文案 (#22178 by @bchen1029) + - 修复 Progress 文案 +#### 优化 +- I18n + - 更新 马来西亚语 翻译 (#22185 by @z4q) + - 更新 挪威语 翻译 (#22145 by @Barsnes) +- Progress + - 新增 defineBackColor 和 textColor 属性 (#22089 by @lm312) +- Statistics + - 新增组件 Statistics (#22159 by @webvs2) +- Other + - 改进WebStorm IDE和其他JetBrains IDE中的代码帮助 (#22135 by @piotrtomiak) + +### 2.15.10 + +*2022-09-13* + +#### Bug 修复 + +- DatePicker + - 修复 props placement 报错信息 问题 (#21908 by @lqzhgood) +- Loading + - 修复 使用 Loading 的DOM元素 sticky失效 问题 (#22087 by @zzjjhh001) +- Docs + - 修复 Popover 文案 (#22083 by @lm312) + - 修复 Skeleton 文案 (#22092 by @lm312) + - 修复 DatePicker 文案 (#21970 by @guojiongwei) +- Tree + - 修复 懒加载默认选中 问题 (#21934 by @kiss-yu) + +#### 优化 + +- I18n + - 新增 僧伽罗语 翻译 (#21936 by @sayuri-gi) + - 更新 西班牙语 翻译 (#21924 by @jcardus) + - 新增 马来西亚语 翻译 (#22028 by @iorange0411) + - 更新 斯瓦希里语 翻译 (#21904 by @Cholowao) +- Utils + - 更新 date-util.js (#22099 by @Due07) +- DatePicker + - 新增 months 和 years 类型 (#21918 by @akiko123456) + +### 2.15.9 + +*2022-06-02* + +#### Bug 修复 + +- Table + - 表头抖动修复 (#21863 by @bofeng) + - 按需引用时 `el-checkbox not imported` 修复 (#21828 by @bobohuochai) +- FormItem + - 修复 rules 切换为 null 时校验未重置 问题 (#21892 by @bofeng) +- Cascader + - 修复 切换 options 时错误报错信息 问题 (#21759 by @louiebb) +- Docs + - 修复 Popover 文案 (#21843 by @lod61) + - 修复 Calendar 文案 (#21814 by @GoJam11) + - 修复 TimePicker 文案 (#21803 by @Alanscut) + - 修复 DatePicker 文案 (#21877 by @Nirvanaiu) +- 其他 + - 官网在线演示功能修复 (#21863 by @bofeng) + +#### 优化 + +- I18n + - 新增 斯瓦希里语 翻译 (#21895 by @quilltouch) +- Chore + - 本地开发时可从 devTools 工具跳转源代码 (#21633 by @polemices) +- DatePicker & Cascader + - 弹窗方向优化 (#21806 by @XivLaw) +- Tooltip + - 优化 `getFirstElement` 代码 (#21886 by @zhankang) +- Input + - 优化 scss 代码 (#21558 by @cheese-git) + +### 2.15.8 + +*2022-04-12* + +#### Bug 修复 + +- Drawer + - 修复 appendToBody 失效问题 (#21264 by @cs1707) +- Switch + - 修复 toggling value 问题(#19473 by @EdwinBetanc0urt) +- Docs + - 修复 input 文案 (#21723 by @justforuse) + - 修复 DatePicker 文案 (#21663 by @justforuse) + - 修复 Skeleton 文案 (#21601 by @yanwydxf) +- 其他 + - 修复 vue 版本(#21736 by @ckvv) + +#### 优化 + +- I18n + - 新增 阿塞拜疆语 翻译 (#21012 by @ricardotondello) + - 更新 斯洛文尼亚语 翻译 (#21729 by @patik123) + - 更新 斯洛伐克语 翻译 (#21711 by @sjaustirni ) + - 新增 冰岛语 的翻译 (#21709 by @aronhr) + - 新增 孟加拉 语的翻译 (#21485 by @llwwtt) + +#### 其他 + +- 因兼容性考虑,撤回2.15.7关于node-sass的更新(#21019 by @linxsbox),重新评估后会在后续合适版本上线 + +### 2.15.7 + +*2021-11-18* + +#### Bug 修复 + +- Select + - 修复 filter 模式下,点击图标不能触发下拉的 bug (#21314 by @dennyak47) + - 修复 composition 模式下 keydown 事件 (#21336 by @bchen1029) +- Badge + - 修复 is-dot class (#21308 by @adaex) +- Form + - validate 方法返回错误信息 (#21374 by @cs1707) +- Table + - 修复 resizeObserver loop limit exceeded (#21255 by @tomieric) + - 修复 toggleAllSelection (#21456 by @cs1707) + - 优化 table 性能 (#21330 by @cs1707) +- Button + - 修复 disabled 优先级 (#21375 by @cs1707) +- Descriptions + - 修复 label slot bug (#21462 by @cs1707) +- SASS + - node-sass 替换为 dart-sass (#21019 by @linxsbox) +- Docs + - 修复 skeleton 文案 (#21408 by @zhhbstudio) + +### 2.15.6 + +*2021-09-02* + +#### Bug 修复 + +- Cascader + - 修复浏览器缩放模式下抖动的 bug (#21207 by @cs1707) + - 优化性能 (#21231 by @cs1707) +- Select + - 修复多选模式下文字溢出的 bug (#21237 by @cs1707) +- Dropdown + - 增加 disabled 属性 (#21235 by @mshioda) +- Radio + - 修复浏览器返回后保留状态的 bug (#21250 by @cs1707) +- Descriptions + - 修复类型定义 (#21265 by @adaex) + - 修复与表格组件混用样式冲突的问题 (#21254 by @adaex) +- Drawer + - 修复 append-to-body (#21264 by @cs1707) +- Local + - 修复 italian 翻译错误 (#21012 by @ricardotondello) + +### 2.15.5 + +*2021-08-04* + +#### Bug 修复 + +- Select + - 修复 resetInputHeight 报错的 bug (#21201 by @cs1707) + +### 2.15.4 + +*2021-08-03* + +#### 新特性 + +- Descriptions + - 新增 Descriptions 组件 (#21129 by @cs1707) +- Result + - 新增 Result 组件 (#21171 by @cs1707) + +#### Bug 修复 + +- Utils + - 修复 isScroll (#21098 by @canvascat) +- Translation + - 更新 it.js (#21133 by @bliberi) +- RadioGroup + - 修复 RadioGroup 与 component 兼容的 bug (#20783 by @lceric) +- Message + - 修复 message[type] (#21088 by @cs1707) +- Carousel + - 修复 setActiveItem 重置计时 (#20846 by @Nekojita1) +- Cascader + - 修复 emitPath (#21185 by @cs1707) +- Select + - 修复 filterable bug (#17494 by @profore) + - 修复浏览器缩放模式下抖动的 bug (#21197 by @cs1707) +- Tree + - 修复 insertChild (#21194 by @cs1707) + +### 2.15.3 + +*2021-06-29* +#### 新特性 + +- Skeleton + - 新增 Skeleton 组件 (#21038 by @cs1707) +- Empty + - 新增 Empty 组件 (#21080 by @cs1707) + +#### Bug 修复 + +- Local + - 修复 hr 语言 week 翻译 (#21040 by @cs1707) +- Table + - 修复 lazy load data (#21041 by @cs1707) +- Docs + - 修改 form 组件 hide-required-asterisk 描述 (#21045 by @cs1707) +- Drawer: + - 修复 destroy (#20715 by @zj9495) +- Row + - 修复 align top (#20963 by @cs1707) +- Select + - 修复 value 为 Boolean 类型的bug (#21052 by @cs1707) +- Calendar + - 修复 first-day-of-week (#21057 by @cs1707) +- Utils + - 修复 fix isScroll (#21065 by @cs1707) + - 修复 (utils.dom by @fw6) +- TypeScript + - 增加 CascaderPanel 类型导出 (#21070 by @qige2016) + - 增加 spinner.d.ts (#21090 by @qige2016) + +### 2.15.2 + +*2021-05-28* + +#### Bug 修复 + +- Image + - 修复 z-index 增加 keydown 事件 添加 stopPropagation (#20859 by @cs1707) +- Input + - 修复 password cursor 展示 (#20870 by @cs1707) + - 修复 password icon 在 edge 下的展示 (#20902 by @cs1707) +- Carousel + - 修复 interval 和 scale bug (#20931 by @cs1707) +- Cascader + - 修复 delete tag bug (#20939 by @cs1707) +- Drawer + - 支持 overflow auto (#20948 by @cs1707) +- 其他 + - 修复 isFunction (#20912 by @cs1707) + +### 2.15.1 + +*2021-02-23* + +#### Bug 修复 + +- Drawer + - 修复 Drawer bug (by @cs1707) +- Image + - 修复 image object fit ratio 在 IE 下的 bug (#19583 by @charlie0228) +- Cascader + - 修复 cascader panel active path (#20730 by @cs1707) +- Calendar + - 修复 calendar 国际化 bug (#20758 by @iamkun) +- ColorPicker + - 修复 bugs (by @UxieVerity) + +#### 优化 + +- Doc + - 更新 Axure 设计资源 v2.1.0 (by @iamkun) + +### 2.15.0 + +*2021-01-15* + +#### Bug 修复 + +- Select + - 修复 placeholder 国际化 bug (#17644 by @nzh63) +- Popconfirm + - 修复 Popconfirm 国际化 bug by @iamkun +- Drawer + - 修复 focus bug (#20626 by @cs1707) +- Image + - 图片预览优化 (#20652 by @cs1707) + +#### 优化 + +- Doc + - 更新法语文档 datetime-picker.md (#20543 by @lonk) + - 更新 Progress 组件文档 (#20641 by @cs1707) + +### 2.14.1 + +*2020-11-11* + +#### Bug 修复 + +- Popover + - 兼容 Vue 2.6 新 v-slot 语法 (#20424 by @iamkun) + +#### 优化 + +- I18n + - 更新阿拉伯语翻译 (#20202 by @elkattan) + - 更新维吾尔语翻译 (#20177 by @IlhamTahir) + +### 2.14.0 + +*2020-10-29* + +#### 非兼容性更新 + +- Popconfirm + - 事件名称修改为 `confirm`, `cancel` (#20240 by @hugiron) + +#### Bug 修复 + +- Progress + - 修复参数错误的问题 (#19985 by @Caaalabash) + +#### 优化 + +- I18n + - 更新俄语翻译 (#19451 by @yangirov) + - 更新高棉语翻译 (#20077 by @Sovai) + - 更新乌克兰语翻译 (#20344 by @MammutAlex) + +### 2.13.2 + +*2020-05-18* + +#### Bug 修复 + +- Autocomplete + - 修复 'change event' 错误 (#19200 by @sxzz) +- Image + - 更新错误状态 (#19194 by @lhx6538665) + +#### 优化 + +- I18n + - 更新 ru-RU popconfirm 翻译 (#19220 by @Opppex) + - 更新 vi 翻译 (#19244 by @quangln2810) + - 更新 Catalan 和 Spanish 翻译 (#19296 by @Ismaaa) + - 更新 Indonesia 翻译 (#19320) by @therour) + - 更新 Brazilian Portuguese 翻译 (#19374 by @diegomengarda) + + +### 2.13.1 + +*2020-04-13* + +#### 新特性 +- Autocomplete + - 添加 change 事件 (#17913 by @sxzz) + +#### Bug 修复 + +- Autocomplete + - 修复类型为 textarea 时建议错误问题 (#18478 by @Roojay) +- Carousel + - 修复 console.warn 文案拼写错误 (#18264 by @IceFox) +- Image + - 修复当 preview-src-list 属性不包含 src 时图片预览大图展示为空的问题 (#18975) (#19130 by @luckyCao) + - 修复第二次图片预览时快捷键失效问题 (#18983) (#19156 by @luckyCao) + - 修复 preview-src-list 为空时点击图片会给 body 添加 overflow: scroll 的问题 (#18967 by @inooNgt) +- Transfer + - 修复和 Form 组件一起使用时错误的行高问题 (#18917 by @Hanx) +- InputNumber + - 正确计算 inputNumberDisabled (#18439 by @ashuser-pendo) +- Chore + - 更新首页文案 (#19155 by @iamkun) +- Doc + - 更新 Popconfirm 文档 (#18324 by @iamkun) + - 修复 step-strictly 文档拼写问题 (#18705 by @dream2023) + - 修复 Steps 组件文档问题 (#17555 by @haoranyu) + +### 2.13.0 + +*2019-11-26* + +#### 新特性 + +- Popconfirm + - 新增 Popconfirm 组件 (#17548 by @iamkun) + +#### Bug fixes + +- BackTop + - 平滑过渡动画 (by @lon) +- DatePicker + - 修复选择最小日期的 bug (#17191 by @smk0621) +- Select + - 修复测试用例 (by @msidolphin) +- Tree + - 增加 font-size 样式 (#17094 by @spengjie) +- Table + - 头部可自定义 (#17291 by @ziyoung) + - 更新头部样式 (#17284 by @ziyoung) + - 修复时候 filter 之后高度问题 (#17348 by @ziyoung) + - 修复 row-style 失效的 bug (#17002 by @a631807682) + - 修复头部消失的 bug (#17341 by @ziyoung) +- Calendar + - 导入 el-button 和 el-button-group (#17376 by @masongzhi) +- MessageBox + - 修复图表位置 (#17410 by @nullptru) +- TimePicker + - 滚动后设置正确的位置 (#16868 by @mattheyan) +- Message + - 修复关闭的 offsetHeight(#17564) (#17852 by @gzwgq222) +- Form + - ValidateField 的回调应为可选项 (#17314 by @CarterLi) +- Cascader + - 修复 TypeScript 3.7 的兼容问题 (#17881 by @CarterLi) +- Menu + - 修复 NavigationDuplicated 在 vue-router@^3.1.0 的报错 (#17269 by @iamkun) +- Dropdown + - 更新类型文件 (#17550 by @iamkun) +- Progress + - 增加 strokeLinecap 属性 (#17552 by @iamkun) +- InfiniteScroll + - 跳过不可见元素触发 (#17553 by @iamkun) +- Image + - 优化用户体验 (#16985 by @luckyCao) + - 优化大图片展示问题 (#16796 by @luckyCao) +- Drawer + - 修复 drawer-append-to-body 失效的 bug (#16953 by @JeremyWuuuuu) +- Select + - 修复空 tag 的 bug (17199 by @luckyCao) +- Scrollbar + - 修复 FireFox 双滚动条的 bug (#18091 by @iamkun) + +#### Optimization + +- I18n + - 更新 sv-SE.js (#17926 by @FOLLGAD) + - 更新 avatar 组件法语文档 (#17762 by @blombard) +- Docs + - 修复 time-select 文档错误 (#17250 by @wacky6) + - 修复 Drawer 文档错误 (#17122 by @haoranyu) + - 更新 Spanish changelog 2.12.0 (#17364 by @Gonzalo2310) + - 修复 Changelog 文档错误 (#17874 by @renlixin) + - 修复 Loading 示例 (#17862 by @MBearo) + - 增加 input event 相关文档 (#18061 by @zhouxinyong) + - 移除 Input repeat change event 相关文档 (#18085 by @zhouxinyong) + +### 2.12.0 + +*2019-08-29* + +#### 新特性 + +- Popover + - 添加 close-delay 属性 (#16671 by @LachlanStuart) +- Theme + - 增加 Chrome 插件: Element Theme Extension (#16686 by @iamkun) +- Icon + - 支持 font-display 属性的配置 (#16805 by @iamfaizalandyka) + +#### Bug fixes + +- Table + - 在表头拖拽后阻止 click 事件的触发 (#16850 by @ziyoung) + - 修复表头 display 为 none 造成浏览器崩溃的问题 (#16956 by @luckyCao) + - 修复没有数据的时表格高度问题 (#16861 by @ziyoung) + - 调用 toggleExpansion 不再抛出异常 (#16304 by @yyjjqq94) + - 挂载时不再触发 sort-change 事件 (#17113 by @a631807682) + - 修复 setCurrentRow 方法不生效的问题 (#16879 by @ziyoung) + - 修复当数据异步加载时,expand-row-keys 不生效的问题 (#16899 by @ziyoung) + - 把 toggleAllSelection 设置为 Table 示例的属性 (#17137 by @ziyoung) +- Tree + - 修复文字与复选框之间的距离 (#16799 by @Hazlank) +- Tabs + - 修复 TabItem 位置不正确的问题 (#16520 by @victorting) + - 修复高亮的 Tab 不在可视区的问题 (#17033 by @nullptru) +- Calendar + - 修复日期的显示问题 (#16772 by @ubitoffee) + - 修复在夏令时的显示问题 (#17208 by @iamkun) +- Cascader + - 修复 CascaderPanel 的显示问题 (#16716 by @zhangHongEn) + - 禁用状态下,关闭按钮不显示 (#16224 by @yyjjqq94) +- Input + - 修复韩语输入问题 (#15069 by @MoonHyuk) + - 触发清除按钮的点击事件 (#16576 by @a631807682) +- Select + - 过滤时,不收起下拉框 (#17205 by @luckyCao) +- Transfer + - 修复样式问题 (#17206 by @iamkun) +- Dialog + - 添加 SCSS 变量 (#16365 by @haoranyu) +- RadioGroup + - is 指定时,不产生非法的 HTML 片段 (#17070 by @nullptru) +- Divider + - 支持自定义类 (#17078 by @island205) +- Carousel + - 修复 change 的触发时机 (#16705 by @iamkun) +- Notification + - 不修改传入的 option (#16704 by @iamkun) +- DatePicker + - 给 picker-option 添加 className 属性 (#16632 by @iamkun) +- DateTimePicker + - 修复时间选择滚动条的问题 (#16854 by @jesse-li) + +#### Optimization + +- Checkbox + - 提高可访问性 (#16575 by @tylertrotter) +- Docs + - 更新 changelog (#16773 by @SimonaliaChen) + - 更新贡献指南 (#14800 by @sinchang) + - 修复 Drawer 文档中的拼写错误 (#16848 by @winkay) + - 更新自定义主题 (#16983 by @iamkun) + - 新增 Esperanto 翻译 (#16955 by @maxkoryukov) + - 更新 input-number 文档 (#16316 by @luckyCao) + - 更新 Spanish 文档 (#16961 #16548 by @Gonzalo2310) +- I18n + - 更新加泰罗尼亚语翻译 (#14722 by @oscaralbareda) + - 更新阿拉伯语翻译 (#16653 by @l3op) +- Test + - 修复拼写错误 (#16672 by @boomler) + - 优化 image 的单元测试 (#16847 by @a631807682) +- Types + - 修复 httprequest 的类型 (#16633 by @luckyCao) + +### 2.11.1 + +*2019-07-26* + +#### Bug 修复 + +- Image + - 修复 Image 组件 SSR 兼容性 (#16737 by @luckyCao) +- Chore + - 更新 dart-sass 的兼容性 (#16744 by @LewisChennnnn) + +### 2.11.0 + +*2019-07-25* + +#### 新特性 + +- Drawer + - 新增抽屉组件 (#16577 by @JeremyWuuuuu) + +#### Bug 修复 + +- Checkbox + - 修复 CSS 样式问题 (#16006 by @Hazlank) +- Tree + - 更新类型定义为泛类型 (#15934 by @JeremyWuuuuu) + - 修复设置节点 isCurrent 的为 false 的问题 (#15870 by @kkkisme) +- Dropdown + - 更新 split-button 默认颜色 (#15931 by @JuniorTour) +- Cascader + - 修复一级菜单更新问题 (#16399 by @luckyCao) + - 懒加载时设默认值 (#16420 by @luckyCao) + - 修复当节点值重复时的显示问题 (#15935 by @junyiz) + - 对外暴露 getCheckedNodes 和修复 options 改变会影响选中的问题 (#16709 by @SimonaliaChen) +- Calendar + - 更新显示正确的 header 的逻辑 (#16354 by @ziyoung) +- Submenu + - 修复 append-to-body 问题 (#16289 by @a631807682) +- Table + - 修复 tree table 数据更新问题 (#16481 by @island205) +- Select + - 修复内存泄漏问题 (#16463 by @island205) +- InfiniteScroll + - 更新命名和说明 (#16698 by @iamkun) +- Avatar + - 修复图片不居中的问题 (#16489 by @luckyCao) +- Dialog + - 增加 destroyOnClose 属性 (#16455 by @ziyoung) +- Image + - 增加大图预览 (#16333 by @luckyCao) + +#### 优化 + +- Docs + - 修复 dropdown 示例 (#16193 by @webxmsj) + - 修正笔误 (#15971 by @howiefh) +- I18n + - 更新泰文翻译 (#16689 by @ponkrit) +- Chore + - 更新基础 API 地址 (#16607 by @iamkun) + - 增加 Form 的主题 token (#16699 by @iamkun) + - 更新统计 (#16609 by @iamkun) + - 修复文档锚点问题 (#16692 by @iamkun) + +### 2.10.1 + +*2019-07-02* + +#### Bug 修复 + +- Table + - 排序 icon 问题修复 (#15439 by @bezany) + - 修复 `append` slot 存在时布局错位问题 (#16332 by @ziyoung) + - 修复 `showOverflowTooltip` 更新无效的问题 (#16295 by @a631807682) + - 修复 `FilterPanel` 中 `Scrollbar` 未注册问题 (#16246 by @ziyoung) +- Chore + - 更新版本号,修复文档问题 (#16233 by @ziyoung) + - 修复英文首页样式问题 (#16254 by @iamkun) + +#### 优化 + +- Tag + - 兼容 IE (#16334 by @ziyoung) +- Chore + - 更新钉钉3群二维码 (#16236 by @iamkun) +- Doc + - 更新主题编辑器文档 (#16244 by @iamkun) + +### 2.10.0 + +*2019-06-25* + +#### 新特性 + +- I18n + - 支持乌兹别克语 (#15796 by @ogabek96) +- Calendar + - 支持 `first-day-of-week` 配置 (#16047 by @ziyoung) +- Avatar + - 新增 `Avatar` 组件 (#16144 by @luckyCao) +- Upload: + - 支持自定义缩略图模版 (#13192 by @victorzhuk) + + +#### Bug 修复 + +- Tree + - 当 `currentKey` 为 `null` 时取消对树节点的高亮 (#15668 by @yyjjqq94) + - 修复多实例共享数据的问题 #15538 (#15615 by @VanMess) +- Upload + - 更新 `fileList` 的类型定义 (#15716 by @underfin) +- Table + - 修复加载 icon 不显示的问题 (#15868 by @ziyoung) + - 修复复杂表格中 hover 行背景色问题 (#15504 by @cnlon) + - 修复 `current-row-key` 和选择事件的问题 (#15983 by @ziyoung) + - `height` 属性接受更多单位 (#16013 by @ziyoung) + - 修复 `reserve-selection` 无效的问题 (#16135 by @ziyoung) +- Menu + - 修复 `popper-append-to-body` 设置后,子菜单无法收起的问题 (#15391 by @PanJiaChen) +- Select + - 修复 `initialInputHeight` 问题 (#15989 by @yyjjqq94) + - 修复输入中文时 `default-first-option` 的行为问题 (#15431 by @VanMess) + - `import` 重复 (#16215 by @lengband) +- Message + - 类型定义中添加 `offset` 属性 (#16027 by @matjaz) +- Timeline + - 修复逆序问题 (#16091 by @ziyoung) +- Slider + - 补充 `input` 事件文档 (#15588 by @VanMess) +- InfiniteScroll + - 更新包名 (#16125 by @iamkun) +- MessageBox + - 修复 `distinguishCancelAndClose` 行为与文档不符的问题 (#15438 by @qingdengyue) +- PopupManager + - 修复无法复写 `z-index` 的问题 (#15738 by @luckyCao) +- Docs + - 删除不必要的内容 (#16194 by @Alexeykhr) + - 更正 `Divider` 属性类型 (#15889 by @haoranyu) +- Chore + - 更新测试 API 地址 (#15807 by @iamkun) + +#### 优化 + +- Tree + -优化循环性能 (#15699 by @KingJeason) +- Theme + - 更新 GA 打点,修改页底地址链接到主题编辑器 (#16007 by @island205) +- Badge + - 更新类型定义 (#16198 by @iamkun) +- Avatar + - 更新主题变量配置 (#16202 by @luckyCao) +- I18n + - 更新葡萄牙语 (#15776 by @gigioSouza) + - 更新波斯语 (#15881 by @pamenary) +- Docs + - 补充入门文档中的组件列表 (#16063 by @pape2016) + - 更新法语文档 (#16208 by @blombard) + - 为 `Alert` 添加 默认插槽文档 (#15444 by @Alexeykhr) + - 更新西班牙语文档 (#15840 by @Gonzalo2310) + - 更新法语文档中的拼写错误 (#15837 by @blombard) + - 更新 2.9.2 西班牙文档 (#16185 by @Gonzalo2310) + +#### 非兼容性更新 + +- Form + - 移除输入框的成功状态 (#16159 by @ziyoung) + +### 2.9.2 + +*2019-06-21* + +#### Bug 修复 + +- Chore + - 修复 TS 定义文件 (#15805 by @NateScarlet) + +### 2.9.1 + +*2019-05-30* + +#### 新特性 + +- Table + - Tree Table 支持 tree-props,default-expand-all,expand-row-keys 属性, toggle-row-expansion 方法,expand-change 事件 (#15709 by @ziyoung) + +#### Bug 修复 + +- Table + - 修复了一些问题 (#15709 by @ziyoung) +- Theme + - 更新接口域名 (#15784 by @iamkun) + +#### 优化 + +- Chore + - 更新 InfiniteScroll 组件定义文件 (#15794 by @iamkun) + +### 2.9.0 + +*2019-05-30* + +#### 新特性 + +- Backtop + - 新增 Backtop 组件 (#15541 by @iamkun) +- PageHeader + - 新增 PageHeader 组件 (#15714 by @ziyoung) +- InfiniteScroll + - 新增 InfiniteScroll 指令 (#15567 by @iamkun) +- Cascader + - 新增多选模式和 filter-method 方法 (#15611 by @SimonaliaChen) +- Message + - 信息依次展示 (#15639 by @island205) +- Tag + - 新增 effect 属性 (#15725 by @SimonaliaChen) +- Tabs + - 卡片模式下标题左对齐 (#15695 by @luckyCao) +- DatePicker + - 支持字符串常量 (#15525 by island205) +- Image + - 支持 attrs 和 listeners (#15578 by @VanMess) +- Theme + - 新增 popup 背景配置 (#15412 by @iamkun) +- Chore + - 更新文档首页 (#15682 by @iamkun) + +#### Bug 修复 + +- Table + - 修复排序条件为空时的排序问题 (#15012 by @joelxr) +- Image + - 修复 ssr 问题和 object-fit 的兼容性 (#15346 by @SimonaliaChen) +- Input + - 修复 show-word-count 样式问题 (#15359 by @lvjiaxuan) + - 修复删除图标样式 (#15354 by @YiiGuxing) +- Calendar + - 修复星期展示错误 (#15399 by @qingdengyue) + - 修复十月展示问题 (#15394 by @qingdengyue) +- Tabs + - 修复 padding 问题 (#15461 by @SimonaliaChen) +- Tag + - 修复阻止冒泡问题 (#15150 by @infjer) +- Form + - 修复 form-item 的高度错误 (#15457 by @SimonaliaChen) + - 修复 resetFields 问题 (15181 by @luckyCao) +- Tooltip + - 修复自定义 tabindex 不生效问题 (#15619 by @SimonaliaChen) +- Link + - 修复图标 class 问题 (#15752 by @iamkun) +- Select + - 回滚清除时,设置 value 为 null 的修改 (#15447 by @iamkun) +- Loading + - 修复 Dom 不更新的问题 (#15123 by @FAKER-A) +- Switch + - 修复事件重复触发问题 (#15178 by @FAKER-A) +- Slider + - 修复点击时样式问题 (#15561 by @luckyCao) +- Radio + - 修复 value 不更新的问题 (#14809 by @OverTree) +- Form + - 修复 resetFields 问题 (15181 by @luckyCao) +- Chore + - 更新依赖 (#15324 by ziyoung) +- Type + - 修复 Loading 定义文件 (#15635 by @iamkun) + - 修复 Icon 定义文件 (#15634 by @iamkun) + - 修复 Link 定义文件 (#15402 by @iamkun) + +#### 优化 + +- Cascader + - 重构 (#15611 by @SimonaliaChen) +- Chore + - 更新新建组件的脚本 (by @iamkun) +- Docs + - 重新命名文档变量 (#15185 by @liupl) + - 更新 Image 组件文档 (#15423 by @haoranyu) + - 修复 Form 组件文档错误 (#15228 by @SHERlocked93) + +### 2.8.2 + +*2019-04-25* + +#### Bug 修复 + +- Icon + - 更新 icon (#15272 by @iamkun) +- 文档 + - 修复 Form 与 Input 文档样式 (#15273 by @ziyoung) + +### 2.8.1 + +*2019-04-25* + +#### Bug 修复 + +- Icon + - 更新 Select 与 Cascader 的 icon (#15264 by @SimonaliaChen) + - 更新 icon (#15258 by @iamkun) + +#### 优化 + +- Chore + - 更新构建脚本 (#15267 by @ziyoung) +- Docs + - 修复 link 的样式 (#15265 by @iamkun) +- 其他 + - migrating 配置兼容驼峰名称 (#15260 by @SimonaliaChen) + +### 2.8.0 + +*2019-04-25* + +#### 新特性 + +- Divider + - 新增 Divider 组件 (#15055 by @island205) +- Rate + - 支持通过对象自定义 colors 与 icon-classes 属性 (#15051 by @SimonaliaChen) +- Link + - 新增 Link 组件 (#15052 by @iamkun) +- Calendar + - 新增 Calendar 组件 (#14908 by @ziyoung) +- Icon + - 新增图标 (#15214 by @iamkun) +- Alert + - 新增高饱和度主题 (#15041 by @island205) +- Image + - 新增 Image 组件 (#15117 by @SimonaliaChen) +- Collapse + - CollapseItem 支持禁用 (#15076 by @ziyoung) +- Carousel + - 新增 direction 属性,支持垂直方向切换 (#15122 by @ziyoung) +- Pagination + - 新增 hide-on-single-page 属性 (#15096 by @ziyoung) +- Slider + - 新增 marks 属性 (#15133 by @luckyCao) +- Input + - 新增 show-word-count 属性 (#15075 by @luckyCao) +- InputNumber + - 新增 step-strictly 属性 (#15050 by @luckyCao) +- Tooltip, Dropdown, Popover + - 新增 tabindex 属性 (#15167 by @ziyoung) + +#### Bug 修复 + +- Notification + - 修复标题不换行的问题 (#15008 by @iamkun) +- Form + - 修复动态表单校验规则不生效的问题 (#14985 by @luckyCao) + - 修复 label 的样式 (#14969 by @ziyoung) + - 当 required 为 true 时,显示星号 (#15144 by @ziyoung) +- Pagination + - 修复 slot 未更新的问题 (#14711 by @lucyhao) +- Table + - 修复懒加载时加载数据的 bug (#15101 by @ziyoung) + - 在合并单元格时,修复单元格的宽度计算不正确的问题 (#15196 by @ziyoung) + - 提升表格的性能 (#14868 by @ziyoung) + - 初始化时不再触发 sort-change 事件 (#14625 by @PeanutWatson) + - 让 height 与 max-height 属性的行为保持一致 (#14660 by @arthurdenner) +- Dialog + - 修复内容不换行的问题 (#15027 by @iamkun) +- Alert + - 更新 typescript 定义文件 (#15186 by @ziyoung) +- Tabs + - Fix issue where Promise rejection was hitting application (#14816 by @ffxsam) + - slot 改变时,重新渲染 (#15238 by @ziyoung) +- Message + - 修复 typescript 定义文件 (#14968 by @agoni1212) +- Select + - 修复当 value 为 undefined 或者 null 的报错 (#15022 by @luckyCao) +- Tree + - 当前节点被删除后,选中的节点也应该删除 (#14604 by @sinchang) + - 提升性能 (#14881 by @ChenZhuoSteve) +- Dropdown + - 修复样式 (#14907 by @doing123) +- Slider + - 修复可访问性问题 (#14792 by @erezsob) +- Menu + - 如果 defaultIndex 不存在,activeIndex 应该为空 (#14074 by @hoythan) +- Directive + - RepeatClick: 使用 Date.now 提升性能 (#14776 by @pavelmash) +- Upload + - 修复 Upload 的背景颜色 (#15039 by @iamkun) +- Theme + - 添加无圆角变量 (#15256 by @iamkun) + +#### 优化 + +- Chore + - 更新中文 changelog (#14965 by @iamkun) + - 当 demo 描述为空时,不再显示 (#15014 by @ziyoung) + - 显示 DevServer 的信息 (#15028 by @iamkun) + - 修复 2.6 changelog 的 bug (#15026 by @iamkun) + - 更新构建脚本 (#14821 by @abc3660170) + - 本次开发时支持热更新 (#15221 by @SimonaliaChen) + - 本地开发时,加载 sourcemap (#15087 by @ibufu) +Docs + - 重命名 demo 中的变量 (#14602 #15003 #15094 #15105 by @liupl) + - 修复 upload 文档中的错误 (#15023 by @iamkun) + - 更新 Form 文档 (#15040 by @iamkun) + - 更新 Tabs 文档 (#15053 by @iamkun) + - 使用 eleme.cn 作为新域名 (#15139 by @ziyoung) + - 修复 Image 组件的路由名 (#15194 by @iamkun) + - 删除多余的法语翻译 (#15207 by @iamkun) + +#### 非兼容性更新 + +- Rate + - 禁用情况下,显示小位数 (#15089 by @haoranyu) +- Select + - 过滤情况下,placeholder 为选中选项的 label (#14989 by @ibufu) + +### 2.7.2 + +*2019-04-03* + +#### 修复 + +- Form + - 修复 `label-width` 为 `auto` 的样式 (#14955 by @ziyoung) + +#### 优化 +- Docs + - 修复文档内图片链接错误 (#14957 by @iamkun) +- Chore + - 修复发布时 mkdir 异常 (#14952 by @iamkun) + +### 2.7.1 + +*2019-04-03* + +#### 修复 + +- Select + - 清空时设置 value 为 null (#14322 by @aaronfulkerson) +- Input + - 当类型改变时更新 DOM (#14889 by @wacky6) +- Table + - 修复当有展开列时 `defaultExpandAll` 的行为 (#14935 by @ziyoung) +- Dialog + - 可以设置背景色 (#14939 by @ziyoung) +- Form + - `label-width` 支持自动宽度 (#14944 by @ziyoung) + +#### 优化 +- Docs + - 更新西班牙语文档 (#14913 by @Gonzalo2310) + - 新增组件自动生成法语文档 (#14924 by @ziyoung) + - 更新 Tabs 文档 (#14938 by @ziyoung) + +### 2.7.0 + +*2019-03-28* + +#### 新特性 + +- Table + - 增加对树形结构数据的支持 (#14632 by @ziyoung) + +#### 修复 + +- Tabs + - 阴影样式使用全局主颜色 (#14558 by @Richard-Choooou) + - 当 label 改变时触发更新 (#14496 by @akki-jat) +- Table + - Table footer 与 body 的对齐一致 (#14730 by @ziyoung) +- NavMenu + - 修复点击 el-submenu 多次触发 childMenu 问题 (#14443 by @PanJiaChen) +- Dropdown + - 兼容 Vue 2.6 新 v-slot 语法 (#14832 by @ziyoung) +- ColorPicker + - 修复十六进制颜色字符串解析问题 (#14793 by @iamkun) +- Tree + - 恢复 pr #13349 (#14847 by @ziyoung) +- Tooltip + - 当初始值为 true 时默认显示 (#14826 by @ziyoung) +- Docs + - 更新 Cascader 文档 (#14442 by @panhezeng) +- Style + - 修复媒体查询 sm-only, md-only, lg-only 问题 (#14611 by @sinchang) + +#### 优化 + +- Chore + - 增加网页描述信息 (#14802 by @iamkun) + +### 2.6.3 + +*2019-03-21* + +#### 修复 + +- 修复 Cascader 文档页的样式 (#14789 by @ziyoung) +- 移除 Cascader 中多余的 DOM 操作 (#14788 by @ziyoung) +- DateRange 支持夏令时 (#14562 by @wacky6) + +### 2.6.2 + +*2019-03-21* + +#### 新特性 + +- DatePicker + - 支持 monthrange 类型 (#14487 by @zxyRealm) +- i18n + - 添加 Croatian 语言包 (#14360 by @danijelh) +- Docs + - 更新 2.6.1 法语文档,修复笔误 (#14555 by @smalesys) + - 更新法语翻译 (#14643 by @smalesys) + +#### 修复 + +- Input + - Fix regression (#14572 by @wacky6) +- DatePicker + - 修复 first-day-of-week 的计算 (#14523 by @sinchang) + - 修复 WeekPicker value-format 的问题 (#13754 by @wacky6) +- Steps + - 修复 #14502 (#14596 by @sinchang) + - 修复简单模式下的样式 (#14610 by @sinchang) +- Docs + - 重命名 Table 文档中的变量 (#14587 by @likwotsing) + - 添加法语文档索引 (#14565 by @iamkun) + - 修复 TimePicker 文档页的样式 (#14579 by @ziyoung) + - 重命名 Upload 文档中的变量 (#14593 by @liupl) + - 在 Form 文档中 添加的 async-validator 文档 (#14694 by @iamkun) + - 修复 Tooltip 文档的 bug (#14748 by @iamkun) + - 修复笔误 (#14751 by @2bj) + - 修复 Switch 在移动端 Webkit 浏览器的高亮问题 (#14703 by @VladG0r) + +#### 优化 + +- Chore: + - 更新 ci 构建脚本 (#14600 by @ziyoung) + - 更新谷歌统计 (#14560 by @iamkun) + - 添加更多谷歌统计事件 (#14633 by @iamkun) + - 更新聊天组信息 (#14741 by @iamkun) + - 升级测试依赖 (#14735 by @wacky6) + - 升级 gulp (#14745 by @ziyoung) + - 使用 codepen 显示 demo,修复文档中的错误 (#14747 by @ziyoung) + +### 2.6.1 + +*2019-03-03* + +#### 修复 + +- **不再指定 node 版本** (by @iamkun in #14546) +- 调整 `deloy-faas.sh` 中的文档目录 (by @ziyoung in #14553) +- 调整 2.6.0 中 changelog 日期样式 (by @island205 in #14547) +- 修复拼写错误 (by @wack6 in #14552) + +### 2.6.0 + +*2019-03-01* + +#### 新特性 +- Timeline + - 添加 Timeline 组件 (by @jikkai in #14248) +- DropdownItem + - `el-dropdown-item` 支持添加 icon (by @gabrielboliveira in #14088) +- Input + - 添加 `show-password` 属性,支持配置显示密码按钮 (by @phshy0607 in #13966) +- Select + - 添加 slot `empty` (by @elfman in #13785) +- Autocomplete + - 添加 `highlight-first-item` 属性,控制是否默认突出显示远程搜索建议中的第一项 (by @YamenSharaf in #14269) +- I18n + - 添加亚美尼亚语支持 (by @hamletbarsamyan in #14214) +- Docs + - 新增法语文档 (by @smalesys in #12153, #14418, #14434) + +#### 优化 +- Alert + - 组件对通过 slot 传入的 description 也应用默认样式类 (by @iamkun in #14488) +- InputNumber + -移除多余的 `parseFloat` (by @JuniorTour in #14172) +- Menu + - 支持 `el-menu-item` 不添加 index (by @georgyfarniev in #13298) +- Table + - 移除无用的 DOM 操作 (by @elfman in #13643) +- Upload + - 代码优化 (by @elfman in #13973) +- Popup + - 移除无用代码 (by @KAionro in #14413) +- Docs + - 添加更多文档说明如何贡献代码 (by @island205 in #14355) + - 添加 `el-input` 是受控组件的警示 (by @wacky6 in #14463) + - 优化 Table 的文档 (by @luguokong in #14329) + - 更新 Input 文档 (by @iamkun in #14437) + - 优化自定义主题文档 (by @wangguohao in #14297) + - 为 Icon 文档添加 hover 效果 (by @tuxinghuan in #14295) +- Build + - 压缩 Element 文档站的 JS 和 CSS 文件 (by @iamkun in #14430) + - 优化 Webpack 打包速度,从6分钟优化到1分多 (by @hetech in #14484) + - 添加 CLI 工具,选择版本号 (by @hetech in #14354) +- 使用 Stale 来管理过时(暂定1年)的 Issue 和 PR (by @island205 in #14392) + +#### 问题修复 +- Menu + - 修复浏览器标签切换引起的 focus 问题 (by @liupl in #13976) +- MessageBox + - 修复 TS 定义 (by @NateScarlet in #14278) +- ScrollBar + - 修复点击鼠标右键导致拖动的问题 (by @xifeiwu in #14196) +- Switch + - 添加 `validate-event` 属性,设置改变 Switch 状态时是否触发表单的校验 (by @hetech in #14426) +- Table + - 修复多 Table 实例共享 `toggleAllSelection` 方法,造成无法切换问题 (by @letanure in #14075) +- Tabs & Dropdown + - 修复样式问题 (by @hetech in #14452) +- Tree + - 与 Table 统一占位文样式 (by @ColinCll in #14331) +- Docs + - 修复 DatetimePicker 文档问题 (by @iamkun in #14290) + - 修复 DatePicker 文档拼写问题 (by @helmut in #14481) + - 修复分页组件文档样式问题 (by @liuchuzhang in #14451) + +#### 非兼容性更新 +- Table + - 修复 row 事件的参数顺序 (by @jikkai in #12086) + +### 2.5.4 + +*2019-02-01* + +#### 修复 + +- 构建: 修复 `.babelrc` 配置问题——导致 Tree 等组件没有动画 (by @island205 in #14282) + +### 2.5.3 + +*2019-01-31* + +#### 优化 + +- 优化 Message 的代码 (by @vok123 in #14029) +- 移除 gh-pages (by @ziyoung in #14266) +- 添加 IssueHunt 的链接 (by @island205 in #14261) + +#### 修复 + +- 修复 UMD 包在服务器端运行出错的问题 (by @island205 in #14242) +- 修复 Tabbar 高亮时的样式 (by @iamkun in #14240) +- 修复 Table 示例代码的错误 (by @xunmeng in #14253) + +### 2.5.2 + +*2019-01-27* + +#### 优化 +- 文档: + - 2.5.1 版本西班牙语文档更新 (by @Gonzalo2310 in #14231) + +#### 修复 +- 构建: + - 删除 umd 模块 `lib/index.js` 中本没有的注释 (by @island205 in #14233) + - 修复 nuxt.js 中关于 `export` 关键字的报错 (by @island205 in #14232) + - 修复发布 2.5.1 过程中的错误 (by @iamkun in #14228) + +### 2.5.1 + +*2019-01-26* + +#### 优化 +- DatePicker:添加月、年高亮的样式(by @Debiancc in #14211) +- 更新 2.5.0 changelog (by @wacky6 in #14217) + + +#### 修复 +- 修复升级 Webpack 4 产生的问题,无法具名 `import` 组件,`ELEMENT.locale()` 调用报错。(by @island205 in #14220) +- 恢复 2.4.11 文档 (by @iamkun in #14222) + + +### 2.5.0 + +*2019-01-25* + +#### 新特性 +- DatePicker + - 新增 `validate-event` 属性 (by @ziyoung in #13531) +- DateTimePicker + - `pickerOptions` 支持 `selectableRange` 选项 (by @eeeeeeeason) +- Tag + - 新增 `click` 事件 (by @licdream in #14106) +- I18n + - 新增 柯尔克孜语 (Kyrgyz) (by @zzjframework in #14174) + +#### 优化 +- 升级到 webpack@4 (by @jikkai in #14173) +- Input + - 简化内部实现,遵循单向数据流;修复若干相关 Bug (by @wacky6 in #13471) +- 更新 Axure 文件,增加新组件 (by @ziyoung in #13773) + +#### 修复 +- Autocomplete + - 修正下拉框最后一行显示不完整的问题 (by @ziyoung in #13597) + - 修正下拉框箭头 (by @liuchuzhang in #13762) +- Carousel + - 组件销毁时释放内部 Timer (by @elfman in #13820) +- Cascader + - 移除已废弃的计算属性的 cache 属性 (by @iamkun in #13737) + - 修正 TypeScript 中 CascaderOption 类型定义 (by @NateScarlet in #13613) + - 修正图标覆盖文字的问题 (by @ziyoung in #13596) +- Checkbox + - 改进显示样式 (by @PanJiaChen) +- DatePicker + - 修正 TimeSpinner 中缺失的 v-for `key` 属性 (by @Ende93 in #13547) + - 修正周选择器在跨年时的高亮行为 (by @suyi91 in #13883) +- Input + - 修复 textarea 时的 DOM 节点引用 (by @laomu1988 @island205 in #13803) +- Pagination + - 输入框的值不会小于 1 (by @elfman in #13727) +- Popover + - 修正 hover 的触发行为 (by @goldengecko in #13104) + - 修正弹出框的内存泄漏 (by @qpxtWhite in #13988) +- Radio + - 改进显示样式 (by @ohhoney1) +- Table + - 改进点击排序箭头时的行为 (by @ohhoney1 in #12890) + - 修正 IE10+ 中 “暂无数据” 提示的垂直布局 (by @imzjy in #13638) + - 修正文档中 `index` 的类型说明 (by @ilovefafa in #13628) + - 修正多级表头使用 `fixed` 属性时,表尾合计行的显示样式 (by @luckyCao in #13914) +- Tabs + - 修正自动滚动 (by @iamkun in #13696) + - 通过面板名称查找面板 (by @iamkun in #13705) + - 使用 `paneName` 计算面板样式 (by @iamkun in #13733) +- Tree + - 修正 `showCheckbox` 不能影响子节点的问题 (by @KidneyFlower) + - 更新文档和 TypeScript 定义 (by @ziyoung in #13540) +- Upload + - `list-type` 改变时,保留 `url` 属性 (by @elfman in #13771) +- Slider + - 修正源代码缩进 (by @wacky6 in #13955) +- I18n + - 补充加泰罗尼亚语 (Catalan) 翻译 (by @jaumesala) + - 补充俄语 (Russian) 翻译 (by @justlp in #13658) + - 补充芬兰语 (Finnish) 翻译 (by @jenkrisu in #14137) +- Doc + - 更新西班牙语文档至 2.4.11 (by @Gonzalo2310 in #13522) +- 其它 + - 移除多余的构建脚本 (by @ziyoung) + - 修正文档超链接 (by @iamkun in #13753) + - 修正文档中不一致的大小写 (by @wonderjar) + - 增加钉钉群的二维码 (by @iamkun in #13957) + - .gitignore 增加 yarn 日志文件 (by @mimimi in #13922) + - 移除赞助商 多态 (by @island205 in #14156) + - Update readme qr code src (by @iamkun in #13960) + - 更新 CDN 链接,修正错别字 (by @ziyoung) + +### 2.4.11 + +*2018-11-21* + +- 撤销 pr #13296,修复点击 Menu 外部导致 Submenu 收起的问题,#13478 +- 调整小屏幕(xs)媒体查询断点,#13468 (by @alekoshen712) + +### 2.4.10 + +*2018-11-16* + +- 修复多次点击 Select 才显示下拉列表的问题,#13268 +- Form 禁用时不显示 Input 的 clear 图标,#13208 +- 调整 Select,Progress,Autocomplete,Tooltip,Collaspe,TimePicker 的样式,#13188 (by @porcelainHeart) #13210 #13266 #13257 #13290 #13347 (by @PanJiaChen) +- Carousel 组件新增 `loop` 属性,#13217 +- Table 的 data 改变时,高亮行会继续保留,#13200 +- Table 的 header slot 可以接收参数,#13263 +- Table 的 `clearFilter` 方法支持参数,#13176 +- Table 单元格内没有内容时不再创建 Tooltip,#13152 (by @rongxingsun) +- ColorPicker 面板的输入框内容可以正常显示了,#13278 +- 在拖拽时,ColorPicker 不再触发表单校验,#13299 +- InputNumber 新增 `select` 方法,#13286 (by @st-sloth) +- Autocomplete 新增 `clear` 事件,#12171(by arthurdenner) #13326 +- 可以通过点击 Menu 外部来关闭 Menu,#13296 +- Form 的 `validateField` 方法可以接收参数,#13319 +- Cascader 新增 `visible-change` 事件,#13415 +- DatePicker 新增 range-separator slot, #13272 (by @milworm) +- Tree 新增 `iconClass` 与 `currentNodeKey` 属性,#13337 #13197 (by @isnifer) +- Progress 的 `status` 添加了 text #13198 (by @ali-master) +- 修复 Tree 的 `defaultCheckedKeys` 导致显示的错误,#13349 (by @dive2Pro) + +### 2.4.9 + +*2018-10-26* + +- Form 组件 clearValidate 方法参数支持字符串,#12990 (by @codinglobster) +- Badge 新增 type 属性,#12991 +- 用户可以使用 scoped-slot 来自定义表头,#13012(by @ivanseidel) +- 修复 IE 下 Select 输入框不能输入的问题,#13034(by @GaliMU) +- Select 多选时,选项不换行,#12329 (by @akki-jat) +- Select 下拉列表展开后,箭头图标也可以正确显示,#12353(by @firesh) +- 修复 Select 的 size 属性不生效的问题,#13070 +- 多选时可以清除 Select 已选中的值,#13049(by @ZSkycat) +- 修复最后一个 TabNav 不能删除的问题,#13039 +- 修复 TabNav 中 label 显示不正确的问题,#13178 +- Alert 新增 title slot,#13082(by @Kingwl) +- 修复 Table 中的 tooltip 内容不正确的问题,#13159(by @elfman) +- 优化 Upload 文件列表删除时的动画,#12987 +- 当 InputNumber 控制按钮不显示时,调整了边距,#13052 + +### 2.4.8 + +- Switch 聚焦时不显示轮廓,#12771 +- 修复 Dropdown 在 ButtonGroup 中样式问题,#12819 (by @bluejfox) +- Dialog 新增 opened 事件,#12828 +- 修复 TabNav 显示顺序不正确的问题,#12846 +- 修复 Tabs 没有滑动到选中 tab 的问题,#12948 +- 修复 Tree 节点在拖拽时标识符不显示的问题,#12854 +- Form 的 validate 事件参数中包含了校验的信息,#12860 (by @YamenSharaf) +- 修复 DatePicker 没有校验用户输入时间的合法性问题,#12898 +- 修复 Table 表头的 `render-header`属性不生效的问题,#12914 + +### 2.4.7 + +*2018-09-14* + +- 修复 DatePicker 未触发表单检验的问题,#12328,#12348 +- 修复 DatePicker 多选时报错的问题,#12347 +- 修复 DatePicker 选择时间时 spinner 位置不正确的问题,#12415 (by @rang-ali) +- 修复 Datepicker 输入框自动填充的问题,#12521 (by @abdallanayer) +- 修复 Cascader 中 Input 未高亮的问题,#12341 +- 修复 Tabpane 顺序不正确的问题,#12346 +- 修复 ColorPicker 取色光标位置不正确的问题,#12376 (by @cnwhy) +- 调整 Submenu 的样式,#12457 +- 修复 Submenu 选中后没有高亮的问题,#12479 +- 修复 Cascader 选择值不正确的问题,#12508 (by @huangjinqiang) +- 修复 Pagination 输入框值不正确的问题,#12525 +- 调整 Pagination 触发事件的顺序,#12530 +- 修复 Table 的 filter 不显示的问题,#12539 +- 修复 Tree 无法删除节点的问题,#12684 +- 修复 Select 在单选时 Input 高度变化的问题,#12719 +- 修复 Form 在嵌套时 label 显示不正确的问题,#12748 +- 新增 Input 的 autocomplete 属性,废弃 auto-complete 属性,#12514 (by @axetroy) +- 新增 Form 的 slot-scope 展示表单校验信息,#12715 (by @YamenSharaf) + +### 2.4.6 + +*2018-08-09* + +- 修复 Table 的 filter 初始值为空数组时不显示筛选图标的问题,#12165 +- 修复 Menu 在更改 `collapse` 时不保存菜单激活状态的问题,#12178 (by @elfman) +- 修复 Cascader 未转义特殊字符的问题,#12248 +- 修复禁用的 RadioButton 在点击时显示 box-shadow 的问题,#12262 +- 修复 Select 初始值为 `undefined` 时方向键失效的问题,#12322 +- 修复 Select 多选时输入的关键字消失的问题,#12304 +- 修复 Select 多选时查询函数没有去抖的问题,#12181 +- 修复 Dialog 在全屏显示时宽度不正确的问题,#12203 +- 修复 Main 在 IE 下的显示不正确的问题,#12237 +- 修复 Input 触发两次表单校验的问题,#12260 +- 修复 Tree 在懒加载时添加节点导致节点消失的问题,#12256 +- 修复 Tree 节点在拖拽后无法删除的问题,#12279 +- 修复 Popover 在 InputNumber 聚焦时不显示的问题,#12284 +- 添加 Autocomplete 的 popper-append-to-body 属性,#12241 +- 添加 Pagination 的 `page-size` 属性 `sync` 修饰符的支持,#12281 + +### 2.4.5 + +*2018-07-26* + +- 修复 Table 设置 `class-name` 对 `expand` 列不生效的问题,#12006 +- 新增 Table 的 `toggleAllSelection` 方法,#12047 +- 修复 Input 包含 Select 时,suffix 插槽位置显示不正确的问题,#12108 +- 修复 Option 的 `line-height` 无法设置的问题,#12120 +- 修复初始值为 `null` 的 TimeSelect 在执行 `resetField` 后无法再赋值的问题,#12010 +- 修复 Tree 组件中不响应方向键以外 keydown 事件的问题,#12008 +- 修复 Tree 在懒加载情况下选中父节点的问题,#12106 +- Tree 的 `getCheckedNodes` 方法新增 `includeHalfChecked` 参数,#12014 + +### 2.4.4 + +*2018-07-13* + +- 修复重置表单后触发 Select 组件校验问题,#11837 +- 修复 Input 组件 `suffix` 与 `append` 共存时样式错乱问题,#11951 +- 修复可清空的只读 Input 仍会显示清空图标的问题,#11967 +- 修复 Tree 节点禁用时仍可以选中的问题,#11847 +- 修复 Tree `default-checked-keys` 属性不生效的问题,#11971 +- 修复 Tree 在过滤节点时下 `empty-text` 不显示的问题,#11971 +- 修复 Table 的 `empty-text` 过长时的位置样式问题,#11965 +- 修复 Table 的 `current-row-key` 设置为 `null` 时高亮行不清除的问题,#11866 +- 修复当 `filters` 为空数组时显示过滤器下拉列表的问题,#11864 +- 修复 Radio 的 label 不阻止事件冒泡的问题,#11912 + +### 2.4.3 + +*2018-07-03* + +- 修复当自定义 Tree 节点高度时,`allow-drop` 不能正常工作的问题,#11797 +- 现在 Form 的 `clearValidate` 方法支持传入参数,指定需要清空校验结果的 FormItem,#11821 +- 新增 MessageBox 的 `distinguishCancelAndClose` 属性,#11831 + +### 2.4.2 + +*2018-06-26* + +- 修复 Table 的 `class-name` 和 `label-class-name` 属性不支持动态更新的问题,#11626 +- 修复 Table 在 `highlight-current-row` 为 `false` 时点击行也会触发高亮的问题,#11691 #11563 +- 修复 ButtonGroup 中只有一个 `round` 或 `circle` 的 Button 时的样式错误,#11605 +- 修复在某些情况下 Pagination 的条目数选择器的样式错误,#11622 +- 修复 Menu 的 `collapse` 属性变化后无法使用 `open` 方法的问题,#11646 +- Tabs 的 `before-leave` 钩子添加了 `activeName` 和 `oldActiveName` 参数,#11713 +- 修复 Cascader 关闭后的聚焦问题,#11588 +- 修复 Cascader 在 `change-on-select` 状态下点击选项不关闭的问题,#11623 +- 现在通过代码改变 Select 的值后会触发表单校验,与 Input 行为一致,#11672 + +### 2.4.1 + +*2018-06-08* + +- 移除 Autocomplete 的重复类型声明,#11388 +- 修复嵌套在 Form 内的 Select 在 FireFox 浏览器中下拉箭头错位的问题,#11427 +- 修复 Select 的初始值为 `null` 时仍然显示清除图标的问题,#11460 +- 修复禁用的 Radio 在点击时显示 box-shadow 的问题,#11462 +- 新增 MessageBox 的 `iconClass` 属性,#11499 +- 新增 Tabs 的 `stretch` 属性,#11476 +- 修复 Tabs 开启 `lazy` 时渲染顺序异常的问题,#11461 +- 修复 Table 展开行时无法保留选中行样式的问题,#11464 +- 修复 Tabs 调用 `before-leave` 并返回 Promise 的时候,Tabs 会存在 focus 状态的问题,#11386 +- 修复 Popover 禁用状态下创建弹出框的问题,#11426 +- 修复 Tree 在懒加载状态下添加新节点造成无限循环的问题,#11430 (by @wangjingf) +- 新增 Dialog 的 `closed` 事件,#11490 + +### 2.4.0 Fullerene + +*2018-05-28* + +#### 新特性 +- 综合 + - 使用原生 webpack 作为构建和打包工具,#11216 + - 可以全局配置弹出层的初始 z-index,#11257 +- Autocomplete + - 新增 `hide-loading` 属性,#11260 +- Button + - 现在圆形按钮也支持通过 `size` 属性改变其尺寸了,#11275 +- InputNumber + - 新增 `precision` 属性,#11281 +- Tabs + - 新增 `before-leave` 钩子,#11259 + - 新增 `lazy` 属性,#11167(by @Kingwl) +- Table + - 新增 `sort` 方法,支持手动排序,#11311 + +#### 修复 +- Input + - 修复使用中文输入法快速输入文字时会导致视图重新渲染的问题,#11235(by @STLighter) +- Popover + - 修复当触发元素为 Radio 或 Checkbox 时控制台报错的问题,#11265 +- Breadcrumb + - 修复 `to` 属性不支持动态更新的问题,#11286 +- Upload + - 修复在 `beforeUpload` 方法返回的 Promise 中 resolve 一个 File 时控制台报错的问题,#11297(by @qusiba) +- Tooltip + - 修复内容为空时箭头错位的问题,#11335 +- Autocomplete + - 修复在快速删除搜索内容后输入建议不正确的问题,#11323 +- ColorPicker + - 修复关闭选色器时触发 `active-change` 事件的问题,#11304 +- Table + - 修复筛选列表过长导致样式超出的问题,#11314 + - 修复排序后导致无法正常显示选中行样式的问题,#11348 +- Checkbox + - 修复单个 Checkbox 不支持表单验证的问题,#11271 +- Radio + - 修复通过空格可以选中被禁用的 Radio 的问题,#11303 +- MessageBox + - 修复连续打开两个 MessageBox 时 `el-popup-parent--hidden` 无法移除的问题,#11371 + +### 2.3.9 + +*2018-05-18* + +- 修复当 TableColumn 的 `prop` 属性指定的字段在数据源中不存在时,鼠标移入该列单元格会报错的问题,#11137 +- 弹出类组件的 `lockScroll` 属性不再为父元素添加内联样式,而是添加相应类名,#11114 +- 修复 Progress 在 `status` 为 exception 时图标不显示的问题,#11172 +- 修复可搜索的 Cascader 在输入关键词后,选项的 `disabled` 属性失效的问题,#11185 +- 修复可展开的 Table 在展开某一行后更新数据源会造成该行无法收起的问题,#11186 +- Tree 的 `setCurrentKey` 方法支持传入 `null`,可取消当前高亮的节点,#11205 + +### 2.3.8 + +*2018-05-11* + +- 修复 `type` 为 dates 的 DatePicker 在选择非当前月的日期后,面板会跳转至当前月的问题,#10973 +- 修复可清空的只读 Input 仍会显示清空图标的问题,#10912 +- 修复范围选择的 DatePicker 在未改变值的情况下关闭下拉面板仍会触发 `change` 事件的问题,#11017 +- 修复 Select 在有分组选项时不能正确通过键盘导航的问题,#11058 +- 新增 Select 的 `prefix` 具名 slot,#11063 +- 新增 FormItem 的 `clearValidate` 方法,#11076 +- 新增 Tree 的 `checkOnClickNode` 属性,#11111 + +### 2.3.7 + +*2018-04-29* + +- 修复 Table 在由于筛选而使原有的滚动条消失后表头各列宽度未及时更新的问题,#10834 +- 修复可清空的 Input 在初始值为 `null` 时仍然显示清空图标的问题,#10912 +- 修复在通过代码改变 ColorPicker 的绑定值后错误地触发 `active-change` 事件的问题,#10903(by @zhangbobell) +- 修复可搜索的 Select 在备选项均被禁用时,通过键盘导航会造成无限循环的问题,#10945 + +### 2.3.6 + +*2018-04-21* + +- 修复 Tree 的 `allow-drop` 回调在使用 `type` 参数后的错误行为,#10821 +- 修复可搜索的单选 Select 在 IE11 中无法输入搜索关键词的问题,#10822 +- 修复单选 Select 在使用鼠标选中某个选项后错误地触发 `blur` 事件的问题,#10822 + +### 2.3.5 + +*2018-04-20* + +- 修复 DatePicker 的 `type` 为 week 时面板错误高亮的问题,#10712 +- 修复 InputNumber 初始值为 0 时输入框为空的问题,#10714 +- 新增 Select 的 `automatic-dropdown` 属性,#10042(by @Seebiscuit) +- 修复 `disabled` 的 Rate 仍能通过键盘左右键改变组件值的问题,#10726(by @Richard-Choooou) +- 现在 DatePicker 的 `type` 属性可以接收 `'dates'`,用于选择多个日期,#10650(by @Mini256) +- 新增 Pagination 的 `prev-click` 和 `next-click` 事件,#10755 +- 新增 Pagination 的 `pager-count` 属性,#10493(by @chongjohn716) +- 新增 `type` 作为 Tree 的 `allow-drop` 属性回调的第三个参数,#10792 +- 改用 ResizeObserver 对元素的尺寸变化进行监测,#10779 + +### 2.3.4 + +*2018-04-12* + +- 删除 SubMenu 在 TypeScript 类型声明中重复的 `showTimeout` 属性,#10566(by @kimond) +- 现在 Transfer 数据项的渲染支持通过 scoped slot 自定义,#10577 +- 修复点击 Pagination 禁用的上一页、下一页按钮仍会触发 `current-change` 事件的问题,#10628 +- 修复未绑定值的 Textarea 在 SSR 中会显示 `undefined` 的问题,#10630 +- 修复 `type` 为 border-card 的 Tabs 中被禁用标签项的样式,#10640 +- 新增 `$index` 作为 Table 的 `formatter` 属性回调的第四个参数,#10645 +- 修复 TypeScript 类型声明未导出 CheckboxButton 的问题,#10666 + +### 2.3.3 + +*2018-04-04* + +- 新增 Card 的 `shadow` 属性,#10418(by @YunYouJun) +- 修复 Badge 在 `value` 属性为 `0` 时不显示上标的问题,#10470 +- 修复 Tree 节点拖拽相关的问题,#10474 #10494 +- 新增 Autocomplete 的 `placement` 属性,#10475 +- 现在 `default-time` 属性也可用于非范围选择的 DateTimePicker 了,#10321(by @RickMacTurk) +- 修复 TabItem 在浏览器失焦和隐藏后出现蓝色边框的问题,#10503 +- 新增 SubMenu 的 `popper-append-to-body` 属性,#10515 +- 现在非链接的 BreadcrumbItem 在 hover 时不再具有视觉反馈,#10551 +- 调整 InputNumber `change` 事件的触发时机,使得在回调中能够取得最新的组件绑定值,#10553 + +### 2.3.2 + +*2018-03-29* + +- 修复 Autocomplete 报错的问题,#10442 + +### 2.3.1 + +*2018-03-29* + +- 修复 Input 的 `type` 属性未传递至原生 input 元素的问题,#10415 +- 新增 Select 的 `blur` 方法,#10416 + +### 2.3.0 Diamond + +*2018-03-28* + +#### 新特性 +- Table + - 现在 TableColumn 的 `formatter` 属性可以是动态的,#10184(by @elfman) + - 新增 `select-on-indeterminate` 属性,#9924(by @syn-zeta) +- Menu + - 新增 `collapse-transition` 属性,#8809(by @limichange) +- Input + - 新增 `select` 方法,#10229 + - 新增 `blur` 方法,#10356 +- ColorPicker + - 新增 `predefine` 属性,#10170(by @elfman) +- Tree + - 新增 `draggable`、`allow-drop` 和 `allow-drag` 属性,以及 `node-drag-start`、`node-drag-enter`、`node-drag-leave`、`node-drag-over`、`node-drag-end` 和 `node-drop` 事件,#9251 #10372(by @elfman) +- Form + - `validate` 方法新增第二个参数,包含未通过本次校验的表单项信息,#10279 + - 新增 `validate` 事件,#10351 +- Progress + - 新增 `color` 属性,#10352(by @YunYouJun) +- Button + - 新增 `circle` 属性,#10359(by @YunYouJun) + +#### 修复 +- Form + - 修复嵌套复合型 Input 时,FormItem 标签与输入框未对齐的问题,#10189 +- Menu + - 现在折叠状态的菜单项仅在传入 `title` slot 时才显示 Tooltip,#10193(by @PanJiaChen) +- Pagination + - 修复 `current-change` 在未发生用户交互时错误触发的问题,#10247 +- DatePicker + - 现在时间日期选择器下拉面板中的值能够正确地从 `format` 属性中获取对应格式了,#10174(by @remizovvv) +- Upload + - 现在拖拽上传会拦截不在 `accept` 属性范围内的文件,#10278 + +### 2.2.2 + +*2018-03-14* + +- 新增 Input 的 `clear` 事件,#9988(by @blackmiaool) +- 现在 ColorPicker 的手动输入支持 `hsl`、`hsv` 和 `rgb` 格式了,#9991 +- 修复 DatePicker 在清除初始值时不触发 `change` 事件的问题,#9986 +- 现在 Rate 的图标类相关属性支持动态更新了,#10003 +- 修复含有固定列的 Table 在设置 `max-height` 属性后有时不能及时更新布局高度的问题,#10034 +- 现在 DatePicker 的范围选择支持先点选结束日期,再点选开始日期了,#8156(by @earlymeme) +- 新增 Pagination 的 `disabled` 属性,#10006 +- 新增 Popover 的 `after-enter` 和 `after-leave` 事件,#10047 +- 修复重置表单后,用户第一次改变 Select 的值时不触发校验的问题,#10105 +- 修复 Table 的固定列在某些情况下宽度不正确的问题,#10130 +- 修复调用 MessageBox 未传入 `title` 时,打开的 MessageBox 会继承上一个实例的 `title` 属性的问题,#10126(by @Pochodaydayup) +- 新增 Slider 的 `input-size` 属性,#10154 +- 新增 Transfer 的 `left-check-change` 和 `right-check-change` 事件,#10156 + +### 2.2.1 + +*2018-03-02* + +- 修复 Aside、Header 和 Footer 在某些布局中被压缩的问题,#9812 +- 修复设置了 `height` 属性的 Table 在服务端渲染时无法加载的问题,#9876 +- 修复可展开的 Table 在展开某一行后高度未重新计算的问题,#9848 +- 修复在 DateTimePicker 中手动输入日期后不能正确触发 `change` 事件的问题,#9913 +- 修复鼠标右键点击 Select 的输入框会展开选项的问题,#9894(by @openks) +- 新增 Slider 的 `tooltip-class` 属性,#9957 +- 现在的 Select 在选中选项后仍然处于 focus 状态,#9857(by @Seebiscuit) +- 新增 Transfer 的 `target-order` 属性,#9960 + +### 2.2.0 Graphite + +*2018-02-12* + +#### 新特性 +- Menu + - SubMenu 新增 `popper-class` 和 `disabled` 属性,#9604 #9771 + - 现在水平模式下的 Menu 支持多级 SubMenu 了,#9741 +- Tree + - 新增 `node-contextmenu` 事件,#9678 + - 现在可以使用 scoped slot 自定义树节点的模板了,#9686 + - 新增 `getNode`、`remove`、`append`、`insertBefore`、`insertAfter`、`getCheckedKeys`、`getHalfCheckedNodes`、`getHalfCheckedKeys` 方法和 `check` 事件,#9718 #9730 +- Transfer + - 新增 `clearQuery` 方法,#9753 +- Select + - 新增 `popper-append-to-body` 属性,#9782 + +#### 修复 +- Table + - 修复点击可展开行的展开图标会触发 `row-click` 事件的问题,#9654 + - 修复某些情况下通过拖动改变列宽后,布局没有同步更新的问题,#9668 + - 修复合计行与固定列并存时的样式问题,#9667 +- Container + - 修复布局组件在 IE11 中无法自动填充可用空间的问题,#9655 +- Loading + - 修复在 `mounted` 中修改 `v-loading` 的值为 true 时不能正确显示 Loading 的问题,#9722 +- Switch + - 修复点击时会触发两次原生 click 事件的问题,#9760 + +### 2.1.0 Charcoal + +*2018-01-31* + +#### 新特性 +- Cascader + - 新增 `focus` 和 `blur` 事件,#9184(by @viewweiwu) +- Table + - `filter-method` 方法加入第三个参数 `column`,#9196(by @liyanlong) +- DatePicker + - 新增 `prefix-icon` 和 `clear-icon` 属性,#9237(by @AdamSGit) + - 新增 `default-time` 属性,#9094(by @nighca) + - `value-format` 属性增加对 `timestamp` 的支持,#9319(by @wacky6) +- InputNumber + - 组件绑定变量的值支持 `undefined`,#9361 +- Select + - 新增 `auto-complete` 属性,#9388 +- Form + - 新增 `disabled` 属性,#9529 + - 新增 `validateOnRuleChange` 属性,#8141 +- Notificaition + - 新增 `closeAll` 方法,#9514 + +#### 修复 +- InputNumber + - 修复初始输入小数点时被重置的问题,#9116 +- Dropdown + - 修复当页面仅有水平滚动条时,某些浏览器下拉菜单定位错误的问题,#9138(by @banzhuanmei) +- Table + - 修复带有固定列的 Table 在列数据变化后固定列的个数计算错误的问题,#9188(by @kolesoffac) + - 修复多级表头最后一列的边框不能正确显示的问题,#9326 + - 修复在 Safari 浏览器中表头错位的问题,#9327 + - 修复带有展开行的表格在展开某一行后,当表格数据更新但 `row-key` 值不变时,该行会自动收起的问题,#9462 + - 修复在一些情况下不必要的多次渲染问题,#9426 + - 修复动态改变 TableColumn 的 `width` 属性时,其宽度计算错误的问题,#9426 +- Loading + - 修复某些情况下 Loading 不能被正确隐藏的问题,#9313 +- DatePicker + - 修复 `focus` 方法在范围选择时无效的问题,#9437 + - 修复当目前时刻处于不可选择的范围内时,点击面板上的「此刻」按钮仍能选中目前时刻的问题,#9470(by @wacky6) + - 修复当在月选择面板中选中天数较少的月份时,日期面板呈现下一个月的问题,#9577(by @wacky6) +- Steps + - 修复在 IE 11 中的样式问题,#9454 + +#### 非兼容性更新 +- Menu + - `collapse` 状态下的弹出菜单现在会插入至 body 元素,修复其位于 Aside 内时弹出菜单不可见的问题,#9263 +- Table + - 勾选多选表格的 checkbox 时不再同时触发 `row-click` 事件,#9467 +- Loading + - 非全屏 Loading 遮罩层的 `z-index` 修改为 2000;全屏 Loading 遮罩层的 `z-index` 值会随页面上的弹出组件动态更新,#9522 +- Dropdown + - `show-timeout` 和 `hide-timeout` 属性现在仅在 trigger 为 `hover` 时生效,#9573 + +### 2.0.11 + +*2018-01-08* + +- 修复 Input 的 `prepend` 或 `append` slot 中 Select 的边框颜色错误,#9089 +- 修复 Select 的 `remove-tag` 事件参数与文档不符的问题,#9090 +- 新增 SubMenu 的 `show-timeout` 和 `hide-timeout` 属性,#8934(by @HugoLew) +- 修复按需引入 Table 时 `show-overflow-tooltip` 的 Tooltip 样式丢失的问题,#9130 +- 修复 Table 在执行 `clearSort` 后点击对应列的排序图标无法正常排序的问题,#9100(by @zEmily) +- 捷克语的 i18n 配置文件由 `cz` 重命名为 `cs-CZ`,#9164 + +### 2.0.10 + +*2017-12-29* + +- 修复了 Table 在固定列和合计行并存时的高度计算错误的问题,#9026 +- 修复了 Table 样式 SCSS 文件错误编译的问题,#9028 +- 现在 DatePicker 的 `change` 事件只会在 `value` 真正改变的时候触发,#9029(by @remizovvv) +- 新增 Input 的 `tabindex` 属性,#9041(by @dicklwm) + +### 2.0.9🎄 + +*2017-12-24* + +- 新增 Upload 的 `before-remove` 钩子方法,#8788(by @firesh) +- 修复 FormItem 的 `error` 属性初始值无效的问题,#8840 +- 通过指令调用的 Loading 现在支持以 `element-loading-custom-class` 属性的方式设置自定义类名,#8826(by @earlymeme) +- 修复 CarouselItem 为异步获取时被隐藏的问题,#8921 +- 新增 Tree 的 `renderAfterExpand` 属性,#8972 + +### 2.0.8 + +*2017-12-12* + +- 新增西班牙语文档 +- 修复 `show-timeout` 对点击触发的 Dropdown 无效的问题,#8734(by @presidenten) +- 修复 Form 对于 `trigger` 为 blur 的校验规则触发时机有误的问题,#8776 +- 修复 DatePicker 在范围选择时 blur 事件触发时机有误的问题,#8784 +- TimePicker 的 `format` 新增对 AM/PM 的支持,#8620(by @firesh) + +### 2.0.7 + +*2017-11-29* + +- 修复禁用文字按钮的样式问题,#8570 + +### 2.0.6 + +*2017-11-29* + +- 修复 Table 排序图标的样式问题,#8405 +- 修复 `trigger` 为 manual 的 Popover 的触发问题,#8467 +- 新增 Autocomplete 的 `prefix-icon` 和 `suffix-icon` 属性,#8446(by @liyanlong) +- 新增 Cascader 的 `separator` 属性,#8501 +- 新增 Input 的 `clearable` 属性,#8509(by @lbogdan) +- 新增 Pagination 的 `background` 属性,#8553 + +### 2.0.5 + +*2017-11-17* + +- 修复上个版本引入的 Popover、Tree、Breadcrumb、Cascader 的 bug,#8188 #8217 #8283 +- 修复 clickoutside 指令的内存泄露问题,#8168 #8225(by @badpunman @STLighter) +- 修复默认尺寸的多选 Select 在清空选项后输入框高度不随之更新的问题,#8317(by @luciy) +- 新增 Select 的 `collapse-tags` 属性,用于在多选时以文字代替 Tag,避免组件高度的增大,#8190 +- 修复被隐藏的 Table 会造成 CPU 占用持续增加的问题,#8351 +- 开放 Table 的 `doLayout` 方法,用于重新计算 Table 的布局,#8351 + +### 2.0.4 + +*2017-11-10* + +- 提升 Cascader、Dropdown、Message、Notification、Popover、Tooltip、Tree 的可访问性 +- 修复当视口变窄时 Container 无法同步更新其宽度的问题,#8042 +- 修复 Tree 的 `updateKeyChildren` 在删除子节点时的行为错误,#8100 +- 修复带有边框的 CheckboxButton 在 Form 中高度错误的问题,#8100 +- 修复 Menu 在解析自定义颜色时的错误,#8153(by @zhouyixiang) + +### 2.0.3 + +*2017-11-03* + +- 修复范围选择的 DatePicker `editable` 和 `readonly` 属性无法正常工作的问题,#7922 +- 修复嵌套的 Tabs 的样式错误,#7941 +- 修复纵向 Steps 中最后一个 Step 的样式错误,#7980 +- 修复 Pagination 的 `current-change` 事件触发时机错误的问题,#7995 +- 修复由于 Menu 使用了未注册的 Tooltip 造成其在按需引入时报错的问题,#7995 + +### 2.0.2 + +*2017-10-31* + +- 在 InputNumber 的加减按钮上单击鼠标右键不再触发值的改变,#7817 +- Form 的 `validate` 方法现在能够正确地在异步校验完成后执行回调了,#7774(by @Allenice) +- 修复 DatePicker 的范围选择在内核为 Chromium 53-57 的浏览器中无法使用的问题,#7838 +- 修复 `list-type` 为 picture-card 的 Upload 预览和删除图标丢失的问题,#7857 +- 新增 TableColumn 的 `sort-by` 属性,#7828(by @wangfengming) +- 修复周模式下的 DatePicker 在选择某年第一周可能会显示为前一年第一周的问题,#7860(by @hh23485) +- 修复垂直模式的 Steps 中图标宽度的样式错误,#7891 +- 增大了 Tree 中展开箭头的点击热区,#7891 + +### 2.0.1 + +*2017-10-28* + +- 修复 RadioButton 和 CheckboxButton 的样式问题,#7793 +- 修复 TimePicker 在某些情况下无法滚动的问题,#7811 +- 修复部分组件在按需引入时样式不完整的问题,#7811 + +### 2.0.0 Carbon + +*2017-10-27* + +#### 新特性 +- 综合 + - 新增 `theme-chalk` 主题 + - 增强以下组件的可访问性:Alert、AutoComplete、Breadcrumb、Button、Checkbox、Collapse、Input、InputNumber、Menu、Progress、Radio、Rate、Slider、Switch 和 Upload + - 新增布局组件 Container、Header、Aside、Main 和 Footer + - 新增 TypeScript 类型声明 + - 重绘了全部图标,并新增了部分图标 + - 新增了一系列基于断点的工具类,用于当视口尺寸满足一定条件时隐藏元素 + - 新增全局配置组件尺寸的功能。在引入 Element 时,配置 `size` 字段可以改变所有组件的默认尺寸 +- Button + - 新增 `round` 属性,用于圆角按钮 #6643 +- TimeSelect + - 可以用 `Up`、`Down` 导航,用 `Enter` 选中时间 #6023 +- TimePicker + - 可以用方向键导航,用 `Enter` 选中时间 #6050 + - 新增 `start-placeholder` 和 `end-placeholder`,用于设置范围选择时两个输入框的占位符 #7169 + - 新增 `arrow-control` 属性,提供另一种交互形式,#7438 +- Tree + - 子节点在首次被展开之前不进行渲染 #6257 + - 新增 `check-descendants` 属性,设置 `lazy` 模式下勾选节点时,是否完全展开整个子树 #6235 +- Tag + - 新增 `size` 属性 #7203 +- Datepicker + - type 为 `datetimerange` 时可以使用 `timeFormat` 格式化时间选择器 #6052 + - 新增 `start-placeholder` 和 `end-placeholder`,用于设置范围选择时两个输入框的占位符 #7169 + - 新增 `value-format` 属性,支持对绑定值的格式进行自定义,#7367 + - 新增 `unlink-panels` 属性,用于在选择日期范围时取消两个日期面板之间的联动 +- MessageBox + - 新增 `closeOnHashChange` 属性 #6043 + - 新增 `center` 属性,提供居中布局 #7029 + - 新增 `roundButton` 属性,使得内部按钮为圆角按钮 #7029 + - 新增 `dangerouslyUseHTMLString` 属性,使得 `message` 支持传入 HTML 字符串* #6043 + - 新增 `inputType` 属性,用户指定内部输入框的类型,#7651 +- Dialog + - 新增 `width`、`fullscreen`、`append-to-body` 属性,支持嵌套使用 + - 新增 `center` 属性,提供居中布局 #7042 + - 新增 `focus-after-closed`、`focus-after-open`属性,支持无障碍访问 #6511 +- ColorPicker + - 增加手动输入色值的支持 #6167 + - 新增 `size` 属性,用于控制组件的大小 #7026 + - 新增 `disabled` 属性,用于禁用组件 #7026 + - 新增 `popper-class` 属性,#7351 +- Message + - 图标部分使用 icon 代替图片,从而支持通过 CSS 修改图标背景色 #6207 + - 新增 `dangerouslyUseHTMLString` 属性,使得 `message` 属性支持传入 HTML 字符串* #6207 + - 新增 `center` 属性,提供居中布局 #6875 +- Notification + - 新增 `position` 属性,用于配置 Notification 出现的位置 #6231 + - 新增 `dangerouslyUseHTMLString` 属性,使得 `message` 属性支持传入 HTML 字符串* #6231 + - 新增 `showClose` 属性,用于隐藏关闭按钮 #6402 +- Rate + - 新增 `show-score` 属性,控制是否在右侧显示当前分数 #6295 +- Tabs + - 新增 `tab-position` 属性,控制选项面板内容显示的上、下、左、右四个方向 #6096 +- Radio + - 增加 `border` 属性和 `size` 属性 #6690 +- Checkbox + - 增加 `border` 属性和 `size` 属性 #6690 +- Alert + - 新增 `center` 属性,提供居中布局 #6876 +- Menu + - 新增 `background-color`、`text-color` 和 `active-text-color` 属性,分别用于设置菜单的背景色、菜单的文字颜色和当前激活菜单的文字颜色 #7064 + - 新增 `open` 和 `close` 方法,支持手动打开和关闭 SubMenu,#7412 +- Form + - 新增 `inline-message` 属性,设置后校验信息会以行内样式显示 #7032 + - 新增 `status-icon` 属性,用于在输入框中显示校验结果反馈图标 #7032 + - Form 和 FormItem 新增 `size` 属性,用于控制表单内组件的尺寸,#7428 + - `validate` 方法在不传入 callback 的情况下返回 promise,#7405 + - 新增 `clearValidate` 方法,用于清空所有表单项的验证信息,#7623 +- Input + - 新增 `suffix`、`prefix` 的 slot,以及 `suffixIcon`、`prefixIcon` 属性,用于给输入框内部增加前置和后置内容 #7032 +- Breadcrumb + - 新增 `separator-class` 属性,可使用图标作为分隔符 #7203 +- Steps + - 新增 `simple` 属性,用于开启简洁风格的步骤条 #7274 +- Pagination + - 新增 `prev-text` 和 `next-text` 属性,用于自定义上一页和下一页的文本 #7005 +- Loading + - 配置对象新增 `spinner` 和 `background` 字段,支持自定义加载图标和背景色,#7390 +- Autocomplete + - 新增 `debounce` 属性,#7413 +- Upload + - 新增 `limit` 和 `on-exceed` 属性,支持对上传文件的个数进行限制,#7405 +- DateTimePicker + - 新增 `time-arrow-control` 属性,用于开启时间选择器的 `arrow-control`,#7438 +- Layout + - 新增断点 `xl`,适用于宽度大于 1920px 的视口 +- Table + - 新增 `span-method` 属性,用于合并行或列 + - 新增 `clearSort` 方法,用于清空排序状态 + - 新增 `clearFilter` 方法,用于清空过滤状态 + - 对于可展开行,当该行展开时会获得一个 `.expanded` 类名,方便自定义样式 + - 新增 `size` 属性,用于控制表格尺寸 + - 新增 `toggleRowExpansion` 方法,用于手动展开或关闭行 + - 新增 `cell-class-name` 属性,用于指定单元格的类名 + - 新增 `cell-style` 属性,用于指定单元格的样式 + - 新增 `header-row-class-name` 属性,用于指定表头行的类名 + - 新增 `header-row-style` 属性,用于指定表头行的样式 + - 新增 `header-cell-class-name` 属性,用于指定表头单元格的类名 + - 新增 `header-cell-style` 属性,用于指定表头单元格的样式 + - TableColumn 的 `prop` 属性支持 `object[key]` 格式 + - TableColumn 新增 `index` 属性,用于自定义索引值 +- Select + - 新增 `reserve-keyword` 属性,用于在选择某个选项后保留当前的搜索关键词 + +#### 修复 +- DatePicker + - 选择周数时,`v-model` 结果返回该周第二天的问题 #6038 + - 在 `daterange` 类型中,第一次的输入会被清空的问题 #6021 +- DateTimePicker + - 和 TimePicker 相互影响的问题 #6090 + - 选择时间小时和秒可超出限制的问题 #6076 +- TimePicker + - 失去焦点时无法正确改变 `v-model` 值的问题 #6023 +- Dialog + - 当含有下拉框时,下拉框的打开和关闭会造成文字虚晃的问题 #6088 +- Select + - 提升性能,修复组件销毁时可能导致 Vue dev-tool 卡死的问题 #6151 +- Table + - 修复 Table 在父元素从 `display: none` 变成其他状态时会隐藏的问题 + - 修复 Table 在父元素为 `display: flex` 时可能出现的宽度逐渐变大的问题 + - 修复 `append` 具名 slot 和固定列并存时,动态获取表格数据会导致固定列消失的问题 + - 修复 `expand-row-keys` 属性初始化无效的问题 + - 修复 `data` 改变时过滤条件失效的问题 + - 修复多级表头时固定列隐藏情况计算错误的问题 + - 修复 `max-height` 变更后无法恢复的问题 + - 修复一些样式上的计算错误 + +#### 非兼容性更新 +- 综合 + - 移除 `theme-default` + - 最低兼容 Vue 2.5.2 和 IE 10 + - 表单组件的 `change` 事件和 Pagination 的 `current-change` 事件现在仅响应用户交互 + - Button 和表单组件的 `size` 属性现在可接受 `medium`、`small` 和 `mini` + - 为了方便使用第三方图标,Button 的 `icon` 属性、Input 的 `prefix-icon` 和 `suffix-icon` 属性、Steps 的 `icon` 属性现在需要传入完整的图标类名 +- Dialog + - 移除 `size` 属性。现在 Dialog 的尺寸由 `width` 和 `fullscreen` 控制 + - 移除通过 `v-model` 控制 Dialog 显示和隐藏的功能 +- Rate + - `text-template` 属性更名为 `score-template` +- Dropdown + - `menu-align` 属性变更为 `placement`,增加更多方位属性 +- Transfer + - `footer-format` 属性更名为 `format` +- Switch + - 由于 `on-*` 属性在 JSX 中会被识别为事件,导致 Switch 所有 `on-*` 属性在 JSX 中无法正常工作,所以 `on-*` 属性更名为 `active-*`,对应地,`off-*` 属性更名为 `inactive-*`。受到影响的属性有:`on-icon-class`、`off-icon-class`、`on-text`、`off-text`、`on-color`、`off-color`、`on-value`、`off-value` + - `active-text` 和 `inactive-text` 属性不再有默认值 +- Tag + - `type` 属性现在支持 `success`、`info`、`warning` 和 `danger` 四个值 +- Menu + - 移除 `theme` 属性。现在通过 `background-color`、`text-color` 和 `active-text-color` 属性进行颜色的自定义 +- Input + - 移除 `icon` 属性。现在通过 `suffix-icon` 属性或者 `suffix` 具名 slot 来加入尾部图标 + - 移除 `on-icon-click` 属性和 `click` 事件。现在如果需要为输入框中的图标添加点击事件,请以具名 slot 的方式添加图标 + - `change` 事件现在仅在输入框失去焦点或用户按下回车时触发,与原生 input 元素一致。如果需要实时响应用户的输入,可以使用 `input` 事件 +- Autocomplete + - 移除 `custom-item` 属性。现在通过 `scoped slot` 自定义输入建议列表项的内容 + - 移除 `props` 属性,现在使用 `value-key` 属性指定输入建议对象中用于显示的键名 +- Steps + - 移除 `center` 属性 + - 现在步骤条将默认充满父容器 +- DatePicker + - `change` 事件参数现在为组件的绑定值,格式由 `value-format` 控制 +- Table + - 移除通过 `inline-template` 自定义列模板的功能 + - `sort-method` 现在和 `Array.sort` 保持一致的逻辑,要求返回一个数字 + - 将 `append` slot 移至 `tbody` 元素以外,以保证其只被渲染一次 + - `expand` 事件更名为 `expand-change`,以保证 API 的命名一致性 + - `row-class-name` 和 `row-style` 的函数参数改为对象,以保证 API 的一致性 + +## +* 在网站上动态渲染任意 HTML 是非常危险的,因为容易导致 [XSS 攻击](https://en.wikipedia.org/wiki/Cross-site_scripting)。因此请在 `dangerouslyUseHTMLString` 打开的情况下,确保 `message` 的内容是可信的,**永远不要**将用户提交的内容赋值给 `message` 属性。 diff --git a/public/static/libs/element-ui/LICENSE b/public/static/libs/element-ui/LICENSE new file mode 100644 index 0000000..cf66100 --- /dev/null +++ b/public/static/libs/element-ui/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2016-present ElemeFE + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/public/static/libs/element-ui/README.md b/public/static/libs/element-ui/README.md new file mode 100644 index 0000000..efac89b --- /dev/null +++ b/public/static/libs/element-ui/README.md @@ -0,0 +1,148 @@ +

+ +

+ +

+ + + + + + + + + + + + + + + +
+ + + + + + + + + + + + + + + +

+ +> A Vue.js 2.0 UI Toolkit for Web. + +Element will stay with Vue 2.x + +For Vue 3.0, we recommend using [Element Plus](https://github.com/element-plus/element-plus)(Element Plus is a community develop project) + +For MiniProgram development, we recommend using [MorJS](https://github.com/eleme/morjs) + +## Links +- Homepage and documentation + - [International users](http://element.eleme.io/#/en-US) + - [Chinese users](http://element.eleme.io/#/zh-CN) + - [Spanish users](http://element.eleme.io/#/es) + - [French users](http://element.eleme.io/#/fr-FR) +- [awesome-element](https://github.com/ElementUI/awesome-element) +- [FAQ](./FAQ.md) +- [Vue.js 3.0 migration](https://github.com/element-plus/element-plus) +- [Customize theme](http://element.eleme.io/#/en-US/component/custom-theme) +- [Preview and generate theme online](https://elementui.github.io/theme-chalk-preview) +- [Element for React](https://github.com/elemefe/element-react) +- [Element for Angular](https://github.com/ElemeFE/element-angular) +- [Atom helper](https://github.com/ElemeFE/element-helper) +- [Visual Studio Code helper](https://github.com/ElemeFE/vscode-element-helper) +- Starter kit + - [element-starter](https://github.com/ElementUI/element-starter) + - [element-in-laravel-starter](https://github.com/ElementUI/element-in-laravel-starter) +- [Design resources](https://github.com/ElementUI/Resources) +- Gitter + - [International users](https://gitter.im/element-en/Lobby) + - [Chinese users](https://gitter.im/ElemeFE/element) + +## Install +```shell +npm install element-ui -S +``` + +## Quick Start +``` javascript +import Vue from 'vue' +import Element from 'element-ui' + +Vue.use(Element) + +// or +import { + Select, + Button + // ... +} from 'element-ui' + +Vue.component(Select.name, Select) +Vue.component(Button.name, Button) +``` +For more information, please refer to [Quick Start](http://element.eleme.io/#/en-US/component/quickstart) in our documentation. + +## Browser Support +Modern browsers and Internet Explorer 10+. + +## Development +Skip this part if you just want to use Element. + +For those who are interested in contributing to Element, please refer to our contributing guide ([中文](https://github.com/ElemeFE/element/blob/master/.github/CONTRIBUTING.zh-CN.md) | [English](https://github.com/ElemeFE/element/blob/master/.github/CONTRIBUTING.en-US.md) | [Español](https://github.com/ElemeFE/element/blob/master/.github/CONTRIBUTING.es.md) | [Français](https://github.com/ElemeFE/element/blob/master/.github/CONTRIBUTING.fr-FR.md)) to see how to run this project. + +## Changelog +Detailed changes for each release are documented in the [release notes](https://github.com/ElemeFE/element/releases). + +## FAQ +We have collected some [frequently asked questions](https://github.com/ElemeFE/element/blob/master/FAQ.md). Before reporting an issue, please search if the FAQ has the answer to your problem. + +## Contribution +Please make sure to read the contributing guide ([中文](https://github.com/ElemeFE/element/blob/master/.github/CONTRIBUTING.zh-CN.md) | [English](https://github.com/ElemeFE/element/blob/master/.github/CONTRIBUTING.en-US.md) | [Español](https://github.com/ElemeFE/element/blob/master/.github/CONTRIBUTING.es.md) | [Français](https://github.com/ElemeFE/element/blob/master/.github/CONTRIBUTING.fr-FR.md)) before making a pull request. + +## Special Thanks +English documentation is brought to you by SwiftGG Translation Team: +- [raychenfj](https://github.com/raychenfj) +- [kevin](http://thekevin.cn/) +- [曾小涛](https://github.com/zengxiaotao) +- [湾仔王二](https://github.com/wanzaiwanger) +- [BlooDLine](http://www.ibloodline.com/) +- [陈铭嘉](https://chenmingjia.github.io/) +- [千叶知风](http://mpc6.com/) +- [梁杰](http://numbbbbb.com) +- [Changing](https://github.com/sunzhuo11) +- [mmoaay](https://github.com/mmoaay) + +Spanish documentation is made possible by these community developers: +- [adavie1](https://github.com/adavie1) +- [carmencitaqiu](https://github.com/carmencitaqiu) +- [coderdiaz](https://github.com/coderdiaz) +- [fedegar33](https://github.com/fedegar33) +- [Gonzalo2310](https://github.com/Gonzalo2310) +- [lesterbx](https://github.com/lesterbx) +- [ProgramerGuy](https://github.com/ProgramerGuy) +- [SantiagoGdaR](https://github.com/SantiagoGdaR) +- [sigfriedCub1990](https://github.com/sigfriedCub1990) +- [thechosenjuan](https://github.com/thechosenjuan) + +French documentation is made possible by these community developers: +- [smalesys](https://github.com/smalesys) +- [blombard](https://github.com/blombard) + +## Join Discussion Group + +Scan the QR code using [Dingtalk App](https://www.dingtalk.com/) to join in discussion group : + +Join Discusion Group + + +## LICENSE +[MIT](LICENSE) diff --git a/public/static/libs/element-ui/lib/alert.js b/public/static/libs/element-ui/lib/alert.js new file mode 100644 index 0000000..314a5a4 --- /dev/null +++ b/public/static/libs/element-ui/lib/alert.js @@ -0,0 +1,419 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 102); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 102: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/alert/src/main.vue?vue&type=template&id=6e53341b& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c("transition", { attrs: { name: "el-alert-fade" } }, [ + _c( + "div", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.visible, + expression: "visible" + } + ], + staticClass: "el-alert", + class: [ + _vm.typeClass, + _vm.center ? "is-center" : "", + "is-" + _vm.effect + ], + attrs: { role: "alert" } + }, + [ + _vm.showIcon + ? _c("i", { + staticClass: "el-alert__icon", + class: [_vm.iconClass, _vm.isBigIcon] + }) + : _vm._e(), + _c("div", { staticClass: "el-alert__content" }, [ + _vm.title || _vm.$slots.title + ? _c( + "span", + { staticClass: "el-alert__title", class: [_vm.isBoldTitle] }, + [_vm._t("title", [_vm._v(_vm._s(_vm.title))])], + 2 + ) + : _vm._e(), + _vm.$slots.default && !_vm.description + ? _c( + "p", + { staticClass: "el-alert__description" }, + [_vm._t("default")], + 2 + ) + : _vm._e(), + _vm.description && !_vm.$slots.default + ? _c("p", { staticClass: "el-alert__description" }, [ + _vm._v(_vm._s(_vm.description)) + ]) + : _vm._e(), + _c( + "i", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.closable, + expression: "closable" + } + ], + staticClass: "el-alert__closebtn", + class: { + "is-customed": _vm.closeText !== "", + "el-icon-close": _vm.closeText === "" + }, + on: { + click: function($event) { + _vm.close() + } + } + }, + [_vm._v(_vm._s(_vm.closeText))] + ) + ]) + ] + ) + ]) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/alert/src/main.vue?vue&type=template&id=6e53341b& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/alert/src/main.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + +var TYPE_CLASSES_MAP = { + 'success': 'el-icon-success', + 'warning': 'el-icon-warning', + 'error': 'el-icon-error' +}; +/* harmony default export */ var mainvue_type_script_lang_js_ = ({ + name: 'ElAlert', + + props: { + title: { + type: String, + default: '' + }, + description: { + type: String, + default: '' + }, + type: { + type: String, + default: 'info' + }, + closable: { + type: Boolean, + default: true + }, + closeText: { + type: String, + default: '' + }, + showIcon: Boolean, + center: Boolean, + effect: { + type: String, + default: 'light', + validator: function validator(value) { + return ['light', 'dark'].indexOf(value) !== -1; + } + } + }, + + data: function data() { + return { + visible: true + }; + }, + + + methods: { + close: function close() { + this.visible = false; + this.$emit('close'); + } + }, + + computed: { + typeClass: function typeClass() { + return 'el-alert--' + this.type; + }, + iconClass: function iconClass() { + return TYPE_CLASSES_MAP[this.type] || 'el-icon-info'; + }, + isBigIcon: function isBigIcon() { + return this.description || this.$slots.default ? 'is-big' : ''; + }, + isBoldTitle: function isBoldTitle() { + return this.description || this.$slots.default ? 'is-bold' : ''; + } + } +}); +// CONCATENATED MODULE: ./packages/alert/src/main.vue?vue&type=script&lang=js& + /* harmony default export */ var src_mainvue_type_script_lang_js_ = (mainvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/alert/src/main.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_mainvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/alert/src/main.vue" +/* harmony default export */ var main = (component.exports); +// CONCATENATED MODULE: ./packages/alert/index.js + + +/* istanbul ignore next */ +main.install = function (Vue) { + Vue.component(main.name, main); +}; + +/* harmony default export */ var packages_alert = __webpack_exports__["default"] = (main); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/aside.js b/public/static/libs/element-ui/lib/aside.js new file mode 100644 index 0000000..03cc8eb --- /dev/null +++ b/public/static/libs/element-ui/lib/aside.js @@ -0,0 +1,276 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 118); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 118: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/aside/src/main.vue?vue&type=template&id=03411dbf& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "aside", + { staticClass: "el-aside", style: { width: _vm.width } }, + [_vm._t("default")], + 2 + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/aside/src/main.vue?vue&type=template&id=03411dbf& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/aside/src/main.vue?vue&type=script&lang=js& +// +// +// +// +// +// + +/* harmony default export */ var mainvue_type_script_lang_js_ = ({ + name: 'ElAside', + + componentName: 'ElAside', + + props: { + width: { + type: String, + default: '300px' + } + } +}); +// CONCATENATED MODULE: ./packages/aside/src/main.vue?vue&type=script&lang=js& + /* harmony default export */ var src_mainvue_type_script_lang_js_ = (mainvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/aside/src/main.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_mainvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/aside/src/main.vue" +/* harmony default export */ var main = (component.exports); +// CONCATENATED MODULE: ./packages/aside/index.js + + +/* istanbul ignore next */ +main.install = function (Vue) { + Vue.component(main.name, main); +}; + +/* harmony default export */ var aside = __webpack_exports__["default"] = (main); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/autocomplete.js b/public/static/libs/element-ui/lib/autocomplete.js new file mode 100644 index 0000000..0092536 --- /dev/null +++ b/public/static/libs/element-ui/lib/autocomplete.js @@ -0,0 +1,952 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 65); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 10: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/input"); + +/***/ }), + +/***/ 11: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/migrating"); + +/***/ }), + +/***/ 12: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/clickoutside"); + +/***/ }), + +/***/ 15: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/scrollbar"); + +/***/ }), + +/***/ 19: +/***/ (function(module, exports) { + +module.exports = require("throttle-debounce/debounce"); + +/***/ }), + +/***/ 22: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/focus"); + +/***/ }), + +/***/ 3: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/util"); + +/***/ }), + +/***/ 4: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/emitter"); + +/***/ }), + +/***/ 5: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/vue-popper"); + +/***/ }), + +/***/ 65: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/autocomplete/src/autocomplete.vue?vue&type=template&id=152f2ee6& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { + directives: [ + { + name: "clickoutside", + rawName: "v-clickoutside", + value: _vm.close, + expression: "close" + } + ], + staticClass: "el-autocomplete", + attrs: { + "aria-haspopup": "listbox", + role: "combobox", + "aria-expanded": _vm.suggestionVisible, + "aria-owns": _vm.id + } + }, + [ + _c( + "el-input", + _vm._b( + { + ref: "input", + on: { + input: _vm.handleInput, + change: _vm.handleChange, + focus: _vm.handleFocus, + blur: _vm.handleBlur, + clear: _vm.handleClear + }, + nativeOn: { + keydown: [ + function($event) { + if ( + !("button" in $event) && + _vm._k($event.keyCode, "up", 38, $event.key, [ + "Up", + "ArrowUp" + ]) + ) { + return null + } + $event.preventDefault() + _vm.highlight(_vm.highlightedIndex - 1) + }, + function($event) { + if ( + !("button" in $event) && + _vm._k($event.keyCode, "down", 40, $event.key, [ + "Down", + "ArrowDown" + ]) + ) { + return null + } + $event.preventDefault() + _vm.highlight(_vm.highlightedIndex + 1) + }, + function($event) { + if ( + !("button" in $event) && + _vm._k($event.keyCode, "enter", 13, $event.key, "Enter") + ) { + return null + } + return _vm.handleKeyEnter($event) + }, + function($event) { + if ( + !("button" in $event) && + _vm._k($event.keyCode, "tab", 9, $event.key, "Tab") + ) { + return null + } + return _vm.close($event) + } + ] + } + }, + "el-input", + [_vm.$props, _vm.$attrs], + false + ), + [ + _vm.$slots.prepend + ? _c("template", { slot: "prepend" }, [_vm._t("prepend")], 2) + : _vm._e(), + _vm.$slots.append + ? _c("template", { slot: "append" }, [_vm._t("append")], 2) + : _vm._e(), + _vm.$slots.prefix + ? _c("template", { slot: "prefix" }, [_vm._t("prefix")], 2) + : _vm._e(), + _vm.$slots.suffix + ? _c("template", { slot: "suffix" }, [_vm._t("suffix")], 2) + : _vm._e() + ], + 2 + ), + _c( + "el-autocomplete-suggestions", + { + ref: "suggestions", + class: [_vm.popperClass ? _vm.popperClass : ""], + attrs: { + "visible-arrow": "", + "popper-options": _vm.popperOptions, + "append-to-body": _vm.popperAppendToBody, + placement: _vm.placement, + id: _vm.id + } + }, + _vm._l(_vm.suggestions, function(item, index) { + return _c( + "li", + { + key: index, + class: { highlighted: _vm.highlightedIndex === index }, + attrs: { + id: _vm.id + "-item-" + index, + role: "option", + "aria-selected": _vm.highlightedIndex === index + }, + on: { + click: function($event) { + _vm.select(item) + } + } + }, + [ + _vm._t( + "default", + [ + _vm._v("\n " + _vm._s(item[_vm.valueKey]) + "\n ") + ], + { item: item } + ) + ], + 2 + ) + }), + 0 + ) + ], + 1 + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete.vue?vue&type=template&id=152f2ee6& + +// EXTERNAL MODULE: external "throttle-debounce/debounce" +var debounce_ = __webpack_require__(19); +var debounce_default = /*#__PURE__*/__webpack_require__.n(debounce_); + +// EXTERNAL MODULE: external "element-ui/lib/input" +var input_ = __webpack_require__(10); +var input_default = /*#__PURE__*/__webpack_require__.n(input_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/clickoutside" +var clickoutside_ = __webpack_require__(12); +var clickoutside_default = /*#__PURE__*/__webpack_require__.n(clickoutside_); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/autocomplete/src/autocomplete-suggestions.vue?vue&type=template&id=cd10dcf0& +var autocomplete_suggestionsvue_type_template_id_cd10dcf0_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "transition", + { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": _vm.doDestroy } }, + [ + _c( + "div", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.showPopper, + expression: "showPopper" + } + ], + staticClass: "el-autocomplete-suggestion el-popper", + class: { + "is-loading": !_vm.parent.hideLoading && _vm.parent.loading + }, + style: { width: _vm.dropdownWidth }, + attrs: { role: "region" } + }, + [ + _c( + "el-scrollbar", + { + attrs: { + tag: "ul", + "wrap-class": "el-autocomplete-suggestion__wrap", + "view-class": "el-autocomplete-suggestion__list" + } + }, + [ + !_vm.parent.hideLoading && _vm.parent.loading + ? _c("li", [_c("i", { staticClass: "el-icon-loading" })]) + : _vm._t("default") + ], + 2 + ) + ], + 1 + ) + ] + ) +} +var autocomplete_suggestionsvue_type_template_id_cd10dcf0_staticRenderFns = [] +autocomplete_suggestionsvue_type_template_id_cd10dcf0_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete-suggestions.vue?vue&type=template&id=cd10dcf0& + +// EXTERNAL MODULE: external "element-ui/lib/utils/vue-popper" +var vue_popper_ = __webpack_require__(5); +var vue_popper_default = /*#__PURE__*/__webpack_require__.n(vue_popper_); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/emitter" +var emitter_ = __webpack_require__(4); +var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_); + +// EXTERNAL MODULE: external "element-ui/lib/scrollbar" +var scrollbar_ = __webpack_require__(15); +var scrollbar_default = /*#__PURE__*/__webpack_require__.n(scrollbar_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/autocomplete/src/autocomplete-suggestions.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + +/* harmony default export */ var autocomplete_suggestionsvue_type_script_lang_js_ = ({ + components: { ElScrollbar: scrollbar_default.a }, + mixins: [vue_popper_default.a, emitter_default.a], + + componentName: 'ElAutocompleteSuggestions', + + data: function data() { + return { + parent: this.$parent, + dropdownWidth: '' + }; + }, + + + props: { + options: { + default: function _default() { + return { + gpuAcceleration: false + }; + } + }, + id: String + }, + + methods: { + select: function select(item) { + this.dispatch('ElAutocomplete', 'item-click', item); + } + }, + + updated: function updated() { + var _this = this; + + this.$nextTick(function (_) { + _this.popperJS && _this.updatePopper(); + }); + }, + mounted: function mounted() { + this.$parent.popperElm = this.popperElm = this.$el; + this.referenceElm = this.$parent.$refs.input.$refs.input || this.$parent.$refs.input.$refs.textarea; + this.referenceList = this.$el.querySelector('.el-autocomplete-suggestion__list'); + this.referenceList.setAttribute('role', 'listbox'); + this.referenceList.setAttribute('id', this.id); + }, + created: function created() { + var _this2 = this; + + this.$on('visible', function (val, inputWidth) { + _this2.dropdownWidth = inputWidth + 'px'; + _this2.showPopper = val; + }); + } +}); +// CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete-suggestions.vue?vue&type=script&lang=js& + /* harmony default export */ var src_autocomplete_suggestionsvue_type_script_lang_js_ = (autocomplete_suggestionsvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete-suggestions.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_autocomplete_suggestionsvue_type_script_lang_js_, + autocomplete_suggestionsvue_type_template_id_cd10dcf0_render, + autocomplete_suggestionsvue_type_template_id_cd10dcf0_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/autocomplete/src/autocomplete-suggestions.vue" +/* harmony default export */ var autocomplete_suggestions = (component.exports); +// EXTERNAL MODULE: external "element-ui/lib/mixins/migrating" +var migrating_ = __webpack_require__(11); +var migrating_default = /*#__PURE__*/__webpack_require__.n(migrating_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/util" +var util_ = __webpack_require__(3); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/focus" +var focus_ = __webpack_require__(22); +var focus_default = /*#__PURE__*/__webpack_require__.n(focus_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/autocomplete/src/autocomplete.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + + + + + + +/* harmony default export */ var autocompletevue_type_script_lang_js_ = ({ + name: 'ElAutocomplete', + + mixins: [emitter_default.a, focus_default()('input'), migrating_default.a], + + inheritAttrs: false, + + componentName: 'ElAutocomplete', + + components: { + ElInput: input_default.a, + ElAutocompleteSuggestions: autocomplete_suggestions + }, + + directives: { Clickoutside: clickoutside_default.a }, + + props: { + valueKey: { + type: String, + default: 'value' + }, + popperClass: String, + popperOptions: Object, + placeholder: String, + clearable: { + type: Boolean, + default: false + }, + disabled: Boolean, + name: String, + size: String, + value: String, + maxlength: Number, + minlength: Number, + autofocus: Boolean, + fetchSuggestions: Function, + triggerOnFocus: { + type: Boolean, + default: true + }, + customItem: String, + selectWhenUnmatched: { + type: Boolean, + default: false + }, + prefixIcon: String, + suffixIcon: String, + label: String, + debounce: { + type: Number, + default: 300 + }, + placement: { + type: String, + default: 'bottom-start' + }, + hideLoading: Boolean, + popperAppendToBody: { + type: Boolean, + default: true + }, + highlightFirstItem: { + type: Boolean, + default: false + } + }, + data: function data() { + return { + activated: false, + suggestions: [], + loading: false, + highlightedIndex: -1, + suggestionDisabled: false + }; + }, + + computed: { + suggestionVisible: function suggestionVisible() { + var suggestions = this.suggestions; + var isValidData = Array.isArray(suggestions) && suggestions.length > 0; + return (isValidData || this.loading) && this.activated; + }, + id: function id() { + return 'el-autocomplete-' + Object(util_["generateId"])(); + } + }, + watch: { + suggestionVisible: function suggestionVisible(val) { + var $input = this.getInput(); + if ($input) { + this.broadcast('ElAutocompleteSuggestions', 'visible', [val, $input.offsetWidth]); + } + } + }, + methods: { + getMigratingConfig: function getMigratingConfig() { + return { + props: { + 'custom-item': 'custom-item is removed, use scoped slot instead.', + 'props': 'props is removed, use value-key instead.' + } + }; + }, + getData: function getData(queryString) { + var _this = this; + + if (this.suggestionDisabled) { + return; + } + this.loading = true; + this.fetchSuggestions(queryString, function (suggestions) { + _this.loading = false; + if (_this.suggestionDisabled) { + return; + } + if (Array.isArray(suggestions)) { + _this.suggestions = suggestions; + _this.highlightedIndex = _this.highlightFirstItem ? 0 : -1; + } else { + console.error('[Element Error][Autocomplete]autocomplete suggestions must be an array'); + } + }); + }, + handleInput: function handleInput(value) { + this.$emit('input', value); + this.suggestionDisabled = false; + if (!this.triggerOnFocus && !value) { + this.suggestionDisabled = true; + this.suggestions = []; + return; + } + this.debouncedGetData(value); + }, + handleChange: function handleChange(value) { + this.$emit('change', value); + }, + handleFocus: function handleFocus(event) { + this.activated = true; + this.$emit('focus', event); + if (this.triggerOnFocus) { + this.debouncedGetData(this.value); + } + }, + handleBlur: function handleBlur(event) { + this.$emit('blur', event); + }, + handleClear: function handleClear() { + this.activated = false; + this.$emit('clear'); + }, + close: function close(e) { + this.activated = false; + }, + handleKeyEnter: function handleKeyEnter(e) { + var _this2 = this; + + if (this.suggestionVisible && this.highlightedIndex >= 0 && this.highlightedIndex < this.suggestions.length) { + e.preventDefault(); + this.select(this.suggestions[this.highlightedIndex]); + } else if (this.selectWhenUnmatched) { + this.$emit('select', { value: this.value }); + this.$nextTick(function (_) { + _this2.suggestions = []; + _this2.highlightedIndex = -1; + }); + } + }, + select: function select(item) { + var _this3 = this; + + this.$emit('input', item[this.valueKey]); + this.$emit('select', item); + this.$nextTick(function (_) { + _this3.suggestions = []; + _this3.highlightedIndex = -1; + }); + }, + highlight: function highlight(index) { + if (!this.suggestionVisible || this.loading) { + return; + } + if (index < 0) { + this.highlightedIndex = -1; + return; + } + if (index >= this.suggestions.length) { + index = this.suggestions.length - 1; + } + var suggestion = this.$refs.suggestions.$el.querySelector('.el-autocomplete-suggestion__wrap'); + var suggestionList = suggestion.querySelectorAll('.el-autocomplete-suggestion__list li'); + + var highlightItem = suggestionList[index]; + var scrollTop = suggestion.scrollTop; + var offsetTop = highlightItem.offsetTop; + + if (offsetTop + highlightItem.scrollHeight > scrollTop + suggestion.clientHeight) { + suggestion.scrollTop += highlightItem.scrollHeight; + } + if (offsetTop < scrollTop) { + suggestion.scrollTop -= highlightItem.scrollHeight; + } + this.highlightedIndex = index; + var $input = this.getInput(); + $input.setAttribute('aria-activedescendant', this.id + '-item-' + this.highlightedIndex); + }, + getInput: function getInput() { + return this.$refs.input.getInput(); + } + }, + mounted: function mounted() { + var _this4 = this; + + this.debouncedGetData = debounce_default()(this.debounce, this.getData); + this.$on('item-click', function (item) { + _this4.select(item); + }); + var $input = this.getInput(); + $input.setAttribute('role', 'textbox'); + $input.setAttribute('aria-autocomplete', 'list'); + $input.setAttribute('aria-controls', 'id'); + $input.setAttribute('aria-activedescendant', this.id + '-item-' + this.highlightedIndex); + }, + beforeDestroy: function beforeDestroy() { + this.$refs.suggestions.$destroy(); + } +}); +// CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete.vue?vue&type=script&lang=js& + /* harmony default export */ var src_autocompletevue_type_script_lang_js_ = (autocompletevue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete.vue + + + + + +/* normalize component */ + +var autocomplete_component = Object(componentNormalizer["a" /* default */])( + src_autocompletevue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var autocomplete_api; } +autocomplete_component.options.__file = "packages/autocomplete/src/autocomplete.vue" +/* harmony default export */ var autocomplete = (autocomplete_component.exports); +// CONCATENATED MODULE: ./packages/autocomplete/index.js + + +/* istanbul ignore next */ +autocomplete.install = function (Vue) { + Vue.component(autocomplete.name, autocomplete); +}; + +/* harmony default export */ var packages_autocomplete = __webpack_exports__["default"] = (autocomplete); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/avatar.js b/public/static/libs/element-ui/lib/avatar.js new file mode 100644 index 0000000..348f328 --- /dev/null +++ b/public/static/libs/element-ui/lib/avatar.js @@ -0,0 +1,362 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 135); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 135: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/avatar/src/main.vue?vue&type=script&lang=js& + +/* harmony default export */ var mainvue_type_script_lang_js_ = ({ + name: 'ElAvatar', + + props: { + size: { + type: [Number, String], + validator: function validator(val) { + if (typeof val === 'string') { + return ['large', 'medium', 'small'].includes(val); + } + return typeof val === 'number'; + } + }, + shape: { + type: String, + default: 'circle', + validator: function validator(val) { + return ['circle', 'square'].includes(val); + } + }, + icon: String, + src: String, + alt: String, + srcSet: String, + error: Function, + fit: { + type: String, + default: 'cover' + } + }, + + data: function data() { + return { + isImageExist: true + }; + }, + + + computed: { + avatarClass: function avatarClass() { + var size = this.size, + icon = this.icon, + shape = this.shape; + + var classList = ['el-avatar']; + + if (size && typeof size === 'string') { + classList.push('el-avatar--' + size); + } + + if (icon) { + classList.push('el-avatar--icon'); + } + + if (shape) { + classList.push('el-avatar--' + shape); + } + + return classList.join(' '); + } + }, + + methods: { + handleError: function handleError() { + var error = this.error; + + var errorFlag = error ? error() : undefined; + if (errorFlag !== false) { + this.isImageExist = false; + } + }, + renderAvatar: function renderAvatar() { + var h = this.$createElement; + var icon = this.icon, + src = this.src, + alt = this.alt, + isImageExist = this.isImageExist, + srcSet = this.srcSet, + fit = this.fit; + + + if (isImageExist && src) { + return h('img', { + attrs: { + src: src, + + alt: alt, + srcSet: srcSet + }, + on: { + 'error': this.handleError + }, + style: { 'object-fit': fit } }); + } + + if (icon) { + return h('i', { 'class': icon }); + } + + return this.$slots.default; + } + }, + + render: function render() { + var h = arguments[0]; + var avatarClass = this.avatarClass, + size = this.size; + + + var sizeStyle = typeof size === 'number' ? { + height: size + 'px', + width: size + 'px', + lineHeight: size + 'px' + } : {}; + + return h( + 'span', + { 'class': avatarClass, style: sizeStyle }, + [this.renderAvatar()] + ); + } +}); +// CONCATENATED MODULE: ./packages/avatar/src/main.vue?vue&type=script&lang=js& + /* harmony default export */ var src_mainvue_type_script_lang_js_ = (mainvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/avatar/src/main.vue +var render, staticRenderFns + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_mainvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/avatar/src/main.vue" +/* harmony default export */ var main = (component.exports); +// CONCATENATED MODULE: ./packages/avatar/index.js + + +/* istanbul ignore next */ +main.install = function (Vue) { + Vue.component(main.name, main); +}; + +/* harmony default export */ var avatar = __webpack_exports__["default"] = (main); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/backtop.js b/public/static/libs/element-ui/lib/backtop.js new file mode 100644 index 0000000..293f5cc --- /dev/null +++ b/public/static/libs/element-ui/lib/backtop.js @@ -0,0 +1,401 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 124); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 124: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/backtop/src/main.vue?vue&type=template&id=257dd4a9& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c("transition", { attrs: { name: "el-fade-in" } }, [ + _vm.visible + ? _c( + "div", + { + staticClass: "el-backtop", + style: { + right: _vm.styleRight, + bottom: _vm.styleBottom + }, + on: { + click: function($event) { + $event.stopPropagation() + return _vm.handleClick($event) + } + } + }, + [ + _vm._t("default", [_c("el-icon", { attrs: { name: "caret-top" } })]) + ], + 2 + ) + : _vm._e() + ]) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/backtop/src/main.vue?vue&type=template&id=257dd4a9& + +// EXTERNAL MODULE: external "throttle-debounce/throttle" +var throttle_ = __webpack_require__(25); +var throttle_default = /*#__PURE__*/__webpack_require__.n(throttle_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/backtop/src/main.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + +var cubic = function cubic(value) { + return Math.pow(value, 3); +}; +var easeInOutCubic = function easeInOutCubic(value) { + return value < 0.5 ? cubic(value * 2) / 2 : 1 - cubic((1 - value) * 2) / 2; +}; + +/* harmony default export */ var mainvue_type_script_lang_js_ = ({ + name: 'ElBacktop', + + props: { + visibilityHeight: { + type: Number, + default: 200 + }, + target: [String], + right: { + type: Number, + default: 40 + }, + bottom: { + type: Number, + default: 40 + } + }, + + data: function data() { + return { + el: null, + container: null, + visible: false + }; + }, + + + computed: { + styleBottom: function styleBottom() { + return this.bottom + 'px'; + }, + styleRight: function styleRight() { + return this.right + 'px'; + } + }, + + mounted: function mounted() { + this.init(); + this.throttledScrollHandler = throttle_default()(300, this.onScroll); + this.container.addEventListener('scroll', this.throttledScrollHandler); + }, + + + methods: { + init: function init() { + this.container = document; + this.el = document.documentElement; + if (this.target) { + this.el = document.querySelector(this.target); + if (!this.el) { + throw new Error('target is not existed: ' + this.target); + } + this.container = this.el; + } + }, + onScroll: function onScroll() { + var scrollTop = this.el.scrollTop; + this.visible = scrollTop >= this.visibilityHeight; + }, + handleClick: function handleClick(e) { + this.scrollToTop(); + this.$emit('click', e); + }, + scrollToTop: function scrollToTop() { + var el = this.el; + var beginTime = Date.now(); + var beginValue = el.scrollTop; + var rAF = window.requestAnimationFrame || function (func) { + return setTimeout(func, 16); + }; + var frameFunc = function frameFunc() { + var progress = (Date.now() - beginTime) / 500; + if (progress < 1) { + el.scrollTop = beginValue * (1 - easeInOutCubic(progress)); + rAF(frameFunc); + } else { + el.scrollTop = 0; + } + }; + rAF(frameFunc); + } + }, + + beforeDestroy: function beforeDestroy() { + this.container.removeEventListener('scroll', this.throttledScrollHandler); + } +}); +// CONCATENATED MODULE: ./packages/backtop/src/main.vue?vue&type=script&lang=js& + /* harmony default export */ var src_mainvue_type_script_lang_js_ = (mainvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/backtop/src/main.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_mainvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/backtop/src/main.vue" +/* harmony default export */ var main = (component.exports); +// CONCATENATED MODULE: ./packages/backtop/index.js + + +/* istanbul ignore next */ +main.install = function (Vue) { + Vue.component(main.name, main); +}; + +/* harmony default export */ var backtop = __webpack_exports__["default"] = (main); + +/***/ }), + +/***/ 25: +/***/ (function(module, exports) { + +module.exports = require("throttle-debounce/throttle"); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/badge.js b/public/static/libs/element-ui/lib/badge.js new file mode 100644 index 0000000..404f54c --- /dev/null +++ b/public/static/libs/element-ui/lib/badge.js @@ -0,0 +1,333 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 106); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 106: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/badge/src/main.vue?vue&type=template&id=7ccb6598& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { staticClass: "el-badge" }, + [ + _vm._t("default"), + _c("transition", { attrs: { name: "el-zoom-in-center" } }, [ + _c("sup", { + directives: [ + { + name: "show", + rawName: "v-show", + value: + !_vm.hidden && (_vm.content || _vm.content === 0 || _vm.isDot), + expression: "!hidden && (content || content === 0 || isDot)" + } + ], + staticClass: "el-badge__content", + class: [ + _vm.type ? "el-badge__content--" + _vm.type : null, + { + "is-fixed": _vm.$slots.default, + "is-dot": _vm.isDot + } + ], + domProps: { textContent: _vm._s(_vm.content) } + }) + ]) + ], + 2 + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/badge/src/main.vue?vue&type=template&id=7ccb6598& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/badge/src/main.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + +/* harmony default export */ var mainvue_type_script_lang_js_ = ({ + name: 'ElBadge', + + props: { + value: [String, Number], + max: Number, + isDot: Boolean, + hidden: Boolean, + type: { + type: String, + validator: function validator(val) { + return ['primary', 'success', 'warning', 'info', 'danger'].indexOf(val) > -1; + } + } + }, + + computed: { + content: function content() { + if (this.isDot) return; + + var value = this.value; + var max = this.max; + + if (typeof value === 'number' && typeof max === 'number') { + return max < value ? max + '+' : value; + } + + return value; + } + } +}); +// CONCATENATED MODULE: ./packages/badge/src/main.vue?vue&type=script&lang=js& + /* harmony default export */ var src_mainvue_type_script_lang_js_ = (mainvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/badge/src/main.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_mainvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/badge/src/main.vue" +/* harmony default export */ var main = (component.exports); +// CONCATENATED MODULE: ./packages/badge/index.js + + +/* istanbul ignore next */ +main.install = function (Vue) { + Vue.component(main.name, main); +}; + +/* harmony default export */ var badge = __webpack_exports__["default"] = (main); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/breadcrumb-item.js b/public/static/libs/element-ui/lib/breadcrumb-item.js new file mode 100644 index 0000000..7a5f457 --- /dev/null +++ b/public/static/libs/element-ui/lib/breadcrumb-item.js @@ -0,0 +1,321 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 99); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 99: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/breadcrumb/src/breadcrumb-item.vue?vue&type=template&id=fcf9eaac& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c("span", { staticClass: "el-breadcrumb__item" }, [ + _c( + "span", + { + ref: "link", + class: ["el-breadcrumb__inner", _vm.to ? "is-link" : ""], + attrs: { role: "link" } + }, + [_vm._t("default")], + 2 + ), + _vm.separatorClass + ? _c("i", { + staticClass: "el-breadcrumb__separator", + class: _vm.separatorClass + }) + : _c( + "span", + { + staticClass: "el-breadcrumb__separator", + attrs: { role: "presentation" } + }, + [_vm._v(_vm._s(_vm.separator))] + ) + ]) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb-item.vue?vue&type=template&id=fcf9eaac& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/breadcrumb/src/breadcrumb-item.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// + +/* harmony default export */ var breadcrumb_itemvue_type_script_lang_js_ = ({ + name: 'ElBreadcrumbItem', + props: { + to: {}, + replace: Boolean + }, + data: function data() { + return { + separator: '', + separatorClass: '' + }; + }, + + + inject: ['elBreadcrumb'], + + mounted: function mounted() { + var _this = this; + + this.separator = this.elBreadcrumb.separator; + this.separatorClass = this.elBreadcrumb.separatorClass; + var link = this.$refs.link; + link.setAttribute('role', 'link'); + link.addEventListener('click', function (_) { + var to = _this.to, + $router = _this.$router; + + if (!to || !$router) return; + _this.replace ? $router.replace(to) : $router.push(to); + }); + } +}); +// CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb-item.vue?vue&type=script&lang=js& + /* harmony default export */ var src_breadcrumb_itemvue_type_script_lang_js_ = (breadcrumb_itemvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb-item.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_breadcrumb_itemvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/breadcrumb/src/breadcrumb-item.vue" +/* harmony default export */ var breadcrumb_item = (component.exports); +// CONCATENATED MODULE: ./packages/breadcrumb-item/index.js + + +/* istanbul ignore next */ +breadcrumb_item.install = function (Vue) { + Vue.component(breadcrumb_item.name, breadcrumb_item); +}; + +/* harmony default export */ var packages_breadcrumb_item = __webpack_exports__["default"] = (breadcrumb_item); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/breadcrumb.js b/public/static/libs/element-ui/lib/breadcrumb.js new file mode 100644 index 0000000..4a852d4 --- /dev/null +++ b/public/static/libs/element-ui/lib/breadcrumb.js @@ -0,0 +1,292 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 98); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 98: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/breadcrumb/src/breadcrumb.vue?vue&type=template&id=4b464c06& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { + staticClass: "el-breadcrumb", + attrs: { "aria-label": "Breadcrumb", role: "navigation" } + }, + [_vm._t("default")], + 2 + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb.vue?vue&type=template&id=4b464c06& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/breadcrumb/src/breadcrumb.vue?vue&type=script&lang=js& +// +// +// +// +// + +/* harmony default export */ var breadcrumbvue_type_script_lang_js_ = ({ + name: 'ElBreadcrumb', + + props: { + separator: { + type: String, + default: '/' + }, + separatorClass: { + type: String, + default: '' + } + }, + + provide: function provide() { + return { + elBreadcrumb: this + }; + }, + mounted: function mounted() { + var items = this.$el.querySelectorAll('.el-breadcrumb__item'); + if (items.length) { + items[items.length - 1].setAttribute('aria-current', 'page'); + } + } +}); +// CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb.vue?vue&type=script&lang=js& + /* harmony default export */ var src_breadcrumbvue_type_script_lang_js_ = (breadcrumbvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_breadcrumbvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/breadcrumb/src/breadcrumb.vue" +/* harmony default export */ var breadcrumb = (component.exports); +// CONCATENATED MODULE: ./packages/breadcrumb/index.js + + +/* istanbul ignore next */ +breadcrumb.install = function (Vue) { + Vue.component(breadcrumb.name, breadcrumb); +}; + +/* harmony default export */ var packages_breadcrumb = __webpack_exports__["default"] = (breadcrumb); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/button-group.js b/public/static/libs/element-ui/lib/button-group.js new file mode 100644 index 0000000..a485d42 --- /dev/null +++ b/public/static/libs/element-ui/lib/button-group.js @@ -0,0 +1,261 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 97); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 97: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/button/src/button-group.vue?vue&type=template&id=3d8661d0& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c("div", { staticClass: "el-button-group" }, [_vm._t("default")], 2) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/button/src/button-group.vue?vue&type=template&id=3d8661d0& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/button/src/button-group.vue?vue&type=script&lang=js& +// +// +// +// +// + +/* harmony default export */ var button_groupvue_type_script_lang_js_ = ({ + name: 'ElButtonGroup' +}); +// CONCATENATED MODULE: ./packages/button/src/button-group.vue?vue&type=script&lang=js& + /* harmony default export */ var src_button_groupvue_type_script_lang_js_ = (button_groupvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/button/src/button-group.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_button_groupvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/button/src/button-group.vue" +/* harmony default export */ var button_group = (component.exports); +// CONCATENATED MODULE: ./packages/button-group/index.js + + +/* istanbul ignore next */ +button_group.install = function (Vue) { + Vue.component(button_group.name, button_group); +}; + +/* harmony default export */ var packages_button_group = __webpack_exports__["default"] = (button_group); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/button.js b/public/static/libs/element-ui/lib/button.js new file mode 100644 index 0000000..a56fb27 --- /dev/null +++ b/public/static/libs/element-ui/lib/button.js @@ -0,0 +1,356 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 96); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 96: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/button/src/button.vue?vue&type=template&id=ca859fb4& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "button", + { + staticClass: "el-button", + class: [ + _vm.type ? "el-button--" + _vm.type : "", + _vm.buttonSize ? "el-button--" + _vm.buttonSize : "", + { + "is-disabled": _vm.buttonDisabled, + "is-loading": _vm.loading, + "is-plain": _vm.plain, + "is-round": _vm.round, + "is-circle": _vm.circle + } + ], + attrs: { + disabled: _vm.buttonDisabled || _vm.loading, + autofocus: _vm.autofocus, + type: _vm.nativeType + }, + on: { click: _vm.handleClick } + }, + [ + _vm.loading ? _c("i", { staticClass: "el-icon-loading" }) : _vm._e(), + _vm.icon && !_vm.loading ? _c("i", { class: _vm.icon }) : _vm._e(), + _vm.$slots.default ? _c("span", [_vm._t("default")], 2) : _vm._e() + ] + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/button/src/button.vue?vue&type=template&id=ca859fb4& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/button/src/button.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + +/* harmony default export */ var buttonvue_type_script_lang_js_ = ({ + name: 'ElButton', + + inject: { + elForm: { + default: '' + }, + elFormItem: { + default: '' + } + }, + + props: { + type: { + type: String, + default: 'default' + }, + size: String, + icon: { + type: String, + default: '' + }, + nativeType: { + type: String, + default: 'button' + }, + loading: Boolean, + disabled: Boolean, + plain: Boolean, + autofocus: Boolean, + round: Boolean, + circle: Boolean + }, + + computed: { + _elFormItemSize: function _elFormItemSize() { + return (this.elFormItem || {}).elFormItemSize; + }, + buttonSize: function buttonSize() { + return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size; + }, + buttonDisabled: function buttonDisabled() { + return this.$options.propsData.hasOwnProperty('disabled') ? this.disabled : (this.elForm || {}).disabled; + } + }, + + methods: { + handleClick: function handleClick(evt) { + this.$emit('click', evt); + } + } +}); +// CONCATENATED MODULE: ./packages/button/src/button.vue?vue&type=script&lang=js& + /* harmony default export */ var src_buttonvue_type_script_lang_js_ = (buttonvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/button/src/button.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_buttonvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/button/src/button.vue" +/* harmony default export */ var src_button = (component.exports); +// CONCATENATED MODULE: ./packages/button/index.js + + +/* istanbul ignore next */ +src_button.install = function (Vue) { + Vue.component(src_button.name, src_button); +}; + +/* harmony default export */ var packages_button = __webpack_exports__["default"] = (src_button); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/calendar.js b/public/static/libs/element-ui/lib/calendar.js new file mode 100644 index 0000000..e47dd92 --- /dev/null +++ b/public/static/libs/element-ui/lib/calendar.js @@ -0,0 +1,935 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 71); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 1: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/date-util"); + +/***/ }), + +/***/ 14: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/button"); + +/***/ }), + +/***/ 24: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/date"); + +/***/ }), + +/***/ 36: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/button-group"); + +/***/ }), + +/***/ 6: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/locale"); + +/***/ }), + +/***/ 71: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/calendar/src/main.vue?vue&type=template&id=6d9756be& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c("div", { staticClass: "el-calendar" }, [ + _c("div", { staticClass: "el-calendar__header" }, [ + _c("div", { staticClass: "el-calendar__title" }, [ + _vm._v("\n " + _vm._s(_vm.i18nDate) + "\n ") + ]), + _vm.validatedRange.length === 0 + ? _c( + "div", + { staticClass: "el-calendar__button-group" }, + [ + _c( + "el-button-group", + [ + _c( + "el-button", + { + attrs: { type: "plain", size: "mini" }, + on: { + click: function($event) { + _vm.selectDate("prev-month") + } + } + }, + [ + _vm._v( + "\n " + + _vm._s(_vm.t("el.datepicker.prevMonth")) + + "\n " + ) + ] + ), + _c( + "el-button", + { + attrs: { type: "plain", size: "mini" }, + on: { + click: function($event) { + _vm.selectDate("today") + } + } + }, + [ + _vm._v( + "\n " + + _vm._s(_vm.t("el.datepicker.today")) + + "\n " + ) + ] + ), + _c( + "el-button", + { + attrs: { type: "plain", size: "mini" }, + on: { + click: function($event) { + _vm.selectDate("next-month") + } + } + }, + [ + _vm._v( + "\n " + + _vm._s(_vm.t("el.datepicker.nextMonth")) + + "\n " + ) + ] + ) + ], + 1 + ) + ], + 1 + ) + : _vm._e() + ]), + _vm.validatedRange.length === 0 + ? _c( + "div", + { key: "no-range", staticClass: "el-calendar__body" }, + [ + _c("date-table", { + attrs: { + date: _vm.date, + "selected-day": _vm.realSelectedDay, + "first-day-of-week": _vm.realFirstDayOfWeek + }, + on: { pick: _vm.pickDay } + }) + ], + 1 + ) + : _c( + "div", + { key: "has-range", staticClass: "el-calendar__body" }, + _vm._l(_vm.validatedRange, function(range, index) { + return _c("date-table", { + key: index, + attrs: { + date: range[0], + "selected-day": _vm.realSelectedDay, + range: range, + "hide-header": index !== 0, + "first-day-of-week": _vm.realFirstDayOfWeek + }, + on: { pick: _vm.pickDay } + }) + }), + 1 + ) + ]) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/calendar/src/main.vue?vue&type=template&id=6d9756be& + +// EXTERNAL MODULE: external "element-ui/lib/mixins/locale" +var locale_ = __webpack_require__(6); +var locale_default = /*#__PURE__*/__webpack_require__.n(locale_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/date" +var date_ = __webpack_require__(24); +var date_default = /*#__PURE__*/__webpack_require__.n(date_); + +// EXTERNAL MODULE: external "element-ui/lib/button" +var button_ = __webpack_require__(14); +var button_default = /*#__PURE__*/__webpack_require__.n(button_); + +// EXTERNAL MODULE: external "element-ui/lib/button-group" +var button_group_ = __webpack_require__(36); +var button_group_default = /*#__PURE__*/__webpack_require__.n(button_group_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/date-util" +var date_util_ = __webpack_require__(1); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/calendar/src/date-table.vue?vue&type=script&lang=js& + + + + +/* harmony default export */ var date_tablevue_type_script_lang_js_ = ({ + props: { + selectedDay: String, // formated date yyyy-MM-dd + range: { + type: Array, + validator: function validator(val) { + if (!(val && val.length)) return true; + var start = val[0], + end = val[1]; + + return Object(date_util_["validateRangeInOneMonth"])(start, end); + } + }, + date: Date, + hideHeader: Boolean, + firstDayOfWeek: Number + }, + + inject: ['elCalendar'], + + methods: { + toNestedArr: function toNestedArr(days) { + return Object(date_util_["range"])(days.length / 7).map(function (_, index) { + var start = index * 7; + return days.slice(start, start + 7); + }); + }, + getFormateDate: function getFormateDate(day, type) { + if (!day || ['prev', 'current', 'next'].indexOf(type) === -1) { + throw new Error('invalid day or type'); + } + var prefix = this.curMonthDatePrefix; + if (type === 'prev') { + prefix = this.prevMonthDatePrefix; + } else if (type === 'next') { + prefix = this.nextMonthDatePrefix; + } + day = ('00' + day).slice(-2); + return prefix + '-' + day; + }, + getCellClass: function getCellClass(_ref) { + var text = _ref.text, + type = _ref.type; + + var classes = [type]; + if (type === 'current') { + var date = this.getFormateDate(text, type); + if (date === this.selectedDay) { + classes.push('is-selected'); + } + if (date === this.formatedToday) { + classes.push('is-today'); + } + } + return classes; + }, + pickDay: function pickDay(_ref2) { + var text = _ref2.text, + type = _ref2.type; + + var date = this.getFormateDate(text, type); + this.$emit('pick', date); + }, + cellRenderProxy: function cellRenderProxy(_ref3) { + var text = _ref3.text, + type = _ref3.type; + var h = this.$createElement; + + var render = this.elCalendar.$scopedSlots.dateCell; + if (!render) return h('span', [text]); + + var day = this.getFormateDate(text, type); + var date = new Date(day); + var data = { + isSelected: this.selectedDay === day, + type: type + '-month', + day: day + }; + return render({ date: date, data: data }); + } + }, + + computed: { + WEEK_DAYS: function WEEK_DAYS() { + return Object(date_util_["getI18nSettings"])().dayNames; + }, + prevMonthDatePrefix: function prevMonthDatePrefix() { + var temp = new Date(this.date.getTime()); + temp.setDate(0); + return date_default.a.format(temp, 'yyyy-MM'); + }, + curMonthDatePrefix: function curMonthDatePrefix() { + return date_default.a.format(this.date, 'yyyy-MM'); + }, + nextMonthDatePrefix: function nextMonthDatePrefix() { + var temp = new Date(this.date.getFullYear(), this.date.getMonth() + 1, 1); + return date_default.a.format(temp, 'yyyy-MM'); + }, + formatedToday: function formatedToday() { + return this.elCalendar.formatedToday; + }, + isInRange: function isInRange() { + return this.range && this.range.length; + }, + rows: function rows() { + var days = []; + // if range exists, should render days in range. + if (this.isInRange) { + var _range = this.range, + start = _range[0], + end = _range[1]; + + var currentMonthRange = Object(date_util_["range"])(end.getDate() - start.getDate() + 1).map(function (_, index) { + return { + text: start.getDate() + index, + type: 'current' + }; + }); + var remaining = currentMonthRange.length % 7; + remaining = remaining === 0 ? 0 : 7 - remaining; + var nextMonthRange = Object(date_util_["range"])(remaining).map(function (_, index) { + return { + text: index + 1, + type: 'next' + }; + }); + days = currentMonthRange.concat(nextMonthRange); + } else { + var date = this.date; + var firstDay = Object(date_util_["getFirstDayOfMonth"])(date); + firstDay = firstDay === 0 ? 7 : firstDay; + var firstDayOfWeek = typeof this.firstDayOfWeek === 'number' ? this.firstDayOfWeek : 1; + var offset = (7 + firstDay - firstDayOfWeek) % 7; + var prevMonthDays = Object(date_util_["getPrevMonthLastDays"])(date, offset).map(function (day) { + return { + text: day, + type: 'prev' + }; + }); + var currentMonthDays = Object(date_util_["getMonthDays"])(date).map(function (day) { + return { + text: day, + type: 'current' + }; + }); + days = [].concat(prevMonthDays, currentMonthDays); + var nextMonthDays = Object(date_util_["range"])(42 - days.length).map(function (_, index) { + return { + text: index + 1, + type: 'next' + }; + }); + days = days.concat(nextMonthDays); + } + return this.toNestedArr(days); + }, + weekDays: function weekDays() { + var start = this.firstDayOfWeek; + var WEEK_DAYS = this.WEEK_DAYS; + + + if (typeof start !== 'number' || start === 0) { + return WEEK_DAYS.slice(); + } else { + return WEEK_DAYS.slice(start).concat(WEEK_DAYS.slice(0, start)); + } + } + }, + + render: function render() { + var _this = this; + + var h = arguments[0]; + + var thead = this.hideHeader ? null : h('thead', [this.weekDays.map(function (day) { + return h( + 'th', + { key: day }, + [day] + ); + })]); + return h( + 'table', + { + 'class': { + 'el-calendar-table': true, + 'is-range': this.isInRange + }, + attrs: { cellspacing: '0', + cellpadding: '0' } + }, + [thead, h('tbody', [this.rows.map(function (row, index) { + return h( + 'tr', + { + 'class': { + 'el-calendar-table__row': true, + 'el-calendar-table__row--hide-border': index === 0 && _this.hideHeader + }, + key: index }, + [row.map(function (cell, key) { + return h( + 'td', + { key: key, + 'class': _this.getCellClass(cell), + on: { + 'click': _this.pickDay.bind(_this, cell) + } + }, + [h( + 'div', + { 'class': 'el-calendar-day' }, + [_this.cellRenderProxy(cell)] + )] + ); + })] + ); + })])] + ); + } +}); +// CONCATENATED MODULE: ./packages/calendar/src/date-table.vue?vue&type=script&lang=js& + /* harmony default export */ var src_date_tablevue_type_script_lang_js_ = (date_tablevue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/calendar/src/date-table.vue +var date_table_render, date_table_staticRenderFns + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_date_tablevue_type_script_lang_js_, + date_table_render, + date_table_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/calendar/src/date-table.vue" +/* harmony default export */ var date_table = (component.exports); +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/calendar/src/main.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + + + + +var validTypes = ['prev-month', 'today', 'next-month']; +var weekDays = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday']; +var oneDay = 86400000; + +/* harmony default export */ var mainvue_type_script_lang_js_ = ({ + name: 'ElCalendar', + + mixins: [locale_default.a], + + components: { + DateTable: date_table, + ElButton: button_default.a, + ElButtonGroup: button_group_default.a + }, + + props: { + value: [Date, String, Number], + range: { + type: Array, + validator: function validator(range) { + if (Array.isArray(range)) { + return range.length === 2 && range.every(function (item) { + return typeof item === 'string' || typeof item === 'number' || item instanceof Date; + }); + } else { + return true; + } + } + }, + firstDayOfWeek: { + type: Number, + default: 1 + } + }, + + provide: function provide() { + return { + elCalendar: this + }; + }, + + + methods: { + pickDay: function pickDay(day) { + this.realSelectedDay = day; + }, + selectDate: function selectDate(type) { + if (validTypes.indexOf(type) === -1) { + throw new Error('invalid type ' + type); + } + var day = ''; + if (type === 'prev-month') { + day = this.prevMonthDatePrefix + '-01'; + } else if (type === 'next-month') { + day = this.nextMonthDatePrefix + '-01'; + } else { + day = this.formatedToday; + } + + if (day === this.formatedDate) return; + this.pickDay(day); + }, + toDate: function toDate(val) { + if (!val) { + throw new Error('invalid val'); + } + return val instanceof Date ? val : new Date(val); + }, + rangeValidator: function rangeValidator(date, isStart) { + var firstDayOfWeek = this.realFirstDayOfWeek; + var expected = isStart ? firstDayOfWeek : firstDayOfWeek === 0 ? 6 : firstDayOfWeek - 1; + var message = (isStart ? 'start' : 'end') + ' of range should be ' + weekDays[expected] + '.'; + if (date.getDay() !== expected) { + console.warn('[ElementCalendar]', message, 'Invalid range will be ignored.'); + return false; + } + return true; + } + }, + + computed: { + prevMonthDatePrefix: function prevMonthDatePrefix() { + var temp = new Date(this.date.getTime()); + temp.setDate(0); + return date_default.a.format(temp, 'yyyy-MM'); + }, + curMonthDatePrefix: function curMonthDatePrefix() { + return date_default.a.format(this.date, 'yyyy-MM'); + }, + nextMonthDatePrefix: function nextMonthDatePrefix() { + var temp = new Date(this.date.getFullYear(), this.date.getMonth() + 1, 1); + return date_default.a.format(temp, 'yyyy-MM'); + }, + formatedDate: function formatedDate() { + return date_default.a.format(this.date, 'yyyy-MM-dd'); + }, + i18nDate: function i18nDate() { + var year = this.date.getFullYear(); + var month = this.date.getMonth() + 1; + return year + ' ' + this.t('el.datepicker.year') + ' ' + this.t('el.datepicker.month' + month); + }, + formatedToday: function formatedToday() { + return date_default.a.format(this.now, 'yyyy-MM-dd'); + }, + + + realSelectedDay: { + get: function get() { + if (!this.value) return this.selectedDay; + return this.formatedDate; + }, + set: function set(val) { + this.selectedDay = val; + var date = new Date(val); + this.$emit('input', date); + } + }, + + date: function date() { + if (!this.value) { + if (this.realSelectedDay) { + var d = this.selectedDay.split('-'); + return new Date(d[0], d[1] - 1, d[2]); + } else if (this.validatedRange.length) { + return this.validatedRange[0][0]; + } + return this.now; + } else { + return this.toDate(this.value); + } + }, + + + // if range is valid, we get a two-digit array + validatedRange: function validatedRange() { + var _this = this; + + var range = this.range; + if (!range) return []; + range = range.reduce(function (prev, val, index) { + var date = _this.toDate(val); + if (_this.rangeValidator(date, index === 0)) { + prev = prev.concat(date); + } + return prev; + }, []); + if (range.length === 2) { + var _range = range, + start = _range[0], + end = _range[1]; + + if (start > end) { + console.warn('[ElementCalendar]end time should be greater than start time'); + return []; + } + // start time and end time in one month + if (Object(date_util_["validateRangeInOneMonth"])(start, end)) { + return [[start, end]]; + } + var data = []; + var startDay = new Date(start.getFullYear(), start.getMonth() + 1, 1); + var lastDay = this.toDate(startDay.getTime() - oneDay); + if (!Object(date_util_["validateRangeInOneMonth"])(startDay, end)) { + console.warn('[ElementCalendar]start time and end time interval must not exceed two months'); + return []; + } + // 第一个月的时间范围 + data.push([start, lastDay]); + // 下一月的时间范围,需要计算一下该月的第一个周起始日 + var firstDayOfWeek = this.realFirstDayOfWeek; + var nextMontFirstDay = startDay.getDay(); + var interval = 0; + if (nextMontFirstDay !== firstDayOfWeek) { + if (firstDayOfWeek === 0) { + interval = 7 - nextMontFirstDay; + } else { + interval = firstDayOfWeek - nextMontFirstDay; + interval = interval > 0 ? interval : 7 + interval; + } + } + startDay = this.toDate(startDay.getTime() + interval * oneDay); + if (startDay.getDate() < end.getDate()) { + data.push([startDay, end]); + } + return data; + } + return []; + }, + realFirstDayOfWeek: function realFirstDayOfWeek() { + if (this.firstDayOfWeek < 1 || this.firstDayOfWeek > 6) { + return 0; + } + return Math.floor(this.firstDayOfWeek); + } + }, + + data: function data() { + return { + selectedDay: '', + now: new Date() + }; + } +}); +// CONCATENATED MODULE: ./packages/calendar/src/main.vue?vue&type=script&lang=js& + /* harmony default export */ var src_mainvue_type_script_lang_js_ = (mainvue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/calendar/src/main.vue + + + + + +/* normalize component */ + +var main_component = Object(componentNormalizer["a" /* default */])( + src_mainvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var main_api; } +main_component.options.__file = "packages/calendar/src/main.vue" +/* harmony default export */ var main = (main_component.exports); +// CONCATENATED MODULE: ./packages/calendar/index.js + + +/* istanbul ignore next */ +main.install = function (Vue) { + Vue.component(main.name, main); +}; + +/* harmony default export */ var calendar = __webpack_exports__["default"] = (main); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/card.js b/public/static/libs/element-ui/lib/card.js new file mode 100644 index 0000000..db637c4 --- /dev/null +++ b/public/static/libs/element-ui/lib/card.js @@ -0,0 +1,296 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 107); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 107: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/card/src/main.vue?vue&type=template&id=59a4a40f& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { + staticClass: "el-card", + class: _vm.shadow ? "is-" + _vm.shadow + "-shadow" : "is-always-shadow" + }, + [ + _vm.$slots.header || _vm.header + ? _c( + "div", + { staticClass: "el-card__header" }, + [_vm._t("header", [_vm._v(_vm._s(_vm.header))])], + 2 + ) + : _vm._e(), + _c( + "div", + { staticClass: "el-card__body", style: _vm.bodyStyle }, + [_vm._t("default")], + 2 + ) + ] + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/card/src/main.vue?vue&type=template&id=59a4a40f& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/card/src/main.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// + +/* harmony default export */ var mainvue_type_script_lang_js_ = ({ + name: 'ElCard', + props: { + header: {}, + bodyStyle: {}, + shadow: { + type: String + } + } +}); +// CONCATENATED MODULE: ./packages/card/src/main.vue?vue&type=script&lang=js& + /* harmony default export */ var src_mainvue_type_script_lang_js_ = (mainvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/card/src/main.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_mainvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/card/src/main.vue" +/* harmony default export */ var main = (component.exports); +// CONCATENATED MODULE: ./packages/card/index.js + + +/* istanbul ignore next */ +main.install = function (Vue) { + Vue.component(main.name, main); +}; + +/* harmony default export */ var card = __webpack_exports__["default"] = (main); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/carousel-item.js b/public/static/libs/element-ui/lib/carousel-item.js new file mode 100644 index 0000000..574a315 --- /dev/null +++ b/public/static/libs/element-ui/lib/carousel-item.js @@ -0,0 +1,433 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 112); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 112: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/carousel/src/item.vue?vue&type=template&id=1801ae19& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.ready, + expression: "ready" + } + ], + staticClass: "el-carousel__item", + class: { + "is-active": _vm.active, + "el-carousel__item--card": _vm.$parent.type === "card", + "is-in-stage": _vm.inStage, + "is-hover": _vm.hover, + "is-animating": _vm.animating + }, + style: _vm.itemStyle, + on: { click: _vm.handleItemClick } + }, + [ + _vm.$parent.type === "card" + ? _c("div", { + directives: [ + { + name: "show", + rawName: "v-show", + value: !_vm.active, + expression: "!active" + } + ], + staticClass: "el-carousel__mask" + }) + : _vm._e(), + _vm._t("default") + ], + 2 + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/carousel/src/item.vue?vue&type=template&id=1801ae19& + +// EXTERNAL MODULE: external "element-ui/lib/utils/util" +var util_ = __webpack_require__(3); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/carousel/src/item.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + +var CARD_SCALE = 0.83; +/* harmony default export */ var itemvue_type_script_lang_js_ = ({ + name: 'ElCarouselItem', + + props: { + name: String, + label: { + type: [String, Number], + default: '' + } + }, + + data: function data() { + return { + hover: false, + translate: 0, + scale: 1, + active: false, + ready: false, + inStage: false, + animating: false + }; + }, + + + methods: { + processIndex: function processIndex(index, activeIndex, length) { + if (activeIndex === 0 && index === length - 1) { + return -1; + } else if (activeIndex === length - 1 && index === 0) { + return length; + } else if (index < activeIndex - 1 && activeIndex - index >= length / 2) { + return length + 1; + } else if (index > activeIndex + 1 && index - activeIndex >= length / 2) { + return -2; + } + return index; + }, + calcCardTranslate: function calcCardTranslate(index, activeIndex) { + var parentWidth = this.$parent.$el.offsetWidth; + if (this.inStage) { + return parentWidth * ((2 - CARD_SCALE) * (index - activeIndex) + 1) / 4; + } else if (index < activeIndex) { + return -(1 + CARD_SCALE) * parentWidth / 4; + } else { + return (3 + CARD_SCALE) * parentWidth / 4; + } + }, + calcTranslate: function calcTranslate(index, activeIndex, isVertical) { + var distance = this.$parent.$el[isVertical ? 'offsetHeight' : 'offsetWidth']; + return distance * (index - activeIndex); + }, + translateItem: function translateItem(index, activeIndex, oldIndex) { + var parentType = this.$parent.type; + var parentDirection = this.parentDirection; + var length = this.$parent.items.length; + if (parentType !== 'card' && oldIndex !== undefined) { + this.animating = index === activeIndex || index === oldIndex; + } + if (index !== activeIndex && length > 2 && this.$parent.loop) { + index = this.processIndex(index, activeIndex, length); + } + if (parentType === 'card') { + if (parentDirection === 'vertical') { + console.warn('[Element Warn][Carousel]vertical direction is not supported in card mode'); + } + this.inStage = Math.round(Math.abs(index - activeIndex)) <= 1; + this.active = index === activeIndex; + this.translate = this.calcCardTranslate(index, activeIndex); + this.scale = this.active ? 1 : CARD_SCALE; + } else { + this.active = index === activeIndex; + var isVertical = parentDirection === 'vertical'; + this.translate = this.calcTranslate(index, activeIndex, isVertical); + this.scale = 1; + } + this.ready = true; + }, + handleItemClick: function handleItemClick() { + var parent = this.$parent; + if (parent && parent.type === 'card') { + var index = parent.items.indexOf(this); + parent.setActiveItem(index); + } + } + }, + + computed: { + parentDirection: function parentDirection() { + return this.$parent.direction; + }, + itemStyle: function itemStyle() { + var translateType = this.parentDirection === 'vertical' ? 'translateY' : 'translateX'; + var value = translateType + '(' + this.translate + 'px) scale(' + this.scale + ')'; + var style = { + transform: value + }; + return Object(util_["autoprefixer"])(style); + } + }, + + created: function created() { + this.$parent && this.$parent.updateItems(); + }, + destroyed: function destroyed() { + this.$parent && this.$parent.updateItems(); + } +}); +// CONCATENATED MODULE: ./packages/carousel/src/item.vue?vue&type=script&lang=js& + /* harmony default export */ var src_itemvue_type_script_lang_js_ = (itemvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/carousel/src/item.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_itemvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/carousel/src/item.vue" +/* harmony default export */ var item = (component.exports); +// CONCATENATED MODULE: ./packages/carousel-item/index.js + + +/* istanbul ignore next */ +item.install = function (Vue) { + Vue.component(item.name, item); +}; + +/* harmony default export */ var carousel_item = __webpack_exports__["default"] = (item); + +/***/ }), + +/***/ 3: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/util"); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/carousel.js b/public/static/libs/element-ui/lib/carousel.js new file mode 100644 index 0000000..56321a6 --- /dev/null +++ b/public/static/libs/element-ui/lib/carousel.js @@ -0,0 +1,706 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 111); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 111: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/carousel/src/main.vue?vue&type=template&id=5d5d1482& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { + class: _vm.carouselClasses, + on: { + mouseenter: function($event) { + $event.stopPropagation() + return _vm.handleMouseEnter($event) + }, + mouseleave: function($event) { + $event.stopPropagation() + return _vm.handleMouseLeave($event) + } + } + }, + [ + _c( + "div", + { + staticClass: "el-carousel__container", + style: { height: _vm.height } + }, + [ + _vm.arrowDisplay + ? _c("transition", { attrs: { name: "carousel-arrow-left" } }, [ + _c( + "button", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: + (_vm.arrow === "always" || _vm.hover) && + (_vm.loop || _vm.activeIndex > 0), + expression: + "(arrow === 'always' || hover) && (loop || activeIndex > 0)" + } + ], + staticClass: "el-carousel__arrow el-carousel__arrow--left", + attrs: { type: "button" }, + on: { + mouseenter: function($event) { + _vm.handleButtonEnter("left") + }, + mouseleave: _vm.handleButtonLeave, + click: function($event) { + $event.stopPropagation() + _vm.throttledArrowClick(_vm.activeIndex - 1) + } + } + }, + [_c("i", { staticClass: "el-icon-arrow-left" })] + ) + ]) + : _vm._e(), + _vm.arrowDisplay + ? _c("transition", { attrs: { name: "carousel-arrow-right" } }, [ + _c( + "button", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: + (_vm.arrow === "always" || _vm.hover) && + (_vm.loop || _vm.activeIndex < _vm.items.length - 1), + expression: + "(arrow === 'always' || hover) && (loop || activeIndex < items.length - 1)" + } + ], + staticClass: "el-carousel__arrow el-carousel__arrow--right", + attrs: { type: "button" }, + on: { + mouseenter: function($event) { + _vm.handleButtonEnter("right") + }, + mouseleave: _vm.handleButtonLeave, + click: function($event) { + $event.stopPropagation() + _vm.throttledArrowClick(_vm.activeIndex + 1) + } + } + }, + [_c("i", { staticClass: "el-icon-arrow-right" })] + ) + ]) + : _vm._e(), + _vm._t("default") + ], + 2 + ), + _vm.indicatorPosition !== "none" + ? _c( + "ul", + { class: _vm.indicatorsClasses }, + _vm._l(_vm.items, function(item, index) { + return _c( + "li", + { + key: index, + class: [ + "el-carousel__indicator", + "el-carousel__indicator--" + _vm.direction, + { "is-active": index === _vm.activeIndex } + ], + on: { + mouseenter: function($event) { + _vm.throttledIndicatorHover(index) + }, + click: function($event) { + $event.stopPropagation() + _vm.handleIndicatorClick(index) + } + } + }, + [ + _c("button", { staticClass: "el-carousel__button" }, [ + _vm.hasLabel + ? _c("span", [_vm._v(_vm._s(item.label))]) + : _vm._e() + ]) + ] + ) + }), + 0 + ) + : _vm._e() + ] + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/carousel/src/main.vue?vue&type=template&id=5d5d1482& + +// EXTERNAL MODULE: external "throttle-debounce/throttle" +var throttle_ = __webpack_require__(25); +var throttle_default = /*#__PURE__*/__webpack_require__.n(throttle_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/resize-event" +var resize_event_ = __webpack_require__(16); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/carousel/src/main.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + +/* harmony default export */ var mainvue_type_script_lang_js_ = ({ + name: 'ElCarousel', + + props: { + initialIndex: { + type: Number, + default: 0 + }, + height: String, + trigger: { + type: String, + default: 'hover' + }, + autoplay: { + type: Boolean, + default: true + }, + interval: { + type: Number, + default: 3000 + }, + indicatorPosition: String, + indicator: { + type: Boolean, + default: true + }, + arrow: { + type: String, + default: 'hover' + }, + type: String, + loop: { + type: Boolean, + default: true + }, + direction: { + type: String, + default: 'horizontal', + validator: function validator(val) { + return ['horizontal', 'vertical'].indexOf(val) !== -1; + } + } + }, + + data: function data() { + return { + items: [], + activeIndex: -1, + containerWidth: 0, + timer: null, + hover: false + }; + }, + + + computed: { + arrowDisplay: function arrowDisplay() { + return this.arrow !== 'never' && this.direction !== 'vertical'; + }, + hasLabel: function hasLabel() { + return this.items.some(function (item) { + return item.label.toString().length > 0; + }); + }, + carouselClasses: function carouselClasses() { + var classes = ['el-carousel', 'el-carousel--' + this.direction]; + if (this.type === 'card') { + classes.push('el-carousel--card'); + } + return classes; + }, + indicatorsClasses: function indicatorsClasses() { + var classes = ['el-carousel__indicators', 'el-carousel__indicators--' + this.direction]; + if (this.hasLabel) { + classes.push('el-carousel__indicators--labels'); + } + if (this.indicatorPosition === 'outside' || this.type === 'card') { + classes.push('el-carousel__indicators--outside'); + } + return classes; + } + }, + + watch: { + items: function items(val) { + if (val.length > 0) this.setActiveItem(this.initialIndex); + }, + activeIndex: function activeIndex(val, oldVal) { + this.resetItemPosition(oldVal); + if (oldVal > -1) { + this.$emit('change', val, oldVal); + } + }, + autoplay: function autoplay(val) { + val ? this.startTimer() : this.pauseTimer(); + }, + loop: function loop() { + this.setActiveItem(this.activeIndex); + }, + interval: function interval() { + this.pauseTimer(); + this.startTimer(); + } + }, + + methods: { + handleMouseEnter: function handleMouseEnter() { + this.hover = true; + this.pauseTimer(); + }, + handleMouseLeave: function handleMouseLeave() { + this.hover = false; + this.startTimer(); + }, + itemInStage: function itemInStage(item, index) { + var length = this.items.length; + if (index === length - 1 && item.inStage && this.items[0].active || item.inStage && this.items[index + 1] && this.items[index + 1].active) { + return 'left'; + } else if (index === 0 && item.inStage && this.items[length - 1].active || item.inStage && this.items[index - 1] && this.items[index - 1].active) { + return 'right'; + } + return false; + }, + handleButtonEnter: function handleButtonEnter(arrow) { + var _this = this; + + if (this.direction === 'vertical') return; + this.items.forEach(function (item, index) { + if (arrow === _this.itemInStage(item, index)) { + item.hover = true; + } + }); + }, + handleButtonLeave: function handleButtonLeave() { + if (this.direction === 'vertical') return; + this.items.forEach(function (item) { + item.hover = false; + }); + }, + updateItems: function updateItems() { + this.items = this.$children.filter(function (child) { + return child.$options.name === 'ElCarouselItem'; + }); + }, + resetItemPosition: function resetItemPosition(oldIndex) { + var _this2 = this; + + this.items.forEach(function (item, index) { + item.translateItem(index, _this2.activeIndex, oldIndex); + }); + }, + playSlides: function playSlides() { + if (this.activeIndex < this.items.length - 1) { + this.activeIndex++; + } else if (this.loop) { + this.activeIndex = 0; + } + }, + pauseTimer: function pauseTimer() { + if (this.timer) { + clearInterval(this.timer); + this.timer = null; + } + }, + startTimer: function startTimer() { + if (this.interval <= 0 || !this.autoplay || this.timer) return; + this.timer = setInterval(this.playSlides, this.interval); + }, + resetTimer: function resetTimer() { + this.pauseTimer(); + this.startTimer(); + }, + setActiveItem: function setActiveItem(index) { + if (typeof index === 'string') { + var filteredItems = this.items.filter(function (item) { + return item.name === index; + }); + if (filteredItems.length > 0) { + index = this.items.indexOf(filteredItems[0]); + } + } + index = Number(index); + if (isNaN(index) || index !== Math.floor(index)) { + console.warn('[Element Warn][Carousel]index must be an integer.'); + return; + } + var length = this.items.length; + var oldIndex = this.activeIndex; + if (index < 0) { + this.activeIndex = this.loop ? length - 1 : 0; + } else if (index >= length) { + this.activeIndex = this.loop ? 0 : length - 1; + } else { + this.activeIndex = index; + } + if (oldIndex === this.activeIndex) { + this.resetItemPosition(oldIndex); + } + this.resetTimer(); + }, + prev: function prev() { + this.setActiveItem(this.activeIndex - 1); + }, + next: function next() { + this.setActiveItem(this.activeIndex + 1); + }, + handleIndicatorClick: function handleIndicatorClick(index) { + this.activeIndex = index; + }, + handleIndicatorHover: function handleIndicatorHover(index) { + if (this.trigger === 'hover' && index !== this.activeIndex) { + this.activeIndex = index; + } + } + }, + + created: function created() { + var _this3 = this; + + this.throttledArrowClick = throttle_default()(300, true, function (index) { + _this3.setActiveItem(index); + }); + this.throttledIndicatorHover = throttle_default()(300, function (index) { + _this3.handleIndicatorHover(index); + }); + }, + mounted: function mounted() { + var _this4 = this; + + this.updateItems(); + this.$nextTick(function () { + Object(resize_event_["addResizeListener"])(_this4.$el, _this4.resetItemPosition); + if (_this4.initialIndex < _this4.items.length && _this4.initialIndex >= 0) { + _this4.activeIndex = _this4.initialIndex; + } + _this4.startTimer(); + }); + }, + beforeDestroy: function beforeDestroy() { + if (this.$el) Object(resize_event_["removeResizeListener"])(this.$el, this.resetItemPosition); + this.pauseTimer(); + } +}); +// CONCATENATED MODULE: ./packages/carousel/src/main.vue?vue&type=script&lang=js& + /* harmony default export */ var src_mainvue_type_script_lang_js_ = (mainvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/carousel/src/main.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_mainvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/carousel/src/main.vue" +/* harmony default export */ var main = (component.exports); +// CONCATENATED MODULE: ./packages/carousel/index.js + + +/* istanbul ignore next */ +main.install = function (Vue) { + Vue.component(main.name, main); +}; + +/* harmony default export */ var carousel = __webpack_exports__["default"] = (main); + +/***/ }), + +/***/ 16: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/resize-event"); + +/***/ }), + +/***/ 25: +/***/ (function(module, exports) { + +module.exports = require("throttle-debounce/throttle"); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/cascader-panel.js b/public/static/libs/element-ui/lib/cascader-panel.js new file mode 100644 index 0000000..f940fb6 --- /dev/null +++ b/public/static/libs/element-ui/lib/cascader-panel.js @@ -0,0 +1,1563 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 61); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 15: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/scrollbar"); + +/***/ }), + +/***/ 18: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/checkbox"); + +/***/ }), + +/***/ 21: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/shared"); + +/***/ }), + +/***/ 26: +/***/ (function(module, exports) { + +module.exports = require("babel-helper-vue-jsx-merge-props"); + +/***/ }), + +/***/ 3: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/util"); + +/***/ }), + +/***/ 31: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/scroll-into-view"); + +/***/ }), + +/***/ 41: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/aria-utils"); + +/***/ }), + +/***/ 52: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/radio"); + +/***/ }), + +/***/ 6: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/locale"); + +/***/ }), + +/***/ 61: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader-panel/src/cascader-panel.vue?vue&type=template&id=34932346& +var cascader_panelvue_type_template_id_34932346_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { + class: ["el-cascader-panel", _vm.border && "is-bordered"], + on: { keydown: _vm.handleKeyDown } + }, + _vm._l(_vm.menus, function(menu, index) { + return _c("cascader-menu", { + key: index, + ref: "menu", + refInFor: true, + attrs: { index: index, nodes: menu } + }) + }), + 1 + ) +} +var staticRenderFns = [] +cascader_panelvue_type_template_id_34932346_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-panel.vue?vue&type=template&id=34932346& + +// EXTERNAL MODULE: external "babel-helper-vue-jsx-merge-props" +var external_babel_helper_vue_jsx_merge_props_ = __webpack_require__(26); +var external_babel_helper_vue_jsx_merge_props_default = /*#__PURE__*/__webpack_require__.n(external_babel_helper_vue_jsx_merge_props_); + +// EXTERNAL MODULE: external "element-ui/lib/scrollbar" +var scrollbar_ = __webpack_require__(15); +var scrollbar_default = /*#__PURE__*/__webpack_require__.n(scrollbar_); + +// EXTERNAL MODULE: external "element-ui/lib/checkbox" +var checkbox_ = __webpack_require__(18); +var checkbox_default = /*#__PURE__*/__webpack_require__.n(checkbox_); + +// EXTERNAL MODULE: external "element-ui/lib/radio" +var radio_ = __webpack_require__(52); +var radio_default = /*#__PURE__*/__webpack_require__.n(radio_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/util" +var util_ = __webpack_require__(3); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader-panel/src/cascader-node.vue?vue&type=script&lang=js& + + + + + + +var stopPropagation = function stopPropagation(e) { + return e.stopPropagation(); +}; + +/* harmony default export */ var cascader_nodevue_type_script_lang_js_ = ({ + inject: ['panel'], + + components: { + ElCheckbox: checkbox_default.a, + ElRadio: radio_default.a + }, + + props: { + node: { + required: true + }, + nodeId: String + }, + + computed: { + config: function config() { + return this.panel.config; + }, + isLeaf: function isLeaf() { + return this.node.isLeaf; + }, + isDisabled: function isDisabled() { + return this.node.isDisabled; + }, + checkedValue: function checkedValue() { + return this.panel.checkedValue; + }, + isChecked: function isChecked() { + return this.node.isSameNode(this.checkedValue); + }, + inActivePath: function inActivePath() { + return this.isInPath(this.panel.activePath); + }, + inCheckedPath: function inCheckedPath() { + var _this = this; + + if (!this.config.checkStrictly) return false; + + return this.panel.checkedNodePaths.some(function (checkedPath) { + return _this.isInPath(checkedPath); + }); + }, + value: function value() { + return this.node.getValueByOption(); + } + }, + + methods: { + handleExpand: function handleExpand() { + var _this2 = this; + + var panel = this.panel, + node = this.node, + isDisabled = this.isDisabled, + config = this.config; + var multiple = config.multiple, + checkStrictly = config.checkStrictly; + + + if (!checkStrictly && isDisabled || node.loading) return; + + if (config.lazy && !node.loaded) { + panel.lazyLoad(node, function () { + // do not use cached leaf value here, invoke this.isLeaf to get new value. + var isLeaf = _this2.isLeaf; + + + if (!isLeaf) _this2.handleExpand(); + if (multiple) { + // if leaf sync checked state, else clear checked state + var checked = isLeaf ? node.checked : false; + _this2.handleMultiCheckChange(checked); + } + }); + } else { + panel.handleExpand(node); + } + }, + handleCheckChange: function handleCheckChange() { + var panel = this.panel, + value = this.value, + node = this.node; + + panel.handleCheckChange(value); + panel.handleExpand(node); + }, + handleMultiCheckChange: function handleMultiCheckChange(checked) { + this.node.doCheck(checked); + this.panel.calculateMultiCheckedValue(); + }, + isInPath: function isInPath(pathNodes) { + var node = this.node; + + var selectedPathNode = pathNodes[node.level - 1] || {}; + return selectedPathNode.uid === node.uid; + }, + renderPrefix: function renderPrefix(h) { + var isLeaf = this.isLeaf, + isChecked = this.isChecked, + config = this.config; + var checkStrictly = config.checkStrictly, + multiple = config.multiple; + + + if (multiple) { + return this.renderCheckbox(h); + } else if (checkStrictly) { + return this.renderRadio(h); + } else if (isLeaf && isChecked) { + return this.renderCheckIcon(h); + } + + return null; + }, + renderPostfix: function renderPostfix(h) { + var node = this.node, + isLeaf = this.isLeaf; + + + if (node.loading) { + return this.renderLoadingIcon(h); + } else if (!isLeaf) { + return this.renderExpandIcon(h); + } + + return null; + }, + renderCheckbox: function renderCheckbox(h) { + var node = this.node, + config = this.config, + isDisabled = this.isDisabled; + + var events = { + on: { change: this.handleMultiCheckChange }, + nativeOn: {} + }; + + if (config.checkStrictly) { + // when every node is selectable, click event should not trigger expand event. + events.nativeOn.click = stopPropagation; + } + + return h('el-checkbox', external_babel_helper_vue_jsx_merge_props_default()([{ + attrs: { + value: node.checked, + indeterminate: node.indeterminate, + disabled: isDisabled + } + }, events])); + }, + renderRadio: function renderRadio(h) { + var checkedValue = this.checkedValue, + value = this.value, + isDisabled = this.isDisabled; + + // to keep same reference if value cause radio's checked state is calculated by reference comparision; + + if (Object(util_["isEqual"])(value, checkedValue)) { + value = checkedValue; + } + + return h( + 'el-radio', + { + attrs: { + value: checkedValue, + label: value, + disabled: isDisabled + }, + on: { + 'change': this.handleCheckChange + }, + nativeOn: { + 'click': stopPropagation + } + }, + [h('span')] + ); + }, + renderCheckIcon: function renderCheckIcon(h) { + return h('i', { 'class': 'el-icon-check el-cascader-node__prefix' }); + }, + renderLoadingIcon: function renderLoadingIcon(h) { + return h('i', { 'class': 'el-icon-loading el-cascader-node__postfix' }); + }, + renderExpandIcon: function renderExpandIcon(h) { + return h('i', { 'class': 'el-icon-arrow-right el-cascader-node__postfix' }); + }, + renderContent: function renderContent(h) { + var panel = this.panel, + node = this.node; + + var render = panel.renderLabelFn; + var vnode = render ? render({ node: node, data: node.data }) : null; + + return h( + 'span', + { 'class': 'el-cascader-node__label' }, + [vnode || node.label] + ); + } + }, + + render: function render(h) { + var _this3 = this; + + var inActivePath = this.inActivePath, + inCheckedPath = this.inCheckedPath, + isChecked = this.isChecked, + isLeaf = this.isLeaf, + isDisabled = this.isDisabled, + config = this.config, + nodeId = this.nodeId; + var expandTrigger = config.expandTrigger, + checkStrictly = config.checkStrictly, + multiple = config.multiple; + + var disabled = !checkStrictly && isDisabled; + var events = { on: {} }; + + if (expandTrigger === 'click') { + events.on.click = this.handleExpand; + } else { + events.on.mouseenter = function (e) { + _this3.handleExpand(); + _this3.$emit('expand', e); + }; + events.on.focus = function (e) { + _this3.handleExpand(); + _this3.$emit('expand', e); + }; + } + if (isLeaf && !isDisabled && !checkStrictly && !multiple) { + events.on.click = this.handleCheckChange; + } + + return h( + 'li', + external_babel_helper_vue_jsx_merge_props_default()([{ + attrs: { + role: 'menuitem', + id: nodeId, + 'aria-expanded': inActivePath, + tabindex: disabled ? null : -1 + }, + 'class': { + 'el-cascader-node': true, + 'is-selectable': checkStrictly, + 'in-active-path': inActivePath, + 'in-checked-path': inCheckedPath, + 'is-active': isChecked, + 'is-disabled': disabled + } + }, events]), + [this.renderPrefix(h), this.renderContent(h), this.renderPostfix(h)] + ); + } +}); +// CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-node.vue?vue&type=script&lang=js& + /* harmony default export */ var src_cascader_nodevue_type_script_lang_js_ = (cascader_nodevue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-node.vue +var cascader_node_render, cascader_node_staticRenderFns + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_cascader_nodevue_type_script_lang_js_, + cascader_node_render, + cascader_node_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/cascader-panel/src/cascader-node.vue" +/* harmony default export */ var cascader_node = (component.exports); +// EXTERNAL MODULE: external "element-ui/lib/mixins/locale" +var locale_ = __webpack_require__(6); +var locale_default = /*#__PURE__*/__webpack_require__.n(locale_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader-panel/src/cascader-menu.vue?vue&type=script&lang=js& + + + + + + + +/* harmony default export */ var cascader_menuvue_type_script_lang_js_ = ({ + name: 'ElCascaderMenu', + + mixins: [locale_default.a], + + inject: ['panel'], + + components: { + ElScrollbar: scrollbar_default.a, + CascaderNode: cascader_node + }, + + props: { + nodes: { + type: Array, + required: true + }, + index: Number + }, + + data: function data() { + return { + activeNode: null, + hoverTimer: null, + id: Object(util_["generateId"])() + }; + }, + + + computed: { + isEmpty: function isEmpty() { + return !this.nodes.length; + }, + menuId: function menuId() { + return 'cascader-menu-' + this.id + '-' + this.index; + } + }, + + methods: { + handleExpand: function handleExpand(e) { + this.activeNode = e.target; + }, + handleMouseMove: function handleMouseMove(e) { + var activeNode = this.activeNode, + hoverTimer = this.hoverTimer; + var hoverZone = this.$refs.hoverZone; + + + if (!activeNode || !hoverZone) return; + + if (activeNode.contains(e.target)) { + clearTimeout(hoverTimer); + + var _$el$getBoundingClien = this.$el.getBoundingClientRect(), + left = _$el$getBoundingClien.left; + + var startX = e.clientX - left; + var _$el = this.$el, + offsetWidth = _$el.offsetWidth, + offsetHeight = _$el.offsetHeight; + + var top = activeNode.offsetTop; + var bottom = top + activeNode.offsetHeight; + + hoverZone.innerHTML = '\n \n \n '; + } else if (!hoverTimer) { + this.hoverTimer = setTimeout(this.clearHoverZone, this.panel.config.hoverThreshold); + } + }, + clearHoverZone: function clearHoverZone() { + var hoverZone = this.$refs.hoverZone; + + if (!hoverZone) return; + hoverZone.innerHTML = ''; + }, + renderEmptyText: function renderEmptyText(h) { + return h( + 'div', + { 'class': 'el-cascader-menu__empty-text' }, + [this.t('el.cascader.noData')] + ); + }, + renderNodeList: function renderNodeList(h) { + var menuId = this.menuId; + var isHoverMenu = this.panel.isHoverMenu; + + var events = { on: {} }; + + if (isHoverMenu) { + events.on.expand = this.handleExpand; + } + + var nodes = this.nodes.map(function (node, index) { + var hasChildren = node.hasChildren; + + return h('cascader-node', external_babel_helper_vue_jsx_merge_props_default()([{ + key: node.uid, + attrs: { node: node, + 'node-id': menuId + '-' + index, + 'aria-haspopup': hasChildren, + 'aria-owns': hasChildren ? menuId : null + } + }, events])); + }); + + return [].concat(nodes, [isHoverMenu ? h('svg', { ref: 'hoverZone', 'class': 'el-cascader-menu__hover-zone' }) : null]); + } + }, + + render: function render(h) { + var isEmpty = this.isEmpty, + menuId = this.menuId; + + var events = { nativeOn: {} }; + + // optimize hover to expand experience (#8010) + if (this.panel.isHoverMenu) { + events.nativeOn.mousemove = this.handleMouseMove; + // events.nativeOn.mouseleave = this.clearHoverZone; + } + + return h( + 'el-scrollbar', + external_babel_helper_vue_jsx_merge_props_default()([{ + attrs: { + tag: 'ul', + role: 'menu', + id: menuId, + + 'wrap-class': 'el-cascader-menu__wrap', + 'view-class': { + 'el-cascader-menu__list': true, + 'is-empty': isEmpty + } + }, + 'class': 'el-cascader-menu' }, events]), + [isEmpty ? this.renderEmptyText(h) : this.renderNodeList(h)] + ); + } +}); +// CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-menu.vue?vue&type=script&lang=js& + /* harmony default export */ var src_cascader_menuvue_type_script_lang_js_ = (cascader_menuvue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-menu.vue +var cascader_menu_render, cascader_menu_staticRenderFns + + + + +/* normalize component */ + +var cascader_menu_component = Object(componentNormalizer["a" /* default */])( + src_cascader_menuvue_type_script_lang_js_, + cascader_menu_render, + cascader_menu_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var cascader_menu_api; } +cascader_menu_component.options.__file = "packages/cascader-panel/src/cascader-menu.vue" +/* harmony default export */ var cascader_menu = (cascader_menu_component.exports); +// EXTERNAL MODULE: external "element-ui/lib/utils/shared" +var shared_ = __webpack_require__(21); + +// CONCATENATED MODULE: ./packages/cascader-panel/src/node.js +var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); + +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + + + + +var uid = 0; + +var node_Node = function () { + function Node(data, config, parentNode) { + _classCallCheck(this, Node); + + this.data = data; + this.config = config; + this.parent = parentNode || null; + this.level = !this.parent ? 1 : this.parent.level + 1; + this.uid = uid++; + + this.initState(); + this.initChildren(); + } + + Node.prototype.initState = function initState() { + var _config = this.config, + valueKey = _config.value, + labelKey = _config.label; + + + this.value = this.data[valueKey]; + this.label = this.data[labelKey]; + this.pathNodes = this.calculatePathNodes(); + this.path = this.pathNodes.map(function (node) { + return node.value; + }); + this.pathLabels = this.pathNodes.map(function (node) { + return node.label; + }); + + // lazy load + this.loading = false; + this.loaded = false; + }; + + Node.prototype.initChildren = function initChildren() { + var _this = this; + + var config = this.config; + + var childrenKey = config.children; + var childrenData = this.data[childrenKey]; + this.hasChildren = Array.isArray(childrenData); + this.children = (childrenData || []).map(function (child) { + return new Node(child, config, _this); + }); + }; + + Node.prototype.calculatePathNodes = function calculatePathNodes() { + var nodes = [this]; + var parent = this.parent; + + while (parent) { + nodes.unshift(parent); + parent = parent.parent; + } + + return nodes; + }; + + Node.prototype.getPath = function getPath() { + return this.path; + }; + + Node.prototype.getValue = function getValue() { + return this.value; + }; + + Node.prototype.getValueByOption = function getValueByOption() { + return this.config.emitPath ? this.getPath() : this.getValue(); + }; + + Node.prototype.getText = function getText(allLevels, separator) { + return allLevels ? this.pathLabels.join(separator) : this.label; + }; + + Node.prototype.isSameNode = function isSameNode(checkedValue) { + var value = this.getValueByOption(); + return this.config.multiple && Array.isArray(checkedValue) ? checkedValue.some(function (val) { + return Object(util_["isEqual"])(val, value); + }) : Object(util_["isEqual"])(checkedValue, value); + }; + + Node.prototype.broadcast = function broadcast(event) { + for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + + var handlerName = 'onParent' + Object(util_["capitalize"])(event); + + this.children.forEach(function (child) { + if (child) { + // bottom up + child.broadcast.apply(child, [event].concat(args)); + child[handlerName] && child[handlerName].apply(child, args); + } + }); + }; + + Node.prototype.emit = function emit(event) { + var parent = this.parent; + + var handlerName = 'onChild' + Object(util_["capitalize"])(event); + if (parent) { + for (var _len2 = arguments.length, args = Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) { + args[_key2 - 1] = arguments[_key2]; + } + + parent[handlerName] && parent[handlerName].apply(parent, args); + parent.emit.apply(parent, [event].concat(args)); + } + }; + + Node.prototype.onParentCheck = function onParentCheck(checked) { + if (!this.isDisabled) { + this.setCheckState(checked); + } + }; + + Node.prototype.onChildCheck = function onChildCheck() { + var children = this.children; + + var validChildren = children.filter(function (child) { + return !child.isDisabled; + }); + var checked = validChildren.length ? validChildren.every(function (child) { + return child.checked; + }) : false; + + this.setCheckState(checked); + }; + + Node.prototype.setCheckState = function setCheckState(checked) { + var totalNum = this.children.length; + var checkedNum = this.children.reduce(function (c, p) { + var num = p.checked ? 1 : p.indeterminate ? 0.5 : 0; + return c + num; + }, 0); + + this.checked = checked; + this.indeterminate = checkedNum !== totalNum && checkedNum > 0; + }; + + Node.prototype.syncCheckState = function syncCheckState(checkedValue) { + var value = this.getValueByOption(); + var checked = this.isSameNode(checkedValue, value); + + this.doCheck(checked); + }; + + Node.prototype.doCheck = function doCheck(checked) { + if (this.checked !== checked) { + if (this.config.checkStrictly) { + this.checked = checked; + } else { + // bottom up to unify the calculation of the indeterminate state + this.broadcast('check', checked); + this.setCheckState(checked); + this.emit('check'); + } + } + }; + + _createClass(Node, [{ + key: 'isDisabled', + get: function get() { + var data = this.data, + parent = this.parent, + config = this.config; + + var disabledKey = config.disabled; + var checkStrictly = config.checkStrictly; + + return data[disabledKey] || !checkStrictly && parent && parent.isDisabled; + } + }, { + key: 'isLeaf', + get: function get() { + var data = this.data, + loaded = this.loaded, + hasChildren = this.hasChildren, + children = this.children; + var _config2 = this.config, + lazy = _config2.lazy, + leafKey = _config2.leaf; + + if (lazy) { + var isLeaf = Object(shared_["isDef"])(data[leafKey]) ? data[leafKey] : loaded ? !children.length : false; + this.hasChildren = !isLeaf; + return isLeaf; + } + return !hasChildren; + } + }]); + + return Node; +}(); + +/* harmony default export */ var src_node = (node_Node); +// CONCATENATED MODULE: ./packages/cascader-panel/src/store.js +function store_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + + + + +var flatNodes = function flatNodes(data, leafOnly) { + return data.reduce(function (res, node) { + if (node.isLeaf) { + res.push(node); + } else { + !leafOnly && res.push(node); + res = res.concat(flatNodes(node.children, leafOnly)); + } + return res; + }, []); +}; + +var store_Store = function () { + function Store(data, config) { + store_classCallCheck(this, Store); + + this.config = config; + this.initNodes(data); + } + + Store.prototype.initNodes = function initNodes(data) { + var _this = this; + + data = Object(util_["coerceTruthyValueToArray"])(data); + this.nodes = data.map(function (nodeData) { + return new src_node(nodeData, _this.config); + }); + this.flattedNodes = this.getFlattedNodes(false, false); + this.leafNodes = this.getFlattedNodes(true, false); + }; + + Store.prototype.appendNode = function appendNode(nodeData, parentNode) { + var node = new src_node(nodeData, this.config, parentNode); + var children = parentNode ? parentNode.children : this.nodes; + + children.push(node); + }; + + Store.prototype.appendNodes = function appendNodes(nodeDataList, parentNode) { + var _this2 = this; + + nodeDataList = Object(util_["coerceTruthyValueToArray"])(nodeDataList); + nodeDataList.forEach(function (nodeData) { + return _this2.appendNode(nodeData, parentNode); + }); + }; + + Store.prototype.getNodes = function getNodes() { + return this.nodes; + }; + + Store.prototype.getFlattedNodes = function getFlattedNodes(leafOnly) { + var cached = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; + + var cachedNodes = leafOnly ? this.leafNodes : this.flattedNodes; + return cached ? cachedNodes : flatNodes(this.nodes, leafOnly); + }; + + Store.prototype.getNodeByValue = function getNodeByValue(value) { + var nodes = this.getFlattedNodes(false, !this.config.lazy).filter(function (node) { + return Object(util_["valueEquals"])(node.path, value) || node.value === value; + }); + return nodes && nodes.length ? nodes[0] : null; + }; + + return Store; +}(); + +/* harmony default export */ var src_store = (store_Store); +// EXTERNAL MODULE: external "element-ui/lib/utils/merge" +var merge_ = __webpack_require__(9); +var merge_default = /*#__PURE__*/__webpack_require__.n(merge_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/aria-utils" +var aria_utils_ = __webpack_require__(41); +var aria_utils_default = /*#__PURE__*/__webpack_require__.n(aria_utils_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/scroll-into-view" +var scroll_into_view_ = __webpack_require__(31); +var scroll_into_view_default = /*#__PURE__*/__webpack_require__.n(scroll_into_view_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader-panel/src/cascader-panel.vue?vue&type=script&lang=js& +var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; + +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + + + + +var KeyCode = aria_utils_default.a.keys; + +var DefaultProps = { + expandTrigger: 'click', // or hover + multiple: false, + checkStrictly: false, // whether all nodes can be selected + emitPath: true, // wether to emit an array of all levels value in which node is located + lazy: false, + lazyLoad: util_["noop"], + value: 'value', + label: 'label', + children: 'children', + leaf: 'leaf', + disabled: 'disabled', + hoverThreshold: 500 +}; + +var cascader_panelvue_type_script_lang_js_isLeaf = function isLeaf(el) { + return !el.getAttribute('aria-owns'); +}; + +var getSibling = function getSibling(el, distance) { + var parentNode = el.parentNode; + + if (parentNode) { + var siblings = parentNode.querySelectorAll('.el-cascader-node[tabindex="-1"]'); + var index = Array.prototype.indexOf.call(siblings, el); + return siblings[index + distance] || null; + } + return null; +}; + +var getMenuIndex = function getMenuIndex(el, distance) { + if (!el) return; + var pieces = el.id.split('-'); + return Number(pieces[pieces.length - 2]); +}; + +var focusNode = function focusNode(el) { + if (!el) return; + el.focus(); + !cascader_panelvue_type_script_lang_js_isLeaf(el) && el.click(); +}; + +var checkNode = function checkNode(el) { + if (!el) return; + + var input = el.querySelector('input'); + if (input) { + input.click(); + } else if (cascader_panelvue_type_script_lang_js_isLeaf(el)) { + el.click(); + } +}; + +/* harmony default export */ var cascader_panelvue_type_script_lang_js_ = ({ + name: 'ElCascaderPanel', + + components: { + CascaderMenu: cascader_menu + }, + + props: { + value: {}, + options: Array, + props: Object, + border: { + type: Boolean, + default: true + }, + renderLabel: Function + }, + + provide: function provide() { + return { + panel: this + }; + }, + data: function data() { + return { + checkedValue: null, + checkedNodePaths: [], + store: [], + menus: [], + activePath: [], + loadCount: 0 + }; + }, + + + computed: { + config: function config() { + return merge_default()(_extends({}, DefaultProps), this.props || {}); + }, + multiple: function multiple() { + return this.config.multiple; + }, + checkStrictly: function checkStrictly() { + return this.config.checkStrictly; + }, + leafOnly: function leafOnly() { + return !this.checkStrictly; + }, + isHoverMenu: function isHoverMenu() { + return this.config.expandTrigger === 'hover'; + }, + renderLabelFn: function renderLabelFn() { + return this.renderLabel || this.$scopedSlots.default; + } + }, + + watch: { + value: function value() { + this.syncCheckedValue(); + this.checkStrictly && this.calculateCheckedNodePaths(); + }, + + options: { + handler: function handler() { + this.initStore(); + }, + immediate: true, + deep: true + }, + checkedValue: function checkedValue(val) { + if (!Object(util_["isEqual"])(val, this.value)) { + this.checkStrictly && this.calculateCheckedNodePaths(); + this.$emit('input', val); + this.$emit('change', val); + } + } + }, + + mounted: function mounted() { + if (!this.isEmptyValue(this.value)) { + this.syncCheckedValue(); + } + }, + + + methods: { + initStore: function initStore() { + var config = this.config, + options = this.options; + + if (config.lazy && Object(util_["isEmpty"])(options)) { + this.lazyLoad(); + } else { + this.store = new src_store(options, config); + this.menus = [this.store.getNodes()]; + this.syncMenuState(); + } + }, + syncCheckedValue: function syncCheckedValue() { + var value = this.value, + checkedValue = this.checkedValue; + + if (!Object(util_["isEqual"])(value, checkedValue)) { + this.activePath = []; + this.checkedValue = value; + this.syncMenuState(); + } + }, + syncMenuState: function syncMenuState() { + var multiple = this.multiple, + checkStrictly = this.checkStrictly; + + this.syncActivePath(); + multiple && this.syncMultiCheckState(); + checkStrictly && this.calculateCheckedNodePaths(); + this.$nextTick(this.scrollIntoView); + }, + syncMultiCheckState: function syncMultiCheckState() { + var _this = this; + + var nodes = this.getFlattedNodes(this.leafOnly); + + nodes.forEach(function (node) { + node.syncCheckState(_this.checkedValue); + }); + }, + isEmptyValue: function isEmptyValue(val) { + var multiple = this.multiple, + config = this.config; + var emitPath = config.emitPath; + + if (multiple || emitPath) { + return Object(util_["isEmpty"])(val); + } + return false; + }, + syncActivePath: function syncActivePath() { + var _this2 = this; + + var store = this.store, + multiple = this.multiple, + activePath = this.activePath, + checkedValue = this.checkedValue; + + + if (!Object(util_["isEmpty"])(activePath)) { + var nodes = activePath.map(function (node) { + return _this2.getNodeByValue(node.getValue()); + }); + this.expandNodes(nodes); + } else if (!this.isEmptyValue(checkedValue)) { + var value = multiple ? checkedValue[0] : checkedValue; + var checkedNode = this.getNodeByValue(value) || {}; + var _nodes = (checkedNode.pathNodes || []).slice(0, -1); + this.expandNodes(_nodes); + } else { + this.activePath = []; + this.menus = [store.getNodes()]; + } + }, + expandNodes: function expandNodes(nodes) { + var _this3 = this; + + nodes.forEach(function (node) { + return _this3.handleExpand(node, true /* silent */); + }); + }, + calculateCheckedNodePaths: function calculateCheckedNodePaths() { + var _this4 = this; + + var checkedValue = this.checkedValue, + multiple = this.multiple; + + var checkedValues = multiple ? Object(util_["coerceTruthyValueToArray"])(checkedValue) : [checkedValue]; + this.checkedNodePaths = checkedValues.map(function (v) { + var checkedNode = _this4.getNodeByValue(v); + return checkedNode ? checkedNode.pathNodes : []; + }); + }, + handleKeyDown: function handleKeyDown(e) { + var target = e.target, + keyCode = e.keyCode; + + + switch (keyCode) { + case KeyCode.up: + var prev = getSibling(target, -1); + focusNode(prev); + break; + case KeyCode.down: + var next = getSibling(target, 1); + focusNode(next); + break; + case KeyCode.left: + var preMenu = this.$refs.menu[getMenuIndex(target) - 1]; + if (preMenu) { + var expandedNode = preMenu.$el.querySelector('.el-cascader-node[aria-expanded="true"]'); + focusNode(expandedNode); + } + break; + case KeyCode.right: + var nextMenu = this.$refs.menu[getMenuIndex(target) + 1]; + if (nextMenu) { + var firstNode = nextMenu.$el.querySelector('.el-cascader-node[tabindex="-1"]'); + focusNode(firstNode); + } + break; + case KeyCode.enter: + checkNode(target); + break; + case KeyCode.esc: + case KeyCode.tab: + this.$emit('close'); + break; + default: + return; + } + }, + handleExpand: function handleExpand(node, silent) { + var activePath = this.activePath; + var level = node.level; + + var path = activePath.slice(0, level - 1); + var menus = this.menus.slice(0, level); + + if (!node.isLeaf) { + path.push(node); + menus.push(node.children); + } + + this.activePath = path; + this.menus = menus; + + if (!silent) { + var pathValues = path.map(function (node) { + return node.getValue(); + }); + var activePathValues = activePath.map(function (node) { + return node.getValue(); + }); + if (!Object(util_["valueEquals"])(pathValues, activePathValues)) { + this.$emit('active-item-change', pathValues); // Deprecated + this.$emit('expand-change', pathValues); + } + } + }, + handleCheckChange: function handleCheckChange(value) { + this.checkedValue = value; + }, + lazyLoad: function lazyLoad(node, onFullfiled) { + var _this5 = this; + + var config = this.config; + + if (!node) { + node = node || { root: true, level: 0 }; + this.store = new src_store([], config); + this.menus = [this.store.getNodes()]; + } + node.loading = true; + var resolve = function resolve(dataList) { + var parent = node.root ? null : node; + dataList && dataList.length && _this5.store.appendNodes(dataList, parent); + node.loading = false; + node.loaded = true; + + // dispose default value on lazy load mode + if (Array.isArray(_this5.checkedValue)) { + var nodeValue = _this5.checkedValue[_this5.loadCount++]; + var valueKey = _this5.config.value; + var leafKey = _this5.config.leaf; + + if (Array.isArray(dataList) && dataList.filter(function (item) { + return item[valueKey] === nodeValue; + }).length > 0) { + var checkedNode = _this5.store.getNodeByValue(nodeValue); + + if (!checkedNode.data[leafKey]) { + _this5.lazyLoad(checkedNode, function () { + _this5.handleExpand(checkedNode); + }); + } + + if (_this5.loadCount === _this5.checkedValue.length) { + _this5.$parent.computePresentText(); + } + } + } + + onFullfiled && onFullfiled(dataList); + }; + config.lazyLoad(node, resolve); + }, + + + /** + * public methods + */ + calculateMultiCheckedValue: function calculateMultiCheckedValue() { + this.checkedValue = this.getCheckedNodes(this.leafOnly).map(function (node) { + return node.getValueByOption(); + }); + }, + scrollIntoView: function scrollIntoView() { + if (this.$isServer) return; + + var menus = this.$refs.menu || []; + menus.forEach(function (menu) { + var menuElement = menu.$el; + if (menuElement) { + var container = menuElement.querySelector('.el-scrollbar__wrap'); + var activeNode = menuElement.querySelector('.el-cascader-node.is-active') || menuElement.querySelector('.el-cascader-node.in-active-path'); + scroll_into_view_default()(container, activeNode); + } + }); + }, + getNodeByValue: function getNodeByValue(val) { + return this.store.getNodeByValue(val); + }, + getFlattedNodes: function getFlattedNodes(leafOnly) { + var cached = !this.config.lazy; + return this.store.getFlattedNodes(leafOnly, cached); + }, + getCheckedNodes: function getCheckedNodes(leafOnly) { + var checkedValue = this.checkedValue, + multiple = this.multiple; + + if (multiple) { + var nodes = this.getFlattedNodes(leafOnly); + return nodes.filter(function (node) { + return node.checked; + }); + } else { + return this.isEmptyValue(checkedValue) ? [] : [this.getNodeByValue(checkedValue)]; + } + }, + clearCheckedNodes: function clearCheckedNodes() { + var config = this.config, + leafOnly = this.leafOnly; + var multiple = config.multiple, + emitPath = config.emitPath; + + if (multiple) { + this.getCheckedNodes(leafOnly).filter(function (node) { + return !node.isDisabled; + }).forEach(function (node) { + return node.doCheck(false); + }); + this.calculateMultiCheckedValue(); + } else { + this.checkedValue = emitPath ? [] : null; + } + } + } +}); +// CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-panel.vue?vue&type=script&lang=js& + /* harmony default export */ var src_cascader_panelvue_type_script_lang_js_ = (cascader_panelvue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-panel.vue + + + + + +/* normalize component */ + +var cascader_panel_component = Object(componentNormalizer["a" /* default */])( + src_cascader_panelvue_type_script_lang_js_, + cascader_panelvue_type_template_id_34932346_render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var cascader_panel_api; } +cascader_panel_component.options.__file = "packages/cascader-panel/src/cascader-panel.vue" +/* harmony default export */ var cascader_panel = (cascader_panel_component.exports); +// CONCATENATED MODULE: ./packages/cascader-panel/index.js + + +/* istanbul ignore next */ +cascader_panel.install = function (Vue) { + Vue.component(cascader_panel.name, cascader_panel); +}; + +/* harmony default export */ var packages_cascader_panel = __webpack_exports__["default"] = (cascader_panel); + +/***/ }), + +/***/ 9: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/merge"); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/cascader.js b/public/static/libs/element-ui/lib/cascader.js new file mode 100644 index 0000000..0bdccb2 --- /dev/null +++ b/public/static/libs/element-ui/lib/cascader.js @@ -0,0 +1,1436 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 115); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 10: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/input"); + +/***/ }), + +/***/ 11: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/migrating"); + +/***/ }), + +/***/ 115: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader/src/cascader.vue?vue&type=template&id=032537a6& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { + directives: [ + { + name: "clickoutside", + rawName: "v-clickoutside", + value: function() { + return _vm.toggleDropDownVisible(false) + }, + expression: "() => toggleDropDownVisible(false)" + } + ], + ref: "reference", + class: [ + "el-cascader", + _vm.realSize && "el-cascader--" + _vm.realSize, + { "is-disabled": _vm.isDisabled } + ], + on: { + mouseenter: function($event) { + _vm.inputHover = true + }, + mouseleave: function($event) { + _vm.inputHover = false + }, + click: function() { + return _vm.toggleDropDownVisible(_vm.readonly ? undefined : true) + }, + keydown: _vm.handleKeyDown + } + }, + [ + _c( + "el-input", + { + ref: "input", + class: { "is-focus": _vm.dropDownVisible }, + attrs: { + size: _vm.realSize, + placeholder: _vm.placeholder, + readonly: _vm.readonly, + disabled: _vm.isDisabled, + "validate-event": false + }, + on: { + focus: _vm.handleFocus, + blur: _vm.handleBlur, + input: _vm.handleInput + }, + model: { + value: _vm.multiple ? _vm.presentText : _vm.inputValue, + callback: function($$v) { + _vm.multiple ? _vm.presentText : (_vm.inputValue = $$v) + }, + expression: "multiple ? presentText : inputValue" + } + }, + [ + _c("template", { slot: "suffix" }, [ + _vm.clearBtnVisible + ? _c("i", { + key: "clear", + staticClass: "el-input__icon el-icon-circle-close", + on: { + click: function($event) { + $event.stopPropagation() + return _vm.handleClear($event) + } + } + }) + : _c("i", { + key: "arrow-down", + class: [ + "el-input__icon", + "el-icon-arrow-down", + _vm.dropDownVisible && "is-reverse" + ], + on: { + click: function($event) { + $event.stopPropagation() + _vm.toggleDropDownVisible() + } + } + }) + ]) + ], + 2 + ), + _vm.multiple + ? _c( + "div", + { staticClass: "el-cascader__tags" }, + [ + _vm._l(_vm.presentTags, function(tag) { + return _c( + "el-tag", + { + key: tag.key, + attrs: { + type: "info", + size: _vm.tagSize, + hit: tag.hitState, + closable: tag.closable, + "disable-transitions": "" + }, + on: { + close: function($event) { + _vm.deleteTag(tag) + } + } + }, + [_c("span", [_vm._v(_vm._s(tag.text))])] + ) + }), + _vm.filterable && !_vm.isDisabled + ? _c("input", { + directives: [ + { + name: "model", + rawName: "v-model.trim", + value: _vm.inputValue, + expression: "inputValue", + modifiers: { trim: true } + } + ], + staticClass: "el-cascader__search-input", + attrs: { + type: "text", + placeholder: _vm.presentTags.length ? "" : _vm.placeholder + }, + domProps: { value: _vm.inputValue }, + on: { + input: [ + function($event) { + if ($event.target.composing) { + return + } + _vm.inputValue = $event.target.value.trim() + }, + function(e) { + return _vm.handleInput(_vm.inputValue, e) + } + ], + click: function($event) { + $event.stopPropagation() + _vm.toggleDropDownVisible(true) + }, + keydown: function($event) { + if ( + !("button" in $event) && + _vm._k( + $event.keyCode, + "delete", + [8, 46], + $event.key, + ["Backspace", "Delete", "Del"] + ) + ) { + return null + } + return _vm.handleDelete($event) + }, + blur: function($event) { + _vm.$forceUpdate() + } + } + }) + : _vm._e() + ], + 2 + ) + : _vm._e(), + _c( + "transition", + { + attrs: { name: "el-zoom-in-top" }, + on: { "after-leave": _vm.handleDropdownLeave } + }, + [ + _c( + "div", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.dropDownVisible, + expression: "dropDownVisible" + } + ], + ref: "popper", + class: ["el-popper", "el-cascader__dropdown", _vm.popperClass] + }, + [ + _c("el-cascader-panel", { + directives: [ + { + name: "show", + rawName: "v-show", + value: !_vm.filtering, + expression: "!filtering" + } + ], + ref: "panel", + attrs: { + options: _vm.options, + props: _vm.config, + border: false, + "render-label": _vm.$scopedSlots.default + }, + on: { + "expand-change": _vm.handleExpandChange, + close: function($event) { + _vm.toggleDropDownVisible(false) + } + }, + model: { + value: _vm.checkedValue, + callback: function($$v) { + _vm.checkedValue = $$v + }, + expression: "checkedValue" + } + }), + _vm.filterable + ? _c( + "el-scrollbar", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.filtering, + expression: "filtering" + } + ], + ref: "suggestionPanel", + staticClass: "el-cascader__suggestion-panel", + attrs: { + tag: "ul", + "view-class": "el-cascader__suggestion-list" + }, + nativeOn: { + keydown: function($event) { + return _vm.handleSuggestionKeyDown($event) + } + } + }, + [ + _vm.suggestions.length + ? _vm._l(_vm.suggestions, function(item, index) { + return _c( + "li", + { + key: item.uid, + class: [ + "el-cascader__suggestion-item", + item.checked && "is-checked" + ], + attrs: { tabindex: -1 }, + on: { + click: function($event) { + _vm.handleSuggestionClick(index) + } + } + }, + [ + _c("span", [_vm._v(_vm._s(item.text))]), + item.checked + ? _c("i", { staticClass: "el-icon-check" }) + : _vm._e() + ] + ) + }) + : _vm._t("empty", [ + _c( + "li", + { staticClass: "el-cascader__empty-text" }, + [_vm._v(_vm._s(_vm.t("el.cascader.noMatch")))] + ) + ]) + ], + 2 + ) + : _vm._e() + ], + 1 + ) + ] + ) + ], + 1 + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/cascader/src/cascader.vue?vue&type=template&id=032537a6& + +// EXTERNAL MODULE: external "element-ui/lib/utils/vue-popper" +var vue_popper_ = __webpack_require__(5); +var vue_popper_default = /*#__PURE__*/__webpack_require__.n(vue_popper_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/clickoutside" +var clickoutside_ = __webpack_require__(12); +var clickoutside_default = /*#__PURE__*/__webpack_require__.n(clickoutside_); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/emitter" +var emitter_ = __webpack_require__(4); +var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/locale" +var locale_ = __webpack_require__(6); +var locale_default = /*#__PURE__*/__webpack_require__.n(locale_); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/migrating" +var migrating_ = __webpack_require__(11); +var migrating_default = /*#__PURE__*/__webpack_require__.n(migrating_); + +// EXTERNAL MODULE: external "element-ui/lib/input" +var input_ = __webpack_require__(10); +var input_default = /*#__PURE__*/__webpack_require__.n(input_); + +// EXTERNAL MODULE: external "element-ui/lib/tag" +var tag_ = __webpack_require__(38); +var tag_default = /*#__PURE__*/__webpack_require__.n(tag_); + +// EXTERNAL MODULE: external "element-ui/lib/scrollbar" +var scrollbar_ = __webpack_require__(15); +var scrollbar_default = /*#__PURE__*/__webpack_require__.n(scrollbar_); + +// EXTERNAL MODULE: external "element-ui/lib/cascader-panel" +var cascader_panel_ = __webpack_require__(51); +var cascader_panel_default = /*#__PURE__*/__webpack_require__.n(cascader_panel_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/aria-utils" +var aria_utils_ = __webpack_require__(41); +var aria_utils_default = /*#__PURE__*/__webpack_require__.n(aria_utils_); + +// EXTERNAL MODULE: external "element-ui/lib/locale" +var lib_locale_ = __webpack_require__(20); + +// EXTERNAL MODULE: external "element-ui/lib/utils/util" +var util_ = __webpack_require__(3); + +// EXTERNAL MODULE: external "element-ui/lib/utils/types" +var types_ = __webpack_require__(17); + +// EXTERNAL MODULE: external "element-ui/lib/utils/shared" +var shared_ = __webpack_require__(21); + +// EXTERNAL MODULE: external "element-ui/lib/utils/resize-event" +var resize_event_ = __webpack_require__(16); + +// EXTERNAL MODULE: external "throttle-debounce/debounce" +var debounce_ = __webpack_require__(19); +var debounce_default = /*#__PURE__*/__webpack_require__.n(debounce_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader/src/cascader.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + + + + + + + + + + + + + + +var KeyCode = aria_utils_default.a.keys; + +var MigratingProps = { + expandTrigger: { + newProp: 'expandTrigger', + type: String + }, + changeOnSelect: { + newProp: 'checkStrictly', + type: Boolean + }, + hoverThreshold: { + newProp: 'hoverThreshold', + type: Number + } +}; + +var PopperMixin = { + props: { + placement: { + type: String, + default: 'bottom-start' + }, + appendToBody: vue_popper_default.a.props.appendToBody, + visibleArrow: { + type: Boolean, + default: true + }, + arrowOffset: vue_popper_default.a.props.arrowOffset, + offset: vue_popper_default.a.props.offset, + boundariesPadding: vue_popper_default.a.props.boundariesPadding, + popperOptions: vue_popper_default.a.props.popperOptions, + transformOrigin: vue_popper_default.a.props.transformOrigin + }, + methods: vue_popper_default.a.methods, + data: vue_popper_default.a.data, + beforeDestroy: vue_popper_default.a.beforeDestroy +}; + +var InputSizeMap = { + medium: 36, + small: 32, + mini: 28 +}; + +/* harmony default export */ var cascadervue_type_script_lang_js_ = ({ + name: 'ElCascader', + + directives: { Clickoutside: clickoutside_default.a }, + + mixins: [PopperMixin, emitter_default.a, locale_default.a, migrating_default.a], + + inject: { + elForm: { + default: '' + }, + elFormItem: { + default: '' + } + }, + + components: { + ElInput: input_default.a, + ElTag: tag_default.a, + ElScrollbar: scrollbar_default.a, + ElCascaderPanel: cascader_panel_default.a + }, + + props: { + value: {}, + options: Array, + props: Object, + size: String, + placeholder: { + type: String, + default: function _default() { + return Object(lib_locale_["t"])('el.cascader.placeholder'); + } + }, + disabled: Boolean, + clearable: Boolean, + filterable: Boolean, + filterMethod: Function, + separator: { + type: String, + default: ' / ' + }, + showAllLevels: { + type: Boolean, + default: true + }, + collapseTags: Boolean, + debounce: { + type: Number, + default: 300 + }, + beforeFilter: { + type: Function, + default: function _default() { + return function () {}; + } + }, + popperClass: String + }, + + data: function data() { + return { + dropDownVisible: false, + checkedValue: this.value, + inputHover: false, + inputValue: null, + presentText: null, + presentTags: [], + checkedNodes: [], + filtering: false, + suggestions: [], + inputInitialHeight: 0, + pressDeleteCount: 0 + }; + }, + + + computed: { + realSize: function realSize() { + var _elFormItemSize = (this.elFormItem || {}).elFormItemSize; + return this.size || _elFormItemSize || (this.$ELEMENT || {}).size; + }, + tagSize: function tagSize() { + return ['small', 'mini'].indexOf(this.realSize) > -1 ? 'mini' : 'small'; + }, + isDisabled: function isDisabled() { + return this.disabled || (this.elForm || {}).disabled; + }, + config: function config() { + var config = this.props || {}; + var $attrs = this.$attrs; + + + Object.keys(MigratingProps).forEach(function (oldProp) { + var _MigratingProps$oldPr = MigratingProps[oldProp], + newProp = _MigratingProps$oldPr.newProp, + type = _MigratingProps$oldPr.type; + + var oldValue = $attrs[oldProp] || $attrs[Object(util_["kebabCase"])(oldProp)]; + if (Object(shared_["isDef"])(oldProp) && !Object(shared_["isDef"])(config[newProp])) { + if (type === Boolean && oldValue === '') { + oldValue = true; + } + config[newProp] = oldValue; + } + }); + + return config; + }, + multiple: function multiple() { + return this.config.multiple; + }, + leafOnly: function leafOnly() { + return !this.config.checkStrictly; + }, + readonly: function readonly() { + return !this.filterable || this.multiple; + }, + clearBtnVisible: function clearBtnVisible() { + if (!this.clearable || this.isDisabled || this.filtering || !this.inputHover) { + return false; + } + + return this.multiple ? !!this.checkedNodes.filter(function (node) { + return !node.isDisabled; + }).length : !!this.presentText; + }, + panel: function panel() { + return this.$refs.panel; + } + }, + + watch: { + disabled: function disabled() { + this.computePresentContent(); + }, + value: function value(val) { + if (!Object(util_["isEqual"])(val, this.checkedValue)) { + this.checkedValue = val; + this.computePresentContent(); + } + }, + checkedValue: function checkedValue(val) { + var value = this.value, + dropDownVisible = this.dropDownVisible; + var _config = this.config, + checkStrictly = _config.checkStrictly, + multiple = _config.multiple; + + + if (!Object(util_["isEqual"])(val, value) || Object(types_["isUndefined"])(value)) { + this.computePresentContent(); + // hide dropdown when single mode + if (!multiple && !checkStrictly && dropDownVisible) { + this.toggleDropDownVisible(false); + } + + this.$emit('input', val); + this.$emit('change', val); + this.dispatch('ElFormItem', 'el.form.change', [val]); + } + }, + + options: { + handler: function handler() { + this.$nextTick(this.computePresentContent); + }, + deep: true + }, + presentText: function presentText(val) { + this.inputValue = val; + }, + presentTags: function presentTags(val, oldVal) { + if (this.multiple && (val.length || oldVal.length)) { + this.$nextTick(this.updateStyle); + } + }, + filtering: function filtering(val) { + this.$nextTick(this.updatePopper); + } + }, + + mounted: function mounted() { + var _this = this; + + var input = this.$refs.input; + + if (input && input.$el) { + this.inputInitialHeight = input.$el.offsetHeight || InputSizeMap[this.realSize] || 40; + } + + if (!this.isEmptyValue(this.value)) { + this.computePresentContent(); + } + + this.filterHandler = debounce_default()(this.debounce, function () { + var inputValue = _this.inputValue; + + + if (!inputValue) { + _this.filtering = false; + return; + } + + var before = _this.beforeFilter(inputValue); + if (before && before.then) { + before.then(_this.getSuggestions); + } else if (before !== false) { + _this.getSuggestions(); + } else { + _this.filtering = false; + } + }); + + Object(resize_event_["addResizeListener"])(this.$el, this.updateStyle); + }, + beforeDestroy: function beforeDestroy() { + Object(resize_event_["removeResizeListener"])(this.$el, this.updateStyle); + }, + + + methods: { + getMigratingConfig: function getMigratingConfig() { + return { + props: { + 'expand-trigger': 'expand-trigger is removed, use `props.expandTrigger` instead.', + 'change-on-select': 'change-on-select is removed, use `props.checkStrictly` instead.', + 'hover-threshold': 'hover-threshold is removed, use `props.hoverThreshold` instead' + }, + events: { + 'active-item-change': 'active-item-change is renamed to expand-change' + } + }; + }, + toggleDropDownVisible: function toggleDropDownVisible(visible) { + var _this2 = this; + + if (this.isDisabled) return; + + var dropDownVisible = this.dropDownVisible; + var input = this.$refs.input; + + visible = Object(shared_["isDef"])(visible) ? visible : !dropDownVisible; + if (visible !== dropDownVisible) { + this.dropDownVisible = visible; + if (visible) { + this.$nextTick(function () { + _this2.updatePopper(); + _this2.panel.scrollIntoView(); + }); + } + input.$refs.input.setAttribute('aria-expanded', visible); + this.$emit('visible-change', visible); + } + }, + handleDropdownLeave: function handleDropdownLeave() { + this.filtering = false; + this.inputValue = this.presentText; + this.doDestroy(); + }, + handleKeyDown: function handleKeyDown(event) { + switch (event.keyCode) { + case KeyCode.enter: + this.toggleDropDownVisible(); + break; + case KeyCode.down: + this.toggleDropDownVisible(true); + this.focusFirstNode(); + event.preventDefault(); + break; + case KeyCode.esc: + case KeyCode.tab: + this.toggleDropDownVisible(false); + break; + } + }, + handleFocus: function handleFocus(e) { + this.$emit('focus', e); + }, + handleBlur: function handleBlur(e) { + this.$emit('blur', e); + }, + handleInput: function handleInput(val, event) { + !this.dropDownVisible && this.toggleDropDownVisible(true); + + if (event && event.isComposing) return; + if (val) { + this.filterHandler(); + } else { + this.filtering = false; + } + }, + handleClear: function handleClear() { + this.presentText = ''; + this.panel.clearCheckedNodes(); + }, + handleExpandChange: function handleExpandChange(value) { + this.$nextTick(this.updatePopper.bind(this)); + this.$emit('expand-change', value); + this.$emit('active-item-change', value); // Deprecated + }, + focusFirstNode: function focusFirstNode() { + var _this3 = this; + + this.$nextTick(function () { + var filtering = _this3.filtering; + var _$refs = _this3.$refs, + popper = _$refs.popper, + suggestionPanel = _$refs.suggestionPanel; + + var firstNode = null; + + if (filtering && suggestionPanel) { + firstNode = suggestionPanel.$el.querySelector('.el-cascader__suggestion-item'); + } else { + var firstMenu = popper.querySelector('.el-cascader-menu'); + firstNode = firstMenu.querySelector('.el-cascader-node[tabindex="-1"]'); + } + + if (firstNode) { + firstNode.focus(); + !filtering && firstNode.click(); + } + }); + }, + computePresentContent: function computePresentContent() { + var _this4 = this; + + // nextTick is required, because checked nodes may not change right now + this.$nextTick(function () { + if (_this4.config.multiple) { + _this4.computePresentTags(); + _this4.presentText = _this4.presentTags.length ? ' ' : null; + } else { + _this4.computePresentText(); + } + }); + }, + isEmptyValue: function isEmptyValue(val) { + var multiple = this.multiple; + var emitPath = this.panel.config.emitPath; + + if (multiple || emitPath) { + return Object(util_["isEmpty"])(val); + } + return false; + }, + computePresentText: function computePresentText() { + var checkedValue = this.checkedValue, + config = this.config; + + if (!this.isEmptyValue(checkedValue)) { + var node = this.panel.getNodeByValue(checkedValue); + if (node && (config.checkStrictly || node.isLeaf)) { + this.presentText = node.getText(this.showAllLevels, this.separator); + return; + } + } + this.presentText = null; + }, + computePresentTags: function computePresentTags() { + var isDisabled = this.isDisabled, + leafOnly = this.leafOnly, + showAllLevels = this.showAllLevels, + separator = this.separator, + collapseTags = this.collapseTags; + + var checkedNodes = this.getCheckedNodes(leafOnly); + var tags = []; + + var genTag = function genTag(node) { + return { + node: node, + key: node.uid, + text: node.getText(showAllLevels, separator), + hitState: false, + closable: !isDisabled && !node.isDisabled + }; + }; + + if (checkedNodes.length) { + var first = checkedNodes[0], + rest = checkedNodes.slice(1); + + var restCount = rest.length; + tags.push(genTag(first)); + + if (restCount) { + if (collapseTags) { + tags.push({ + key: -1, + text: '+ ' + restCount, + closable: false + }); + } else { + rest.forEach(function (node) { + return tags.push(genTag(node)); + }); + } + } + } + + this.checkedNodes = checkedNodes; + this.presentTags = tags; + }, + getSuggestions: function getSuggestions() { + var _this5 = this; + + var filterMethod = this.filterMethod; + + + if (!Object(types_["isFunction"])(filterMethod)) { + filterMethod = function filterMethod(node, keyword) { + return node.text.includes(keyword); + }; + } + + var suggestions = this.panel.getFlattedNodes(this.leafOnly).filter(function (node) { + if (node.isDisabled) return false; + node.text = node.getText(_this5.showAllLevels, _this5.separator) || ''; + return filterMethod(node, _this5.inputValue); + }); + + if (this.multiple) { + this.presentTags.forEach(function (tag) { + tag.hitState = false; + }); + } else { + suggestions.forEach(function (node) { + node.checked = Object(util_["isEqual"])(_this5.checkedValue, node.getValueByOption()); + }); + } + + this.filtering = true; + this.suggestions = suggestions; + this.$nextTick(this.updatePopper); + }, + handleSuggestionKeyDown: function handleSuggestionKeyDown(event) { + var keyCode = event.keyCode, + target = event.target; + + switch (keyCode) { + case KeyCode.enter: + target.click(); + break; + case KeyCode.up: + var prev = target.previousElementSibling; + prev && prev.focus(); + break; + case KeyCode.down: + var next = target.nextElementSibling; + next && next.focus(); + break; + case KeyCode.esc: + case KeyCode.tab: + this.toggleDropDownVisible(false); + break; + } + }, + handleDelete: function handleDelete() { + var inputValue = this.inputValue, + pressDeleteCount = this.pressDeleteCount, + presentTags = this.presentTags; + + var lastIndex = presentTags.length - 1; + var lastTag = presentTags[lastIndex]; + this.pressDeleteCount = inputValue ? 0 : pressDeleteCount + 1; + + if (!lastTag) return; + + if (this.pressDeleteCount) { + if (lastTag.hitState) { + this.deleteTag(lastTag); + } else { + lastTag.hitState = true; + } + } + }, + handleSuggestionClick: function handleSuggestionClick(index) { + var multiple = this.multiple; + + var targetNode = this.suggestions[index]; + + if (multiple) { + var checked = targetNode.checked; + + targetNode.doCheck(!checked); + this.panel.calculateMultiCheckedValue(); + } else { + this.checkedValue = targetNode.getValueByOption(); + this.toggleDropDownVisible(false); + } + }, + deleteTag: function deleteTag(tag) { + var checkedValue = this.checkedValue; + + var current = tag.node.getValueByOption(); + var val = checkedValue.find(function (n) { + return Object(util_["isEqual"])(n, current); + }); + this.checkedValue = checkedValue.filter(function (n) { + return !Object(util_["isEqual"])(n, current); + }); + this.$emit('remove-tag', val); + }, + updateStyle: function updateStyle() { + var $el = this.$el, + inputInitialHeight = this.inputInitialHeight; + + if (this.$isServer || !$el) return; + + var suggestionPanel = this.$refs.suggestionPanel; + + var inputInner = $el.querySelector('.el-input__inner'); + + if (!inputInner) return; + + var tags = $el.querySelector('.el-cascader__tags'); + var suggestionPanelEl = null; + + if (suggestionPanel && (suggestionPanelEl = suggestionPanel.$el)) { + var suggestionList = suggestionPanelEl.querySelector('.el-cascader__suggestion-list'); + suggestionList.style.minWidth = inputInner.offsetWidth + 'px'; + } + + if (tags) { + var offsetHeight = Math.round(tags.getBoundingClientRect().height); + var height = Math.max(offsetHeight + 6, inputInitialHeight) + 'px'; + inputInner.style.height = height; + if (this.dropDownVisible) { + this.updatePopper(); + } + } + }, + + + /** + * public methods + */ + getCheckedNodes: function getCheckedNodes(leafOnly) { + return this.panel.getCheckedNodes(leafOnly); + } + } +}); +// CONCATENATED MODULE: ./packages/cascader/src/cascader.vue?vue&type=script&lang=js& + /* harmony default export */ var src_cascadervue_type_script_lang_js_ = (cascadervue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/cascader/src/cascader.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_cascadervue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/cascader/src/cascader.vue" +/* harmony default export */ var cascader = (component.exports); +// CONCATENATED MODULE: ./packages/cascader/index.js + + +/* istanbul ignore next */ +cascader.install = function (Vue) { + Vue.component(cascader.name, cascader); +}; + +/* harmony default export */ var packages_cascader = __webpack_exports__["default"] = (cascader); + +/***/ }), + +/***/ 12: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/clickoutside"); + +/***/ }), + +/***/ 15: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/scrollbar"); + +/***/ }), + +/***/ 16: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/resize-event"); + +/***/ }), + +/***/ 17: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/types"); + +/***/ }), + +/***/ 19: +/***/ (function(module, exports) { + +module.exports = require("throttle-debounce/debounce"); + +/***/ }), + +/***/ 20: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/locale"); + +/***/ }), + +/***/ 21: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/shared"); + +/***/ }), + +/***/ 3: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/util"); + +/***/ }), + +/***/ 38: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/tag"); + +/***/ }), + +/***/ 4: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/emitter"); + +/***/ }), + +/***/ 41: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/aria-utils"); + +/***/ }), + +/***/ 5: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/vue-popper"); + +/***/ }), + +/***/ 51: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/cascader-panel"); + +/***/ }), + +/***/ 6: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/locale"); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/checkbox-button.js b/public/static/libs/element-ui/lib/checkbox-button.js new file mode 100644 index 0000000..e890bfc --- /dev/null +++ b/public/static/libs/element-ui/lib/checkbox-button.js @@ -0,0 +1,582 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 92); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 4: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/emitter"); + +/***/ }), + +/***/ 92: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox-button.vue?vue&type=template&id=478e906e& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "label", + { + staticClass: "el-checkbox-button", + class: [ + _vm.size ? "el-checkbox-button--" + _vm.size : "", + { "is-disabled": _vm.isDisabled }, + { "is-checked": _vm.isChecked }, + { "is-focus": _vm.focus } + ], + attrs: { + role: "checkbox", + "aria-checked": _vm.isChecked, + "aria-disabled": _vm.isDisabled + } + }, + [ + _vm.trueLabel || _vm.falseLabel + ? _c("input", { + directives: [ + { + name: "model", + rawName: "v-model", + value: _vm.model, + expression: "model" + } + ], + staticClass: "el-checkbox-button__original", + attrs: { + type: "checkbox", + name: _vm.name, + disabled: _vm.isDisabled, + "true-value": _vm.trueLabel, + "false-value": _vm.falseLabel + }, + domProps: { + checked: Array.isArray(_vm.model) + ? _vm._i(_vm.model, null) > -1 + : _vm._q(_vm.model, _vm.trueLabel) + }, + on: { + change: [ + function($event) { + var $$a = _vm.model, + $$el = $event.target, + $$c = $$el.checked ? _vm.trueLabel : _vm.falseLabel + if (Array.isArray($$a)) { + var $$v = null, + $$i = _vm._i($$a, $$v) + if ($$el.checked) { + $$i < 0 && (_vm.model = $$a.concat([$$v])) + } else { + $$i > -1 && + (_vm.model = $$a + .slice(0, $$i) + .concat($$a.slice($$i + 1))) + } + } else { + _vm.model = $$c + } + }, + _vm.handleChange + ], + focus: function($event) { + _vm.focus = true + }, + blur: function($event) { + _vm.focus = false + } + } + }) + : _c("input", { + directives: [ + { + name: "model", + rawName: "v-model", + value: _vm.model, + expression: "model" + } + ], + staticClass: "el-checkbox-button__original", + attrs: { + type: "checkbox", + name: _vm.name, + disabled: _vm.isDisabled + }, + domProps: { + value: _vm.label, + checked: Array.isArray(_vm.model) + ? _vm._i(_vm.model, _vm.label) > -1 + : _vm.model + }, + on: { + change: [ + function($event) { + var $$a = _vm.model, + $$el = $event.target, + $$c = $$el.checked ? true : false + if (Array.isArray($$a)) { + var $$v = _vm.label, + $$i = _vm._i($$a, $$v) + if ($$el.checked) { + $$i < 0 && (_vm.model = $$a.concat([$$v])) + } else { + $$i > -1 && + (_vm.model = $$a + .slice(0, $$i) + .concat($$a.slice($$i + 1))) + } + } else { + _vm.model = $$c + } + }, + _vm.handleChange + ], + focus: function($event) { + _vm.focus = true + }, + blur: function($event) { + _vm.focus = false + } + } + }), + _vm.$slots.default || _vm.label + ? _c( + "span", + { + staticClass: "el-checkbox-button__inner", + style: _vm.isChecked ? _vm.activeStyle : null + }, + [_vm._t("default", [_vm._v(_vm._s(_vm.label))])], + 2 + ) + : _vm._e() + ] + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/checkbox/src/checkbox-button.vue?vue&type=template&id=478e906e& + +// EXTERNAL MODULE: external "element-ui/lib/mixins/emitter" +var emitter_ = __webpack_require__(4); +var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox-button.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + +/* harmony default export */ var checkbox_buttonvue_type_script_lang_js_ = ({ + name: 'ElCheckboxButton', + + mixins: [emitter_default.a], + + inject: { + elForm: { + default: '' + }, + elFormItem: { + default: '' + } + }, + + data: function data() { + return { + selfModel: false, + focus: false, + isLimitExceeded: false + }; + }, + + + props: { + value: {}, + label: {}, + disabled: Boolean, + checked: Boolean, + name: String, + trueLabel: [String, Number], + falseLabel: [String, Number] + }, + computed: { + model: { + get: function get() { + return this._checkboxGroup ? this.store : this.value !== undefined ? this.value : this.selfModel; + }, + set: function set(val) { + if (this._checkboxGroup) { + this.isLimitExceeded = false; + this._checkboxGroup.min !== undefined && val.length < this._checkboxGroup.min && (this.isLimitExceeded = true); + + this._checkboxGroup.max !== undefined && val.length > this._checkboxGroup.max && (this.isLimitExceeded = true); + + this.isLimitExceeded === false && this.dispatch('ElCheckboxGroup', 'input', [val]); + } else if (this.value !== undefined) { + this.$emit('input', val); + } else { + this.selfModel = val; + } + } + }, + + isChecked: function isChecked() { + if ({}.toString.call(this.model) === '[object Boolean]') { + return this.model; + } else if (Array.isArray(this.model)) { + return this.model.indexOf(this.label) > -1; + } else if (this.model !== null && this.model !== undefined) { + return this.model === this.trueLabel; + } + }, + _checkboxGroup: function _checkboxGroup() { + var parent = this.$parent; + while (parent) { + if (parent.$options.componentName !== 'ElCheckboxGroup') { + parent = parent.$parent; + } else { + return parent; + } + } + return false; + }, + store: function store() { + return this._checkboxGroup ? this._checkboxGroup.value : this.value; + }, + activeStyle: function activeStyle() { + return { + backgroundColor: this._checkboxGroup.fill || '', + borderColor: this._checkboxGroup.fill || '', + color: this._checkboxGroup.textColor || '', + 'box-shadow': '-1px 0 0 0 ' + this._checkboxGroup.fill + + }; + }, + _elFormItemSize: function _elFormItemSize() { + return (this.elFormItem || {}).elFormItemSize; + }, + size: function size() { + return this._checkboxGroup.checkboxGroupSize || this._elFormItemSize || (this.$ELEMENT || {}).size; + }, + + + /* used to make the isDisabled judgment under max/min props */ + isLimitDisabled: function isLimitDisabled() { + var _checkboxGroup2 = this._checkboxGroup, + max = _checkboxGroup2.max, + min = _checkboxGroup2.min; + + return !!(max || min) && this.model.length >= max && !this.isChecked || this.model.length <= min && this.isChecked; + }, + isDisabled: function isDisabled() { + return this._checkboxGroup ? this._checkboxGroup.disabled || this.disabled || (this.elForm || {}).disabled || this.isLimitDisabled : this.disabled || (this.elForm || {}).disabled; + } + }, + methods: { + addToStore: function addToStore() { + if (Array.isArray(this.model) && this.model.indexOf(this.label) === -1) { + this.model.push(this.label); + } else { + this.model = this.trueLabel || true; + } + }, + handleChange: function handleChange(ev) { + var _this = this; + + if (this.isLimitExceeded) return; + var value = void 0; + if (ev.target.checked) { + value = this.trueLabel === undefined ? true : this.trueLabel; + } else { + value = this.falseLabel === undefined ? false : this.falseLabel; + } + this.$emit('change', value, ev); + this.$nextTick(function () { + if (_this._checkboxGroup) { + _this.dispatch('ElCheckboxGroup', 'change', [_this._checkboxGroup.value]); + } + }); + } + }, + + created: function created() { + this.checked && this.addToStore(); + } +}); +// CONCATENATED MODULE: ./packages/checkbox/src/checkbox-button.vue?vue&type=script&lang=js& + /* harmony default export */ var src_checkbox_buttonvue_type_script_lang_js_ = (checkbox_buttonvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/checkbox/src/checkbox-button.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_checkbox_buttonvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/checkbox/src/checkbox-button.vue" +/* harmony default export */ var checkbox_button = (component.exports); +// CONCATENATED MODULE: ./packages/checkbox-button/index.js + + +/* istanbul ignore next */ +checkbox_button.install = function (Vue) { + Vue.component(checkbox_button.name, checkbox_button); +}; + +/* harmony default export */ var packages_checkbox_button = __webpack_exports__["default"] = (checkbox_button); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/checkbox-group.js b/public/static/libs/element-ui/lib/checkbox-group.js new file mode 100644 index 0000000..7f75dfc --- /dev/null +++ b/public/static/libs/element-ui/lib/checkbox-group.js @@ -0,0 +1,312 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 93); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 4: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/emitter"); + +/***/ }), + +/***/ 93: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox-group.vue?vue&type=template&id=7289a290& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { + staticClass: "el-checkbox-group", + attrs: { role: "group", "aria-label": "checkbox-group" } + }, + [_vm._t("default")], + 2 + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/checkbox/src/checkbox-group.vue?vue&type=template&id=7289a290& + +// EXTERNAL MODULE: external "element-ui/lib/mixins/emitter" +var emitter_ = __webpack_require__(4); +var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox-group.vue?vue&type=script&lang=js& + + + +/* harmony default export */ var checkbox_groupvue_type_script_lang_js_ = ({ + name: 'ElCheckboxGroup', + + componentName: 'ElCheckboxGroup', + + mixins: [emitter_default.a], + + inject: { + elFormItem: { + default: '' + } + }, + + props: { + value: {}, + disabled: Boolean, + min: Number, + max: Number, + size: String, + fill: String, + textColor: String + }, + + computed: { + _elFormItemSize: function _elFormItemSize() { + return (this.elFormItem || {}).elFormItemSize; + }, + checkboxGroupSize: function checkboxGroupSize() { + return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size; + } + }, + + watch: { + value: function value(_value) { + this.dispatch('ElFormItem', 'el.form.change', [_value]); + } + } +}); +// CONCATENATED MODULE: ./packages/checkbox/src/checkbox-group.vue?vue&type=script&lang=js& + /* harmony default export */ var src_checkbox_groupvue_type_script_lang_js_ = (checkbox_groupvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/checkbox/src/checkbox-group.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_checkbox_groupvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/checkbox/src/checkbox-group.vue" +/* harmony default export */ var checkbox_group = (component.exports); +// CONCATENATED MODULE: ./packages/checkbox-group/index.js + + +/* istanbul ignore next */ +checkbox_group.install = function (Vue) { + Vue.component(checkbox_group.name, checkbox_group); +}; + +/* harmony default export */ var packages_checkbox_group = __webpack_exports__["default"] = (checkbox_group); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/checkbox.js b/public/static/libs/element-ui/lib/checkbox.js new file mode 100644 index 0000000..707b180 --- /dev/null +++ b/public/static/libs/element-ui/lib/checkbox.js @@ -0,0 +1,626 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 91); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 4: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/emitter"); + +/***/ }), + +/***/ 91: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox.vue?vue&type=template&id=d0387074& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "label", + { + staticClass: "el-checkbox", + class: [ + _vm.border && _vm.checkboxSize + ? "el-checkbox--" + _vm.checkboxSize + : "", + { "is-disabled": _vm.isDisabled }, + { "is-bordered": _vm.border }, + { "is-checked": _vm.isChecked } + ], + attrs: { id: _vm.id } + }, + [ + _c( + "span", + { + staticClass: "el-checkbox__input", + class: { + "is-disabled": _vm.isDisabled, + "is-checked": _vm.isChecked, + "is-indeterminate": _vm.indeterminate, + "is-focus": _vm.focus + }, + attrs: { + tabindex: _vm.indeterminate ? 0 : false, + role: _vm.indeterminate ? "checkbox" : false, + "aria-checked": _vm.indeterminate ? "mixed" : false + } + }, + [ + _c("span", { staticClass: "el-checkbox__inner" }), + _vm.trueLabel || _vm.falseLabel + ? _c("input", { + directives: [ + { + name: "model", + rawName: "v-model", + value: _vm.model, + expression: "model" + } + ], + staticClass: "el-checkbox__original", + attrs: { + type: "checkbox", + "aria-hidden": _vm.indeterminate ? "true" : "false", + name: _vm.name, + disabled: _vm.isDisabled, + "true-value": _vm.trueLabel, + "false-value": _vm.falseLabel + }, + domProps: { + checked: Array.isArray(_vm.model) + ? _vm._i(_vm.model, null) > -1 + : _vm._q(_vm.model, _vm.trueLabel) + }, + on: { + change: [ + function($event) { + var $$a = _vm.model, + $$el = $event.target, + $$c = $$el.checked ? _vm.trueLabel : _vm.falseLabel + if (Array.isArray($$a)) { + var $$v = null, + $$i = _vm._i($$a, $$v) + if ($$el.checked) { + $$i < 0 && (_vm.model = $$a.concat([$$v])) + } else { + $$i > -1 && + (_vm.model = $$a + .slice(0, $$i) + .concat($$a.slice($$i + 1))) + } + } else { + _vm.model = $$c + } + }, + _vm.handleChange + ], + focus: function($event) { + _vm.focus = true + }, + blur: function($event) { + _vm.focus = false + } + } + }) + : _c("input", { + directives: [ + { + name: "model", + rawName: "v-model", + value: _vm.model, + expression: "model" + } + ], + staticClass: "el-checkbox__original", + attrs: { + type: "checkbox", + "aria-hidden": _vm.indeterminate ? "true" : "false", + disabled: _vm.isDisabled, + name: _vm.name + }, + domProps: { + value: _vm.label, + checked: Array.isArray(_vm.model) + ? _vm._i(_vm.model, _vm.label) > -1 + : _vm.model + }, + on: { + change: [ + function($event) { + var $$a = _vm.model, + $$el = $event.target, + $$c = $$el.checked ? true : false + if (Array.isArray($$a)) { + var $$v = _vm.label, + $$i = _vm._i($$a, $$v) + if ($$el.checked) { + $$i < 0 && (_vm.model = $$a.concat([$$v])) + } else { + $$i > -1 && + (_vm.model = $$a + .slice(0, $$i) + .concat($$a.slice($$i + 1))) + } + } else { + _vm.model = $$c + } + }, + _vm.handleChange + ], + focus: function($event) { + _vm.focus = true + }, + blur: function($event) { + _vm.focus = false + } + } + }) + ] + ), + _vm.$slots.default || _vm.label + ? _c( + "span", + { staticClass: "el-checkbox__label" }, + [ + _vm._t("default"), + !_vm.$slots.default ? [_vm._v(_vm._s(_vm.label))] : _vm._e() + ], + 2 + ) + : _vm._e() + ] + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/checkbox/src/checkbox.vue?vue&type=template&id=d0387074& + +// EXTERNAL MODULE: external "element-ui/lib/mixins/emitter" +var emitter_ = __webpack_require__(4); +var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + +/* harmony default export */ var checkboxvue_type_script_lang_js_ = ({ + name: 'ElCheckbox', + + mixins: [emitter_default.a], + + inject: { + elForm: { + default: '' + }, + elFormItem: { + default: '' + } + }, + + componentName: 'ElCheckbox', + + data: function data() { + return { + selfModel: false, + focus: false, + isLimitExceeded: false + }; + }, + + + computed: { + model: { + get: function get() { + return this.isGroup ? this.store : this.value !== undefined ? this.value : this.selfModel; + }, + set: function set(val) { + if (this.isGroup) { + this.isLimitExceeded = false; + this._checkboxGroup.min !== undefined && val.length < this._checkboxGroup.min && (this.isLimitExceeded = true); + + this._checkboxGroup.max !== undefined && val.length > this._checkboxGroup.max && (this.isLimitExceeded = true); + + this.isLimitExceeded === false && this.dispatch('ElCheckboxGroup', 'input', [val]); + } else { + this.$emit('input', val); + this.selfModel = val; + } + } + }, + + isChecked: function isChecked() { + if ({}.toString.call(this.model) === '[object Boolean]') { + return this.model; + } else if (Array.isArray(this.model)) { + return this.model.indexOf(this.label) > -1; + } else if (this.model !== null && this.model !== undefined) { + return this.model === this.trueLabel; + } + }, + isGroup: function isGroup() { + var parent = this.$parent; + while (parent) { + if (parent.$options.componentName !== 'ElCheckboxGroup') { + parent = parent.$parent; + } else { + this._checkboxGroup = parent; + return true; + } + } + return false; + }, + store: function store() { + return this._checkboxGroup ? this._checkboxGroup.value : this.value; + }, + + + /* used to make the isDisabled judgment under max/min props */ + isLimitDisabled: function isLimitDisabled() { + var _checkboxGroup = this._checkboxGroup, + max = _checkboxGroup.max, + min = _checkboxGroup.min; + + return !!(max || min) && this.model.length >= max && !this.isChecked || this.model.length <= min && this.isChecked; + }, + isDisabled: function isDisabled() { + return this.isGroup ? this._checkboxGroup.disabled || this.disabled || (this.elForm || {}).disabled || this.isLimitDisabled : this.disabled || (this.elForm || {}).disabled; + }, + _elFormItemSize: function _elFormItemSize() { + return (this.elFormItem || {}).elFormItemSize; + }, + checkboxSize: function checkboxSize() { + var temCheckboxSize = this.size || this._elFormItemSize || (this.$ELEMENT || {}).size; + return this.isGroup ? this._checkboxGroup.checkboxGroupSize || temCheckboxSize : temCheckboxSize; + } + }, + + props: { + value: {}, + label: {}, + indeterminate: Boolean, + disabled: Boolean, + checked: Boolean, + name: String, + trueLabel: [String, Number], + falseLabel: [String, Number], + id: String, /* 当indeterminate为真时,为controls提供相关连的checkbox的id,表明元素间的控制关系*/ + controls: String, /* 当indeterminate为真时,为controls提供相关连的checkbox的id,表明元素间的控制关系*/ + border: Boolean, + size: String + }, + + methods: { + addToStore: function addToStore() { + if (Array.isArray(this.model) && this.model.indexOf(this.label) === -1) { + this.model.push(this.label); + } else { + this.model = this.trueLabel || true; + } + }, + handleChange: function handleChange(ev) { + var _this = this; + + if (this.isLimitExceeded) return; + var value = void 0; + if (ev.target.checked) { + value = this.trueLabel === undefined ? true : this.trueLabel; + } else { + value = this.falseLabel === undefined ? false : this.falseLabel; + } + this.$emit('change', value, ev); + this.$nextTick(function () { + if (_this.isGroup) { + _this.dispatch('ElCheckboxGroup', 'change', [_this._checkboxGroup.value]); + } + }); + } + }, + + created: function created() { + this.checked && this.addToStore(); + }, + mounted: function mounted() { + // 为indeterminate元素 添加aria-controls 属性 + if (this.indeterminate) { + this.$el.setAttribute('aria-controls', this.controls); + } + }, + + + watch: { + value: function value(_value) { + this.dispatch('ElFormItem', 'el.form.change', _value); + } + } +}); +// CONCATENATED MODULE: ./packages/checkbox/src/checkbox.vue?vue&type=script&lang=js& + /* harmony default export */ var src_checkboxvue_type_script_lang_js_ = (checkboxvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/checkbox/src/checkbox.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_checkboxvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/checkbox/src/checkbox.vue" +/* harmony default export */ var src_checkbox = (component.exports); +// CONCATENATED MODULE: ./packages/checkbox/index.js + + +/* istanbul ignore next */ +src_checkbox.install = function (Vue) { + Vue.component(src_checkbox.name, src_checkbox); +}; + +/* harmony default export */ var packages_checkbox = __webpack_exports__["default"] = (src_checkbox); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/col.js b/public/static/libs/element-ui/lib/col.js new file mode 100644 index 0000000..94b1af7 --- /dev/null +++ b/public/static/libs/element-ui/lib/col.js @@ -0,0 +1,176 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 140); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 140: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./packages/col/src/col.js +var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; + +/* harmony default export */ var col = ({ + name: 'ElCol', + + props: { + span: { + type: Number, + default: 24 + }, + tag: { + type: String, + default: 'div' + }, + offset: Number, + pull: Number, + push: Number, + xs: [Number, Object], + sm: [Number, Object], + md: [Number, Object], + lg: [Number, Object], + xl: [Number, Object] + }, + + computed: { + gutter: function gutter() { + var parent = this.$parent; + while (parent && parent.$options.componentName !== 'ElRow') { + parent = parent.$parent; + } + return parent ? parent.gutter : 0; + } + }, + render: function render(h) { + var _this = this; + + var classList = []; + var style = {}; + + if (this.gutter) { + style.paddingLeft = this.gutter / 2 + 'px'; + style.paddingRight = style.paddingLeft; + } + + ['span', 'offset', 'pull', 'push'].forEach(function (prop) { + if (_this[prop] || _this[prop] === 0) { + classList.push(prop !== 'span' ? 'el-col-' + prop + '-' + _this[prop] : 'el-col-' + _this[prop]); + } + }); + + ['xs', 'sm', 'md', 'lg', 'xl'].forEach(function (size) { + if (typeof _this[size] === 'number') { + classList.push('el-col-' + size + '-' + _this[size]); + } else if (_typeof(_this[size]) === 'object') { + var props = _this[size]; + Object.keys(props).forEach(function (prop) { + classList.push(prop !== 'span' ? 'el-col-' + size + '-' + prop + '-' + props[prop] : 'el-col-' + size + '-' + props[prop]); + }); + } + }); + + return h(this.tag, { + class: ['el-col', classList], + style: style + }, this.$slots.default); + } +}); +// CONCATENATED MODULE: ./packages/col/index.js + + +/* istanbul ignore next */ +col.install = function (Vue) { + Vue.component(col.name, col); +}; + +/* harmony default export */ var packages_col = __webpack_exports__["default"] = (col); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/collapse-item.js b/public/static/libs/element-ui/lib/collapse-item.js new file mode 100644 index 0000000..066abb8 --- /dev/null +++ b/public/static/libs/element-ui/lib/collapse-item.js @@ -0,0 +1,496 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 114); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 114: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/collapse/src/collapse-item.vue?vue&type=template&id=2d05faac& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { + staticClass: "el-collapse-item", + class: { "is-active": _vm.isActive, "is-disabled": _vm.disabled } + }, + [ + _c( + "div", + { + attrs: { + role: "tab", + "aria-expanded": _vm.isActive, + "aria-controls": "el-collapse-content-" + _vm.id, + "aria-describedby": "el-collapse-content-" + _vm.id + } + }, + [ + _c( + "div", + { + staticClass: "el-collapse-item__header", + class: { + focusing: _vm.focusing, + "is-active": _vm.isActive + }, + attrs: { + role: "button", + id: "el-collapse-head-" + _vm.id, + tabindex: _vm.disabled ? undefined : 0 + }, + on: { + click: _vm.handleHeaderClick, + keyup: function($event) { + if ( + !("button" in $event) && + _vm._k($event.keyCode, "space", 32, $event.key, [ + " ", + "Spacebar" + ]) && + _vm._k($event.keyCode, "enter", 13, $event.key, "Enter") + ) { + return null + } + $event.stopPropagation() + return _vm.handleEnterClick($event) + }, + focus: _vm.handleFocus, + blur: function($event) { + _vm.focusing = false + } + } + }, + [ + _vm._t("title", [_vm._v(_vm._s(_vm.title))]), + _c("i", { + staticClass: "el-collapse-item__arrow el-icon-arrow-right", + class: { "is-active": _vm.isActive } + }) + ], + 2 + ) + ] + ), + _c("el-collapse-transition", [ + _c( + "div", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.isActive, + expression: "isActive" + } + ], + staticClass: "el-collapse-item__wrap", + attrs: { + role: "tabpanel", + "aria-hidden": !_vm.isActive, + "aria-labelledby": "el-collapse-head-" + _vm.id, + id: "el-collapse-content-" + _vm.id + } + }, + [ + _c( + "div", + { staticClass: "el-collapse-item__content" }, + [_vm._t("default")], + 2 + ) + ] + ) + ]) + ], + 1 + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/collapse/src/collapse-item.vue?vue&type=template&id=2d05faac& + +// EXTERNAL MODULE: external "element-ui/lib/transitions/collapse-transition" +var collapse_transition_ = __webpack_require__(28); +var collapse_transition_default = /*#__PURE__*/__webpack_require__.n(collapse_transition_); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/emitter" +var emitter_ = __webpack_require__(4); +var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/util" +var util_ = __webpack_require__(3); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/collapse/src/collapse-item.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + +/* harmony default export */ var collapse_itemvue_type_script_lang_js_ = ({ + name: 'ElCollapseItem', + + componentName: 'ElCollapseItem', + + mixins: [emitter_default.a], + + components: { ElCollapseTransition: collapse_transition_default.a }, + + data: function data() { + return { + contentWrapStyle: { + height: 'auto', + display: 'block' + }, + contentHeight: 0, + focusing: false, + isClick: false, + id: Object(util_["generateId"])() + }; + }, + + + inject: ['collapse'], + + props: { + title: String, + name: { + type: [String, Number], + default: function _default() { + return this._uid; + } + }, + disabled: Boolean + }, + + computed: { + isActive: function isActive() { + return this.collapse.activeNames.indexOf(this.name) > -1; + } + }, + + methods: { + handleFocus: function handleFocus() { + var _this = this; + + setTimeout(function () { + if (!_this.isClick) { + _this.focusing = true; + } else { + _this.isClick = false; + } + }, 50); + }, + handleHeaderClick: function handleHeaderClick() { + if (this.disabled) return; + this.dispatch('ElCollapse', 'item-click', this); + this.focusing = false; + this.isClick = true; + }, + handleEnterClick: function handleEnterClick() { + this.dispatch('ElCollapse', 'item-click', this); + } + } +}); +// CONCATENATED MODULE: ./packages/collapse/src/collapse-item.vue?vue&type=script&lang=js& + /* harmony default export */ var src_collapse_itemvue_type_script_lang_js_ = (collapse_itemvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/collapse/src/collapse-item.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_collapse_itemvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/collapse/src/collapse-item.vue" +/* harmony default export */ var collapse_item = (component.exports); +// CONCATENATED MODULE: ./packages/collapse-item/index.js + + +/* istanbul ignore next */ +collapse_item.install = function (Vue) { + Vue.component(collapse_item.name, collapse_item); +}; + +/* harmony default export */ var packages_collapse_item = __webpack_exports__["default"] = (collapse_item); + +/***/ }), + +/***/ 28: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/transitions/collapse-transition"); + +/***/ }), + +/***/ 3: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/util"); + +/***/ }), + +/***/ 4: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/emitter"); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/collapse.js b/public/static/libs/element-ui/lib/collapse.js new file mode 100644 index 0000000..89dd0b3 --- /dev/null +++ b/public/static/libs/element-ui/lib/collapse.js @@ -0,0 +1,328 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 113); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 113: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/collapse/src/collapse.vue?vue&type=template&id=461d57f4& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { + staticClass: "el-collapse", + attrs: { role: "tablist", "aria-multiselectable": "true" } + }, + [_vm._t("default")], + 2 + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/collapse/src/collapse.vue?vue&type=template&id=461d57f4& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/collapse/src/collapse.vue?vue&type=script&lang=js& +// +// +// +// +// + +/* harmony default export */ var collapsevue_type_script_lang_js_ = ({ + name: 'ElCollapse', + + componentName: 'ElCollapse', + + props: { + accordion: Boolean, + value: { + type: [Array, String, Number], + default: function _default() { + return []; + } + } + }, + + data: function data() { + return { + activeNames: [].concat(this.value) + }; + }, + provide: function provide() { + return { + collapse: this + }; + }, + + + watch: { + value: function value(_value) { + this.activeNames = [].concat(_value); + } + }, + + methods: { + setActiveNames: function setActiveNames(activeNames) { + activeNames = [].concat(activeNames); + var value = this.accordion ? activeNames[0] : activeNames; + this.activeNames = activeNames; + this.$emit('input', value); + this.$emit('change', value); + }, + handleItemClick: function handleItemClick(item) { + if (this.accordion) { + this.setActiveNames((this.activeNames[0] || this.activeNames[0] === 0) && this.activeNames[0] === item.name ? '' : item.name); + } else { + var activeNames = this.activeNames.slice(0); + var index = activeNames.indexOf(item.name); + + if (index > -1) { + activeNames.splice(index, 1); + } else { + activeNames.push(item.name); + } + this.setActiveNames(activeNames); + } + } + }, + + created: function created() { + this.$on('item-click', this.handleItemClick); + } +}); +// CONCATENATED MODULE: ./packages/collapse/src/collapse.vue?vue&type=script&lang=js& + /* harmony default export */ var src_collapsevue_type_script_lang_js_ = (collapsevue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/collapse/src/collapse.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_collapsevue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/collapse/src/collapse.vue" +/* harmony default export */ var collapse = (component.exports); +// CONCATENATED MODULE: ./packages/collapse/index.js + + +/* istanbul ignore next */ +collapse.install = function (Vue) { + Vue.component(collapse.name, collapse); +}; + +/* harmony default export */ var packages_collapse = __webpack_exports__["default"] = (collapse); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/color-picker.js b/public/static/libs/element-ui/lib/color-picker.js new file mode 100644 index 0000000..ed3ac64 --- /dev/null +++ b/public/static/libs/element-ui/lib/color-picker.js @@ -0,0 +1,1957 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 55); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 10: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/input"); + +/***/ }), + +/***/ 12: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/clickoutside"); + +/***/ }), + +/***/ 14: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/button"); + +/***/ }), + +/***/ 4: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/emitter"); + +/***/ }), + +/***/ 5: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/vue-popper"); + +/***/ }), + +/***/ 55: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/main.vue?vue&type=template&id=55c8ade7& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { + directives: [ + { + name: "clickoutside", + rawName: "v-clickoutside", + value: _vm.hide, + expression: "hide" + } + ], + class: [ + "el-color-picker", + _vm.colorDisabled ? "is-disabled" : "", + _vm.colorSize ? "el-color-picker--" + _vm.colorSize : "" + ] + }, + [ + _vm.colorDisabled + ? _c("div", { staticClass: "el-color-picker__mask" }) + : _vm._e(), + _c( + "div", + { + staticClass: "el-color-picker__trigger", + on: { click: _vm.handleTrigger } + }, + [ + _c( + "span", + { + staticClass: "el-color-picker__color", + class: { "is-alpha": _vm.showAlpha } + }, + [ + _c("span", { + staticClass: "el-color-picker__color-inner", + style: { + backgroundColor: _vm.displayedColor + } + }), + !_vm.value && !_vm.showPanelColor + ? _c("span", { + staticClass: "el-color-picker__empty el-icon-close" + }) + : _vm._e() + ] + ), + _c("span", { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.value || _vm.showPanelColor, + expression: "value || showPanelColor" + } + ], + staticClass: "el-color-picker__icon el-icon-arrow-down" + }) + ] + ), + _c("picker-dropdown", { + ref: "dropdown", + class: ["el-color-picker__panel", _vm.popperClass || ""], + attrs: { + color: _vm.color, + "show-alpha": _vm.showAlpha, + predefine: _vm.predefine + }, + on: { pick: _vm.confirmValue, clear: _vm.clearValue }, + model: { + value: _vm.showPicker, + callback: function($$v) { + _vm.showPicker = $$v + }, + expression: "showPicker" + } + }) + ], + 1 + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/color-picker/src/main.vue?vue&type=template&id=55c8ade7& + +// CONCATENATED MODULE: ./packages/color-picker/src/color.js +var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; + +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + +var hsv2hsl = function hsv2hsl(hue, sat, val) { + return [hue, sat * val / ((hue = (2 - sat) * val) < 1 ? hue : 2 - hue) || 0, hue / 2]; +}; + +// Need to handle 1.0 as 100%, since once it is a number, there is no difference between it and 1 +// +var isOnePointZero = function isOnePointZero(n) { + return typeof n === 'string' && n.indexOf('.') !== -1 && parseFloat(n) === 1; +}; + +var isPercentage = function isPercentage(n) { + return typeof n === 'string' && n.indexOf('%') !== -1; +}; + +// Take input from [0, n] and return it as [0, 1] +var bound01 = function bound01(value, max) { + if (isOnePointZero(value)) value = '100%'; + + var processPercent = isPercentage(value); + value = Math.min(max, Math.max(0, parseFloat(value))); + + // Automatically convert percentage into number + if (processPercent) { + value = parseInt(value * max, 10) / 100; + } + + // Handle floating point rounding errors + if (Math.abs(value - max) < 0.000001) { + return 1; + } + + // Convert into [0, 1] range if it isn't already + return value % max / parseFloat(max); +}; + +var INT_HEX_MAP = { 10: 'A', 11: 'B', 12: 'C', 13: 'D', 14: 'E', 15: 'F' }; + +var toHex = function toHex(_ref) { + var r = _ref.r, + g = _ref.g, + b = _ref.b; + + var hexOne = function hexOne(value) { + value = Math.min(Math.round(value), 255); + var high = Math.floor(value / 16); + var low = value % 16; + return '' + (INT_HEX_MAP[high] || high) + (INT_HEX_MAP[low] || low); + }; + + if (isNaN(r) || isNaN(g) || isNaN(b)) return ''; + + return '#' + hexOne(r) + hexOne(g) + hexOne(b); +}; + +var HEX_INT_MAP = { A: 10, B: 11, C: 12, D: 13, E: 14, F: 15 }; + +var parseHexChannel = function parseHexChannel(hex) { + if (hex.length === 2) { + return (HEX_INT_MAP[hex[0].toUpperCase()] || +hex[0]) * 16 + (HEX_INT_MAP[hex[1].toUpperCase()] || +hex[1]); + } + + return HEX_INT_MAP[hex[1].toUpperCase()] || +hex[1]; +}; + +var hsl2hsv = function hsl2hsv(hue, sat, light) { + sat = sat / 100; + light = light / 100; + var smin = sat; + var lmin = Math.max(light, 0.01); + var sv = void 0; + var v = void 0; + + light *= 2; + sat *= light <= 1 ? light : 2 - light; + smin *= lmin <= 1 ? lmin : 2 - lmin; + v = (light + sat) / 2; + sv = light === 0 ? 2 * smin / (lmin + smin) : 2 * sat / (light + sat); + + return { + h: hue, + s: sv * 100, + v: v * 100 + }; +}; + +// `rgbToHsv` +// Converts an RGB color value to HSV +// *Assumes:* r, g, and b are contained in the set [0, 255] or [0, 1] +// *Returns:* { h, s, v } in [0,1] +var rgb2hsv = function rgb2hsv(r, g, b) { + r = bound01(r, 255); + g = bound01(g, 255); + b = bound01(b, 255); + + var max = Math.max(r, g, b); + var min = Math.min(r, g, b); + var h = void 0, + s = void 0; + var v = max; + + var d = max - min; + s = max === 0 ? 0 : d / max; + + if (max === min) { + h = 0; // achromatic + } else { + switch (max) { + case r: + h = (g - b) / d + (g < b ? 6 : 0); + break; + case g: + h = (b - r) / d + 2; + break; + case b: + h = (r - g) / d + 4; + break; + } + h /= 6; + } + + return { h: h * 360, s: s * 100, v: v * 100 }; +}; + +// `hsvToRgb` +// Converts an HSV color value to RGB. +// *Assumes:* h is contained in [0, 1] or [0, 360] and s and v are contained in [0, 1] or [0, 100] +// *Returns:* { r, g, b } in the set [0, 255] +var hsv2rgb = function hsv2rgb(h, s, v) { + h = bound01(h, 360) * 6; + s = bound01(s, 100); + v = bound01(v, 100); + + var i = Math.floor(h); + var f = h - i; + var p = v * (1 - s); + var q = v * (1 - f * s); + var t = v * (1 - (1 - f) * s); + var mod = i % 6; + var r = [v, q, p, p, t, v][mod]; + var g = [t, v, v, q, p, p][mod]; + var b = [p, p, t, v, v, q][mod]; + + return { + r: Math.round(r * 255), + g: Math.round(g * 255), + b: Math.round(b * 255) + }; +}; + +var Color = function () { + function Color(options) { + _classCallCheck(this, Color); + + this._hue = 0; + this._saturation = 100; + this._value = 100; + this._alpha = 100; + + this.enableAlpha = false; + this.format = 'hex'; + this.value = ''; + + options = options || {}; + + for (var option in options) { + if (options.hasOwnProperty(option)) { + this[option] = options[option]; + } + } + + this.doOnChange(); + } + + Color.prototype.set = function set(prop, value) { + if (arguments.length === 1 && (typeof prop === 'undefined' ? 'undefined' : _typeof(prop)) === 'object') { + for (var p in prop) { + if (prop.hasOwnProperty(p)) { + this.set(p, prop[p]); + } + } + + return; + } + + this['_' + prop] = value; + this.doOnChange(); + }; + + Color.prototype.get = function get(prop) { + return this['_' + prop]; + }; + + Color.prototype.toRgb = function toRgb() { + return hsv2rgb(this._hue, this._saturation, this._value); + }; + + Color.prototype.fromString = function fromString(value) { + var _this = this; + + if (!value) { + this._hue = 0; + this._saturation = 100; + this._value = 100; + + this.doOnChange(); + return; + } + + var fromHSV = function fromHSV(h, s, v) { + _this._hue = Math.max(0, Math.min(360, h)); + _this._saturation = Math.max(0, Math.min(100, s)); + _this._value = Math.max(0, Math.min(100, v)); + + _this.doOnChange(); + }; + + if (value.indexOf('hsl') !== -1) { + var parts = value.replace(/hsla|hsl|\(|\)/gm, '').split(/\s|,/g).filter(function (val) { + return val !== ''; + }).map(function (val, index) { + return index > 2 ? parseFloat(val) : parseInt(val, 10); + }); + + if (parts.length === 4) { + this._alpha = Math.floor(parseFloat(parts[3]) * 100); + } else if (parts.length === 3) { + this._alpha = 100; + } + if (parts.length >= 3) { + var _hsl2hsv = hsl2hsv(parts[0], parts[1], parts[2]), + h = _hsl2hsv.h, + s = _hsl2hsv.s, + v = _hsl2hsv.v; + + fromHSV(h, s, v); + } + } else if (value.indexOf('hsv') !== -1) { + var _parts = value.replace(/hsva|hsv|\(|\)/gm, '').split(/\s|,/g).filter(function (val) { + return val !== ''; + }).map(function (val, index) { + return index > 2 ? parseFloat(val) : parseInt(val, 10); + }); + + if (_parts.length === 4) { + this._alpha = Math.floor(parseFloat(_parts[3]) * 100); + } else if (_parts.length === 3) { + this._alpha = 100; + } + if (_parts.length >= 3) { + fromHSV(_parts[0], _parts[1], _parts[2]); + } + } else if (value.indexOf('rgb') !== -1) { + var _parts2 = value.replace(/rgba|rgb|\(|\)/gm, '').split(/\s|,/g).filter(function (val) { + return val !== ''; + }).map(function (val, index) { + return index > 2 ? parseFloat(val) : parseInt(val, 10); + }); + + if (_parts2.length === 4) { + this._alpha = Math.floor(parseFloat(_parts2[3]) * 100); + } else if (_parts2.length === 3) { + this._alpha = 100; + } + if (_parts2.length >= 3) { + var _rgb2hsv = rgb2hsv(_parts2[0], _parts2[1], _parts2[2]), + _h = _rgb2hsv.h, + _s = _rgb2hsv.s, + _v = _rgb2hsv.v; + + fromHSV(_h, _s, _v); + } + } else if (value.indexOf('#') !== -1) { + var hex = value.replace('#', '').trim(); + if (!/^(?:[0-9a-fA-F]{3}){1,2}|[0-9a-fA-F]{8}$/.test(hex)) return; + var r = void 0, + g = void 0, + b = void 0; + + if (hex.length === 3) { + r = parseHexChannel(hex[0] + hex[0]); + g = parseHexChannel(hex[1] + hex[1]); + b = parseHexChannel(hex[2] + hex[2]); + } else if (hex.length === 6 || hex.length === 8) { + r = parseHexChannel(hex.substring(0, 2)); + g = parseHexChannel(hex.substring(2, 4)); + b = parseHexChannel(hex.substring(4, 6)); + } + + if (hex.length === 8) { + this._alpha = Math.floor(parseHexChannel(hex.substring(6)) / 255 * 100); + } else if (hex.length === 3 || hex.length === 6) { + this._alpha = 100; + } + + var _rgb2hsv2 = rgb2hsv(r, g, b), + _h2 = _rgb2hsv2.h, + _s2 = _rgb2hsv2.s, + _v2 = _rgb2hsv2.v; + + fromHSV(_h2, _s2, _v2); + } + }; + + Color.prototype.compare = function compare(color) { + return Math.abs(color._hue - this._hue) < 2 && Math.abs(color._saturation - this._saturation) < 1 && Math.abs(color._value - this._value) < 1 && Math.abs(color._alpha - this._alpha) < 1; + }; + + Color.prototype.doOnChange = function doOnChange() { + var _hue = this._hue, + _saturation = this._saturation, + _value = this._value, + _alpha = this._alpha, + format = this.format; + + + if (this.enableAlpha) { + switch (format) { + case 'hsl': + var hsl = hsv2hsl(_hue, _saturation / 100, _value / 100); + this.value = 'hsla(' + _hue + ', ' + Math.round(hsl[1] * 100) + '%, ' + Math.round(hsl[2] * 100) + '%, ' + _alpha / 100 + ')'; + break; + case 'hsv': + this.value = 'hsva(' + _hue + ', ' + Math.round(_saturation) + '%, ' + Math.round(_value) + '%, ' + _alpha / 100 + ')'; + break; + default: + var _hsv2rgb = hsv2rgb(_hue, _saturation, _value), + r = _hsv2rgb.r, + g = _hsv2rgb.g, + b = _hsv2rgb.b; + + this.value = 'rgba(' + r + ', ' + g + ', ' + b + ', ' + _alpha / 100 + ')'; + } + } else { + switch (format) { + case 'hsl': + var _hsl = hsv2hsl(_hue, _saturation / 100, _value / 100); + this.value = 'hsl(' + _hue + ', ' + Math.round(_hsl[1] * 100) + '%, ' + Math.round(_hsl[2] * 100) + '%)'; + break; + case 'hsv': + this.value = 'hsv(' + _hue + ', ' + Math.round(_saturation) + '%, ' + Math.round(_value) + '%)'; + break; + case 'rgb': + var _hsv2rgb2 = hsv2rgb(_hue, _saturation, _value), + _r = _hsv2rgb2.r, + _g = _hsv2rgb2.g, + _b = _hsv2rgb2.b; + + this.value = 'rgb(' + _r + ', ' + _g + ', ' + _b + ')'; + break; + default: + this.value = toHex(hsv2rgb(_hue, _saturation, _value)); + } + } + }; + + return Color; +}(); + +/* harmony default export */ var src_color = (Color); +; +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/picker-dropdown.vue?vue&type=template&id=06601625& +var picker_dropdownvue_type_template_id_06601625_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "transition", + { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": _vm.doDestroy } }, + [ + _c( + "div", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.showPopper, + expression: "showPopper" + } + ], + staticClass: "el-color-dropdown" + }, + [ + _c( + "div", + { staticClass: "el-color-dropdown__main-wrapper" }, + [ + _c("hue-slider", { + ref: "hue", + staticStyle: { float: "right" }, + attrs: { color: _vm.color, vertical: "" } + }), + _c("sv-panel", { ref: "sl", attrs: { color: _vm.color } }) + ], + 1 + ), + _vm.showAlpha + ? _c("alpha-slider", { ref: "alpha", attrs: { color: _vm.color } }) + : _vm._e(), + _vm.predefine + ? _c("predefine", { + attrs: { color: _vm.color, colors: _vm.predefine } + }) + : _vm._e(), + _c( + "div", + { staticClass: "el-color-dropdown__btns" }, + [ + _c( + "span", + { staticClass: "el-color-dropdown__value" }, + [ + _c("el-input", { + attrs: { "validate-event": false, size: "mini" }, + on: { blur: _vm.handleConfirm }, + nativeOn: { + keyup: function($event) { + if ( + !("button" in $event) && + _vm._k( + $event.keyCode, + "enter", + 13, + $event.key, + "Enter" + ) + ) { + return null + } + return _vm.handleConfirm($event) + } + }, + model: { + value: _vm.customInput, + callback: function($$v) { + _vm.customInput = $$v + }, + expression: "customInput" + } + }) + ], + 1 + ), + _c( + "el-button", + { + staticClass: "el-color-dropdown__link-btn", + attrs: { size: "mini", type: "text" }, + on: { + click: function($event) { + _vm.$emit("clear") + } + } + }, + [ + _vm._v( + "\n " + + _vm._s(_vm.t("el.colorpicker.clear")) + + "\n " + ) + ] + ), + _c( + "el-button", + { + staticClass: "el-color-dropdown__btn", + attrs: { plain: "", size: "mini" }, + on: { click: _vm.confirmValue } + }, + [ + _vm._v( + "\n " + + _vm._s(_vm.t("el.colorpicker.confirm")) + + "\n " + ) + ] + ) + ], + 1 + ) + ], + 1 + ) + ] + ) +} +var picker_dropdownvue_type_template_id_06601625_staticRenderFns = [] +picker_dropdownvue_type_template_id_06601625_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/color-picker/src/components/picker-dropdown.vue?vue&type=template&id=06601625& + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/sv-panel.vue?vue&type=template&id=d8583596& +var sv_panelvue_type_template_id_d8583596_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { + staticClass: "el-color-svpanel", + style: { + backgroundColor: _vm.background + } + }, + [ + _c("div", { staticClass: "el-color-svpanel__white" }), + _c("div", { staticClass: "el-color-svpanel__black" }), + _c( + "div", + { + staticClass: "el-color-svpanel__cursor", + style: { + top: _vm.cursorTop + "px", + left: _vm.cursorLeft + "px" + } + }, + [_c("div")] + ) + ] + ) +} +var sv_panelvue_type_template_id_d8583596_staticRenderFns = [] +sv_panelvue_type_template_id_d8583596_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/color-picker/src/components/sv-panel.vue?vue&type=template&id=d8583596& + +// EXTERNAL MODULE: external "vue" +var external_vue_ = __webpack_require__(7); +var external_vue_default = /*#__PURE__*/__webpack_require__.n(external_vue_); + +// CONCATENATED MODULE: ./packages/color-picker/src/draggable.js + +var isDragging = false; + +/* harmony default export */ var draggable = (function (element, options) { + if (external_vue_default.a.prototype.$isServer) return; + var moveFn = function moveFn(event) { + if (options.drag) { + options.drag(event); + } + }; + var upFn = function upFn(event) { + document.removeEventListener('mousemove', moveFn); + document.removeEventListener('mouseup', upFn); + document.onselectstart = null; + document.ondragstart = null; + + isDragging = false; + + if (options.end) { + options.end(event); + } + }; + element.addEventListener('mousedown', function (event) { + if (isDragging) return; + document.onselectstart = function () { + return false; + }; + document.ondragstart = function () { + return false; + }; + + document.addEventListener('mousemove', moveFn); + document.addEventListener('mouseup', upFn); + isDragging = true; + + if (options.start) { + options.start(event); + } + }); +}); +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/sv-panel.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + +/* harmony default export */ var sv_panelvue_type_script_lang_js_ = ({ + name: 'el-sl-panel', + + props: { + color: { + required: true + } + }, + + computed: { + colorValue: function colorValue() { + var hue = this.color.get('hue'); + var value = this.color.get('value'); + return { hue: hue, value: value }; + } + }, + + watch: { + colorValue: function colorValue() { + this.update(); + } + }, + + methods: { + update: function update() { + var saturation = this.color.get('saturation'); + var value = this.color.get('value'); + + var el = this.$el; + var width = el.clientWidth, + height = el.clientHeight; + + + this.cursorLeft = saturation * width / 100; + this.cursorTop = (100 - value) * height / 100; + + this.background = 'hsl(' + this.color.get('hue') + ', 100%, 50%)'; + }, + handleDrag: function handleDrag(event) { + var el = this.$el; + var rect = el.getBoundingClientRect(); + + var left = event.clientX - rect.left; + var top = event.clientY - rect.top; + left = Math.max(0, left); + left = Math.min(left, rect.width); + + top = Math.max(0, top); + top = Math.min(top, rect.height); + + this.cursorLeft = left; + this.cursorTop = top; + this.color.set({ + saturation: left / rect.width * 100, + value: 100 - top / rect.height * 100 + }); + } + }, + + mounted: function mounted() { + var _this = this; + + draggable(this.$el, { + drag: function drag(event) { + _this.handleDrag(event); + }, + end: function end(event) { + _this.handleDrag(event); + } + }); + + this.update(); + }, + data: function data() { + return { + cursorTop: 0, + cursorLeft: 0, + background: 'hsl(0, 100%, 50%)' + }; + } +}); +// CONCATENATED MODULE: ./packages/color-picker/src/components/sv-panel.vue?vue&type=script&lang=js& + /* harmony default export */ var components_sv_panelvue_type_script_lang_js_ = (sv_panelvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/color-picker/src/components/sv-panel.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + components_sv_panelvue_type_script_lang_js_, + sv_panelvue_type_template_id_d8583596_render, + sv_panelvue_type_template_id_d8583596_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/color-picker/src/components/sv-panel.vue" +/* harmony default export */ var sv_panel = (component.exports); +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/hue-slider.vue?vue&type=template&id=5cdc43b1& +var hue_slidervue_type_template_id_5cdc43b1_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { + staticClass: "el-color-hue-slider", + class: { "is-vertical": _vm.vertical } + }, + [ + _c("div", { + ref: "bar", + staticClass: "el-color-hue-slider__bar", + on: { click: _vm.handleClick } + }), + _c("div", { + ref: "thumb", + staticClass: "el-color-hue-slider__thumb", + style: { + left: _vm.thumbLeft + "px", + top: _vm.thumbTop + "px" + } + }) + ] + ) +} +var hue_slidervue_type_template_id_5cdc43b1_staticRenderFns = [] +hue_slidervue_type_template_id_5cdc43b1_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/color-picker/src/components/hue-slider.vue?vue&type=template&id=5cdc43b1& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/hue-slider.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// + + + +/* harmony default export */ var hue_slidervue_type_script_lang_js_ = ({ + name: 'el-color-hue-slider', + + props: { + color: { + required: true + }, + + vertical: Boolean + }, + + data: function data() { + return { + thumbLeft: 0, + thumbTop: 0 + }; + }, + + + computed: { + hueValue: function hueValue() { + var hue = this.color.get('hue'); + return hue; + } + }, + + watch: { + hueValue: function hueValue() { + this.update(); + } + }, + + methods: { + handleClick: function handleClick(event) { + var thumb = this.$refs.thumb; + var target = event.target; + + if (target !== thumb) { + this.handleDrag(event); + } + }, + handleDrag: function handleDrag(event) { + var rect = this.$el.getBoundingClientRect(); + var thumb = this.$refs.thumb; + + var hue = void 0; + + if (!this.vertical) { + var left = event.clientX - rect.left; + left = Math.min(left, rect.width - thumb.offsetWidth / 2); + left = Math.max(thumb.offsetWidth / 2, left); + + hue = Math.round((left - thumb.offsetWidth / 2) / (rect.width - thumb.offsetWidth) * 360); + } else { + var top = event.clientY - rect.top; + top = Math.min(top, rect.height - thumb.offsetHeight / 2); + top = Math.max(thumb.offsetHeight / 2, top); + + hue = Math.round((top - thumb.offsetHeight / 2) / (rect.height - thumb.offsetHeight) * 360); + } + + this.color.set('hue', hue); + }, + getThumbLeft: function getThumbLeft() { + if (this.vertical) return 0; + var el = this.$el; + var hue = this.color.get('hue'); + + if (!el) return 0; + var thumb = this.$refs.thumb; + return Math.round(hue * (el.offsetWidth - thumb.offsetWidth / 2) / 360); + }, + getThumbTop: function getThumbTop() { + if (!this.vertical) return 0; + var el = this.$el; + var hue = this.color.get('hue'); + + if (!el) return 0; + var thumb = this.$refs.thumb; + return Math.round(hue * (el.offsetHeight - thumb.offsetHeight / 2) / 360); + }, + update: function update() { + this.thumbLeft = this.getThumbLeft(); + this.thumbTop = this.getThumbTop(); + } + }, + + mounted: function mounted() { + var _this = this; + + var _$refs = this.$refs, + bar = _$refs.bar, + thumb = _$refs.thumb; + + + var dragConfig = { + drag: function drag(event) { + _this.handleDrag(event); + }, + end: function end(event) { + _this.handleDrag(event); + } + }; + + draggable(bar, dragConfig); + draggable(thumb, dragConfig); + this.update(); + } +}); +// CONCATENATED MODULE: ./packages/color-picker/src/components/hue-slider.vue?vue&type=script&lang=js& + /* harmony default export */ var components_hue_slidervue_type_script_lang_js_ = (hue_slidervue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/color-picker/src/components/hue-slider.vue + + + + + +/* normalize component */ + +var hue_slider_component = Object(componentNormalizer["a" /* default */])( + components_hue_slidervue_type_script_lang_js_, + hue_slidervue_type_template_id_5cdc43b1_render, + hue_slidervue_type_template_id_5cdc43b1_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var hue_slider_api; } +hue_slider_component.options.__file = "packages/color-picker/src/components/hue-slider.vue" +/* harmony default export */ var hue_slider = (hue_slider_component.exports); +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/alpha-slider.vue?vue&type=template&id=068c66cb& +var alpha_slidervue_type_template_id_068c66cb_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { + staticClass: "el-color-alpha-slider", + class: { "is-vertical": _vm.vertical } + }, + [ + _c("div", { + ref: "bar", + staticClass: "el-color-alpha-slider__bar", + style: { + background: _vm.background + }, + on: { click: _vm.handleClick } + }), + _c("div", { + ref: "thumb", + staticClass: "el-color-alpha-slider__thumb", + style: { + left: _vm.thumbLeft + "px", + top: _vm.thumbTop + "px" + } + }) + ] + ) +} +var alpha_slidervue_type_template_id_068c66cb_staticRenderFns = [] +alpha_slidervue_type_template_id_068c66cb_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/color-picker/src/components/alpha-slider.vue?vue&type=template&id=068c66cb& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/alpha-slider.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + +/* harmony default export */ var alpha_slidervue_type_script_lang_js_ = ({ + name: 'el-color-alpha-slider', + + props: { + color: { + required: true + }, + vertical: Boolean + }, + + watch: { + 'color._alpha': function color_alpha() { + this.update(); + }, + 'color.value': function colorValue() { + this.update(); + } + }, + + methods: { + handleClick: function handleClick(event) { + var thumb = this.$refs.thumb; + var target = event.target; + + if (target !== thumb) { + this.handleDrag(event); + } + }, + handleDrag: function handleDrag(event) { + var rect = this.$el.getBoundingClientRect(); + var thumb = this.$refs.thumb; + + + if (!this.vertical) { + var left = event.clientX - rect.left; + left = Math.max(thumb.offsetWidth / 2, left); + left = Math.min(left, rect.width - thumb.offsetWidth / 2); + + this.color.set('alpha', Math.round((left - thumb.offsetWidth / 2) / (rect.width - thumb.offsetWidth) * 100)); + } else { + var top = event.clientY - rect.top; + top = Math.max(thumb.offsetHeight / 2, top); + top = Math.min(top, rect.height - thumb.offsetHeight / 2); + + this.color.set('alpha', Math.round((top - thumb.offsetHeight / 2) / (rect.height - thumb.offsetHeight) * 100)); + } + }, + getThumbLeft: function getThumbLeft() { + if (this.vertical) return 0; + var el = this.$el; + var alpha = this.color._alpha; + + if (!el) return 0; + var thumb = this.$refs.thumb; + return Math.round(alpha * (el.offsetWidth - thumb.offsetWidth / 2) / 100); + }, + getThumbTop: function getThumbTop() { + if (!this.vertical) return 0; + var el = this.$el; + var alpha = this.color._alpha; + + if (!el) return 0; + var thumb = this.$refs.thumb; + return Math.round(alpha * (el.offsetHeight - thumb.offsetHeight / 2) / 100); + }, + getBackground: function getBackground() { + if (this.color && this.color.value) { + var _color$toRgb = this.color.toRgb(), + r = _color$toRgb.r, + g = _color$toRgb.g, + b = _color$toRgb.b; + + return 'linear-gradient(to right, rgba(' + r + ', ' + g + ', ' + b + ', 0) 0%, rgba(' + r + ', ' + g + ', ' + b + ', 1) 100%)'; + } + return null; + }, + update: function update() { + this.thumbLeft = this.getThumbLeft(); + this.thumbTop = this.getThumbTop(); + this.background = this.getBackground(); + } + }, + + data: function data() { + return { + thumbLeft: 0, + thumbTop: 0, + background: null + }; + }, + mounted: function mounted() { + var _this = this; + + var _$refs = this.$refs, + bar = _$refs.bar, + thumb = _$refs.thumb; + + + var dragConfig = { + drag: function drag(event) { + _this.handleDrag(event); + }, + end: function end(event) { + _this.handleDrag(event); + } + }; + + draggable(bar, dragConfig); + draggable(thumb, dragConfig); + this.update(); + } +}); +// CONCATENATED MODULE: ./packages/color-picker/src/components/alpha-slider.vue?vue&type=script&lang=js& + /* harmony default export */ var components_alpha_slidervue_type_script_lang_js_ = (alpha_slidervue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/color-picker/src/components/alpha-slider.vue + + + + + +/* normalize component */ + +var alpha_slider_component = Object(componentNormalizer["a" /* default */])( + components_alpha_slidervue_type_script_lang_js_, + alpha_slidervue_type_template_id_068c66cb_render, + alpha_slidervue_type_template_id_068c66cb_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var alpha_slider_api; } +alpha_slider_component.options.__file = "packages/color-picker/src/components/alpha-slider.vue" +/* harmony default export */ var alpha_slider = (alpha_slider_component.exports); +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/predefine.vue?vue&type=template&id=06e03093& +var predefinevue_type_template_id_06e03093_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c("div", { staticClass: "el-color-predefine" }, [ + _c( + "div", + { staticClass: "el-color-predefine__colors" }, + _vm._l(_vm.rgbaColors, function(item, index) { + return _c( + "div", + { + key: _vm.colors[index], + staticClass: "el-color-predefine__color-selector", + class: { selected: item.selected, "is-alpha": item._alpha < 100 }, + on: { + click: function($event) { + _vm.handleSelect(index) + } + } + }, + [_c("div", { style: { "background-color": item.value } })] + ) + }), + 0 + ) + ]) +} +var predefinevue_type_template_id_06e03093_staticRenderFns = [] +predefinevue_type_template_id_06e03093_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/color-picker/src/components/predefine.vue?vue&type=template&id=06e03093& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/predefine.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + +/* harmony default export */ var predefinevue_type_script_lang_js_ = ({ + props: { + colors: { type: Array, required: true }, + color: { required: true } + }, + data: function data() { + return { + rgbaColors: this.parseColors(this.colors, this.color) + }; + }, + + methods: { + handleSelect: function handleSelect(index) { + this.color.fromString(this.colors[index]); + }, + parseColors: function parseColors(colors, color) { + return colors.map(function (value) { + var c = new src_color(); + c.enableAlpha = true; + c.format = 'rgba'; + c.fromString(value); + c.selected = c.value === color.value; + return c; + }); + } + }, + watch: { + '$parent.currentColor': function $parentCurrentColor(val) { + var color = new src_color(); + color.fromString(val); + + this.rgbaColors.forEach(function (item) { + item.selected = color.compare(item); + }); + }, + colors: function colors(newVal) { + this.rgbaColors = this.parseColors(newVal, this.color); + }, + color: function color(newVal) { + this.rgbaColors = this.parseColors(this.colors, newVal); + } + } +}); +// CONCATENATED MODULE: ./packages/color-picker/src/components/predefine.vue?vue&type=script&lang=js& + /* harmony default export */ var components_predefinevue_type_script_lang_js_ = (predefinevue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/color-picker/src/components/predefine.vue + + + + + +/* normalize component */ + +var predefine_component = Object(componentNormalizer["a" /* default */])( + components_predefinevue_type_script_lang_js_, + predefinevue_type_template_id_06e03093_render, + predefinevue_type_template_id_06e03093_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var predefine_api; } +predefine_component.options.__file = "packages/color-picker/src/components/predefine.vue" +/* harmony default export */ var predefine = (predefine_component.exports); +// EXTERNAL MODULE: external "element-ui/lib/utils/vue-popper" +var vue_popper_ = __webpack_require__(5); +var vue_popper_default = /*#__PURE__*/__webpack_require__.n(vue_popper_); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/locale" +var locale_ = __webpack_require__(6); +var locale_default = /*#__PURE__*/__webpack_require__.n(locale_); + +// EXTERNAL MODULE: external "element-ui/lib/input" +var input_ = __webpack_require__(10); +var input_default = /*#__PURE__*/__webpack_require__.n(input_); + +// EXTERNAL MODULE: external "element-ui/lib/button" +var button_ = __webpack_require__(14); +var button_default = /*#__PURE__*/__webpack_require__.n(button_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/picker-dropdown.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + + + + + + +/* harmony default export */ var picker_dropdownvue_type_script_lang_js_ = ({ + name: 'el-color-picker-dropdown', + + mixins: [vue_popper_default.a, locale_default.a], + + components: { + SvPanel: sv_panel, + HueSlider: hue_slider, + AlphaSlider: alpha_slider, + ElInput: input_default.a, + ElButton: button_default.a, + Predefine: predefine + }, + + props: { + color: { + required: true + }, + showAlpha: Boolean, + predefine: Array + }, + + data: function data() { + return { + customInput: '' + }; + }, + + + computed: { + currentColor: function currentColor() { + var parent = this.$parent; + return !parent.value && !parent.showPanelColor ? '' : parent.color.value; + } + }, + + methods: { + confirmValue: function confirmValue() { + this.$emit('pick'); + }, + handleConfirm: function handleConfirm() { + this.color.fromString(this.customInput); + } + }, + + mounted: function mounted() { + this.$parent.popperElm = this.popperElm = this.$el; + this.referenceElm = this.$parent.$el; + }, + + + watch: { + showPopper: function showPopper(val) { + var _this = this; + + if (val === true) { + this.$nextTick(function () { + var _$refs = _this.$refs, + sl = _$refs.sl, + hue = _$refs.hue, + alpha = _$refs.alpha; + + sl && sl.update(); + hue && hue.update(); + alpha && alpha.update(); + }); + } + }, + + + currentColor: { + immediate: true, + handler: function handler(val) { + this.customInput = val; + } + } + } +}); +// CONCATENATED MODULE: ./packages/color-picker/src/components/picker-dropdown.vue?vue&type=script&lang=js& + /* harmony default export */ var components_picker_dropdownvue_type_script_lang_js_ = (picker_dropdownvue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/color-picker/src/components/picker-dropdown.vue + + + + + +/* normalize component */ + +var picker_dropdown_component = Object(componentNormalizer["a" /* default */])( + components_picker_dropdownvue_type_script_lang_js_, + picker_dropdownvue_type_template_id_06601625_render, + picker_dropdownvue_type_template_id_06601625_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var picker_dropdown_api; } +picker_dropdown_component.options.__file = "packages/color-picker/src/components/picker-dropdown.vue" +/* harmony default export */ var picker_dropdown = (picker_dropdown_component.exports); +// EXTERNAL MODULE: external "element-ui/lib/utils/clickoutside" +var clickoutside_ = __webpack_require__(12); +var clickoutside_default = /*#__PURE__*/__webpack_require__.n(clickoutside_); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/emitter" +var emitter_ = __webpack_require__(4); +var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/main.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + + +/* harmony default export */ var mainvue_type_script_lang_js_ = ({ + name: 'ElColorPicker', + + mixins: [emitter_default.a], + + props: { + value: String, + showAlpha: Boolean, + colorFormat: String, + disabled: Boolean, + size: String, + popperClass: String, + predefine: Array + }, + + inject: { + elForm: { + default: '' + }, + elFormItem: { + default: '' + } + }, + + directives: { Clickoutside: clickoutside_default.a }, + + computed: { + displayedColor: function displayedColor() { + if (!this.value && !this.showPanelColor) { + return 'transparent'; + } + + return this.displayedRgb(this.color, this.showAlpha); + }, + _elFormItemSize: function _elFormItemSize() { + return (this.elFormItem || {}).elFormItemSize; + }, + colorSize: function colorSize() { + return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size; + }, + colorDisabled: function colorDisabled() { + return this.disabled || (this.elForm || {}).disabled; + } + }, + + watch: { + value: function value(val) { + if (!val) { + this.showPanelColor = false; + } else if (val && val !== this.color.value) { + this.color.fromString(val); + } + }, + + color: { + deep: true, + handler: function handler() { + this.showPanelColor = true; + } + }, + displayedColor: function displayedColor(val) { + if (!this.showPicker) return; + var currentValueColor = new src_color({ + enableAlpha: this.showAlpha, + format: this.colorFormat + }); + currentValueColor.fromString(this.value); + + var currentValueColorRgb = this.displayedRgb(currentValueColor, this.showAlpha); + if (val !== currentValueColorRgb) { + this.$emit('active-change', val); + } + } + }, + + methods: { + handleTrigger: function handleTrigger() { + if (this.colorDisabled) return; + this.showPicker = !this.showPicker; + }, + confirmValue: function confirmValue() { + var value = this.color.value; + this.$emit('input', value); + this.$emit('change', value); + this.dispatch('ElFormItem', 'el.form.change', value); + this.showPicker = false; + }, + clearValue: function clearValue() { + this.$emit('input', null); + this.$emit('change', null); + if (this.value !== null) { + this.dispatch('ElFormItem', 'el.form.change', null); + } + this.showPanelColor = false; + this.showPicker = false; + this.resetColor(); + }, + hide: function hide() { + this.showPicker = false; + this.resetColor(); + }, + resetColor: function resetColor() { + var _this = this; + + this.$nextTick(function (_) { + if (_this.value) { + _this.color.fromString(_this.value); + } else { + _this.showPanelColor = false; + } + }); + }, + displayedRgb: function displayedRgb(color, showAlpha) { + if (!(color instanceof src_color)) { + throw Error('color should be instance of Color Class'); + } + + var _color$toRgb = color.toRgb(), + r = _color$toRgb.r, + g = _color$toRgb.g, + b = _color$toRgb.b; + + return showAlpha ? 'rgba(' + r + ', ' + g + ', ' + b + ', ' + color.get('alpha') / 100 + ')' : 'rgb(' + r + ', ' + g + ', ' + b + ')'; + } + }, + + mounted: function mounted() { + var value = this.value; + if (value) { + this.color.fromString(value); + } + this.popperElm = this.$refs.dropdown.$el; + }, + data: function data() { + var color = new src_color({ + enableAlpha: this.showAlpha, + format: this.colorFormat + }); + + return { + color: color, + showPicker: false, + showPanelColor: false + }; + }, + + + components: { + PickerDropdown: picker_dropdown + } +}); +// CONCATENATED MODULE: ./packages/color-picker/src/main.vue?vue&type=script&lang=js& + /* harmony default export */ var src_mainvue_type_script_lang_js_ = (mainvue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/color-picker/src/main.vue + + + + + +/* normalize component */ + +var main_component = Object(componentNormalizer["a" /* default */])( + src_mainvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var main_api; } +main_component.options.__file = "packages/color-picker/src/main.vue" +/* harmony default export */ var main = (main_component.exports); +// CONCATENATED MODULE: ./packages/color-picker/index.js + + +/* istanbul ignore next */ +main.install = function (Vue) { + Vue.component(main.name, main); +}; + +/* harmony default export */ var color_picker = __webpack_exports__["default"] = (main); + +/***/ }), + +/***/ 6: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/locale"); + +/***/ }), + +/***/ 7: +/***/ (function(module, exports) { + +module.exports = require("vue"); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/container.js b/public/static/libs/element-ui/lib/container.js new file mode 100644 index 0000000..8a12910 --- /dev/null +++ b/public/static/libs/element-ui/lib/container.js @@ -0,0 +1,287 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 116); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 116: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/container/src/main.vue?vue&type=template&id=5bf181d4& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "section", + { staticClass: "el-container", class: { "is-vertical": _vm.isVertical } }, + [_vm._t("default")], + 2 + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/container/src/main.vue?vue&type=template&id=5bf181d4& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/container/src/main.vue?vue&type=script&lang=js& +// +// +// +// +// +// + +/* harmony default export */ var mainvue_type_script_lang_js_ = ({ + name: 'ElContainer', + + componentName: 'ElContainer', + + props: { + direction: String + }, + + computed: { + isVertical: function isVertical() { + if (this.direction === 'vertical') { + return true; + } else if (this.direction === 'horizontal') { + return false; + } + return this.$slots && this.$slots.default ? this.$slots.default.some(function (vnode) { + var tag = vnode.componentOptions && vnode.componentOptions.tag; + return tag === 'el-header' || tag === 'el-footer'; + }) : false; + } + } +}); +// CONCATENATED MODULE: ./packages/container/src/main.vue?vue&type=script&lang=js& + /* harmony default export */ var src_mainvue_type_script_lang_js_ = (mainvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/container/src/main.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_mainvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/container/src/main.vue" +/* harmony default export */ var main = (component.exports); +// CONCATENATED MODULE: ./packages/container/index.js + + +/* istanbul ignore next */ +main.install = function (Vue) { + Vue.component(main.name, main); +}; + +/* harmony default export */ var container = __webpack_exports__["default"] = (main); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/date-picker.js b/public/static/libs/element-ui/lib/date-picker.js new file mode 100644 index 0000000..963ab53 --- /dev/null +++ b/public/static/libs/element-ui/lib/date-picker.js @@ -0,0 +1,6358 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 56); +/******/ }) +/************************************************************************/ +/******/ ([ +/* 0 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), +/* 1 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/date-util"); + +/***/ }), +/* 2 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/dom"); + +/***/ }), +/* 3 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/util"); + +/***/ }), +/* 4 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/emitter"); + +/***/ }), +/* 5 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/vue-popper"); + +/***/ }), +/* 6 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/locale"); + +/***/ }), +/* 7 */ +/***/ (function(module, exports) { + +module.exports = require("vue"); + +/***/ }), +/* 8 */, +/* 9 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/merge"); + +/***/ }), +/* 10 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/input"); + +/***/ }), +/* 11 */, +/* 12 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/clickoutside"); + +/***/ }), +/* 13 */, +/* 14 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/button"); + +/***/ }), +/* 15 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/scrollbar"); + +/***/ }), +/* 16 */, +/* 17 */, +/* 18 */, +/* 19 */, +/* 20 */, +/* 21 */, +/* 22 */, +/* 23 */, +/* 24 */, +/* 25 */, +/* 26 */, +/* 27 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/time.vue?vue&type=template&id=3d939089& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "transition", + { + attrs: { name: "el-zoom-in-top" }, + on: { + "after-leave": function($event) { + _vm.$emit("dodestroy") + } + } + }, + [ + _c( + "div", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.visible, + expression: "visible" + } + ], + staticClass: "el-time-panel el-popper", + class: _vm.popperClass + }, + [ + _c( + "div", + { + staticClass: "el-time-panel__content", + class: { "has-seconds": _vm.showSeconds } + }, + [ + _c("time-spinner", { + ref: "spinner", + attrs: { + "arrow-control": _vm.useArrow, + "show-seconds": _vm.showSeconds, + "am-pm-mode": _vm.amPmMode, + date: _vm.date + }, + on: { + change: _vm.handleChange, + "select-range": _vm.setSelectionRange + } + }) + ], + 1 + ), + _c("div", { staticClass: "el-time-panel__footer" }, [ + _c( + "button", + { + staticClass: "el-time-panel__btn cancel", + attrs: { type: "button" }, + on: { click: _vm.handleCancel } + }, + [_vm._v(_vm._s(_vm.t("el.datepicker.cancel")))] + ), + _c( + "button", + { + staticClass: "el-time-panel__btn", + class: { confirm: !_vm.disabled }, + attrs: { type: "button" }, + on: { + click: function($event) { + _vm.handleConfirm() + } + } + }, + [_vm._v(_vm._s(_vm.t("el.datepicker.confirm")))] + ) + ]) + ] + ) + ] + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/date-picker/src/panel/time.vue?vue&type=template&id=3d939089& + +// EXTERNAL MODULE: external "element-ui/lib/utils/date-util" +var date_util_ = __webpack_require__(1); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/locale" +var locale_ = __webpack_require__(6); +var locale_default = /*#__PURE__*/__webpack_require__.n(locale_); + +// EXTERNAL MODULE: ./packages/date-picker/src/basic/time-spinner.vue + 4 modules +var time_spinner = __webpack_require__(34); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/time.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + +/* harmony default export */ var timevue_type_script_lang_js_ = ({ + mixins: [locale_default.a], + + components: { + TimeSpinner: time_spinner["a" /* default */] + }, + + props: { + visible: Boolean, + timeArrowControl: Boolean + }, + + watch: { + visible: function visible(val) { + var _this = this; + + if (val) { + this.oldValue = this.value; + this.$nextTick(function () { + return _this.$refs.spinner.emitSelectRange('hours'); + }); + } else { + this.needInitAdjust = true; + } + }, + value: function value(newVal) { + var _this2 = this; + + var date = void 0; + if (newVal instanceof Date) { + date = Object(date_util_["limitTimeRange"])(newVal, this.selectableRange, this.format); + } else if (!newVal) { + date = this.defaultValue ? new Date(this.defaultValue) : new Date(); + } + + this.date = date; + if (this.visible && this.needInitAdjust) { + this.$nextTick(function (_) { + return _this2.adjustSpinners(); + }); + this.needInitAdjust = false; + } + }, + selectableRange: function selectableRange(val) { + this.$refs.spinner.selectableRange = val; + }, + defaultValue: function defaultValue(val) { + if (!Object(date_util_["isDate"])(this.value)) { + this.date = val ? new Date(val) : new Date(); + } + } + }, + + data: function data() { + return { + popperClass: '', + format: 'HH:mm:ss', + value: '', + defaultValue: null, + date: new Date(), + oldValue: new Date(), + selectableRange: [], + selectionRange: [0, 2], + disabled: false, + arrowControl: false, + needInitAdjust: true + }; + }, + + + computed: { + showSeconds: function showSeconds() { + return (this.format || '').indexOf('ss') !== -1; + }, + useArrow: function useArrow() { + return this.arrowControl || this.timeArrowControl || false; + }, + amPmMode: function amPmMode() { + if ((this.format || '').indexOf('A') !== -1) return 'A'; + if ((this.format || '').indexOf('a') !== -1) return 'a'; + return ''; + } + }, + + methods: { + handleCancel: function handleCancel() { + this.$emit('pick', this.oldValue, false); + }, + handleChange: function handleChange(date) { + // this.visible avoids edge cases, when use scrolls during panel closing animation + if (this.visible) { + this.date = Object(date_util_["clearMilliseconds"])(date); + // if date is out of range, do not emit + if (this.isValidValue(this.date)) { + this.$emit('pick', this.date, true); + } + } + }, + setSelectionRange: function setSelectionRange(start, end) { + this.$emit('select-range', start, end); + this.selectionRange = [start, end]; + }, + handleConfirm: function handleConfirm() { + var visible = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; + var first = arguments[1]; + + if (first) return; + var date = Object(date_util_["clearMilliseconds"])(Object(date_util_["limitTimeRange"])(this.date, this.selectableRange, this.format)); + this.$emit('pick', date, visible, first); + }, + handleKeydown: function handleKeydown(event) { + var keyCode = event.keyCode; + var mapping = { 38: -1, 40: 1, 37: -1, 39: 1 }; + + // Left or Right + if (keyCode === 37 || keyCode === 39) { + var step = mapping[keyCode]; + this.changeSelectionRange(step); + event.preventDefault(); + return; + } + + // Up or Down + if (keyCode === 38 || keyCode === 40) { + var _step = mapping[keyCode]; + this.$refs.spinner.scrollDown(_step); + event.preventDefault(); + return; + } + }, + isValidValue: function isValidValue(date) { + return Object(date_util_["timeWithinRange"])(date, this.selectableRange, this.format); + }, + adjustSpinners: function adjustSpinners() { + return this.$refs.spinner.adjustSpinners(); + }, + changeSelectionRange: function changeSelectionRange(step) { + var list = [0, 3].concat(this.showSeconds ? [6] : []); + var mapping = ['hours', 'minutes'].concat(this.showSeconds ? ['seconds'] : []); + var index = list.indexOf(this.selectionRange[0]); + var next = (index + step + list.length) % list.length; + this.$refs.spinner.emitSelectRange(mapping[next]); + } + }, + + mounted: function mounted() { + var _this3 = this; + + this.$nextTick(function () { + return _this3.handleConfirm(true, true); + }); + this.$emit('mounted'); + } +}); +// CONCATENATED MODULE: ./packages/date-picker/src/panel/time.vue?vue&type=script&lang=js& + /* harmony default export */ var panel_timevue_type_script_lang_js_ = (timevue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/date-picker/src/panel/time.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + panel_timevue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/date-picker/src/panel/time.vue" +/* harmony default export */ var time = __webpack_exports__["a"] = (component.exports); + +/***/ }), +/* 28 */, +/* 29 */, +/* 30 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony import */ var element_ui_src_utils_dom__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(2); +/* harmony import */ var element_ui_src_utils_dom__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(element_ui_src_utils_dom__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var element_ui_src_utils_util__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3); +/* harmony import */ var element_ui_src_utils_util__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(element_ui_src_utils_util__WEBPACK_IMPORTED_MODULE_1__); + + + +/* harmony default export */ __webpack_exports__["a"] = ({ + bind: function bind(el, binding, vnode) { + var interval = null; + var startTime = void 0; + var maxIntervals = Object(element_ui_src_utils_util__WEBPACK_IMPORTED_MODULE_1__["isMac"])() ? 100 : 200; + var handler = function handler() { + return vnode.context[binding.expression].apply(); + }; + var clear = function clear() { + if (Date.now() - startTime < maxIntervals) { + handler(); + } + clearInterval(interval); + interval = null; + }; + + Object(element_ui_src_utils_dom__WEBPACK_IMPORTED_MODULE_0__["on"])(el, 'mousedown', function (e) { + if (e.button !== 0) return; + startTime = Date.now(); + Object(element_ui_src_utils_dom__WEBPACK_IMPORTED_MODULE_0__["once"])(document, 'mouseup', clear); + clearInterval(interval); + interval = setInterval(handler, maxIntervals); + }); + } +}); + +/***/ }), +/* 31 */, +/* 32 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/picker.vue?vue&type=template&id=79ae069f& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return !_vm.ranged + ? _c( + "el-input", + _vm._b( + { + directives: [ + { + name: "clickoutside", + rawName: "v-clickoutside", + value: _vm.handleClose, + expression: "handleClose" + } + ], + ref: "reference", + staticClass: "el-date-editor", + class: "el-date-editor--" + _vm.type, + attrs: { + readonly: + !_vm.editable || + _vm.readonly || + _vm.type === "dates" || + _vm.type === "week" || + _vm.type === "years" || + _vm.type === "months", + disabled: _vm.pickerDisabled, + size: _vm.pickerSize, + name: _vm.name, + placeholder: _vm.placeholder, + value: _vm.displayValue, + validateEvent: false + }, + on: { + focus: _vm.handleFocus, + input: function(value) { + return (_vm.userInput = value) + }, + change: _vm.handleChange + }, + nativeOn: { + keydown: function($event) { + return _vm.handleKeydown($event) + }, + mouseenter: function($event) { + return _vm.handleMouseEnter($event) + }, + mouseleave: function($event) { + _vm.showClose = false + } + } + }, + "el-input", + _vm.firstInputId, + false + ), + [ + _c("i", { + staticClass: "el-input__icon", + class: _vm.triggerClass, + attrs: { slot: "prefix" }, + on: { click: _vm.handleFocus }, + slot: "prefix" + }), + _vm.haveTrigger + ? _c("i", { + staticClass: "el-input__icon", + class: [_vm.showClose ? "" + _vm.clearIcon : ""], + attrs: { slot: "suffix" }, + on: { click: _vm.handleClickIcon }, + slot: "suffix" + }) + : _vm._e() + ] + ) + : _c( + "div", + { + directives: [ + { + name: "clickoutside", + rawName: "v-clickoutside", + value: _vm.handleClose, + expression: "handleClose" + } + ], + ref: "reference", + staticClass: "el-date-editor el-range-editor el-input__inner", + class: [ + "el-date-editor--" + _vm.type, + _vm.pickerSize ? "el-range-editor--" + _vm.pickerSize : "", + _vm.pickerDisabled ? "is-disabled" : "", + _vm.pickerVisible ? "is-active" : "" + ], + on: { + click: _vm.handleRangeClick, + mouseenter: _vm.handleMouseEnter, + mouseleave: function($event) { + _vm.showClose = false + }, + keydown: _vm.handleKeydown + } + }, + [ + _c("i", { + class: ["el-input__icon", "el-range__icon", _vm.triggerClass] + }), + _c( + "input", + _vm._b( + { + staticClass: "el-range-input", + attrs: { + autocomplete: "off", + placeholder: _vm.startPlaceholder, + disabled: _vm.pickerDisabled, + readonly: !_vm.editable || _vm.readonly, + name: _vm.name && _vm.name[0] + }, + domProps: { value: _vm.displayValue && _vm.displayValue[0] }, + on: { + input: _vm.handleStartInput, + change: _vm.handleStartChange, + focus: _vm.handleFocus + } + }, + "input", + _vm.firstInputId, + false + ) + ), + _vm._t("range-separator", [ + _c("span", { staticClass: "el-range-separator" }, [ + _vm._v(_vm._s(_vm.rangeSeparator)) + ]) + ]), + _c( + "input", + _vm._b( + { + staticClass: "el-range-input", + attrs: { + autocomplete: "off", + placeholder: _vm.endPlaceholder, + disabled: _vm.pickerDisabled, + readonly: !_vm.editable || _vm.readonly, + name: _vm.name && _vm.name[1] + }, + domProps: { value: _vm.displayValue && _vm.displayValue[1] }, + on: { + input: _vm.handleEndInput, + change: _vm.handleEndChange, + focus: _vm.handleFocus + } + }, + "input", + _vm.secondInputId, + false + ) + ), + _vm.haveTrigger + ? _c("i", { + staticClass: "el-input__icon el-range__close-icon", + class: [_vm.showClose ? "" + _vm.clearIcon : ""], + on: { click: _vm.handleClickIcon } + }) + : _vm._e() + ], + 2 + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/date-picker/src/picker.vue?vue&type=template&id=79ae069f& + +// EXTERNAL MODULE: external "vue" +var external_vue_ = __webpack_require__(7); +var external_vue_default = /*#__PURE__*/__webpack_require__.n(external_vue_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/clickoutside" +var clickoutside_ = __webpack_require__(12); +var clickoutside_default = /*#__PURE__*/__webpack_require__.n(clickoutside_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/date-util" +var date_util_ = __webpack_require__(1); + +// EXTERNAL MODULE: external "element-ui/lib/utils/vue-popper" +var vue_popper_ = __webpack_require__(5); +var vue_popper_default = /*#__PURE__*/__webpack_require__.n(vue_popper_); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/emitter" +var emitter_ = __webpack_require__(4); +var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_); + +// EXTERNAL MODULE: external "element-ui/lib/input" +var input_ = __webpack_require__(10); +var input_default = /*#__PURE__*/__webpack_require__.n(input_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/merge" +var merge_ = __webpack_require__(9); +var merge_default = /*#__PURE__*/__webpack_require__.n(merge_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/picker.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + + + + + +var NewPopper = { + props: { + appendToBody: vue_popper_default.a.props.appendToBody, + offset: vue_popper_default.a.props.offset, + boundariesPadding: vue_popper_default.a.props.boundariesPadding, + arrowOffset: vue_popper_default.a.props.arrowOffset, + transformOrigin: vue_popper_default.a.props.transformOrigin + }, + methods: vue_popper_default.a.methods, + data: function data() { + return merge_default()({ visibleArrow: true }, vue_popper_default.a.data); + }, + + beforeDestroy: vue_popper_default.a.beforeDestroy +}; + +var DEFAULT_FORMATS = { + date: 'yyyy-MM-dd', + month: 'yyyy-MM', + months: 'yyyy-MM', + datetime: 'yyyy-MM-dd HH:mm:ss', + time: 'HH:mm:ss', + week: 'yyyywWW', + timerange: 'HH:mm:ss', + daterange: 'yyyy-MM-dd', + monthrange: 'yyyy-MM', + datetimerange: 'yyyy-MM-dd HH:mm:ss', + year: 'yyyy', + years: 'yyyy' +}; +var HAVE_TRIGGER_TYPES = ['date', 'datetime', 'time', 'time-select', 'week', 'month', 'year', 'daterange', 'monthrange', 'timerange', 'datetimerange', 'dates', 'months', 'years']; +var pickervue_type_script_lang_js_DATE_FORMATTER = function DATE_FORMATTER(value, format) { + if (format === 'timestamp') return value.getTime(); + return Object(date_util_["formatDate"])(value, format); +}; +var pickervue_type_script_lang_js_DATE_PARSER = function DATE_PARSER(text, format) { + if (format === 'timestamp') return new Date(Number(text)); + return Object(date_util_["parseDate"])(text, format); +}; +var RANGE_FORMATTER = function RANGE_FORMATTER(value, format) { + if (Array.isArray(value) && value.length === 2) { + var start = value[0]; + var end = value[1]; + + if (start && end) { + return [pickervue_type_script_lang_js_DATE_FORMATTER(start, format), pickervue_type_script_lang_js_DATE_FORMATTER(end, format)]; + } + } + return ''; +}; +var RANGE_PARSER = function RANGE_PARSER(array, format, separator) { + if (!Array.isArray(array)) { + array = array.split(separator); + } + if (array.length === 2) { + var range1 = array[0]; + var range2 = array[1]; + + return [pickervue_type_script_lang_js_DATE_PARSER(range1, format), pickervue_type_script_lang_js_DATE_PARSER(range2, format)]; + } + return []; +}; +var TYPE_VALUE_RESOLVER_MAP = { + default: { + formatter: function formatter(value) { + if (!value) return ''; + return '' + value; + }, + parser: function parser(text) { + if (text === undefined || text === '') return null; + return text; + } + }, + week: { + formatter: function formatter(value, format) { + var week = Object(date_util_["getWeekNumber"])(value); + var month = value.getMonth(); + var trueDate = new Date(value); + if (week === 1 && month === 11) { + trueDate.setHours(0, 0, 0, 0); + trueDate.setDate(trueDate.getDate() + 3 - (trueDate.getDay() + 6) % 7); + } + var date = Object(date_util_["formatDate"])(trueDate, format); + + date = /WW/.test(date) ? date.replace(/WW/, week < 10 ? '0' + week : week) : date.replace(/W/, week); + return date; + }, + parser: function parser(text, format) { + // parse as if a normal date + return TYPE_VALUE_RESOLVER_MAP.date.parser(text, format); + } + }, + date: { + formatter: pickervue_type_script_lang_js_DATE_FORMATTER, + parser: pickervue_type_script_lang_js_DATE_PARSER + }, + datetime: { + formatter: pickervue_type_script_lang_js_DATE_FORMATTER, + parser: pickervue_type_script_lang_js_DATE_PARSER + }, + daterange: { + formatter: RANGE_FORMATTER, + parser: RANGE_PARSER + }, + monthrange: { + formatter: RANGE_FORMATTER, + parser: RANGE_PARSER + }, + datetimerange: { + formatter: RANGE_FORMATTER, + parser: RANGE_PARSER + }, + timerange: { + formatter: RANGE_FORMATTER, + parser: RANGE_PARSER + }, + time: { + formatter: pickervue_type_script_lang_js_DATE_FORMATTER, + parser: pickervue_type_script_lang_js_DATE_PARSER + }, + month: { + formatter: pickervue_type_script_lang_js_DATE_FORMATTER, + parser: pickervue_type_script_lang_js_DATE_PARSER + }, + year: { + formatter: pickervue_type_script_lang_js_DATE_FORMATTER, + parser: pickervue_type_script_lang_js_DATE_PARSER + }, + number: { + formatter: function formatter(value) { + if (!value) return ''; + return '' + value; + }, + parser: function parser(text) { + var result = Number(text); + + if (!isNaN(text)) { + return result; + } else { + return null; + } + } + }, + dates: { + formatter: function formatter(value, format) { + return value.map(function (date) { + return pickervue_type_script_lang_js_DATE_FORMATTER(date, format); + }); + }, + parser: function parser(value, format) { + return (typeof value === 'string' ? value.split(', ') : value).map(function (date) { + return date instanceof Date ? date : pickervue_type_script_lang_js_DATE_PARSER(date, format); + }); + } + }, + months: { + formatter: function formatter(value, format) { + return value.map(function (date) { + return pickervue_type_script_lang_js_DATE_FORMATTER(date, format); + }); + }, + parser: function parser(value, format) { + return (typeof value === 'string' ? value.split(', ') : value).map(function (date) { + return date instanceof Date ? date : pickervue_type_script_lang_js_DATE_PARSER(date, format); + }); + } + }, + years: { + formatter: function formatter(value, format) { + return value.map(function (date) { + return pickervue_type_script_lang_js_DATE_FORMATTER(date, format); + }); + }, + parser: function parser(value, format) { + return (typeof value === 'string' ? value.split(', ') : value).map(function (date) { + return date instanceof Date ? date : pickervue_type_script_lang_js_DATE_PARSER(date, format); + }); + } + } +}; +var PLACEMENT_MAP = { + left: 'bottom-start', + center: 'bottom', + right: 'bottom-end' +}; + +var parseAsFormatAndType = function parseAsFormatAndType(value, customFormat, type) { + var rangeSeparator = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : '-'; + + if (!value) return null; + var parser = (TYPE_VALUE_RESOLVER_MAP[type] || TYPE_VALUE_RESOLVER_MAP['default']).parser; + var format = customFormat || DEFAULT_FORMATS[type]; + return parser(value, format, rangeSeparator); +}; + +var formatAsFormatAndType = function formatAsFormatAndType(value, customFormat, type) { + if (!value) return null; + var formatter = (TYPE_VALUE_RESOLVER_MAP[type] || TYPE_VALUE_RESOLVER_MAP['default']).formatter; + var format = customFormat || DEFAULT_FORMATS[type]; + return formatter(value, format); +}; + +/* + * Considers: + * 1. Date object + * 2. date string + * 3. array of 1 or 2 + */ +var valueEquals = function valueEquals(a, b) { + // considers Date object and string + var dateEquals = function dateEquals(a, b) { + var aIsDate = a instanceof Date; + var bIsDate = b instanceof Date; + if (aIsDate && bIsDate) { + return a.getTime() === b.getTime(); + } + if (!aIsDate && !bIsDate) { + return a === b; + } + return false; + }; + + var aIsArray = a instanceof Array; + var bIsArray = b instanceof Array; + if (aIsArray && bIsArray) { + if (a.length !== b.length) { + return false; + } + return a.every(function (item, index) { + return dateEquals(item, b[index]); + }); + } + if (!aIsArray && !bIsArray) { + return dateEquals(a, b); + } + return false; +}; + +var isString = function isString(val) { + return typeof val === 'string' || val instanceof String; +}; + +var validator = function validator(val) { + // either: String, Array of String, null / undefined + return val === null || val === undefined || isString(val) || Array.isArray(val) && val.length === 2 && val.every(isString); +}; + +/* harmony default export */ var pickervue_type_script_lang_js_ = ({ + mixins: [emitter_default.a, NewPopper], + + inject: { + elForm: { + default: '' + }, + elFormItem: { + default: '' + } + }, + + props: { + size: String, + format: String, + valueFormat: String, + readonly: Boolean, + placeholder: String, + startPlaceholder: String, + endPlaceholder: String, + prefixIcon: String, + clearIcon: { + type: String, + default: 'el-icon-circle-close' + }, + name: { + default: '', + validator: validator + }, + disabled: Boolean, + clearable: { + type: Boolean, + default: true + }, + id: { + default: '', + validator: validator + }, + popperClass: String, + editable: { + type: Boolean, + default: true + }, + align: { + type: String, + default: 'left' + }, + value: {}, + defaultValue: {}, + defaultTime: {}, + rangeSeparator: { + default: '-' + }, + pickerOptions: {}, + unlinkPanels: Boolean, + validateEvent: { + type: Boolean, + default: true + } + }, + + components: { ElInput: input_default.a }, + + directives: { Clickoutside: clickoutside_default.a }, + + data: function data() { + return { + pickerVisible: false, + showClose: false, + userInput: null, + valueOnOpen: null, // value when picker opens, used to determine whether to emit change + unwatchPickerOptions: null + }; + }, + + + watch: { + pickerVisible: function pickerVisible(val) { + if (this.readonly || this.pickerDisabled) return; + if (val) { + this.showPicker(); + this.valueOnOpen = Array.isArray(this.value) ? [].concat(this.value) : this.value; + } else { + this.hidePicker(); + this.emitChange(this.value); + this.userInput = null; + if (this.validateEvent) { + this.dispatch('ElFormItem', 'el.form.blur'); + } + this.$emit('blur', this); + this.blur(); + } + }, + + parsedValue: { + immediate: true, + handler: function handler(val) { + if (this.picker) { + this.picker.value = val; + } + } + }, + defaultValue: function defaultValue(val) { + // NOTE: should eventually move to jsx style picker + panel ? + if (this.picker) { + this.picker.defaultValue = val; + } + }, + value: function value(val, oldVal) { + if (!valueEquals(val, oldVal) && !this.pickerVisible && this.validateEvent) { + this.dispatch('ElFormItem', 'el.form.change', val); + } + } + }, + + computed: { + ranged: function ranged() { + return this.type.indexOf('range') > -1; + }, + reference: function reference() { + var reference = this.$refs.reference; + return reference.$el || reference; + }, + refInput: function refInput() { + if (this.reference) { + return [].slice.call(this.reference.querySelectorAll('input')); + } + return []; + }, + valueIsEmpty: function valueIsEmpty() { + var val = this.value; + if (Array.isArray(val)) { + for (var i = 0, len = val.length; i < len; i++) { + if (val[i]) { + return false; + } + } + } else { + if (val) { + return false; + } + } + return true; + }, + triggerClass: function triggerClass() { + return this.prefixIcon || (this.type.indexOf('time') !== -1 ? 'el-icon-time' : 'el-icon-date'); + }, + selectionMode: function selectionMode() { + if (this.type === 'week') { + return 'week'; + } else if (this.type === 'month') { + return 'month'; + } else if (this.type === 'year') { + return 'year'; + } else if (this.type === 'dates') { + return 'dates'; + } else if (this.type === 'months') { + return 'months'; + } else if (this.type === 'years') { + return 'years'; + } + + return 'day'; + }, + haveTrigger: function haveTrigger() { + if (typeof this.showTrigger !== 'undefined') { + return this.showTrigger; + } + return HAVE_TRIGGER_TYPES.indexOf(this.type) !== -1; + }, + displayValue: function displayValue() { + var formattedValue = formatAsFormatAndType(this.parsedValue, this.format, this.type, this.rangeSeparator); + if (Array.isArray(this.userInput)) { + return [this.userInput[0] || formattedValue && formattedValue[0] || '', this.userInput[1] || formattedValue && formattedValue[1] || '']; + } else if (this.userInput !== null) { + return this.userInput; + } else if (formattedValue) { + return this.type === 'dates' || this.type === 'years' || this.type === 'months' ? formattedValue.join(', ') : formattedValue; + } else { + return ''; + } + }, + parsedValue: function parsedValue() { + if (!this.value) return this.value; // component value is not set + if (this.type === 'time-select') return this.value; // time-select does not require parsing, this might change in next major version + + var valueIsDateObject = Object(date_util_["isDateObject"])(this.value) || Array.isArray(this.value) && this.value.every(date_util_["isDateObject"]); + if (valueIsDateObject) { + return this.value; + } + + if (this.valueFormat) { + return parseAsFormatAndType(this.value, this.valueFormat, this.type, this.rangeSeparator) || this.value; + } + + // NOTE: deal with common but incorrect usage, should remove in next major version + // user might provide string / timestamp without value-format, coerce them into date (or array of date) + return Array.isArray(this.value) ? this.value.map(function (val) { + return new Date(val); + }) : new Date(this.value); + }, + _elFormItemSize: function _elFormItemSize() { + return (this.elFormItem || {}).elFormItemSize; + }, + pickerSize: function pickerSize() { + return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size; + }, + pickerDisabled: function pickerDisabled() { + return this.disabled || (this.elForm || {}).disabled; + }, + firstInputId: function firstInputId() { + var obj = {}; + var id = void 0; + if (this.ranged) { + id = this.id && this.id[0]; + } else { + id = this.id; + } + if (id) obj.id = id; + return obj; + }, + secondInputId: function secondInputId() { + var obj = {}; + var id = void 0; + if (this.ranged) { + id = this.id && this.id[1]; + } + if (id) obj.id = id; + return obj; + } + }, + + created: function created() { + // vue-popper + this.popperOptions = { + boundariesPadding: 0, + gpuAcceleration: false + }; + this.placement = PLACEMENT_MAP[this.align] || PLACEMENT_MAP.left; + + this.$on('fieldReset', this.handleFieldReset); + }, + + + methods: { + focus: function focus() { + if (!this.ranged) { + this.$refs.reference.focus(); + } else { + this.handleFocus(); + } + }, + blur: function blur() { + this.refInput.forEach(function (input) { + return input.blur(); + }); + }, + + + // {parse, formatTo} Value deals maps component value with internal Date + parseValue: function parseValue(value) { + var isParsed = Object(date_util_["isDateObject"])(value) || Array.isArray(value) && value.every(date_util_["isDateObject"]); + if (this.valueFormat && !isParsed) { + return parseAsFormatAndType(value, this.valueFormat, this.type, this.rangeSeparator) || value; + } else { + return value; + } + }, + formatToValue: function formatToValue(date) { + var isFormattable = Object(date_util_["isDateObject"])(date) || Array.isArray(date) && date.every(date_util_["isDateObject"]); + if (this.valueFormat && isFormattable) { + return formatAsFormatAndType(date, this.valueFormat, this.type, this.rangeSeparator); + } else { + return date; + } + }, + + + // {parse, formatTo} String deals with user input + parseString: function parseString(value) { + var type = Array.isArray(value) ? this.type : this.type.replace('range', ''); + return parseAsFormatAndType(value, this.format, type); + }, + formatToString: function formatToString(value) { + var type = Array.isArray(value) ? this.type : this.type.replace('range', ''); + return formatAsFormatAndType(value, this.format, type); + }, + handleMouseEnter: function handleMouseEnter() { + if (this.readonly || this.pickerDisabled) return; + if (!this.valueIsEmpty && this.clearable) { + this.showClose = true; + } + }, + handleChange: function handleChange() { + if (this.userInput) { + var value = this.parseString(this.displayValue); + if (value) { + this.picker.value = value; + if (this.isValidValue(value)) { + this.emitInput(value); + this.userInput = null; + } + } + } + if (this.userInput === '') { + this.emitInput(null); + this.emitChange(null); + this.userInput = null; + } + }, + handleStartInput: function handleStartInput(event) { + if (this.userInput) { + this.userInput = [event.target.value, this.userInput[1]]; + } else { + this.userInput = [event.target.value, null]; + } + }, + handleEndInput: function handleEndInput(event) { + if (this.userInput) { + this.userInput = [this.userInput[0], event.target.value]; + } else { + this.userInput = [null, event.target.value]; + } + }, + handleStartChange: function handleStartChange(event) { + var value = this.parseString(this.userInput && this.userInput[0]); + if (value) { + this.userInput = [this.formatToString(value), this.displayValue[1]]; + var newValue = [value, this.picker.value && this.picker.value[1]]; + this.picker.value = newValue; + if (this.isValidValue(newValue)) { + this.emitInput(newValue); + this.userInput = null; + } + } + }, + handleEndChange: function handleEndChange(event) { + var value = this.parseString(this.userInput && this.userInput[1]); + if (value) { + this.userInput = [this.displayValue[0], this.formatToString(value)]; + var newValue = [this.picker.value && this.picker.value[0], value]; + this.picker.value = newValue; + if (this.isValidValue(newValue)) { + this.emitInput(newValue); + this.userInput = null; + } + } + }, + handleClickIcon: function handleClickIcon(event) { + if (this.readonly || this.pickerDisabled) return; + if (this.showClose) { + this.valueOnOpen = this.value; + event.stopPropagation(); + this.emitInput(null); + this.emitChange(null); + this.showClose = false; + if (this.picker && typeof this.picker.handleClear === 'function') { + this.picker.handleClear(); + } + } else { + this.pickerVisible = !this.pickerVisible; + } + }, + handleClose: function handleClose() { + if (!this.pickerVisible) return; + this.pickerVisible = false; + + if (this.type === 'dates' || this.type === 'years' || this.type === 'months') { + // restore to former value + var oldValue = parseAsFormatAndType(this.valueOnOpen, this.valueFormat, this.type, this.rangeSeparator) || this.valueOnOpen; + this.emitInput(oldValue); + } + }, + handleFieldReset: function handleFieldReset(initialValue) { + this.userInput = initialValue === '' ? null : initialValue; + }, + handleFocus: function handleFocus() { + var type = this.type; + + if (HAVE_TRIGGER_TYPES.indexOf(type) !== -1 && !this.pickerVisible) { + this.pickerVisible = true; + } + this.$emit('focus', this); + }, + handleKeydown: function handleKeydown(event) { + var _this = this; + + var keyCode = event.keyCode; + + // ESC + if (keyCode === 27) { + this.pickerVisible = false; + event.stopPropagation(); + return; + } + + // Tab + if (keyCode === 9) { + if (!this.ranged) { + this.handleChange(); + this.pickerVisible = this.picker.visible = false; + this.blur(); + event.stopPropagation(); + } else { + // user may change focus between two input + setTimeout(function () { + if (_this.refInput.indexOf(document.activeElement) === -1) { + _this.pickerVisible = false; + _this.blur(); + event.stopPropagation(); + } + }, 0); + } + return; + } + + // Enter + if (keyCode === 13) { + if (this.userInput === '' || this.isValidValue(this.parseString(this.displayValue))) { + this.handleChange(); + this.pickerVisible = this.picker.visible = false; + this.blur(); + } + event.stopPropagation(); + return; + } + + // if user is typing, do not let picker handle key input + if (this.userInput) { + event.stopPropagation(); + return; + } + + // delegate other keys to panel + if (this.picker && this.picker.handleKeydown) { + this.picker.handleKeydown(event); + } + }, + handleRangeClick: function handleRangeClick() { + var type = this.type; + + if (HAVE_TRIGGER_TYPES.indexOf(type) !== -1 && !this.pickerVisible) { + this.pickerVisible = true; + } + this.$emit('focus', this); + }, + hidePicker: function hidePicker() { + if (this.picker) { + this.picker.resetView && this.picker.resetView(); + this.pickerVisible = this.picker.visible = false; + this.destroyPopper(); + } + }, + showPicker: function showPicker() { + var _this2 = this; + + if (this.$isServer) return; + if (!this.picker) { + this.mountPicker(); + } + this.pickerVisible = this.picker.visible = true; + + this.updatePopper(); + + this.picker.value = this.parsedValue; + this.picker.resetView && this.picker.resetView(); + + this.$nextTick(function () { + _this2.picker.adjustSpinners && _this2.picker.adjustSpinners(); + }); + }, + mountPicker: function mountPicker() { + var _this3 = this; + + this.picker = new external_vue_default.a(this.panel).$mount(); + this.picker.defaultValue = this.defaultValue; + this.picker.defaultTime = this.defaultTime; + this.picker.popperClass = this.popperClass; + this.popperElm = this.picker.$el; + this.picker.width = this.reference.getBoundingClientRect().width; + this.picker.showTime = this.type === 'datetime' || this.type === 'datetimerange'; + this.picker.selectionMode = this.selectionMode; + this.picker.unlinkPanels = this.unlinkPanels; + this.picker.arrowControl = this.arrowControl || this.timeArrowControl || false; + this.$watch('format', function (format) { + _this3.picker.format = format; + }); + + var updateOptions = function updateOptions() { + var options = _this3.pickerOptions; + + if (options && options.selectableRange) { + var ranges = options.selectableRange; + var parser = TYPE_VALUE_RESOLVER_MAP.datetimerange.parser; + var format = DEFAULT_FORMATS.timerange; + + ranges = Array.isArray(ranges) ? ranges : [ranges]; + _this3.picker.selectableRange = ranges.map(function (range) { + return parser(range, format, _this3.rangeSeparator); + }); + } + + for (var option in options) { + if (options.hasOwnProperty(option) && + // 忽略 time-picker 的该配置项 + option !== 'selectableRange') { + _this3.picker[option] = options[option]; + } + } + + // main format must prevail over undocumented pickerOptions.format + if (_this3.format) { + _this3.picker.format = _this3.format; + } + }; + updateOptions(); + this.unwatchPickerOptions = this.$watch('pickerOptions', function () { + return updateOptions(); + }, { deep: true }); + this.$el.appendChild(this.picker.$el); + this.picker.resetView && this.picker.resetView(); + + this.picker.$on('dodestroy', this.doDestroy); + this.picker.$on('pick', function () { + var date = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; + var visible = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; + + _this3.userInput = null; + _this3.pickerVisible = _this3.picker.visible = visible; + _this3.emitInput(date); + _this3.picker.resetView && _this3.picker.resetView(); + }); + + this.picker.$on('select-range', function (start, end, pos) { + if (_this3.refInput.length === 0) return; + if (!pos || pos === 'min') { + _this3.refInput[0].setSelectionRange(start, end); + _this3.refInput[0].focus(); + } else if (pos === 'max') { + _this3.refInput[1].setSelectionRange(start, end); + _this3.refInput[1].focus(); + } + }); + }, + unmountPicker: function unmountPicker() { + if (this.picker) { + this.picker.$destroy(); + this.picker.$off(); + if (typeof this.unwatchPickerOptions === 'function') { + this.unwatchPickerOptions(); + } + this.picker.$el.parentNode.removeChild(this.picker.$el); + } + }, + emitChange: function emitChange(val) { + // determine user real change only + if (!valueEquals(val, this.valueOnOpen)) { + this.$emit('change', val); + this.valueOnOpen = val; + if (this.validateEvent) { + this.dispatch('ElFormItem', 'el.form.change', val); + } + } + }, + emitInput: function emitInput(val) { + var formatted = this.formatToValue(val); + if (!valueEquals(this.value, formatted)) { + this.$emit('input', formatted); + } + }, + isValidValue: function isValidValue(value) { + if (!this.picker) { + this.mountPicker(); + } + if (this.picker.isValidValue) { + return value && this.picker.isValidValue(value); + } else { + return true; + } + } + } +}); +// CONCATENATED MODULE: ./packages/date-picker/src/picker.vue?vue&type=script&lang=js& + /* harmony default export */ var src_pickervue_type_script_lang_js_ = (pickervue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/date-picker/src/picker.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_pickervue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/date-picker/src/picker.vue" +/* harmony default export */ var picker = __webpack_exports__["a"] = (component.exports); + +/***/ }), +/* 33 */, +/* 34 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/time-spinner.vue?vue&type=template&id=1facadeb& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { + staticClass: "el-time-spinner", + class: { "has-seconds": _vm.showSeconds } + }, + [ + !_vm.arrowControl + ? [ + _c( + "el-scrollbar", + { + ref: "hours", + staticClass: "el-time-spinner__wrapper", + attrs: { + "wrap-style": "max-height: inherit;", + "view-class": "el-time-spinner__list", + noresize: "", + tag: "ul" + }, + nativeOn: { + mouseenter: function($event) { + _vm.emitSelectRange("hours") + }, + mousemove: function($event) { + _vm.adjustCurrentSpinner("hours") + } + } + }, + _vm._l(_vm.hoursList, function(disabled, hour) { + return _c( + "li", + { + key: hour, + staticClass: "el-time-spinner__item", + class: { active: hour === _vm.hours, disabled: disabled }, + on: { + click: function($event) { + _vm.handleClick("hours", { + value: hour, + disabled: disabled + }) + } + } + }, + [ + _vm._v( + _vm._s( + ("0" + (_vm.amPmMode ? hour % 12 || 12 : hour)).slice( + -2 + ) + ) + _vm._s(_vm.amPm(hour)) + ) + ] + ) + }), + 0 + ), + _c( + "el-scrollbar", + { + ref: "minutes", + staticClass: "el-time-spinner__wrapper", + attrs: { + "wrap-style": "max-height: inherit;", + "view-class": "el-time-spinner__list", + noresize: "", + tag: "ul" + }, + nativeOn: { + mouseenter: function($event) { + _vm.emitSelectRange("minutes") + }, + mousemove: function($event) { + _vm.adjustCurrentSpinner("minutes") + } + } + }, + _vm._l(_vm.minutesList, function(enabled, key) { + return _c( + "li", + { + key: key, + staticClass: "el-time-spinner__item", + class: { active: key === _vm.minutes, disabled: !enabled }, + on: { + click: function($event) { + _vm.handleClick("minutes", { + value: key, + disabled: false + }) + } + } + }, + [_vm._v(_vm._s(("0" + key).slice(-2)))] + ) + }), + 0 + ), + _c( + "el-scrollbar", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.showSeconds, + expression: "showSeconds" + } + ], + ref: "seconds", + staticClass: "el-time-spinner__wrapper", + attrs: { + "wrap-style": "max-height: inherit;", + "view-class": "el-time-spinner__list", + noresize: "", + tag: "ul" + }, + nativeOn: { + mouseenter: function($event) { + _vm.emitSelectRange("seconds") + }, + mousemove: function($event) { + _vm.adjustCurrentSpinner("seconds") + } + } + }, + _vm._l(60, function(second, key) { + return _c( + "li", + { + key: key, + staticClass: "el-time-spinner__item", + class: { active: key === _vm.seconds }, + on: { + click: function($event) { + _vm.handleClick("seconds", { + value: key, + disabled: false + }) + } + } + }, + [_vm._v(_vm._s(("0" + key).slice(-2)))] + ) + }), + 0 + ) + ] + : _vm._e(), + _vm.arrowControl + ? [ + _c( + "div", + { + staticClass: "el-time-spinner__wrapper is-arrow", + on: { + mouseenter: function($event) { + _vm.emitSelectRange("hours") + } + } + }, + [ + _c("i", { + directives: [ + { + name: "repeat-click", + rawName: "v-repeat-click", + value: _vm.decrease, + expression: "decrease" + } + ], + staticClass: "el-time-spinner__arrow el-icon-arrow-up" + }), + _c("i", { + directives: [ + { + name: "repeat-click", + rawName: "v-repeat-click", + value: _vm.increase, + expression: "increase" + } + ], + staticClass: "el-time-spinner__arrow el-icon-arrow-down" + }), + _c( + "ul", + { ref: "hours", staticClass: "el-time-spinner__list" }, + _vm._l(_vm.arrowHourList, function(hour, key) { + return _c( + "li", + { + key: key, + staticClass: "el-time-spinner__item", + class: { + active: hour === _vm.hours, + disabled: _vm.hoursList[hour] + } + }, + [ + _vm._v( + _vm._s( + hour === undefined + ? "" + : ( + "0" + (_vm.amPmMode ? hour % 12 || 12 : hour) + ).slice(-2) + _vm.amPm(hour) + ) + ) + ] + ) + }), + 0 + ) + ] + ), + _c( + "div", + { + staticClass: "el-time-spinner__wrapper is-arrow", + on: { + mouseenter: function($event) { + _vm.emitSelectRange("minutes") + } + } + }, + [ + _c("i", { + directives: [ + { + name: "repeat-click", + rawName: "v-repeat-click", + value: _vm.decrease, + expression: "decrease" + } + ], + staticClass: "el-time-spinner__arrow el-icon-arrow-up" + }), + _c("i", { + directives: [ + { + name: "repeat-click", + rawName: "v-repeat-click", + value: _vm.increase, + expression: "increase" + } + ], + staticClass: "el-time-spinner__arrow el-icon-arrow-down" + }), + _c( + "ul", + { ref: "minutes", staticClass: "el-time-spinner__list" }, + _vm._l(_vm.arrowMinuteList, function(minute, key) { + return _c( + "li", + { + key: key, + staticClass: "el-time-spinner__item", + class: { active: minute === _vm.minutes } + }, + [ + _vm._v( + "\n " + + _vm._s( + minute === undefined + ? "" + : ("0" + minute).slice(-2) + ) + + "\n " + ) + ] + ) + }), + 0 + ) + ] + ), + _vm.showSeconds + ? _c( + "div", + { + staticClass: "el-time-spinner__wrapper is-arrow", + on: { + mouseenter: function($event) { + _vm.emitSelectRange("seconds") + } + } + }, + [ + _c("i", { + directives: [ + { + name: "repeat-click", + rawName: "v-repeat-click", + value: _vm.decrease, + expression: "decrease" + } + ], + staticClass: "el-time-spinner__arrow el-icon-arrow-up" + }), + _c("i", { + directives: [ + { + name: "repeat-click", + rawName: "v-repeat-click", + value: _vm.increase, + expression: "increase" + } + ], + staticClass: "el-time-spinner__arrow el-icon-arrow-down" + }), + _c( + "ul", + { ref: "seconds", staticClass: "el-time-spinner__list" }, + _vm._l(_vm.arrowSecondList, function(second, key) { + return _c( + "li", + { + key: key, + staticClass: "el-time-spinner__item", + class: { active: second === _vm.seconds } + }, + [ + _vm._v( + "\n " + + _vm._s( + second === undefined + ? "" + : ("0" + second).slice(-2) + ) + + "\n " + ) + ] + ) + }), + 0 + ) + ] + ) + : _vm._e() + ] + : _vm._e() + ], + 2 + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/date-picker/src/basic/time-spinner.vue?vue&type=template&id=1facadeb& + +// EXTERNAL MODULE: external "element-ui/lib/utils/date-util" +var date_util_ = __webpack_require__(1); + +// EXTERNAL MODULE: external "element-ui/lib/scrollbar" +var scrollbar_ = __webpack_require__(15); +var scrollbar_default = /*#__PURE__*/__webpack_require__.n(scrollbar_); + +// EXTERNAL MODULE: ./src/directives/repeat-click.js +var repeat_click = __webpack_require__(30); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/time-spinner.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + +/* harmony default export */ var time_spinnervue_type_script_lang_js_ = ({ + components: { ElScrollbar: scrollbar_default.a }, + + directives: { + repeatClick: repeat_click["a" /* default */] + }, + + props: { + date: {}, + defaultValue: {}, // reserved for future use + showSeconds: { + type: Boolean, + default: true + }, + arrowControl: Boolean, + amPmMode: { + type: String, + default: '' // 'a': am/pm; 'A': AM/PM + } + }, + + computed: { + hours: function hours() { + return this.date.getHours(); + }, + minutes: function minutes() { + return this.date.getMinutes(); + }, + seconds: function seconds() { + return this.date.getSeconds(); + }, + hoursList: function hoursList() { + return Object(date_util_["getRangeHours"])(this.selectableRange); + }, + minutesList: function minutesList() { + return Object(date_util_["getRangeMinutes"])(this.selectableRange, this.hours); + }, + arrowHourList: function arrowHourList() { + var hours = this.hours; + return [hours > 0 ? hours - 1 : undefined, hours, hours < 23 ? hours + 1 : undefined]; + }, + arrowMinuteList: function arrowMinuteList() { + var minutes = this.minutes; + return [minutes > 0 ? minutes - 1 : undefined, minutes, minutes < 59 ? minutes + 1 : undefined]; + }, + arrowSecondList: function arrowSecondList() { + var seconds = this.seconds; + return [seconds > 0 ? seconds - 1 : undefined, seconds, seconds < 59 ? seconds + 1 : undefined]; + } + }, + + data: function data() { + return { + selectableRange: [], + currentScrollbar: null + }; + }, + mounted: function mounted() { + var _this = this; + + this.$nextTick(function () { + !_this.arrowControl && _this.bindScrollEvent(); + }); + }, + + + methods: { + increase: function increase() { + this.scrollDown(1); + }, + decrease: function decrease() { + this.scrollDown(-1); + }, + modifyDateField: function modifyDateField(type, value) { + switch (type) { + case 'hours': + this.$emit('change', Object(date_util_["modifyTime"])(this.date, value, this.minutes, this.seconds));break; + case 'minutes': + this.$emit('change', Object(date_util_["modifyTime"])(this.date, this.hours, value, this.seconds));break; + case 'seconds': + this.$emit('change', Object(date_util_["modifyTime"])(this.date, this.hours, this.minutes, value));break; + } + }, + handleClick: function handleClick(type, _ref) { + var value = _ref.value, + disabled = _ref.disabled; + + if (!disabled) { + this.modifyDateField(type, value); + this.emitSelectRange(type); + this.adjustSpinner(type, value); + } + }, + emitSelectRange: function emitSelectRange(type) { + if (type === 'hours') { + this.$emit('select-range', 0, 2); + } else if (type === 'minutes') { + this.$emit('select-range', 3, 5); + } else if (type === 'seconds') { + this.$emit('select-range', 6, 8); + } + this.currentScrollbar = type; + }, + bindScrollEvent: function bindScrollEvent() { + var _this2 = this; + + var bindFunction = function bindFunction(type) { + _this2.$refs[type].wrap.onscroll = function (e) { + // TODO: scroll is emitted when set scrollTop programatically + // should find better solutions in the future! + _this2.handleScroll(type, e); + }; + }; + bindFunction('hours'); + bindFunction('minutes'); + bindFunction('seconds'); + }, + handleScroll: function handleScroll(type) { + var value = Math.min(Math.round((this.$refs[type].wrap.scrollTop - (this.scrollBarHeight(type) * 0.5 - 10) / this.typeItemHeight(type) + 3) / this.typeItemHeight(type)), type === 'hours' ? 23 : 59); + this.modifyDateField(type, value); + }, + + + // NOTE: used by datetime / date-range panel + // renamed from adjustScrollTop + // should try to refactory it + adjustSpinners: function adjustSpinners() { + this.adjustSpinner('hours', this.hours); + this.adjustSpinner('minutes', this.minutes); + this.adjustSpinner('seconds', this.seconds); + }, + adjustCurrentSpinner: function adjustCurrentSpinner(type) { + this.adjustSpinner(type, this[type]); + }, + adjustSpinner: function adjustSpinner(type, value) { + if (this.arrowControl) return; + var el = this.$refs[type].wrap; + if (el) { + el.scrollTop = Math.max(0, value * this.typeItemHeight(type)); + } + }, + scrollDown: function scrollDown(step) { + var _this3 = this; + + if (!this.currentScrollbar) { + this.emitSelectRange('hours'); + } + + var label = this.currentScrollbar; + var hoursList = this.hoursList; + var now = this[label]; + + if (this.currentScrollbar === 'hours') { + var total = Math.abs(step); + step = step > 0 ? 1 : -1; + var length = hoursList.length; + while (length-- && total) { + now = (now + step + hoursList.length) % hoursList.length; + if (hoursList[now]) { + continue; + } + total--; + } + if (hoursList[now]) return; + } else { + now = (now + step + 60) % 60; + } + + this.modifyDateField(label, now); + this.adjustSpinner(label, now); + this.$nextTick(function () { + return _this3.emitSelectRange(_this3.currentScrollbar); + }); + }, + amPm: function amPm(hour) { + var shouldShowAmPm = this.amPmMode.toLowerCase() === 'a'; + if (!shouldShowAmPm) return ''; + var isCapital = this.amPmMode === 'A'; + var content = hour < 12 ? ' am' : ' pm'; + if (isCapital) content = content.toUpperCase(); + return content; + }, + typeItemHeight: function typeItemHeight(type) { + return this.$refs[type].$el.querySelector('li').offsetHeight; + }, + scrollBarHeight: function scrollBarHeight(type) { + return this.$refs[type].$el.offsetHeight; + } + } +}); +// CONCATENATED MODULE: ./packages/date-picker/src/basic/time-spinner.vue?vue&type=script&lang=js& + /* harmony default export */ var basic_time_spinnervue_type_script_lang_js_ = (time_spinnervue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/date-picker/src/basic/time-spinner.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + basic_time_spinnervue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/date-picker/src/basic/time-spinner.vue" +/* harmony default export */ var time_spinner = __webpack_exports__["a"] = (component.exports); + +/***/ }), +/* 35 */, +/* 36 */, +/* 37 */, +/* 38 */, +/* 39 */, +/* 40 */, +/* 41 */, +/* 42 */, +/* 43 */, +/* 44 */, +/* 45 */, +/* 46 */, +/* 47 */, +/* 48 */, +/* 49 */, +/* 50 */, +/* 51 */, +/* 52 */, +/* 53 */, +/* 54 */, +/* 55 */, +/* 56 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// EXTERNAL MODULE: ./packages/date-picker/src/picker.vue + 4 modules +var picker = __webpack_require__(32); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/date.vue?vue&type=template&id=2440d4ea& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "transition", + { + attrs: { name: "el-zoom-in-top" }, + on: { "after-enter": _vm.handleEnter, "after-leave": _vm.handleLeave } + }, + [ + _c( + "div", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.visible, + expression: "visible" + } + ], + staticClass: "el-picker-panel el-date-picker el-popper", + class: [ + { + "has-sidebar": _vm.$slots.sidebar || _vm.shortcuts, + "has-time": _vm.showTime + }, + _vm.popperClass + ] + }, + [ + _c( + "div", + { staticClass: "el-picker-panel__body-wrapper" }, + [ + _vm._t("sidebar"), + _vm.shortcuts + ? _c( + "div", + { staticClass: "el-picker-panel__sidebar" }, + _vm._l(_vm.shortcuts, function(shortcut, key) { + return _c( + "button", + { + key: key, + staticClass: "el-picker-panel__shortcut", + attrs: { type: "button" }, + on: { + click: function($event) { + _vm.handleShortcutClick(shortcut) + } + } + }, + [_vm._v(_vm._s(shortcut.text))] + ) + }), + 0 + ) + : _vm._e(), + _c("div", { staticClass: "el-picker-panel__body" }, [ + _vm.showTime + ? _c("div", { staticClass: "el-date-picker__time-header" }, [ + _c( + "span", + { staticClass: "el-date-picker__editor-wrap" }, + [ + _c("el-input", { + attrs: { + placeholder: _vm.t("el.datepicker.selectDate"), + value: _vm.visibleDate, + size: "small" + }, + on: { + input: function(val) { + return (_vm.userInputDate = val) + }, + change: _vm.handleVisibleDateChange + } + }) + ], + 1 + ), + _c( + "span", + { + directives: [ + { + name: "clickoutside", + rawName: "v-clickoutside", + value: _vm.handleTimePickClose, + expression: "handleTimePickClose" + } + ], + staticClass: "el-date-picker__editor-wrap" + }, + [ + _c("el-input", { + ref: "input", + attrs: { + placeholder: _vm.t("el.datepicker.selectTime"), + value: _vm.visibleTime, + size: "small" + }, + on: { + focus: function($event) { + _vm.timePickerVisible = true + }, + input: function(val) { + return (_vm.userInputTime = val) + }, + change: _vm.handleVisibleTimeChange + } + }), + _c("time-picker", { + ref: "timepicker", + attrs: { + "time-arrow-control": _vm.arrowControl, + visible: _vm.timePickerVisible + }, + on: { + pick: _vm.handleTimePick, + mounted: _vm.proxyTimePickerDataProperties + } + }) + ], + 1 + ) + ]) + : _vm._e(), + _c( + "div", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.currentView !== "time", + expression: "currentView !== 'time'" + } + ], + staticClass: "el-date-picker__header", + class: { + "el-date-picker__header--bordered": + _vm.currentView === "year" || + _vm.currentView === "month" + } + }, + [ + _c("button", { + staticClass: + "el-picker-panel__icon-btn el-date-picker__prev-btn el-icon-d-arrow-left", + attrs: { + type: "button", + "aria-label": _vm.t("el.datepicker.prevYear") + }, + on: { click: _vm.prevYear } + }), + _c("button", { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.currentView === "date", + expression: "currentView === 'date'" + } + ], + staticClass: + "el-picker-panel__icon-btn el-date-picker__prev-btn el-icon-arrow-left", + attrs: { + type: "button", + "aria-label": _vm.t("el.datepicker.prevMonth") + }, + on: { click: _vm.prevMonth } + }), + _c( + "span", + { + staticClass: "el-date-picker__header-label", + attrs: { role: "button" }, + on: { click: _vm.showYearPicker } + }, + [_vm._v(_vm._s(_vm.yearLabel))] + ), + _c( + "span", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.currentView === "date", + expression: "currentView === 'date'" + } + ], + staticClass: "el-date-picker__header-label", + class: { active: _vm.currentView === "month" }, + attrs: { role: "button" }, + on: { click: _vm.showMonthPicker } + }, + [ + _vm._v( + _vm._s(_vm.t("el.datepicker.month" + (_vm.month + 1))) + ) + ] + ), + _c("button", { + staticClass: + "el-picker-panel__icon-btn el-date-picker__next-btn el-icon-d-arrow-right", + attrs: { + type: "button", + "aria-label": _vm.t("el.datepicker.nextYear") + }, + on: { click: _vm.nextYear } + }), + _c("button", { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.currentView === "date", + expression: "currentView === 'date'" + } + ], + staticClass: + "el-picker-panel__icon-btn el-date-picker__next-btn el-icon-arrow-right", + attrs: { + type: "button", + "aria-label": _vm.t("el.datepicker.nextMonth") + }, + on: { click: _vm.nextMonth } + }) + ] + ), + _c( + "div", + { staticClass: "el-picker-panel__content" }, + [ + _c("date-table", { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.currentView === "date", + expression: "currentView === 'date'" + } + ], + attrs: { + "selection-mode": _vm.selectionMode, + "first-day-of-week": _vm.firstDayOfWeek, + value: _vm.value, + "default-value": _vm.defaultValue + ? new Date(_vm.defaultValue) + : null, + date: _vm.date, + "cell-class-name": _vm.cellClassName, + "disabled-date": _vm.disabledDate + }, + on: { pick: _vm.handleDatePick } + }), + _c("year-table", { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.currentView === "year", + expression: "currentView === 'year'" + } + ], + attrs: { + "selection-mode": _vm.selectionMode, + value: _vm.value, + "default-value": _vm.defaultValue + ? new Date(_vm.defaultValue) + : null, + date: _vm.date, + "disabled-date": _vm.disabledDate + }, + on: { pick: _vm.handleYearPick } + }), + _c("month-table", { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.currentView === "month", + expression: "currentView === 'month'" + } + ], + attrs: { + "selection-mode": _vm.selectionMode, + value: _vm.value, + "default-value": _vm.defaultValue + ? new Date(_vm.defaultValue) + : null, + date: _vm.date, + "disabled-date": _vm.disabledDate + }, + on: { pick: _vm.handleMonthPick } + }) + ], + 1 + ) + ]) + ], + 2 + ), + _c( + "div", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: + _vm.footerVisible && + (_vm.currentView === "date" || + _vm.currentView === "month" || + _vm.currentView === "year"), + expression: + "footerVisible && (currentView === 'date' || currentView === 'month' || currentView === 'year')" + } + ], + staticClass: "el-picker-panel__footer" + }, + [ + _c( + "el-button", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: + _vm.selectionMode !== "dates" && + _vm.selectionMode !== "months" && + _vm.selectionMode !== "years", + expression: + "selectionMode !== 'dates' && selectionMode !== 'months' && selectionMode !== 'years'" + } + ], + staticClass: "el-picker-panel__link-btn", + attrs: { size: "mini", type: "text" }, + on: { click: _vm.changeToNow } + }, + [ + _vm._v( + "\n " + + _vm._s(_vm.t("el.datepicker.now")) + + "\n " + ) + ] + ), + _c( + "el-button", + { + staticClass: "el-picker-panel__link-btn", + attrs: { plain: "", size: "mini" }, + on: { click: _vm.confirm } + }, + [ + _vm._v( + "\n " + + _vm._s(_vm.t("el.datepicker.confirm")) + + "\n " + ) + ] + ) + ], + 1 + ) + ] + ) + ] + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/date-picker/src/panel/date.vue?vue&type=template&id=2440d4ea& + +// EXTERNAL MODULE: external "element-ui/lib/utils/date-util" +var date_util_ = __webpack_require__(1); + +// EXTERNAL MODULE: external "element-ui/lib/utils/clickoutside" +var clickoutside_ = __webpack_require__(12); +var clickoutside_default = /*#__PURE__*/__webpack_require__.n(clickoutside_); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/locale" +var locale_ = __webpack_require__(6); +var locale_default = /*#__PURE__*/__webpack_require__.n(locale_); + +// EXTERNAL MODULE: external "element-ui/lib/input" +var input_ = __webpack_require__(10); +var input_default = /*#__PURE__*/__webpack_require__.n(input_); + +// EXTERNAL MODULE: external "element-ui/lib/button" +var button_ = __webpack_require__(14); +var button_default = /*#__PURE__*/__webpack_require__.n(button_); + +// EXTERNAL MODULE: ./packages/date-picker/src/panel/time.vue + 4 modules +var panel_time = __webpack_require__(27); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/year-table.vue?vue&type=template&id=c86ab5e0& +var year_tablevue_type_template_id_c86ab5e0_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "table", + { staticClass: "el-year-table", on: { click: _vm.handleYearTableClick } }, + [ + _c("tbody", [ + _c("tr", [ + _c( + "td", + { + staticClass: "available", + class: _vm.getCellStyle(_vm.startYear + 0) + }, + [_c("a", { staticClass: "cell" }, [_vm._v(_vm._s(_vm.startYear))])] + ), + _c( + "td", + { + staticClass: "available", + class: _vm.getCellStyle(_vm.startYear + 1) + }, + [ + _c("a", { staticClass: "cell" }, [ + _vm._v(_vm._s(_vm.startYear + 1)) + ]) + ] + ), + _c( + "td", + { + staticClass: "available", + class: _vm.getCellStyle(_vm.startYear + 2) + }, + [ + _c("a", { staticClass: "cell" }, [ + _vm._v(_vm._s(_vm.startYear + 2)) + ]) + ] + ), + _c( + "td", + { + staticClass: "available", + class: _vm.getCellStyle(_vm.startYear + 3) + }, + [ + _c("a", { staticClass: "cell" }, [ + _vm._v(_vm._s(_vm.startYear + 3)) + ]) + ] + ) + ]), + _c("tr", [ + _c( + "td", + { + staticClass: "available", + class: _vm.getCellStyle(_vm.startYear + 4) + }, + [ + _c("a", { staticClass: "cell" }, [ + _vm._v(_vm._s(_vm.startYear + 4)) + ]) + ] + ), + _c( + "td", + { + staticClass: "available", + class: _vm.getCellStyle(_vm.startYear + 5) + }, + [ + _c("a", { staticClass: "cell" }, [ + _vm._v(_vm._s(_vm.startYear + 5)) + ]) + ] + ), + _c( + "td", + { + staticClass: "available", + class: _vm.getCellStyle(_vm.startYear + 6) + }, + [ + _c("a", { staticClass: "cell" }, [ + _vm._v(_vm._s(_vm.startYear + 6)) + ]) + ] + ), + _c( + "td", + { + staticClass: "available", + class: _vm.getCellStyle(_vm.startYear + 7) + }, + [ + _c("a", { staticClass: "cell" }, [ + _vm._v(_vm._s(_vm.startYear + 7)) + ]) + ] + ) + ]), + _c("tr", [ + _c( + "td", + { + staticClass: "available", + class: _vm.getCellStyle(_vm.startYear + 8) + }, + [ + _c("a", { staticClass: "cell" }, [ + _vm._v(_vm._s(_vm.startYear + 8)) + ]) + ] + ), + _c( + "td", + { + staticClass: "available", + class: _vm.getCellStyle(_vm.startYear + 9) + }, + [ + _c("a", { staticClass: "cell" }, [ + _vm._v(_vm._s(_vm.startYear + 9)) + ]) + ] + ), + _c("td"), + _c("td") + ]) + ]) + ] + ) +} +var year_tablevue_type_template_id_c86ab5e0_staticRenderFns = [] +year_tablevue_type_template_id_c86ab5e0_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/date-picker/src/basic/year-table.vue?vue&type=template&id=c86ab5e0& + +// EXTERNAL MODULE: external "element-ui/lib/utils/dom" +var dom_ = __webpack_require__(2); + +// EXTERNAL MODULE: external "element-ui/lib/utils/util" +var util_ = __webpack_require__(3); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/year-table.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + +var year_tablevue_type_script_lang_js_datesInYear = function datesInYear(year) { + var numOfDays = Object(date_util_["getDayCountOfYear"])(year); + var firstDay = new Date(year, 0, 1); + return Object(date_util_["range"])(numOfDays).map(function (n) { + return Object(date_util_["nextDate"])(firstDay, n); + }); +}; + +/* harmony default export */ var year_tablevue_type_script_lang_js_ = ({ + props: { + disabledDate: {}, + value: {}, + defaultValue: { + validator: function validator(val) { + // null or valid Date Object + return val === null || val instanceof Date && Object(date_util_["isDate"])(val); + } + }, + date: {}, + selectionMode: {} + }, + + computed: { + startYear: function startYear() { + return Math.floor(this.date.getFullYear() / 10) * 10; + } + }, + + methods: { + getCellStyle: function getCellStyle(year) { + var style = {}; + var today = new Date(); + + style.disabled = typeof this.disabledDate === 'function' ? year_tablevue_type_script_lang_js_datesInYear(year).every(this.disabledDate) : false; + style.current = Object(util_["arrayFindIndex"])(Object(util_["coerceTruthyValueToArray"])(this.value), function (date) { + return date.getFullYear() === year; + }) >= 0; + style.today = today.getFullYear() === year; + style.default = this.defaultValue && this.defaultValue.getFullYear() === year; + + return style; + }, + handleYearTableClick: function handleYearTableClick(event) { + var target = event.target; + if (target.tagName === 'A') { + if (Object(dom_["hasClass"])(target.parentNode, 'disabled')) return; + var year = target.textContent || target.innerText; + if (this.selectionMode === 'years') { + var value = this.value || []; + var idx = Object(util_["arrayFindIndex"])(value, function (date) { + return date.getFullYear() === Number(year); + }); + var newValue = idx > -1 ? [].concat(value.slice(0, idx), value.slice(idx + 1)) : [].concat(value, [new Date(year)]); + this.$emit('pick', newValue); + } else { + this.$emit('pick', Number(year)); + } + } + } + } +}); +// CONCATENATED MODULE: ./packages/date-picker/src/basic/year-table.vue?vue&type=script&lang=js& + /* harmony default export */ var basic_year_tablevue_type_script_lang_js_ = (year_tablevue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/date-picker/src/basic/year-table.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + basic_year_tablevue_type_script_lang_js_, + year_tablevue_type_template_id_c86ab5e0_render, + year_tablevue_type_template_id_c86ab5e0_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/date-picker/src/basic/year-table.vue" +/* harmony default export */ var year_table = (component.exports); +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/month-table.vue?vue&type=template&id=654d4f42& +var month_tablevue_type_template_id_654d4f42_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "table", + { + staticClass: "el-month-table", + on: { click: _vm.handleMonthTableClick, mousemove: _vm.handleMouseMove } + }, + [ + _c( + "tbody", + _vm._l(_vm.rows, function(row, key) { + return _c( + "tr", + { key: key }, + _vm._l(row, function(cell, key) { + return _c("td", { key: key, class: _vm.getCellStyle(cell) }, [ + _c("div", [ + _c("a", { staticClass: "cell" }, [ + _vm._v( + _vm._s( + _vm.t("el.datepicker.months." + _vm.months[cell.text]) + ) + ) + ]) + ]) + ]) + }), + 0 + ) + }), + 0 + ) + ] + ) +} +var month_tablevue_type_template_id_654d4f42_staticRenderFns = [] +month_tablevue_type_template_id_654d4f42_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/date-picker/src/basic/month-table.vue?vue&type=template&id=654d4f42& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/month-table.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + + +var month_tablevue_type_script_lang_js_datesInMonth = function datesInMonth(year, month) { + var numOfDays = Object(date_util_["getDayCountOfMonth"])(year, month); + var firstDay = new Date(year, month, 1); + return Object(date_util_["range"])(numOfDays).map(function (n) { + return Object(date_util_["nextDate"])(firstDay, n); + }); +}; + +var clearDate = function clearDate(date) { + return new Date(date.getFullYear(), date.getMonth()); +}; + +var getMonthTimestamp = function getMonthTimestamp(time) { + if (typeof time === 'number' || typeof time === 'string') { + return clearDate(new Date(time)).getTime(); + } else if (time instanceof Date) { + return clearDate(time).getTime(); + } else { + return NaN; + } +}; + +// remove the first element that satisfies `pred` from arr +// return a new array if modification occurs +// return the original array otherwise +var month_tablevue_type_script_lang_js_removeFromArray = function removeFromArray(arr, pred) { + var idx = typeof pred === 'function' ? Object(util_["arrayFindIndex"])(arr, pred) : arr.indexOf(pred); + return idx >= 0 ? [].concat(arr.slice(0, idx), arr.slice(idx + 1)) : arr; +}; +/* harmony default export */ var month_tablevue_type_script_lang_js_ = ({ + props: { + disabledDate: {}, + value: {}, + selectionMode: { + default: 'month' + }, + minDate: {}, + + maxDate: {}, + defaultValue: { + validator: function validator(val) { + // null or valid Date Object + return val === null || Object(date_util_["isDate"])(val) || Array.isArray(val) && val.every(date_util_["isDate"]); + } + }, + date: {}, + rangeState: { + default: function _default() { + return { + endDate: null, + selecting: false + }; + } + } + }, + + mixins: [locale_default.a], + + watch: { + 'rangeState.endDate': function rangeStateEndDate(newVal) { + this.markRange(this.minDate, newVal); + }, + minDate: function minDate(newVal, oldVal) { + if (getMonthTimestamp(newVal) !== getMonthTimestamp(oldVal)) { + this.markRange(this.minDate, this.maxDate); + } + }, + maxDate: function maxDate(newVal, oldVal) { + if (getMonthTimestamp(newVal) !== getMonthTimestamp(oldVal)) { + this.markRange(this.minDate, this.maxDate); + } + } + }, + + data: function data() { + return { + months: ['jan', 'feb', 'mar', 'apr', 'may', 'jun', 'jul', 'aug', 'sep', 'oct', 'nov', 'dec'], + tableRows: [[], [], []], + lastRow: null, + lastColumn: null + }; + }, + + + methods: { + cellMatchesDate: function cellMatchesDate(cell, date) { + var value = new Date(date); + return this.date.getFullYear() === value.getFullYear() && Number(cell.text) === value.getMonth(); + }, + getCellStyle: function getCellStyle(cell) { + var _this = this; + + var style = {}; + var year = this.date.getFullYear(); + var today = new Date(); + var month = cell.text; + var defaultValue = this.defaultValue ? Array.isArray(this.defaultValue) ? this.defaultValue : [this.defaultValue] : []; + style.disabled = typeof this.disabledDate === 'function' ? month_tablevue_type_script_lang_js_datesInMonth(year, month).every(this.disabledDate) : false; + style.current = Object(util_["arrayFindIndex"])(Object(util_["coerceTruthyValueToArray"])(this.value), function (date) { + return date.getFullYear() === year && date.getMonth() === month; + }) >= 0; + style.today = today.getFullYear() === year && today.getMonth() === month; + style.default = defaultValue.some(function (date) { + return _this.cellMatchesDate(cell, date); + }); + + if (cell.inRange) { + style['in-range'] = true; + + if (cell.start) { + style['start-date'] = true; + } + + if (cell.end) { + style['end-date'] = true; + } + } + return style; + }, + getMonthOfCell: function getMonthOfCell(month) { + var year = this.date.getFullYear(); + return new Date(year, month, 1); + }, + markRange: function markRange(minDate, maxDate) { + minDate = getMonthTimestamp(minDate); + maxDate = getMonthTimestamp(maxDate) || minDate; + var _ref = [Math.min(minDate, maxDate), Math.max(minDate, maxDate)]; + minDate = _ref[0]; + maxDate = _ref[1]; + + var rows = this.rows; + for (var i = 0, k = rows.length; i < k; i++) { + var row = rows[i]; + for (var j = 0, l = row.length; j < l; j++) { + + var cell = row[j]; + var index = i * 4 + j; + var time = new Date(this.date.getFullYear(), index).getTime(); + + cell.inRange = minDate && time >= minDate && time <= maxDate; + cell.start = minDate && time === minDate; + cell.end = maxDate && time === maxDate; + } + } + }, + handleMouseMove: function handleMouseMove(event) { + if (!this.rangeState.selecting) return; + + var target = event.target; + if (target.tagName === 'A') { + target = target.parentNode.parentNode; + } + if (target.tagName === 'DIV') { + target = target.parentNode; + } + if (target.tagName !== 'TD') return; + + var row = target.parentNode.rowIndex; + var column = target.cellIndex; + // can not select disabled date + if (this.rows[row][column].disabled) return; + + // only update rangeState when mouse moves to a new cell + // this avoids frequent Date object creation and improves performance + if (row !== this.lastRow || column !== this.lastColumn) { + this.lastRow = row; + this.lastColumn = column; + this.$emit('changerange', { + minDate: this.minDate, + maxDate: this.maxDate, + rangeState: { + selecting: true, + endDate: this.getMonthOfCell(row * 4 + column) + } + }); + } + }, + handleMonthTableClick: function handleMonthTableClick(event) { + var target = event.target; + if (target.tagName === 'A') { + target = target.parentNode.parentNode; + } + if (target.tagName === 'DIV') { + target = target.parentNode; + } + if (target.tagName !== 'TD') return; + if (Object(dom_["hasClass"])(target, 'disabled')) return; + var column = target.cellIndex; + var row = target.parentNode.rowIndex; + var month = row * 4 + column; + var newDate = this.getMonthOfCell(month); + if (this.selectionMode === 'range') { + if (!this.rangeState.selecting) { + this.$emit('pick', { minDate: newDate, maxDate: null }); + this.rangeState.selecting = true; + } else { + if (newDate >= this.minDate) { + this.$emit('pick', { minDate: this.minDate, maxDate: newDate }); + } else { + this.$emit('pick', { minDate: newDate, maxDate: this.minDate }); + } + this.rangeState.selecting = false; + } + } else if (this.selectionMode === 'months') { + var value = this.value || []; + var year = this.date.getFullYear(); + var newValue = Object(util_["arrayFindIndex"])(value, function (date) { + return date.getFullYear() === year && date.getMonth() === month; + }) >= 0 ? month_tablevue_type_script_lang_js_removeFromArray(value, function (date) { + return date.getTime() === newDate.getTime(); + }) : [].concat(value, [newDate]); + this.$emit('pick', newValue); + } else { + this.$emit('pick', month); + } + } + }, + + computed: { + rows: function rows() { + var _this2 = this; + + // TODO: refactory rows / getCellClasses + var rows = this.tableRows; + var disabledDate = this.disabledDate; + var selectedDate = []; + var now = getMonthTimestamp(new Date()); + + for (var i = 0; i < 3; i++) { + var row = rows[i]; + + var _loop = function _loop(j) { + var cell = row[j]; + if (!cell) { + cell = { row: i, column: j, type: 'normal', inRange: false, start: false, end: false }; + } + + cell.type = 'normal'; + + var index = i * 4 + j; + var time = new Date(_this2.date.getFullYear(), index).getTime(); + cell.inRange = time >= getMonthTimestamp(_this2.minDate) && time <= getMonthTimestamp(_this2.maxDate); + cell.start = _this2.minDate && time === getMonthTimestamp(_this2.minDate); + cell.end = _this2.maxDate && time === getMonthTimestamp(_this2.maxDate); + var isToday = time === now; + + if (isToday) { + cell.type = 'today'; + } + cell.text = index; + var cellDate = new Date(time); + cell.disabled = typeof disabledDate === 'function' && disabledDate(cellDate); + cell.selected = Object(util_["arrayFind"])(selectedDate, function (date) { + return date.getTime() === cellDate.getTime(); + }); + + _this2.$set(row, j, cell); + }; + + for (var j = 0; j < 4; j++) { + _loop(j); + } + } + return rows; + } + } +}); +// CONCATENATED MODULE: ./packages/date-picker/src/basic/month-table.vue?vue&type=script&lang=js& + /* harmony default export */ var basic_month_tablevue_type_script_lang_js_ = (month_tablevue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/date-picker/src/basic/month-table.vue + + + + + +/* normalize component */ + +var month_table_component = Object(componentNormalizer["a" /* default */])( + basic_month_tablevue_type_script_lang_js_, + month_tablevue_type_template_id_654d4f42_render, + month_tablevue_type_template_id_654d4f42_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var month_table_api; } +month_table_component.options.__file = "packages/date-picker/src/basic/month-table.vue" +/* harmony default export */ var month_table = (month_table_component.exports); +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/date-table.vue?vue&type=template&id=5d1f3341& +var date_tablevue_type_template_id_5d1f3341_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "table", + { + staticClass: "el-date-table", + class: { "is-week-mode": _vm.selectionMode === "week" }, + attrs: { cellspacing: "0", cellpadding: "0" }, + on: { click: _vm.handleClick, mousemove: _vm.handleMouseMove } + }, + [ + _c( + "tbody", + [ + _c( + "tr", + [ + _vm.showWeekNumber + ? _c("th", [_vm._v(_vm._s(_vm.t("el.datepicker.week")))]) + : _vm._e(), + _vm._l(_vm.WEEKS, function(week, key) { + return _c("th", { key: key }, [ + _vm._v(_vm._s(_vm.t("el.datepicker.weeks." + week))) + ]) + }) + ], + 2 + ), + _vm._l(_vm.rows, function(row, key) { + return _c( + "tr", + { + key: key, + staticClass: "el-date-table__row", + class: { current: _vm.isWeekActive(row[1]) } + }, + _vm._l(row, function(cell, key) { + return _c("td", { key: key, class: _vm.getCellClasses(cell) }, [ + _c("div", [ + _c("span", [ + _vm._v("\n " + _vm._s(cell.text) + "\n ") + ]) + ]) + ]) + }), + 0 + ) + }) + ], + 2 + ) + ] + ) +} +var date_tablevue_type_template_id_5d1f3341_staticRenderFns = [] +date_tablevue_type_template_id_5d1f3341_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/date-picker/src/basic/date-table.vue?vue&type=template&id=5d1f3341& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/date-table.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + +var _WEEKS = ['sun', 'mon', 'tue', 'wed', 'thu', 'fri', 'sat']; +var date_tablevue_type_script_lang_js_getDateTimestamp = function getDateTimestamp(time) { + if (typeof time === 'number' || typeof time === 'string') { + return Object(date_util_["clearTime"])(new Date(time)).getTime(); + } else if (time instanceof Date) { + return Object(date_util_["clearTime"])(time).getTime(); + } else { + return NaN; + } +}; + +// remove the first element that satisfies `pred` from arr +// return a new array if modification occurs +// return the original array otherwise +var date_tablevue_type_script_lang_js_removeFromArray = function removeFromArray(arr, pred) { + var idx = typeof pred === 'function' ? Object(util_["arrayFindIndex"])(arr, pred) : arr.indexOf(pred); + return idx >= 0 ? [].concat(arr.slice(0, idx), arr.slice(idx + 1)) : arr; +}; + +/* harmony default export */ var date_tablevue_type_script_lang_js_ = ({ + mixins: [locale_default.a], + + props: { + firstDayOfWeek: { + default: 7, + type: Number, + validator: function validator(val) { + return val >= 1 && val <= 7; + } + }, + + value: {}, + + defaultValue: { + validator: function validator(val) { + // either: null, valid Date object, Array of valid Date objects + return val === null || Object(date_util_["isDate"])(val) || Array.isArray(val) && val.every(date_util_["isDate"]); + } + }, + + date: {}, + + selectionMode: { + default: 'day' + }, + + showWeekNumber: { + type: Boolean, + default: false + }, + + disabledDate: {}, + + cellClassName: {}, + + minDate: {}, + + maxDate: {}, + + rangeState: { + default: function _default() { + return { + endDate: null, + selecting: false + }; + } + } + }, + + computed: { + offsetDay: function offsetDay() { + var week = this.firstDayOfWeek; + // 周日为界限,左右偏移的天数,3217654 例如周一就是 -1,目的是调整前两行日期的位置 + return week > 3 ? 7 - week : -week; + }, + WEEKS: function WEEKS() { + var week = this.firstDayOfWeek; + return _WEEKS.concat(_WEEKS).slice(week, week + 7); + }, + year: function year() { + return this.date.getFullYear(); + }, + month: function month() { + return this.date.getMonth(); + }, + startDate: function startDate() { + return Object(date_util_["getStartDateOfMonth"])(this.year, this.month); + }, + rows: function rows() { + var _this = this; + + // TODO: refactory rows / getCellClasses + var date = new Date(this.year, this.month, 1); + var day = Object(date_util_["getFirstDayOfMonth"])(date); // day of first day + var dateCountOfMonth = Object(date_util_["getDayCountOfMonth"])(date.getFullYear(), date.getMonth()); + var dateCountOfLastMonth = Object(date_util_["getDayCountOfMonth"])(date.getFullYear(), date.getMonth() === 0 ? 11 : date.getMonth() - 1); + + day = day === 0 ? 7 : day; + + var offset = this.offsetDay; + var rows = this.tableRows; + var count = 1; + + var startDate = this.startDate; + var disabledDate = this.disabledDate; + var cellClassName = this.cellClassName; + var selectedDate = this.selectionMode === 'dates' ? Object(util_["coerceTruthyValueToArray"])(this.value) : []; + var now = date_tablevue_type_script_lang_js_getDateTimestamp(new Date()); + + for (var i = 0; i < 6; i++) { + var row = rows[i]; + + if (this.showWeekNumber) { + if (!row[0]) { + row[0] = { type: 'week', text: Object(date_util_["getWeekNumber"])(Object(date_util_["nextDate"])(startDate, i * 7 + 1)) }; + } + } + + var _loop = function _loop(j) { + var cell = row[_this.showWeekNumber ? j + 1 : j]; + if (!cell) { + cell = { row: i, column: j, type: 'normal', inRange: false, start: false, end: false }; + } + + cell.type = 'normal'; + + var index = i * 7 + j; + var time = Object(date_util_["nextDate"])(startDate, index - offset).getTime(); + cell.inRange = time >= date_tablevue_type_script_lang_js_getDateTimestamp(_this.minDate) && time <= date_tablevue_type_script_lang_js_getDateTimestamp(_this.maxDate); + cell.start = _this.minDate && time === date_tablevue_type_script_lang_js_getDateTimestamp(_this.minDate); + cell.end = _this.maxDate && time === date_tablevue_type_script_lang_js_getDateTimestamp(_this.maxDate); + var isToday = time === now; + + if (isToday) { + cell.type = 'today'; + } + + if (i >= 0 && i <= 1) { + var numberOfDaysFromPreviousMonth = day + offset < 0 ? 7 + day + offset : day + offset; + + if (j + i * 7 >= numberOfDaysFromPreviousMonth) { + cell.text = count++; + } else { + cell.text = dateCountOfLastMonth - (numberOfDaysFromPreviousMonth - j % 7) + 1 + i * 7; + cell.type = 'prev-month'; + } + } else { + if (count <= dateCountOfMonth) { + cell.text = count++; + } else { + cell.text = count++ - dateCountOfMonth; + cell.type = 'next-month'; + } + } + + var cellDate = new Date(time); + cell.disabled = typeof disabledDate === 'function' && disabledDate(cellDate); + cell.selected = Object(util_["arrayFind"])(selectedDate, function (date) { + return date.getTime() === cellDate.getTime(); + }); + cell.customClass = typeof cellClassName === 'function' && cellClassName(cellDate); + _this.$set(row, _this.showWeekNumber ? j + 1 : j, cell); + }; + + for (var j = 0; j < 7; j++) { + _loop(j); + } + + if (this.selectionMode === 'week') { + var start = this.showWeekNumber ? 1 : 0; + var end = this.showWeekNumber ? 7 : 6; + var isWeekActive = this.isWeekActive(row[start + 1]); + + row[start].inRange = isWeekActive; + row[start].start = isWeekActive; + row[end].inRange = isWeekActive; + row[end].end = isWeekActive; + } + } + + return rows; + } + }, + + watch: { + 'rangeState.endDate': function rangeStateEndDate(newVal) { + this.markRange(this.minDate, newVal); + }, + minDate: function minDate(newVal, oldVal) { + if (date_tablevue_type_script_lang_js_getDateTimestamp(newVal) !== date_tablevue_type_script_lang_js_getDateTimestamp(oldVal)) { + this.markRange(this.minDate, this.maxDate); + } + }, + maxDate: function maxDate(newVal, oldVal) { + if (date_tablevue_type_script_lang_js_getDateTimestamp(newVal) !== date_tablevue_type_script_lang_js_getDateTimestamp(oldVal)) { + this.markRange(this.minDate, this.maxDate); + } + } + }, + + data: function data() { + return { + tableRows: [[], [], [], [], [], []], + lastRow: null, + lastColumn: null + }; + }, + + + methods: { + cellMatchesDate: function cellMatchesDate(cell, date) { + var value = new Date(date); + return this.year === value.getFullYear() && this.month === value.getMonth() && Number(cell.text) === value.getDate(); + }, + getCellClasses: function getCellClasses(cell) { + var _this2 = this; + + var selectionMode = this.selectionMode; + var defaultValue = this.defaultValue ? Array.isArray(this.defaultValue) ? this.defaultValue : [this.defaultValue] : []; + + var classes = []; + if ((cell.type === 'normal' || cell.type === 'today') && !cell.disabled) { + classes.push('available'); + if (cell.type === 'today') { + classes.push('today'); + } + } else { + classes.push(cell.type); + } + + if (cell.type === 'normal' && defaultValue.some(function (date) { + return _this2.cellMatchesDate(cell, date); + })) { + classes.push('default'); + } + + if (selectionMode === 'day' && (cell.type === 'normal' || cell.type === 'today') && this.cellMatchesDate(cell, this.value)) { + classes.push('current'); + } + + if (cell.inRange && (cell.type === 'normal' || cell.type === 'today' || this.selectionMode === 'week')) { + classes.push('in-range'); + + if (cell.start) { + classes.push('start-date'); + } + + if (cell.end) { + classes.push('end-date'); + } + } + + if (cell.disabled) { + classes.push('disabled'); + } + + if (cell.selected) { + classes.push('selected'); + } + + if (cell.customClass) { + classes.push(cell.customClass); + } + + return classes.join(' '); + }, + getDateOfCell: function getDateOfCell(row, column) { + var offsetFromStart = row * 7 + (column - (this.showWeekNumber ? 1 : 0)) - this.offsetDay; + return Object(date_util_["nextDate"])(this.startDate, offsetFromStart); + }, + isWeekActive: function isWeekActive(cell) { + if (this.selectionMode !== 'week') return false; + var newDate = new Date(this.year, this.month, 1); + var year = newDate.getFullYear(); + var month = newDate.getMonth(); + + if (cell.type === 'prev-month') { + newDate.setMonth(month === 0 ? 11 : month - 1); + newDate.setFullYear(month === 0 ? year - 1 : year); + } + + if (cell.type === 'next-month') { + newDate.setMonth(month === 11 ? 0 : month + 1); + newDate.setFullYear(month === 11 ? year + 1 : year); + } + + newDate.setDate(parseInt(cell.text, 10)); + + if (Object(date_util_["isDate"])(this.value)) { + var dayOffset = (this.value.getDay() - this.firstDayOfWeek + 7) % 7 - 1; + var weekDate = Object(date_util_["prevDate"])(this.value, dayOffset); + return weekDate.getTime() === newDate.getTime(); + } + return false; + }, + markRange: function markRange(minDate, maxDate) { + minDate = date_tablevue_type_script_lang_js_getDateTimestamp(minDate); + maxDate = date_tablevue_type_script_lang_js_getDateTimestamp(maxDate) || minDate; + var _ref = [Math.min(minDate, maxDate), Math.max(minDate, maxDate)]; + minDate = _ref[0]; + maxDate = _ref[1]; + + + var startDate = this.startDate; + var rows = this.rows; + for (var i = 0, k = rows.length; i < k; i++) { + var row = rows[i]; + for (var j = 0, l = row.length; j < l; j++) { + if (this.showWeekNumber && j === 0) continue; + + var _cell = row[j]; + var index = i * 7 + j + (this.showWeekNumber ? -1 : 0); + var time = Object(date_util_["nextDate"])(startDate, index - this.offsetDay).getTime(); + + _cell.inRange = minDate && time >= minDate && time <= maxDate; + _cell.start = minDate && time === minDate; + _cell.end = maxDate && time === maxDate; + } + } + }, + handleMouseMove: function handleMouseMove(event) { + if (!this.rangeState.selecting) return; + + var target = event.target; + if (target.tagName === 'SPAN') { + target = target.parentNode.parentNode; + } + if (target.tagName === 'DIV') { + target = target.parentNode; + } + if (target.tagName !== 'TD') return; + + var row = target.parentNode.rowIndex - 1; + var column = target.cellIndex; + + // can not select disabled date + if (this.rows[row][column].disabled) return; + + // only update rangeState when mouse moves to a new cell + // this avoids frequent Date object creation and improves performance + if (row !== this.lastRow || column !== this.lastColumn) { + this.lastRow = row; + this.lastColumn = column; + this.$emit('changerange', { + minDate: this.minDate, + maxDate: this.maxDate, + rangeState: { + selecting: true, + endDate: this.getDateOfCell(row, column) + } + }); + } + }, + handleClick: function handleClick(event) { + var target = event.target; + if (target.tagName === 'SPAN') { + target = target.parentNode.parentNode; + } + if (target.tagName === 'DIV') { + target = target.parentNode; + } + + if (target.tagName !== 'TD') return; + + var row = target.parentNode.rowIndex - 1; + var column = this.selectionMode === 'week' ? 1 : target.cellIndex; + var cell = this.rows[row][column]; + + if (cell.disabled || cell.type === 'week') return; + + var newDate = this.getDateOfCell(row, column); + + if (this.selectionMode === 'range') { + if (!this.rangeState.selecting) { + this.$emit('pick', { minDate: newDate, maxDate: null }); + this.rangeState.selecting = true; + } else { + if (newDate >= this.minDate) { + this.$emit('pick', { minDate: this.minDate, maxDate: newDate }); + } else { + this.$emit('pick', { minDate: newDate, maxDate: this.minDate }); + } + this.rangeState.selecting = false; + } + } else if (this.selectionMode === 'day') { + this.$emit('pick', newDate); + } else if (this.selectionMode === 'week') { + var weekNumber = Object(date_util_["getWeekNumber"])(newDate); + var value = newDate.getFullYear() + 'w' + weekNumber; + this.$emit('pick', { + year: newDate.getFullYear(), + week: weekNumber, + value: value, + date: newDate + }); + } else if (this.selectionMode === 'dates') { + var _value = this.value || []; + var newValue = cell.selected ? date_tablevue_type_script_lang_js_removeFromArray(_value, function (date) { + return date.getTime() === newDate.getTime(); + }) : [].concat(_value, [newDate]); + this.$emit('pick', newValue); + } + } + } +}); +// CONCATENATED MODULE: ./packages/date-picker/src/basic/date-table.vue?vue&type=script&lang=js& + /* harmony default export */ var basic_date_tablevue_type_script_lang_js_ = (date_tablevue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/date-picker/src/basic/date-table.vue + + + + + +/* normalize component */ + +var date_table_component = Object(componentNormalizer["a" /* default */])( + basic_date_tablevue_type_script_lang_js_, + date_tablevue_type_template_id_5d1f3341_render, + date_tablevue_type_template_id_5d1f3341_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var date_table_api; } +date_table_component.options.__file = "packages/date-picker/src/basic/date-table.vue" +/* harmony default export */ var date_table = (date_table_component.exports); +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/date.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + + + + + + + +/* harmony default export */ var datevue_type_script_lang_js_ = ({ + mixins: [locale_default.a], + + directives: { Clickoutside: clickoutside_default.a }, + + watch: { + showTime: function showTime(val) { + var _this = this; + + /* istanbul ignore if */ + if (!val) return; + this.$nextTick(function (_) { + var inputElm = _this.$refs.input.$el; + if (inputElm) { + _this.pickerWidth = inputElm.getBoundingClientRect().width + 10; + } + }); + }, + value: function value(val) { + if (this.selectionMode === 'dates' && this.value) return; + if (this.selectionMode === 'months' && this.value) return; + if (this.selectionMode === 'years' && this.value) return; + if (Object(date_util_["isDate"])(val)) { + this.date = new Date(val); + } else { + this.date = this.getDefaultValue(); + } + }, + defaultValue: function defaultValue(val) { + if (!Object(date_util_["isDate"])(this.value)) { + this.date = val ? new Date(val) : new Date(); + } + }, + timePickerVisible: function timePickerVisible(val) { + var _this2 = this; + + if (val) this.$nextTick(function () { + return _this2.$refs.timepicker.adjustSpinners(); + }); + }, + selectionMode: function selectionMode(newVal) { + if (newVal === 'month') { + /* istanbul ignore next */ + if (this.currentView !== 'year' || this.currentView !== 'month') { + this.currentView = 'month'; + } + } else if (newVal === 'dates') { + this.currentView = 'date'; + } else if (newVal === 'years') { + this.currentView = 'year'; + } else if (newVal === 'months') { + this.currentView = 'month'; + } + } + }, + + methods: { + proxyTimePickerDataProperties: function proxyTimePickerDataProperties() { + var _this3 = this; + + var format = function format(timeFormat) { + _this3.$refs.timepicker.format = timeFormat; + }; + var value = function value(_value) { + _this3.$refs.timepicker.value = _value; + }; + var date = function date(_date) { + _this3.$refs.timepicker.date = _date; + }; + var selectableRange = function selectableRange(_selectableRange) { + _this3.$refs.timepicker.selectableRange = _selectableRange; + }; + + this.$watch('value', value); + this.$watch('date', date); + this.$watch('selectableRange', selectableRange); + + format(this.timeFormat); + value(this.value); + date(this.date); + selectableRange(this.selectableRange); + }, + handleClear: function handleClear() { + this.date = this.getDefaultValue(); + this.$emit('pick', null); + }, + emit: function emit(value) { + var _this4 = this; + + for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + + if (!value) { + this.$emit.apply(this, ['pick', value].concat(args)); + } else if (Array.isArray(value)) { + var dates = value.map(function (date) { + return _this4.showTime ? Object(date_util_["clearMilliseconds"])(date) : Object(date_util_["clearTime"])(date); + }); + this.$emit.apply(this, ['pick', dates].concat(args)); + } else { + this.$emit.apply(this, ['pick', this.showTime ? Object(date_util_["clearMilliseconds"])(value) : Object(date_util_["clearTime"])(value)].concat(args)); + } + this.userInputDate = null; + this.userInputTime = null; + }, + + + // resetDate() { + // this.date = new Date(this.date); + // }, + + showMonthPicker: function showMonthPicker() { + this.currentView = 'month'; + }, + showYearPicker: function showYearPicker() { + this.currentView = 'year'; + }, + + + // XXX: 没用到 + // handleLabelClick() { + // if (this.currentView === 'date') { + // this.showMonthPicker(); + // } else if (this.currentView === 'month') { + // this.showYearPicker(); + // } + // }, + + prevMonth: function prevMonth() { + this.date = Object(date_util_["prevMonth"])(this.date); + }, + nextMonth: function nextMonth() { + this.date = Object(date_util_["nextMonth"])(this.date); + }, + prevYear: function prevYear() { + if (this.currentView === 'year') { + this.date = Object(date_util_["prevYear"])(this.date, 10); + } else { + this.date = Object(date_util_["prevYear"])(this.date); + } + }, + nextYear: function nextYear() { + if (this.currentView === 'year') { + this.date = Object(date_util_["nextYear"])(this.date, 10); + } else { + this.date = Object(date_util_["nextYear"])(this.date); + } + }, + handleShortcutClick: function handleShortcutClick(shortcut) { + if (shortcut.onClick) { + shortcut.onClick(this); + } + }, + handleTimePick: function handleTimePick(value, visible, first) { + if (Object(date_util_["isDate"])(value)) { + var newDate = this.value ? Object(date_util_["modifyTime"])(this.value, value.getHours(), value.getMinutes(), value.getSeconds()) : Object(date_util_["modifyWithTimeString"])(this.getDefaultValue(), this.defaultTime); + this.date = newDate; + this.emit(this.date, true); + } else { + this.emit(value, true); + } + if (!first) { + this.timePickerVisible = visible; + } + }, + handleTimePickClose: function handleTimePickClose() { + this.timePickerVisible = false; + }, + handleMonthPick: function handleMonthPick(month) { + if (this.selectionMode === 'month') { + this.date = Object(date_util_["modifyDate"])(this.date, this.year, month, 1); + this.emit(this.date); + } else if (this.selectionMode === 'months') { + this.emit(month, true); + } else { + this.date = Object(date_util_["changeYearMonthAndClampDate"])(this.date, this.year, month); + // TODO: should emit intermediate value ?? + // this.emit(this.date); + this.currentView = 'date'; + } + }, + handleDatePick: function handleDatePick(value) { + if (this.selectionMode === 'day') { + var newDate = this.value ? Object(date_util_["modifyDate"])(this.value, value.getFullYear(), value.getMonth(), value.getDate()) : Object(date_util_["modifyWithTimeString"])(value, this.defaultTime); + // change default time while out of selectableRange + if (!this.checkDateWithinRange(newDate)) { + newDate = Object(date_util_["modifyDate"])(this.selectableRange[0][0], value.getFullYear(), value.getMonth(), value.getDate()); + } + this.date = newDate; + this.emit(this.date, this.showTime); + } else if (this.selectionMode === 'week') { + this.emit(value.date); + } else if (this.selectionMode === 'dates') { + this.emit(value, true); // set false to keep panel open + } + }, + handleYearPick: function handleYearPick(year) { + if (this.selectionMode === 'year') { + this.date = Object(date_util_["modifyDate"])(this.date, year, 0, 1); + this.emit(this.date); + } else if (this.selectionMode === 'years') { + this.emit(year, true); + } else { + this.date = Object(date_util_["changeYearMonthAndClampDate"])(this.date, year, this.month); + // TODO: should emit intermediate value ?? + // this.emit(this.date, true); + this.currentView = 'month'; + } + }, + changeToNow: function changeToNow() { + // NOTE: not a permanent solution + // consider disable "now" button in the future + if ((!this.disabledDate || !this.disabledDate(new Date())) && this.checkDateWithinRange(new Date())) { + this.date = new Date(); + this.emit(this.date); + } + }, + confirm: function confirm() { + if (this.selectionMode === 'dates' || this.selectionMode === 'months' || this.selectionMode === 'years') { + this.emit(this.value); + } else { + // value were emitted in handle{Date,Time}Pick, nothing to update here + // deal with the scenario where: user opens the picker, then confirm without doing anything + var value = this.value ? this.value : Object(date_util_["modifyWithTimeString"])(this.getDefaultValue(), this.defaultTime); + this.date = new Date(value); // refresh date + this.emit(value); + } + }, + resetView: function resetView() { + if (this.selectionMode === 'month' || this.selectionMode === 'months') { + this.currentView = 'month'; + } else if (this.selectionMode === 'year' || this.selectionMode === 'years') { + this.currentView = 'year'; + } else { + this.currentView = 'date'; + } + }, + handleEnter: function handleEnter() { + document.body.addEventListener('keydown', this.handleKeydown); + }, + handleLeave: function handleLeave() { + this.$emit('dodestroy'); + document.body.removeEventListener('keydown', this.handleKeydown); + }, + handleKeydown: function handleKeydown(event) { + var keyCode = event.keyCode; + var list = [38, 40, 37, 39]; + if (this.visible && !this.timePickerVisible) { + if (list.indexOf(keyCode) !== -1) { + this.handleKeyControl(keyCode); + event.stopPropagation(); + event.preventDefault(); + } + if (keyCode === 13 && this.userInputDate === null && this.userInputTime === null) { + // Enter + this.emit(this.date, false); + } + } + }, + handleKeyControl: function handleKeyControl(keyCode) { + var mapping = { + 'year': { + 38: -4, 40: 4, 37: -1, 39: 1, offset: function offset(date, step) { + return date.setFullYear(date.getFullYear() + step); + } + }, + 'month': { + 38: -4, 40: 4, 37: -1, 39: 1, offset: function offset(date, step) { + return date.setMonth(date.getMonth() + step); + } + }, + 'week': { + 38: -1, 40: 1, 37: -1, 39: 1, offset: function offset(date, step) { + return date.setDate(date.getDate() + step * 7); + } + }, + 'day': { + 38: -7, 40: 7, 37: -1, 39: 1, offset: function offset(date, step) { + return date.setDate(date.getDate() + step); + } + } + }; + var mode = this.selectionMode; + var year = 3.1536e10; + var now = this.date.getTime(); + var newDate = new Date(this.date.getTime()); + while (Math.abs(now - newDate.getTime()) <= year) { + var map = mapping[mode]; + map.offset(newDate, map[keyCode]); + if (typeof this.disabledDate === 'function' && this.disabledDate(newDate)) { + continue; + } + this.date = newDate; + this.$emit('pick', newDate, true); + break; + } + }, + handleVisibleTimeChange: function handleVisibleTimeChange(value) { + var time = Object(date_util_["parseDate"])(value, this.timeFormat); + if (time && this.checkDateWithinRange(time)) { + this.date = Object(date_util_["modifyDate"])(time, this.year, this.month, this.monthDate); + this.userInputTime = null; + this.$refs.timepicker.value = this.date; + this.timePickerVisible = false; + this.emit(this.date, true); + } + }, + handleVisibleDateChange: function handleVisibleDateChange(value) { + var date = Object(date_util_["parseDate"])(value, this.dateFormat); + if (date) { + if (typeof this.disabledDate === 'function' && this.disabledDate(date)) { + return; + } + this.date = Object(date_util_["modifyTime"])(date, this.date.getHours(), this.date.getMinutes(), this.date.getSeconds()); + this.userInputDate = null; + this.resetView(); + this.emit(this.date, true); + } + }, + isValidValue: function isValidValue(value) { + return value && !isNaN(value) && (typeof this.disabledDate === 'function' ? !this.disabledDate(value) : true) && this.checkDateWithinRange(value); + }, + getDefaultValue: function getDefaultValue() { + // if default-value is set, return it + // otherwise, return now (the moment this method gets called) + return this.defaultValue ? new Date(this.defaultValue) : new Date(); + }, + checkDateWithinRange: function checkDateWithinRange(date) { + return this.selectableRange.length > 0 ? Object(date_util_["timeWithinRange"])(date, this.selectableRange, this.format || 'HH:mm:ss') : true; + } + }, + + components: { + TimePicker: panel_time["a" /* default */], YearTable: year_table, MonthTable: month_table, DateTable: date_table, ElInput: input_default.a, ElButton: button_default.a + }, + + data: function data() { + return { + popperClass: '', + date: new Date(), + value: '', + defaultValue: null, // use getDefaultValue() for time computation + defaultTime: null, + showTime: false, + selectionMode: 'day', + shortcuts: '', + visible: false, + currentView: 'date', + disabledDate: '', + cellClassName: '', + selectableRange: [], + firstDayOfWeek: 7, + showWeekNumber: false, + timePickerVisible: false, + format: '', + arrowControl: false, + userInputDate: null, + userInputTime: null + }; + }, + + + computed: { + year: function year() { + return this.date.getFullYear(); + }, + month: function month() { + return this.date.getMonth(); + }, + week: function week() { + return Object(date_util_["getWeekNumber"])(this.date); + }, + monthDate: function monthDate() { + return this.date.getDate(); + }, + footerVisible: function footerVisible() { + return this.showTime || this.selectionMode === 'dates' || this.selectionMode === 'months' || this.selectionMode === 'years'; + }, + visibleTime: function visibleTime() { + if (this.userInputTime !== null) { + return this.userInputTime; + } else { + return Object(date_util_["formatDate"])(this.value || this.defaultValue, this.timeFormat); + } + }, + visibleDate: function visibleDate() { + if (this.userInputDate !== null) { + return this.userInputDate; + } else { + return Object(date_util_["formatDate"])(this.value || this.defaultValue, this.dateFormat); + } + }, + yearLabel: function yearLabel() { + var yearTranslation = this.t('el.datepicker.year'); + if (this.currentView === 'year') { + var startYear = Math.floor(this.year / 10) * 10; + if (yearTranslation) { + return startYear + ' ' + yearTranslation + ' - ' + (startYear + 9) + ' ' + yearTranslation; + } + return startYear + ' - ' + (startYear + 9); + } + return this.year + ' ' + yearTranslation; + }, + timeFormat: function timeFormat() { + if (this.format) { + return Object(date_util_["extractTimeFormat"])(this.format); + } else { + return 'HH:mm:ss'; + } + }, + dateFormat: function dateFormat() { + if (this.format) { + return Object(date_util_["extractDateFormat"])(this.format); + } else { + return 'yyyy-MM-dd'; + } + } + } +}); +// CONCATENATED MODULE: ./packages/date-picker/src/panel/date.vue?vue&type=script&lang=js& + /* harmony default export */ var panel_datevue_type_script_lang_js_ = (datevue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/date-picker/src/panel/date.vue + + + + + +/* normalize component */ + +var date_component = Object(componentNormalizer["a" /* default */])( + panel_datevue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var date_api; } +date_component.options.__file = "packages/date-picker/src/panel/date.vue" +/* harmony default export */ var panel_date = (date_component.exports); +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/date-range.vue?vue&type=template&id=2652849a& +var date_rangevue_type_template_id_2652849a_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "transition", + { + attrs: { name: "el-zoom-in-top" }, + on: { + "after-leave": function($event) { + _vm.$emit("dodestroy") + } + } + }, + [ + _c( + "div", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.visible, + expression: "visible" + } + ], + staticClass: "el-picker-panel el-date-range-picker el-popper", + class: [ + { + "has-sidebar": _vm.$slots.sidebar || _vm.shortcuts, + "has-time": _vm.showTime + }, + _vm.popperClass + ] + }, + [ + _c( + "div", + { staticClass: "el-picker-panel__body-wrapper" }, + [ + _vm._t("sidebar"), + _vm.shortcuts + ? _c( + "div", + { staticClass: "el-picker-panel__sidebar" }, + _vm._l(_vm.shortcuts, function(shortcut, key) { + return _c( + "button", + { + key: key, + staticClass: "el-picker-panel__shortcut", + attrs: { type: "button" }, + on: { + click: function($event) { + _vm.handleShortcutClick(shortcut) + } + } + }, + [_vm._v(_vm._s(shortcut.text))] + ) + }), + 0 + ) + : _vm._e(), + _c("div", { staticClass: "el-picker-panel__body" }, [ + _vm.showTime + ? _c( + "div", + { staticClass: "el-date-range-picker__time-header" }, + [ + _c( + "span", + { staticClass: "el-date-range-picker__editors-wrap" }, + [ + _c( + "span", + { + staticClass: + "el-date-range-picker__time-picker-wrap" + }, + [ + _c("el-input", { + ref: "minInput", + staticClass: "el-date-range-picker__editor", + attrs: { + size: "small", + disabled: _vm.rangeState.selecting, + placeholder: _vm.t( + "el.datepicker.startDate" + ), + value: _vm.minVisibleDate + }, + on: { + input: function(val) { + return _vm.handleDateInput(val, "min") + }, + change: function(val) { + return _vm.handleDateChange(val, "min") + } + } + }) + ], + 1 + ), + _c( + "span", + { + directives: [ + { + name: "clickoutside", + rawName: "v-clickoutside", + value: _vm.handleMinTimeClose, + expression: "handleMinTimeClose" + } + ], + staticClass: + "el-date-range-picker__time-picker-wrap" + }, + [ + _c("el-input", { + staticClass: "el-date-range-picker__editor", + attrs: { + size: "small", + disabled: _vm.rangeState.selecting, + placeholder: _vm.t( + "el.datepicker.startTime" + ), + value: _vm.minVisibleTime + }, + on: { + focus: function($event) { + _vm.minTimePickerVisible = true + }, + input: function(val) { + return _vm.handleTimeInput(val, "min") + }, + change: function(val) { + return _vm.handleTimeChange(val, "min") + } + } + }), + _c("time-picker", { + ref: "minTimePicker", + attrs: { + "time-arrow-control": _vm.arrowControl, + visible: _vm.minTimePickerVisible + }, + on: { + pick: _vm.handleMinTimePick, + mounted: function($event) { + _vm.$refs.minTimePicker.format = + _vm.timeFormat + } + } + }) + ], + 1 + ) + ] + ), + _c("span", { staticClass: "el-icon-arrow-right" }), + _c( + "span", + { + staticClass: + "el-date-range-picker__editors-wrap is-right" + }, + [ + _c( + "span", + { + staticClass: + "el-date-range-picker__time-picker-wrap" + }, + [ + _c("el-input", { + staticClass: "el-date-range-picker__editor", + attrs: { + size: "small", + disabled: _vm.rangeState.selecting, + placeholder: _vm.t("el.datepicker.endDate"), + value: _vm.maxVisibleDate, + readonly: !_vm.minDate + }, + on: { + input: function(val) { + return _vm.handleDateInput(val, "max") + }, + change: function(val) { + return _vm.handleDateChange(val, "max") + } + } + }) + ], + 1 + ), + _c( + "span", + { + directives: [ + { + name: "clickoutside", + rawName: "v-clickoutside", + value: _vm.handleMaxTimeClose, + expression: "handleMaxTimeClose" + } + ], + staticClass: + "el-date-range-picker__time-picker-wrap" + }, + [ + _c("el-input", { + staticClass: "el-date-range-picker__editor", + attrs: { + size: "small", + disabled: _vm.rangeState.selecting, + placeholder: _vm.t("el.datepicker.endTime"), + value: _vm.maxVisibleTime, + readonly: !_vm.minDate + }, + on: { + focus: function($event) { + _vm.minDate && + (_vm.maxTimePickerVisible = true) + }, + input: function(val) { + return _vm.handleTimeInput(val, "max") + }, + change: function(val) { + return _vm.handleTimeChange(val, "max") + } + } + }), + _c("time-picker", { + ref: "maxTimePicker", + attrs: { + "time-arrow-control": _vm.arrowControl, + visible: _vm.maxTimePickerVisible + }, + on: { + pick: _vm.handleMaxTimePick, + mounted: function($event) { + _vm.$refs.maxTimePicker.format = + _vm.timeFormat + } + } + }) + ], + 1 + ) + ] + ) + ] + ) + : _vm._e(), + _c( + "div", + { + staticClass: + "el-picker-panel__content el-date-range-picker__content is-left" + }, + [ + _c("div", { staticClass: "el-date-range-picker__header" }, [ + _c("button", { + staticClass: + "el-picker-panel__icon-btn el-icon-d-arrow-left", + attrs: { type: "button" }, + on: { click: _vm.leftPrevYear } + }), + _c("button", { + staticClass: + "el-picker-panel__icon-btn el-icon-arrow-left", + attrs: { type: "button" }, + on: { click: _vm.leftPrevMonth } + }), + _vm.unlinkPanels + ? _c("button", { + staticClass: + "el-picker-panel__icon-btn el-icon-d-arrow-right", + class: { "is-disabled": !_vm.enableYearArrow }, + attrs: { + type: "button", + disabled: !_vm.enableYearArrow + }, + on: { click: _vm.leftNextYear } + }) + : _vm._e(), + _vm.unlinkPanels + ? _c("button", { + staticClass: + "el-picker-panel__icon-btn el-icon-arrow-right", + class: { "is-disabled": !_vm.enableMonthArrow }, + attrs: { + type: "button", + disabled: !_vm.enableMonthArrow + }, + on: { click: _vm.leftNextMonth } + }) + : _vm._e(), + _c("div", [_vm._v(_vm._s(_vm.leftLabel))]) + ]), + _c("date-table", { + attrs: { + "selection-mode": "range", + date: _vm.leftDate, + "default-value": _vm.defaultValue, + "min-date": _vm.minDate, + "max-date": _vm.maxDate, + "range-state": _vm.rangeState, + "disabled-date": _vm.disabledDate, + "cell-class-name": _vm.cellClassName, + "first-day-of-week": _vm.firstDayOfWeek + }, + on: { + changerange: _vm.handleChangeRange, + pick: _vm.handleRangePick + } + }) + ], + 1 + ), + _c( + "div", + { + staticClass: + "el-picker-panel__content el-date-range-picker__content is-right" + }, + [ + _c("div", { staticClass: "el-date-range-picker__header" }, [ + _vm.unlinkPanels + ? _c("button", { + staticClass: + "el-picker-panel__icon-btn el-icon-d-arrow-left", + class: { "is-disabled": !_vm.enableYearArrow }, + attrs: { + type: "button", + disabled: !_vm.enableYearArrow + }, + on: { click: _vm.rightPrevYear } + }) + : _vm._e(), + _vm.unlinkPanels + ? _c("button", { + staticClass: + "el-picker-panel__icon-btn el-icon-arrow-left", + class: { "is-disabled": !_vm.enableMonthArrow }, + attrs: { + type: "button", + disabled: !_vm.enableMonthArrow + }, + on: { click: _vm.rightPrevMonth } + }) + : _vm._e(), + _c("button", { + staticClass: + "el-picker-panel__icon-btn el-icon-d-arrow-right", + attrs: { type: "button" }, + on: { click: _vm.rightNextYear } + }), + _c("button", { + staticClass: + "el-picker-panel__icon-btn el-icon-arrow-right", + attrs: { type: "button" }, + on: { click: _vm.rightNextMonth } + }), + _c("div", [_vm._v(_vm._s(_vm.rightLabel))]) + ]), + _c("date-table", { + attrs: { + "selection-mode": "range", + date: _vm.rightDate, + "default-value": _vm.defaultValue, + "min-date": _vm.minDate, + "max-date": _vm.maxDate, + "range-state": _vm.rangeState, + "disabled-date": _vm.disabledDate, + "cell-class-name": _vm.cellClassName, + "first-day-of-week": _vm.firstDayOfWeek + }, + on: { + changerange: _vm.handleChangeRange, + pick: _vm.handleRangePick + } + }) + ], + 1 + ) + ]) + ], + 2 + ), + _vm.showTime + ? _c( + "div", + { staticClass: "el-picker-panel__footer" }, + [ + _c( + "el-button", + { + staticClass: "el-picker-panel__link-btn", + attrs: { size: "mini", type: "text" }, + on: { click: _vm.handleClear } + }, + [ + _vm._v( + "\n " + + _vm._s(_vm.t("el.datepicker.clear")) + + "\n " + ) + ] + ), + _c( + "el-button", + { + staticClass: "el-picker-panel__link-btn", + attrs: { + plain: "", + size: "mini", + disabled: _vm.btnDisabled + }, + on: { + click: function($event) { + _vm.handleConfirm(false) + } + } + }, + [ + _vm._v( + "\n " + + _vm._s(_vm.t("el.datepicker.confirm")) + + "\n " + ) + ] + ) + ], + 1 + ) + : _vm._e() + ] + ) + ] + ) +} +var date_rangevue_type_template_id_2652849a_staticRenderFns = [] +date_rangevue_type_template_id_2652849a_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/date-picker/src/panel/date-range.vue?vue&type=template&id=2652849a& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/date-range.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + + + + + +var date_rangevue_type_script_lang_js_calcDefaultValue = function calcDefaultValue(defaultValue) { + if (Array.isArray(defaultValue)) { + return [new Date(defaultValue[0]), new Date(defaultValue[1])]; + } else if (defaultValue) { + return [new Date(defaultValue), Object(date_util_["nextDate"])(new Date(defaultValue), 1)]; + } else { + return [new Date(), Object(date_util_["nextDate"])(new Date(), 1)]; + } +}; + +/* harmony default export */ var date_rangevue_type_script_lang_js_ = ({ + mixins: [locale_default.a], + + directives: { Clickoutside: clickoutside_default.a }, + + computed: { + btnDisabled: function btnDisabled() { + return !(this.minDate && this.maxDate && !this.selecting && this.isValidValue([this.minDate, this.maxDate])); + }, + leftLabel: function leftLabel() { + return this.leftDate.getFullYear() + ' ' + this.t('el.datepicker.year') + ' ' + this.t('el.datepicker.month' + (this.leftDate.getMonth() + 1)); + }, + rightLabel: function rightLabel() { + return this.rightDate.getFullYear() + ' ' + this.t('el.datepicker.year') + ' ' + this.t('el.datepicker.month' + (this.rightDate.getMonth() + 1)); + }, + leftYear: function leftYear() { + return this.leftDate.getFullYear(); + }, + leftMonth: function leftMonth() { + return this.leftDate.getMonth(); + }, + leftMonthDate: function leftMonthDate() { + return this.leftDate.getDate(); + }, + rightYear: function rightYear() { + return this.rightDate.getFullYear(); + }, + rightMonth: function rightMonth() { + return this.rightDate.getMonth(); + }, + rightMonthDate: function rightMonthDate() { + return this.rightDate.getDate(); + }, + minVisibleDate: function minVisibleDate() { + if (this.dateUserInput.min !== null) return this.dateUserInput.min; + if (this.minDate) return Object(date_util_["formatDate"])(this.minDate, this.dateFormat); + return ''; + }, + maxVisibleDate: function maxVisibleDate() { + if (this.dateUserInput.max !== null) return this.dateUserInput.max; + if (this.maxDate || this.minDate) return Object(date_util_["formatDate"])(this.maxDate || this.minDate, this.dateFormat); + return ''; + }, + minVisibleTime: function minVisibleTime() { + if (this.timeUserInput.min !== null) return this.timeUserInput.min; + if (this.minDate) return Object(date_util_["formatDate"])(this.minDate, this.timeFormat); + return ''; + }, + maxVisibleTime: function maxVisibleTime() { + if (this.timeUserInput.max !== null) return this.timeUserInput.max; + if (this.maxDate || this.minDate) return Object(date_util_["formatDate"])(this.maxDate || this.minDate, this.timeFormat); + return ''; + }, + timeFormat: function timeFormat() { + if (this.format) { + return Object(date_util_["extractTimeFormat"])(this.format); + } else { + return 'HH:mm:ss'; + } + }, + dateFormat: function dateFormat() { + if (this.format) { + return Object(date_util_["extractDateFormat"])(this.format); + } else { + return 'yyyy-MM-dd'; + } + }, + enableMonthArrow: function enableMonthArrow() { + var nextMonth = (this.leftMonth + 1) % 12; + var yearOffset = this.leftMonth + 1 >= 12 ? 1 : 0; + return this.unlinkPanels && new Date(this.leftYear + yearOffset, nextMonth) < new Date(this.rightYear, this.rightMonth); + }, + enableYearArrow: function enableYearArrow() { + return this.unlinkPanels && this.rightYear * 12 + this.rightMonth - (this.leftYear * 12 + this.leftMonth + 1) >= 12; + } + }, + + data: function data() { + return { + popperClass: '', + value: [], + defaultValue: null, + defaultTime: null, + minDate: '', + maxDate: '', + leftDate: new Date(), + rightDate: Object(date_util_["nextMonth"])(new Date()), + rangeState: { + endDate: null, + selecting: false, + row: null, + column: null + }, + showTime: false, + shortcuts: '', + visible: '', + disabledDate: '', + cellClassName: '', + firstDayOfWeek: 7, + minTimePickerVisible: false, + maxTimePickerVisible: false, + format: '', + arrowControl: false, + unlinkPanels: false, + dateUserInput: { + min: null, + max: null + }, + timeUserInput: { + min: null, + max: null + } + }; + }, + + + watch: { + minDate: function minDate(val) { + var _this = this; + + this.dateUserInput.min = null; + this.timeUserInput.min = null; + this.$nextTick(function () { + if (_this.$refs.maxTimePicker && _this.maxDate && _this.maxDate < _this.minDate) { + var format = 'HH:mm:ss'; + _this.$refs.maxTimePicker.selectableRange = [[Object(date_util_["parseDate"])(Object(date_util_["formatDate"])(_this.minDate, format), format), Object(date_util_["parseDate"])('23:59:59', format)]]; + } + }); + if (val && this.$refs.minTimePicker) { + this.$refs.minTimePicker.date = val; + this.$refs.minTimePicker.value = val; + } + }, + maxDate: function maxDate(val) { + this.dateUserInput.max = null; + this.timeUserInput.max = null; + if (val && this.$refs.maxTimePicker) { + this.$refs.maxTimePicker.date = val; + this.$refs.maxTimePicker.value = val; + } + }, + minTimePickerVisible: function minTimePickerVisible(val) { + var _this2 = this; + + if (val) { + this.$nextTick(function () { + _this2.$refs.minTimePicker.date = _this2.minDate; + _this2.$refs.minTimePicker.value = _this2.minDate; + _this2.$refs.minTimePicker.adjustSpinners(); + }); + } + }, + maxTimePickerVisible: function maxTimePickerVisible(val) { + var _this3 = this; + + if (val) { + this.$nextTick(function () { + _this3.$refs.maxTimePicker.date = _this3.maxDate; + _this3.$refs.maxTimePicker.value = _this3.maxDate; + _this3.$refs.maxTimePicker.adjustSpinners(); + }); + } + }, + value: function value(newVal) { + if (!newVal) { + this.minDate = null; + this.maxDate = null; + } else if (Array.isArray(newVal)) { + this.minDate = Object(date_util_["isDate"])(newVal[0]) ? new Date(newVal[0]) : null; + this.maxDate = Object(date_util_["isDate"])(newVal[1]) ? new Date(newVal[1]) : null; + if (this.minDate) { + this.leftDate = this.minDate; + if (this.unlinkPanels && this.maxDate) { + var minDateYear = this.minDate.getFullYear(); + var minDateMonth = this.minDate.getMonth(); + var maxDateYear = this.maxDate.getFullYear(); + var maxDateMonth = this.maxDate.getMonth(); + this.rightDate = minDateYear === maxDateYear && minDateMonth === maxDateMonth ? Object(date_util_["nextMonth"])(this.maxDate) : this.maxDate; + } else { + this.rightDate = Object(date_util_["nextMonth"])(this.leftDate); + } + } else { + this.leftDate = date_rangevue_type_script_lang_js_calcDefaultValue(this.defaultValue)[0]; + this.rightDate = Object(date_util_["nextMonth"])(this.leftDate); + } + } + }, + defaultValue: function defaultValue(val) { + if (!Array.isArray(this.value)) { + var _calcDefaultValue = date_rangevue_type_script_lang_js_calcDefaultValue(val), + left = _calcDefaultValue[0], + right = _calcDefaultValue[1]; + + this.leftDate = left; + this.rightDate = val && val[1] && this.unlinkPanels ? right : Object(date_util_["nextMonth"])(this.leftDate); + } + } + }, + + methods: { + handleClear: function handleClear() { + this.minDate = null; + this.maxDate = null; + this.leftDate = date_rangevue_type_script_lang_js_calcDefaultValue(this.defaultValue)[0]; + this.rightDate = Object(date_util_["nextMonth"])(this.leftDate); + this.$emit('pick', null); + }, + handleChangeRange: function handleChangeRange(val) { + this.minDate = val.minDate; + this.maxDate = val.maxDate; + this.rangeState = val.rangeState; + }, + handleDateInput: function handleDateInput(value, type) { + this.dateUserInput[type] = value; + if (value.length !== this.dateFormat.length) return; + var parsedValue = Object(date_util_["parseDate"])(value, this.dateFormat); + + if (parsedValue) { + if (typeof this.disabledDate === 'function' && this.disabledDate(new Date(parsedValue))) { + return; + } + if (type === 'min') { + this.minDate = Object(date_util_["modifyDate"])(this.minDate || new Date(), parsedValue.getFullYear(), parsedValue.getMonth(), parsedValue.getDate()); + this.leftDate = new Date(parsedValue); + if (!this.unlinkPanels) { + this.rightDate = Object(date_util_["nextMonth"])(this.leftDate); + } + } else { + this.maxDate = Object(date_util_["modifyDate"])(this.maxDate || new Date(), parsedValue.getFullYear(), parsedValue.getMonth(), parsedValue.getDate()); + this.rightDate = new Date(parsedValue); + if (!this.unlinkPanels) { + this.leftDate = Object(date_util_["prevMonth"])(parsedValue); + } + } + } + }, + handleDateChange: function handleDateChange(value, type) { + var parsedValue = Object(date_util_["parseDate"])(value, this.dateFormat); + if (parsedValue) { + if (type === 'min') { + this.minDate = Object(date_util_["modifyDate"])(this.minDate, parsedValue.getFullYear(), parsedValue.getMonth(), parsedValue.getDate()); + if (this.minDate > this.maxDate) { + this.maxDate = this.minDate; + } + } else { + this.maxDate = Object(date_util_["modifyDate"])(this.maxDate, parsedValue.getFullYear(), parsedValue.getMonth(), parsedValue.getDate()); + if (this.maxDate < this.minDate) { + this.minDate = this.maxDate; + } + } + } + }, + handleTimeInput: function handleTimeInput(value, type) { + var _this4 = this; + + this.timeUserInput[type] = value; + if (value.length !== this.timeFormat.length) return; + var parsedValue = Object(date_util_["parseDate"])(value, this.timeFormat); + + if (parsedValue) { + if (type === 'min') { + this.minDate = Object(date_util_["modifyTime"])(this.minDate, parsedValue.getHours(), parsedValue.getMinutes(), parsedValue.getSeconds()); + this.$nextTick(function (_) { + return _this4.$refs.minTimePicker.adjustSpinners(); + }); + } else { + this.maxDate = Object(date_util_["modifyTime"])(this.maxDate, parsedValue.getHours(), parsedValue.getMinutes(), parsedValue.getSeconds()); + this.$nextTick(function (_) { + return _this4.$refs.maxTimePicker.adjustSpinners(); + }); + } + } + }, + handleTimeChange: function handleTimeChange(value, type) { + var parsedValue = Object(date_util_["parseDate"])(value, this.timeFormat); + if (parsedValue) { + if (type === 'min') { + this.minDate = Object(date_util_["modifyTime"])(this.minDate, parsedValue.getHours(), parsedValue.getMinutes(), parsedValue.getSeconds()); + if (this.minDate > this.maxDate) { + this.maxDate = this.minDate; + } + this.$refs.minTimePicker.value = this.minDate; + this.minTimePickerVisible = false; + } else { + this.maxDate = Object(date_util_["modifyTime"])(this.maxDate, parsedValue.getHours(), parsedValue.getMinutes(), parsedValue.getSeconds()); + if (this.maxDate < this.minDate) { + this.minDate = this.maxDate; + } + this.$refs.maxTimePicker.value = this.minDate; + this.maxTimePickerVisible = false; + } + } + }, + handleRangePick: function handleRangePick(val) { + var _this5 = this; + + var close = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; + + var defaultTime = this.defaultTime || []; + var minDate = Object(date_util_["modifyWithTimeString"])(val.minDate, defaultTime[0]); + var maxDate = Object(date_util_["modifyWithTimeString"])(val.maxDate, defaultTime[1]); + + if (this.maxDate === maxDate && this.minDate === minDate) { + return; + } + this.onPick && this.onPick(val); + this.maxDate = maxDate; + this.minDate = minDate; + + // workaround for https://github.com/ElemeFE/element/issues/7539, should remove this block when we don't have to care about Chromium 55 - 57 + setTimeout(function () { + _this5.maxDate = maxDate; + _this5.minDate = minDate; + }, 10); + if (!close || this.showTime) return; + this.handleConfirm(); + }, + handleShortcutClick: function handleShortcutClick(shortcut) { + if (shortcut.onClick) { + shortcut.onClick(this); + } + }, + handleMinTimePick: function handleMinTimePick(value, visible, first) { + this.minDate = this.minDate || new Date(); + if (value) { + this.minDate = Object(date_util_["modifyTime"])(this.minDate, value.getHours(), value.getMinutes(), value.getSeconds()); + } + + if (!first) { + this.minTimePickerVisible = visible; + } + + if (!this.maxDate || this.maxDate && this.maxDate.getTime() < this.minDate.getTime()) { + this.maxDate = new Date(this.minDate); + } + }, + handleMinTimeClose: function handleMinTimeClose() { + this.minTimePickerVisible = false; + }, + handleMaxTimePick: function handleMaxTimePick(value, visible, first) { + if (this.maxDate && value) { + this.maxDate = Object(date_util_["modifyTime"])(this.maxDate, value.getHours(), value.getMinutes(), value.getSeconds()); + } + + if (!first) { + this.maxTimePickerVisible = visible; + } + + if (this.maxDate && this.minDate && this.minDate.getTime() > this.maxDate.getTime()) { + this.minDate = new Date(this.maxDate); + } + }, + handleMaxTimeClose: function handleMaxTimeClose() { + this.maxTimePickerVisible = false; + }, + + + // leftPrev*, rightNext* need to take care of `unlinkPanels` + leftPrevYear: function leftPrevYear() { + this.leftDate = Object(date_util_["prevYear"])(this.leftDate); + if (!this.unlinkPanels) { + this.rightDate = Object(date_util_["nextMonth"])(this.leftDate); + } + }, + leftPrevMonth: function leftPrevMonth() { + this.leftDate = Object(date_util_["prevMonth"])(this.leftDate); + if (!this.unlinkPanels) { + this.rightDate = Object(date_util_["nextMonth"])(this.leftDate); + } + }, + rightNextYear: function rightNextYear() { + if (!this.unlinkPanels) { + this.leftDate = Object(date_util_["nextYear"])(this.leftDate); + this.rightDate = Object(date_util_["nextMonth"])(this.leftDate); + } else { + this.rightDate = Object(date_util_["nextYear"])(this.rightDate); + } + }, + rightNextMonth: function rightNextMonth() { + if (!this.unlinkPanels) { + this.leftDate = Object(date_util_["nextMonth"])(this.leftDate); + this.rightDate = Object(date_util_["nextMonth"])(this.leftDate); + } else { + this.rightDate = Object(date_util_["nextMonth"])(this.rightDate); + } + }, + + + // leftNext*, rightPrev* are called when `unlinkPanels` is true + leftNextYear: function leftNextYear() { + this.leftDate = Object(date_util_["nextYear"])(this.leftDate); + }, + leftNextMonth: function leftNextMonth() { + this.leftDate = Object(date_util_["nextMonth"])(this.leftDate); + }, + rightPrevYear: function rightPrevYear() { + this.rightDate = Object(date_util_["prevYear"])(this.rightDate); + }, + rightPrevMonth: function rightPrevMonth() { + this.rightDate = Object(date_util_["prevMonth"])(this.rightDate); + }, + handleConfirm: function handleConfirm() { + var visible = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; + + if (this.isValidValue([this.minDate, this.maxDate])) { + this.$emit('pick', [this.minDate, this.maxDate], visible); + } + }, + isValidValue: function isValidValue(value) { + return Array.isArray(value) && value && value[0] && value[1] && Object(date_util_["isDate"])(value[0]) && Object(date_util_["isDate"])(value[1]) && value[0].getTime() <= value[1].getTime() && (typeof this.disabledDate === 'function' ? !this.disabledDate(value[0]) && !this.disabledDate(value[1]) : true); + }, + resetView: function resetView() { + // NOTE: this is a hack to reset {min, max}Date on picker open. + // TODO: correct way of doing so is to refactor {min, max}Date to be dependent on value and internal selection state + // an alternative would be resetView whenever picker becomes visible, should also investigate date-panel's resetView + if (this.minDate && this.maxDate == null) this.rangeState.selecting = false; + this.minDate = this.value && Object(date_util_["isDate"])(this.value[0]) ? new Date(this.value[0]) : null; + this.maxDate = this.value && Object(date_util_["isDate"])(this.value[0]) ? new Date(this.value[1]) : null; + } + }, + + components: { TimePicker: panel_time["a" /* default */], DateTable: date_table, ElInput: input_default.a, ElButton: button_default.a } +}); +// CONCATENATED MODULE: ./packages/date-picker/src/panel/date-range.vue?vue&type=script&lang=js& + /* harmony default export */ var panel_date_rangevue_type_script_lang_js_ = (date_rangevue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/date-picker/src/panel/date-range.vue + + + + + +/* normalize component */ + +var date_range_component = Object(componentNormalizer["a" /* default */])( + panel_date_rangevue_type_script_lang_js_, + date_rangevue_type_template_id_2652849a_render, + date_rangevue_type_template_id_2652849a_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var date_range_api; } +date_range_component.options.__file = "packages/date-picker/src/panel/date-range.vue" +/* harmony default export */ var date_range = (date_range_component.exports); +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/month-range.vue?vue&type=template&id=f2645fb8& +var month_rangevue_type_template_id_f2645fb8_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "transition", + { + attrs: { name: "el-zoom-in-top" }, + on: { + "after-leave": function($event) { + _vm.$emit("dodestroy") + } + } + }, + [ + _c( + "div", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.visible, + expression: "visible" + } + ], + staticClass: "el-picker-panel el-date-range-picker el-popper", + class: [ + { + "has-sidebar": _vm.$slots.sidebar || _vm.shortcuts + }, + _vm.popperClass + ] + }, + [ + _c( + "div", + { staticClass: "el-picker-panel__body-wrapper" }, + [ + _vm._t("sidebar"), + _vm.shortcuts + ? _c( + "div", + { staticClass: "el-picker-panel__sidebar" }, + _vm._l(_vm.shortcuts, function(shortcut, key) { + return _c( + "button", + { + key: key, + staticClass: "el-picker-panel__shortcut", + attrs: { type: "button" }, + on: { + click: function($event) { + _vm.handleShortcutClick(shortcut) + } + } + }, + [_vm._v(_vm._s(shortcut.text))] + ) + }), + 0 + ) + : _vm._e(), + _c("div", { staticClass: "el-picker-panel__body" }, [ + _c( + "div", + { + staticClass: + "el-picker-panel__content el-date-range-picker__content is-left" + }, + [ + _c("div", { staticClass: "el-date-range-picker__header" }, [ + _c("button", { + staticClass: + "el-picker-panel__icon-btn el-icon-d-arrow-left", + attrs: { type: "button" }, + on: { click: _vm.leftPrevYear } + }), + _vm.unlinkPanels + ? _c("button", { + staticClass: + "el-picker-panel__icon-btn el-icon-d-arrow-right", + class: { "is-disabled": !_vm.enableYearArrow }, + attrs: { + type: "button", + disabled: !_vm.enableYearArrow + }, + on: { click: _vm.leftNextYear } + }) + : _vm._e(), + _c("div", [_vm._v(_vm._s(_vm.leftLabel))]) + ]), + _c("month-table", { + attrs: { + "selection-mode": "range", + date: _vm.leftDate, + "default-value": _vm.defaultValue, + "min-date": _vm.minDate, + "max-date": _vm.maxDate, + "range-state": _vm.rangeState, + "disabled-date": _vm.disabledDate + }, + on: { + changerange: _vm.handleChangeRange, + pick: _vm.handleRangePick + } + }) + ], + 1 + ), + _c( + "div", + { + staticClass: + "el-picker-panel__content el-date-range-picker__content is-right" + }, + [ + _c("div", { staticClass: "el-date-range-picker__header" }, [ + _vm.unlinkPanels + ? _c("button", { + staticClass: + "el-picker-panel__icon-btn el-icon-d-arrow-left", + class: { "is-disabled": !_vm.enableYearArrow }, + attrs: { + type: "button", + disabled: !_vm.enableYearArrow + }, + on: { click: _vm.rightPrevYear } + }) + : _vm._e(), + _c("button", { + staticClass: + "el-picker-panel__icon-btn el-icon-d-arrow-right", + attrs: { type: "button" }, + on: { click: _vm.rightNextYear } + }), + _c("div", [_vm._v(_vm._s(_vm.rightLabel))]) + ]), + _c("month-table", { + attrs: { + "selection-mode": "range", + date: _vm.rightDate, + "default-value": _vm.defaultValue, + "min-date": _vm.minDate, + "max-date": _vm.maxDate, + "range-state": _vm.rangeState, + "disabled-date": _vm.disabledDate + }, + on: { + changerange: _vm.handleChangeRange, + pick: _vm.handleRangePick + } + }) + ], + 1 + ) + ]) + ], + 2 + ) + ] + ) + ] + ) +} +var month_rangevue_type_template_id_f2645fb8_staticRenderFns = [] +month_rangevue_type_template_id_f2645fb8_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/date-picker/src/panel/month-range.vue?vue&type=template&id=f2645fb8& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/month-range.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + + + + +var month_rangevue_type_script_lang_js_calcDefaultValue = function calcDefaultValue(defaultValue) { + if (Array.isArray(defaultValue)) { + return [new Date(defaultValue[0]), new Date(defaultValue[1])]; + } else if (defaultValue) { + return [new Date(defaultValue), Object(date_util_["nextMonth"])(new Date(defaultValue))]; + } else { + return [new Date(), Object(date_util_["nextMonth"])(new Date())]; + } +}; +/* harmony default export */ var month_rangevue_type_script_lang_js_ = ({ + mixins: [locale_default.a], + + directives: { Clickoutside: clickoutside_default.a }, + + computed: { + btnDisabled: function btnDisabled() { + return !(this.minDate && this.maxDate && !this.selecting && this.isValidValue([this.minDate, this.maxDate])); + }, + leftLabel: function leftLabel() { + return this.leftDate.getFullYear() + ' ' + this.t('el.datepicker.year'); + }, + rightLabel: function rightLabel() { + return this.rightDate.getFullYear() + ' ' + this.t('el.datepicker.year'); + }, + leftYear: function leftYear() { + return this.leftDate.getFullYear(); + }, + rightYear: function rightYear() { + return this.rightDate.getFullYear() === this.leftDate.getFullYear() ? this.leftDate.getFullYear() + 1 : this.rightDate.getFullYear(); + }, + enableYearArrow: function enableYearArrow() { + return this.unlinkPanels && this.rightYear > this.leftYear + 1; + } + }, + + data: function data() { + return { + popperClass: '', + value: [], + defaultValue: null, + defaultTime: null, + minDate: '', + maxDate: '', + leftDate: new Date(), + rightDate: Object(date_util_["nextYear"])(new Date()), + rangeState: { + endDate: null, + selecting: false, + row: null, + column: null + }, + shortcuts: '', + visible: '', + disabledDate: '', + format: '', + arrowControl: false, + unlinkPanels: false + }; + }, + + + watch: { + value: function value(newVal) { + if (!newVal) { + this.minDate = null; + this.maxDate = null; + } else if (Array.isArray(newVal)) { + this.minDate = Object(date_util_["isDate"])(newVal[0]) ? new Date(newVal[0]) : null; + this.maxDate = Object(date_util_["isDate"])(newVal[1]) ? new Date(newVal[1]) : null; + if (this.minDate) { + this.leftDate = this.minDate; + if (this.unlinkPanels && this.maxDate) { + var minDateYear = this.minDate.getFullYear(); + var maxDateYear = this.maxDate.getFullYear(); + this.rightDate = minDateYear === maxDateYear ? Object(date_util_["nextYear"])(this.maxDate) : this.maxDate; + } else { + this.rightDate = Object(date_util_["nextYear"])(this.leftDate); + } + } else { + this.leftDate = month_rangevue_type_script_lang_js_calcDefaultValue(this.defaultValue)[0]; + this.rightDate = Object(date_util_["nextYear"])(this.leftDate); + } + } + }, + defaultValue: function defaultValue(val) { + if (!Array.isArray(this.value)) { + var _calcDefaultValue = month_rangevue_type_script_lang_js_calcDefaultValue(val), + left = _calcDefaultValue[0], + right = _calcDefaultValue[1]; + + this.leftDate = left; + this.rightDate = val && val[1] && left.getFullYear() !== right.getFullYear() && this.unlinkPanels ? right : Object(date_util_["nextYear"])(this.leftDate); + } + } + }, + + methods: { + handleClear: function handleClear() { + this.minDate = null; + this.maxDate = null; + this.leftDate = month_rangevue_type_script_lang_js_calcDefaultValue(this.defaultValue)[0]; + this.rightDate = Object(date_util_["nextYear"])(this.leftDate); + this.$emit('pick', null); + }, + handleChangeRange: function handleChangeRange(val) { + this.minDate = val.minDate; + this.maxDate = val.maxDate; + this.rangeState = val.rangeState; + }, + handleRangePick: function handleRangePick(val) { + var _this = this; + + var close = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; + + var defaultTime = this.defaultTime || []; + var minDate = Object(date_util_["modifyWithTimeString"])(val.minDate, defaultTime[0]); + var maxDate = Object(date_util_["modifyWithTimeString"])(val.maxDate, defaultTime[1]); + if (this.maxDate === maxDate && this.minDate === minDate) { + return; + } + this.onPick && this.onPick(val); + this.maxDate = maxDate; + this.minDate = minDate; + + // workaround for https://github.com/ElemeFE/element/issues/7539, should remove this block when we don't have to care about Chromium 55 - 57 + setTimeout(function () { + _this.maxDate = maxDate; + _this.minDate = minDate; + }, 10); + if (!close) return; + this.handleConfirm(); + }, + handleShortcutClick: function handleShortcutClick(shortcut) { + if (shortcut.onClick) { + shortcut.onClick(this); + } + }, + + + // leftPrev*, rightNext* need to take care of `unlinkPanels` + leftPrevYear: function leftPrevYear() { + this.leftDate = Object(date_util_["prevYear"])(this.leftDate); + if (!this.unlinkPanels) { + this.rightDate = Object(date_util_["prevYear"])(this.rightDate); + } + }, + rightNextYear: function rightNextYear() { + if (!this.unlinkPanels) { + this.leftDate = Object(date_util_["nextYear"])(this.leftDate); + } + this.rightDate = Object(date_util_["nextYear"])(this.rightDate); + }, + + + // leftNext*, rightPrev* are called when `unlinkPanels` is true + leftNextYear: function leftNextYear() { + this.leftDate = Object(date_util_["nextYear"])(this.leftDate); + }, + rightPrevYear: function rightPrevYear() { + this.rightDate = Object(date_util_["prevYear"])(this.rightDate); + }, + handleConfirm: function handleConfirm() { + var visible = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; + + if (this.isValidValue([this.minDate, this.maxDate])) { + this.$emit('pick', [this.minDate, this.maxDate], visible); + } + }, + isValidValue: function isValidValue(value) { + return Array.isArray(value) && value && value[0] && value[1] && Object(date_util_["isDate"])(value[0]) && Object(date_util_["isDate"])(value[1]) && value[0].getTime() <= value[1].getTime() && (typeof this.disabledDate === 'function' ? !this.disabledDate(value[0]) && !this.disabledDate(value[1]) : true); + }, + resetView: function resetView() { + // NOTE: this is a hack to reset {min, max}Date on picker open. + // TODO: correct way of doing so is to refactor {min, max}Date to be dependent on value and internal selection state + // an alternative would be resetView whenever picker becomes visible, should also investigate date-panel's resetView + this.minDate = this.value && Object(date_util_["isDate"])(this.value[0]) ? new Date(this.value[0]) : null; + this.maxDate = this.value && Object(date_util_["isDate"])(this.value[0]) ? new Date(this.value[1]) : null; + } + }, + + components: { MonthTable: month_table, ElInput: input_default.a, ElButton: button_default.a } +}); +// CONCATENATED MODULE: ./packages/date-picker/src/panel/month-range.vue?vue&type=script&lang=js& + /* harmony default export */ var panel_month_rangevue_type_script_lang_js_ = (month_rangevue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/date-picker/src/panel/month-range.vue + + + + + +/* normalize component */ + +var month_range_component = Object(componentNormalizer["a" /* default */])( + panel_month_rangevue_type_script_lang_js_, + month_rangevue_type_template_id_f2645fb8_render, + month_rangevue_type_template_id_f2645fb8_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var month_range_api; } +month_range_component.options.__file = "packages/date-picker/src/panel/month-range.vue" +/* harmony default export */ var month_range = (month_range_component.exports); +// CONCATENATED MODULE: ./packages/date-picker/src/picker/date-picker.js + + + + + +var date_picker_getPanel = function getPanel(type) { + if (type === 'daterange' || type === 'datetimerange') { + return date_range; + } else if (type === 'monthrange') { + return month_range; + } + return panel_date; +}; + +/* harmony default export */ var date_picker = ({ + mixins: [picker["a" /* default */]], + + name: 'ElDatePicker', + + props: { + type: { + type: String, + default: 'date' + }, + timeArrowControl: Boolean + }, + + watch: { + type: function type(_type) { + if (this.picker) { + this.unmountPicker(); + this.panel = date_picker_getPanel(_type); + this.mountPicker(); + } else { + this.panel = date_picker_getPanel(_type); + } + } + }, + + created: function created() { + this.panel = date_picker_getPanel(this.type); + } +}); +// CONCATENATED MODULE: ./packages/date-picker/index.js + + +/* istanbul ignore next */ +date_picker.install = function install(Vue) { + Vue.component(date_picker.name, date_picker); +}; + +/* harmony default export */ var packages_date_picker = __webpack_exports__["default"] = (date_picker); + +/***/ }) +/******/ ]); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/descriptions-item.js b/public/static/libs/element-ui/lib/descriptions-item.js new file mode 100644 index 0000000..099db18 --- /dev/null +++ b/public/static/libs/element-ui/lib/descriptions-item.js @@ -0,0 +1,139 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 142); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 142: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./packages/descriptions/src/descriptions-item.js +/* harmony default export */ var descriptions_item = ({ + name: 'ElDescriptionsItem', + props: { + label: { + type: String, + default: '' + }, + span: { + type: Number, + default: 1 + }, + contentClassName: { + type: String, + default: '' + }, + contentStyle: { + type: Object + }, + labelClassName: { + type: String, + default: '' + }, + labelStyle: { + type: Object + } + }, + render: function render() { + return null; + } +}); +// CONCATENATED MODULE: ./packages/descriptions-item/index.js + + +/* istanbul ignore next */ +descriptions_item.install = function install(Vue) { + Vue.component(descriptions_item.name, descriptions_item); +}; + +/* harmony default export */ var packages_descriptions_item = __webpack_exports__["default"] = (descriptions_item); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/descriptions.js b/public/static/libs/element-ui/lib/descriptions.js new file mode 100644 index 0000000..ed147c8 --- /dev/null +++ b/public/static/libs/element-ui/lib/descriptions.js @@ -0,0 +1,456 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 137); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 137: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./packages/descriptions/src/descriptions-row.js +var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; + +/* harmony default export */ var descriptions_row = ({ + name: 'ElDescriptionsRow', + props: { + row: { + type: Array + } + }, + inject: ['elDescriptions'], + render: function render(h) { + var elDescriptions = this.elDescriptions; + + var row = (this.row || []).map(function (item) { + return _extends({}, item, { + label: item.slots.label || item.props.label + }, ['labelClassName', 'contentClassName', 'labelStyle', 'contentStyle'].reduce(function (res, key) { + res[key] = item.props[key] || elDescriptions[key]; + return res; + }, {})); + }); + if (elDescriptions.direction === 'vertical') { + return h('tbody', [h( + 'tr', + { 'class': 'el-descriptions-row' }, + [row.map(function (item) { + var _ref; + + return h( + 'th', + { + 'class': (_ref = { + 'el-descriptions-item__cell': true, + 'el-descriptions-item__label': true, + 'has-colon': elDescriptions.border ? false : elDescriptions.colon, + 'is-bordered-label': elDescriptions.border + }, _ref[item.labelClassName] = true, _ref), + style: item.labelStyle, + attrs: { colSpan: item.props.span + } + }, + [item.label] + ); + })] + ), h( + 'tr', + { 'class': 'el-descriptions-row' }, + [row.map(function (item) { + return h( + 'td', + { + 'class': ['el-descriptions-item__cell', 'el-descriptions-item__content', item.contentClassName], + style: item.contentStyle, + attrs: { colSpan: item.props.span + } + }, + [item.slots.default] + ); + })] + )]); + } + if (elDescriptions.border) { + return h('tbody', [h( + 'tr', + { 'class': 'el-descriptions-row' }, + [row.map(function (item) { + var _ref2; + + return [h( + 'th', + { + 'class': (_ref2 = { + 'el-descriptions-item__cell': true, + 'el-descriptions-item__label': true, + 'is-bordered-label': elDescriptions.border + }, _ref2[item.labelClassName] = true, _ref2), + style: item.labelStyle, + attrs: { colSpan: '1' + } + }, + [item.label] + ), h( + 'td', + { + 'class': ['el-descriptions-item__cell', 'el-descriptions-item__content', item.contentClassName], + style: item.contentStyle, + attrs: { colSpan: item.props.span * 2 - 1 + } + }, + [item.slots.default] + )]; + })] + )]); + } + return h('tbody', [h( + 'tr', + { 'class': 'el-descriptions-row' }, + [row.map(function (item) { + var _ref3; + + return h( + 'td', + { 'class': 'el-descriptions-item el-descriptions-item__cell', attrs: { colSpan: item.props.span } + }, + [h( + 'div', + { 'class': 'el-descriptions-item__container' }, + [h( + 'span', + { + 'class': (_ref3 = { + 'el-descriptions-item__label': true, + 'has-colon': elDescriptions.colon + }, _ref3[item.labelClassName] = true, _ref3), + style: item.labelStyle + }, + [item.label] + ), h( + 'span', + { + 'class': ['el-descriptions-item__content', item.contentClassName], + style: item.contentStyle + }, + [item.slots.default] + )] + )] + ); + })] + )]); + } +}); +// EXTERNAL MODULE: external "element-ui/lib/utils/types" +var types_ = __webpack_require__(17); + +// CONCATENATED MODULE: ./packages/descriptions/src/index.js +var src_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; + +var _components; + + + + +/* harmony default export */ var src = ({ + name: 'ElDescriptions', + components: (_components = {}, _components[descriptions_row.name] = descriptions_row, _components), + props: { + border: { + type: Boolean, + default: false + }, + column: { + type: Number, + default: 3 + }, + direction: { + type: String, + default: 'horizontal' + }, + size: { + type: String + // validator: isValidComponentSize, + }, + title: { + type: String, + default: '' + }, + extra: { + type: String, + default: '' + }, + labelStyle: { + type: Object + }, + contentStyle: { + type: Object + }, + labelClassName: { + type: String, + default: '' + }, + contentClassName: { + type: String, + default: '' + }, + colon: { + type: Boolean, + default: true + } + }, + computed: { + descriptionsSize: function descriptionsSize() { + return this.size || (this.$ELEMENT || {}).size; + } + }, + provide: function provide() { + return { + elDescriptions: this + }; + }, + + methods: { + getOptionProps: function getOptionProps(vnode) { + if (vnode.componentOptions) { + var componentOptions = vnode.componentOptions; + var _componentOptions$pro = componentOptions.propsData, + propsData = _componentOptions$pro === undefined ? {} : _componentOptions$pro, + _componentOptions$Cto = componentOptions.Ctor, + Ctor = _componentOptions$Cto === undefined ? {} : _componentOptions$Cto; + + var props = (Ctor.options || {}).props || {}; + var res = {}; + for (var k in props) { + var v = props[k]; + var defaultValue = v.default; + if (defaultValue !== undefined) { + res[k] = Object(types_["isFunction"])(defaultValue) ? defaultValue.call(vnode) : defaultValue; + } + } + return src_extends({}, res, propsData); + } + return {}; + }, + getSlots: function getSlots(vnode) { + var _this = this; + + var componentOptions = vnode.componentOptions || {}; + var children = vnode.children || componentOptions.children || []; + var slots = {}; + children.forEach(function (child) { + if (!_this.isEmptyElement(child)) { + var name = child.data && child.data.slot || 'default'; + slots[name] = slots[name] || []; + if (child.tag === 'template') { + slots[name].push(child.children); + } else { + slots[name].push(child); + } + } + }); + return src_extends({}, slots); + }, + isEmptyElement: function isEmptyElement(c) { + return !(c.tag || c.text && c.text.trim() !== ''); + }, + filledNode: function filledNode(node, span, count) { + var isLast = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false; + + if (!node.props) { + node.props = {}; + } + if (span > count) { + node.props.span = count; + } + if (isLast) { + // set the max span, cause of the last td + node.props.span = count; + } + return node; + }, + getRows: function getRows() { + var _this2 = this; + + var children = (this.$slots.default || []).filter(function (vnode) { + return vnode.tag && vnode.componentOptions && vnode.componentOptions.Ctor.options.name === 'ElDescriptionsItem'; + }); + var nodes = children.map(function (vnode) { + return { + props: _this2.getOptionProps(vnode), + slots: _this2.getSlots(vnode), + vnode: vnode + }; + }); + var rows = []; + var temp = []; + var count = this.column; + + nodes.forEach(function (node, index) { + var span = node.props.span || 1; + + if (index === children.length - 1) { + temp.push(_this2.filledNode(node, span, count, true)); + rows.push(temp); + return; + } + + if (span < count) { + count -= span; + temp.push(node); + } else { + temp.push(_this2.filledNode(node, span, count)); + rows.push(temp); + count = _this2.column; + temp = []; + } + }); + + return rows; + } + }, + render: function render() { + var h = arguments[0]; + var title = this.title, + extra = this.extra, + border = this.border, + descriptionsSize = this.descriptionsSize, + $slots = this.$slots; + + var rows = this.getRows(); + + return h( + 'div', + { 'class': 'el-descriptions' }, + [title || extra || $slots.title || $slots.extra ? h( + 'div', + { 'class': 'el-descriptions__header' }, + [h( + 'div', + { 'class': 'el-descriptions__title' }, + [$slots.title ? $slots.title : title] + ), h( + 'div', + { 'class': 'el-descriptions__extra' }, + [$slots.extra ? $slots.extra : extra] + )] + ) : null, h( + 'div', + { 'class': 'el-descriptions__body' }, + [h( + 'table', + { 'class': ['el-descriptions__table', { 'is-bordered': border }, descriptionsSize ? 'el-descriptions--' + descriptionsSize : ''] }, + [rows.map(function (row) { + return h(descriptions_row, { + attrs: { row: row } + }); + })] + )] + )] + ); + } +}); +// CONCATENATED MODULE: ./packages/descriptions/index.js + + +/* istanbul ignore next */ +src.install = function install(Vue) { + Vue.component(src.name, src); +}; + +/* harmony default export */ var descriptions = __webpack_exports__["default"] = (src); + +/***/ }), + +/***/ 17: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/types"); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/dialog.js b/public/static/libs/element-ui/lib/dialog.js new file mode 100644 index 0000000..b79f082 --- /dev/null +++ b/public/static/libs/element-ui/lib/dialog.js @@ -0,0 +1,597 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 82); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 11: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/migrating"); + +/***/ }), + +/***/ 13: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/popup"); + +/***/ }), + +/***/ 4: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/emitter"); + +/***/ }), + +/***/ 82: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/dialog/src/component.vue?vue&type=template&id=60140e62& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "transition", + { + attrs: { name: "dialog-fade" }, + on: { "after-enter": _vm.afterEnter, "after-leave": _vm.afterLeave } + }, + [ + _c( + "div", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.visible, + expression: "visible" + } + ], + staticClass: "el-dialog__wrapper", + on: { + click: function($event) { + if ($event.target !== $event.currentTarget) { + return null + } + return _vm.handleWrapperClick($event) + } + } + }, + [ + _c( + "div", + { + key: _vm.key, + ref: "dialog", + class: [ + "el-dialog", + { + "is-fullscreen": _vm.fullscreen, + "el-dialog--center": _vm.center + }, + _vm.customClass + ], + style: _vm.style, + attrs: { + role: "dialog", + "aria-modal": "true", + "aria-label": _vm.title || "dialog" + } + }, + [ + _c( + "div", + { staticClass: "el-dialog__header" }, + [ + _vm._t("title", [ + _c("span", { staticClass: "el-dialog__title" }, [ + _vm._v(_vm._s(_vm.title)) + ]) + ]), + _vm.showClose + ? _c( + "button", + { + staticClass: "el-dialog__headerbtn", + attrs: { type: "button", "aria-label": "Close" }, + on: { click: _vm.handleClose } + }, + [ + _c("i", { + staticClass: + "el-dialog__close el-icon el-icon-close" + }) + ] + ) + : _vm._e() + ], + 2 + ), + _vm.rendered + ? _c( + "div", + { staticClass: "el-dialog__body" }, + [_vm._t("default")], + 2 + ) + : _vm._e(), + _vm.$slots.footer + ? _c( + "div", + { staticClass: "el-dialog__footer" }, + [_vm._t("footer")], + 2 + ) + : _vm._e() + ] + ) + ] + ) + ] + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/dialog/src/component.vue?vue&type=template&id=60140e62& + +// EXTERNAL MODULE: external "element-ui/lib/utils/popup" +var popup_ = __webpack_require__(13); +var popup_default = /*#__PURE__*/__webpack_require__.n(popup_); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/migrating" +var migrating_ = __webpack_require__(11); +var migrating_default = /*#__PURE__*/__webpack_require__.n(migrating_); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/emitter" +var emitter_ = __webpack_require__(4); +var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dialog/src/component.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + +/* harmony default export */ var componentvue_type_script_lang_js_ = ({ + name: 'ElDialog', + + mixins: [popup_default.a, emitter_default.a, migrating_default.a], + + props: { + title: { + type: String, + default: '' + }, + + modal: { + type: Boolean, + default: true + }, + + modalAppendToBody: { + type: Boolean, + default: true + }, + + appendToBody: { + type: Boolean, + default: false + }, + + lockScroll: { + type: Boolean, + default: true + }, + + closeOnClickModal: { + type: Boolean, + default: true + }, + + closeOnPressEscape: { + type: Boolean, + default: true + }, + + showClose: { + type: Boolean, + default: true + }, + + width: String, + + fullscreen: Boolean, + + customClass: { + type: String, + default: '' + }, + + top: { + type: String, + default: '15vh' + }, + beforeClose: Function, + center: { + type: Boolean, + default: false + }, + + destroyOnClose: Boolean + }, + + data: function data() { + return { + closed: false, + key: 0 + }; + }, + + + watch: { + visible: function visible(val) { + var _this = this; + + if (val) { + this.closed = false; + this.$emit('open'); + this.$el.addEventListener('scroll', this.updatePopper); + this.$nextTick(function () { + _this.$refs.dialog.scrollTop = 0; + }); + if (this.appendToBody) { + document.body.appendChild(this.$el); + } + } else { + this.$el.removeEventListener('scroll', this.updatePopper); + if (!this.closed) this.$emit('close'); + if (this.destroyOnClose) { + this.$nextTick(function () { + _this.key++; + }); + } + } + } + }, + + computed: { + style: function style() { + var style = {}; + if (!this.fullscreen) { + style.marginTop = this.top; + if (this.width) { + style.width = this.width; + } + } + return style; + } + }, + + methods: { + getMigratingConfig: function getMigratingConfig() { + return { + props: { + 'size': 'size is removed.' + } + }; + }, + handleWrapperClick: function handleWrapperClick() { + if (!this.closeOnClickModal) return; + this.handleClose(); + }, + handleClose: function handleClose() { + if (typeof this.beforeClose === 'function') { + this.beforeClose(this.hide); + } else { + this.hide(); + } + }, + hide: function hide(cancel) { + if (cancel !== false) { + this.$emit('update:visible', false); + this.$emit('close'); + this.closed = true; + } + }, + updatePopper: function updatePopper() { + this.broadcast('ElSelectDropdown', 'updatePopper'); + this.broadcast('ElDropdownMenu', 'updatePopper'); + }, + afterEnter: function afterEnter() { + this.$emit('opened'); + }, + afterLeave: function afterLeave() { + this.$emit('closed'); + } + }, + + mounted: function mounted() { + if (this.visible) { + this.rendered = true; + this.open(); + if (this.appendToBody) { + document.body.appendChild(this.$el); + } + } + }, + destroyed: function destroyed() { + // if appendToBody is true, remove DOM node after destroy + if (this.appendToBody && this.$el && this.$el.parentNode) { + this.$el.parentNode.removeChild(this.$el); + } + } +}); +// CONCATENATED MODULE: ./packages/dialog/src/component.vue?vue&type=script&lang=js& + /* harmony default export */ var src_componentvue_type_script_lang_js_ = (componentvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/dialog/src/component.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_componentvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/dialog/src/component.vue" +/* harmony default export */ var src_component = (component.exports); +// CONCATENATED MODULE: ./packages/dialog/index.js + + +/* istanbul ignore next */ +src_component.install = function (Vue) { + Vue.component(src_component.name, src_component); +}; + +/* harmony default export */ var dialog = __webpack_exports__["default"] = (src_component); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/directives/mousewheel.js b/public/static/libs/element-ui/lib/directives/mousewheel.js new file mode 100644 index 0000000..3a2fa1a --- /dev/null +++ b/public/static/libs/element-ui/lib/directives/mousewheel.js @@ -0,0 +1,26 @@ +'use strict'; + +exports.__esModule = true; + +var _normalizeWheel = require('normalize-wheel'); + +var _normalizeWheel2 = _interopRequireDefault(_normalizeWheel); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var isFirefox = typeof navigator !== 'undefined' && navigator.userAgent.toLowerCase().indexOf('firefox') > -1; + +var mousewheel = function mousewheel(element, callback) { + if (element && element.addEventListener) { + element.addEventListener(isFirefox ? 'DOMMouseScroll' : 'mousewheel', function (event) { + var normalized = (0, _normalizeWheel2.default)(event); + callback && callback.apply(this, [event, normalized]); + }); + } +}; + +exports.default = { + bind: function bind(el, binding) { + mousewheel(el, binding.value); + } +}; \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/directives/repeat-click.js b/public/static/libs/element-ui/lib/directives/repeat-click.js new file mode 100644 index 0000000..3937ff3 --- /dev/null +++ b/public/static/libs/element-ui/lib/directives/repeat-click.js @@ -0,0 +1,33 @@ +'use strict'; + +exports.__esModule = true; + +var _dom = require('element-ui/lib/utils/dom'); + +var _util = require('element-ui/lib/utils/util'); + +exports.default = { + bind: function bind(el, binding, vnode) { + var interval = null; + var startTime = void 0; + var maxIntervals = (0, _util.isMac)() ? 100 : 200; + var handler = function handler() { + return vnode.context[binding.expression].apply(); + }; + var clear = function clear() { + if (Date.now() - startTime < maxIntervals) { + handler(); + } + clearInterval(interval); + interval = null; + }; + + (0, _dom.on)(el, 'mousedown', function (e) { + if (e.button !== 0) return; + startTime = Date.now(); + (0, _dom.once)(document, 'mouseup', clear); + clearInterval(interval); + interval = setInterval(handler, maxIntervals); + }); + } +}; \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/divider.js b/public/static/libs/element-ui/lib/divider.js new file mode 100644 index 0000000..12940d2 --- /dev/null +++ b/public/static/libs/element-ui/lib/divider.js @@ -0,0 +1,312 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 123); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 123: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/divider/src/main.vue?vue&type=template&id=7fa02a7e&functional=true& +var render = function(_h, _vm) { + var _c = _vm._c + return _c( + "div", + _vm._g( + _vm._b( + { + class: [ + _vm.data.staticClass, + "el-divider", + "el-divider--" + _vm.props.direction + ] + }, + "div", + _vm.data.attrs, + false + ), + _vm.listeners + ), + [ + _vm.slots().default && _vm.props.direction !== "vertical" + ? _c( + "div", + { class: ["el-divider__text", "is-" + _vm.props.contentPosition] }, + [_vm._t("default")], + 2 + ) + : _vm._e() + ] + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/divider/src/main.vue?vue&type=template&id=7fa02a7e&functional=true& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/divider/src/main.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + +/* harmony default export */ var mainvue_type_script_lang_js_ = ({ + name: 'ElDivider', + props: { + direction: { + type: String, + default: 'horizontal', + validator: function validator(val) { + return ['horizontal', 'vertical'].indexOf(val) !== -1; + } + }, + contentPosition: { + type: String, + default: 'center', + validator: function validator(val) { + return ['left', 'center', 'right'].indexOf(val) !== -1; + } + } + } +}); +// CONCATENATED MODULE: ./packages/divider/src/main.vue?vue&type=script&lang=js& + /* harmony default export */ var src_mainvue_type_script_lang_js_ = (mainvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/divider/src/main.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_mainvue_type_script_lang_js_, + render, + staticRenderFns, + true, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/divider/src/main.vue" +/* harmony default export */ var main = (component.exports); +// CONCATENATED MODULE: ./packages/divider/index.js + + +/* istanbul ignore next */ +main.install = function (Vue) { + Vue.component(main.name, main); +}; + +/* harmony default export */ var divider = __webpack_exports__["default"] = (main); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/drawer.js b/public/static/libs/element-ui/lib/drawer.js new file mode 100644 index 0000000..ed85f07 --- /dev/null +++ b/public/static/libs/element-ui/lib/drawer.js @@ -0,0 +1,591 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 126); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 126: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/drawer/src/main.vue?vue&type=template&id=a4885264& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "transition", + { + attrs: { name: "el-drawer-fade" }, + on: { "after-enter": _vm.afterEnter, "after-leave": _vm.afterLeave } + }, + [ + _c( + "div", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.visible, + expression: "visible" + } + ], + staticClass: "el-drawer__wrapper", + attrs: { tabindex: "-1" } + }, + [ + _c( + "div", + { + staticClass: "el-drawer__container", + class: _vm.visible && "el-drawer__open", + attrs: { role: "document", tabindex: "-1" }, + on: { + click: function($event) { + if ($event.target !== $event.currentTarget) { + return null + } + return _vm.handleWrapperClick($event) + } + } + }, + [ + _c( + "div", + { + ref: "drawer", + staticClass: "el-drawer", + class: [_vm.direction, _vm.customClass], + style: _vm.isHorizontal + ? "width: " + _vm.drawerSize + : "height: " + _vm.drawerSize, + attrs: { + "aria-modal": "true", + "aria-labelledby": "el-drawer__title", + "aria-label": _vm.title, + role: "dialog", + tabindex: "-1" + } + }, + [ + _vm.withHeader + ? _c( + "header", + { + staticClass: "el-drawer__header", + attrs: { id: "el-drawer__title" } + }, + [ + _vm._t("title", [ + _c( + "span", + { attrs: { role: "heading", title: _vm.title } }, + [_vm._v(_vm._s(_vm.title))] + ) + ]), + _vm.showClose + ? _c( + "button", + { + staticClass: "el-drawer__close-btn", + attrs: { + "aria-label": + "close " + (_vm.title || "drawer"), + type: "button" + }, + on: { click: _vm.closeDrawer } + }, + [ + _c("i", { + staticClass: + "el-dialog__close el-icon el-icon-close" + }) + ] + ) + : _vm._e() + ], + 2 + ) + : _vm._e(), + _vm.rendered + ? _c( + "section", + { staticClass: "el-drawer__body" }, + [_vm._t("default")], + 2 + ) + : _vm._e() + ] + ) + ] + ) + ] + ) + ] + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/drawer/src/main.vue?vue&type=template&id=a4885264& + +// EXTERNAL MODULE: external "element-ui/lib/utils/popup" +var popup_ = __webpack_require__(13); +var popup_default = /*#__PURE__*/__webpack_require__.n(popup_); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/emitter" +var emitter_ = __webpack_require__(4); +var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/drawer/src/main.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + +/* harmony default export */ var mainvue_type_script_lang_js_ = ({ + name: 'ElDrawer', + mixins: [popup_default.a, emitter_default.a], + props: { + appendToBody: { + type: Boolean, + default: false + }, + beforeClose: { + type: Function + }, + customClass: { + type: String, + default: '' + }, + closeOnPressEscape: { + type: Boolean, + default: true + }, + destroyOnClose: { + type: Boolean, + default: false + }, + modal: { + type: Boolean, + default: true + }, + direction: { + type: String, + default: 'rtl', + validator: function validator(val) { + return ['ltr', 'rtl', 'ttb', 'btt'].indexOf(val) !== -1; + } + }, + modalAppendToBody: { + type: Boolean, + default: true + }, + showClose: { + type: Boolean, + default: true + }, + size: { + type: [Number, String], + default: '30%' + }, + title: { + type: String, + default: '' + }, + visible: { + type: Boolean + }, + wrapperClosable: { + type: Boolean, + default: true + }, + withHeader: { + type: Boolean, + default: true + } + }, + computed: { + isHorizontal: function isHorizontal() { + return this.direction === 'rtl' || this.direction === 'ltr'; + }, + drawerSize: function drawerSize() { + return typeof this.size === 'number' ? this.size + 'px' : this.size; + } + }, + data: function data() { + return { + closed: false, + prevActiveElement: null + }; + }, + + watch: { + visible: function visible(val) { + var _this = this; + + if (val) { + this.closed = false; + this.$emit('open'); + if (this.appendToBody) { + document.body.appendChild(this.$el); + } + this.prevActiveElement = document.activeElement; + } else { + if (!this.closed) { + this.$emit('close'); + if (this.destroyOnClose === true) { + this.rendered = false; + } + } + this.$nextTick(function () { + if (_this.prevActiveElement) { + _this.prevActiveElement.focus(); + } + }); + } + } + }, + methods: { + afterEnter: function afterEnter() { + this.$emit('opened'); + }, + afterLeave: function afterLeave() { + this.$emit('closed'); + }, + hide: function hide(cancel) { + if (cancel !== false) { + this.$emit('update:visible', false); + this.$emit('close'); + if (this.destroyOnClose === true) { + this.rendered = false; + } + this.closed = true; + } + }, + handleWrapperClick: function handleWrapperClick() { + if (this.wrapperClosable) { + this.closeDrawer(); + } + }, + closeDrawer: function closeDrawer() { + if (typeof this.beforeClose === 'function') { + this.beforeClose(this.hide); + } else { + this.hide(); + } + }, + handleClose: function handleClose() { + // This method here will be called by PopupManger, when the `closeOnPressEscape` was set to true + // pressing `ESC` will call this method, and also close the drawer. + // This method also calls `beforeClose` if there was one. + this.closeDrawer(); + } + }, + mounted: function mounted() { + if (this.visible) { + this.rendered = true; + this.open(); + if (this.appendToBody) { + document.body.appendChild(this.$el); + } + } + }, + destroyed: function destroyed() { + // if appendToBody is true, remove DOM node after destroy + if (this.appendToBody && this.$el && this.$el.parentNode) { + this.$el.parentNode.removeChild(this.$el); + } + } +}); +// CONCATENATED MODULE: ./packages/drawer/src/main.vue?vue&type=script&lang=js& + /* harmony default export */ var src_mainvue_type_script_lang_js_ = (mainvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/drawer/src/main.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_mainvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/drawer/src/main.vue" +/* harmony default export */ var main = (component.exports); +// CONCATENATED MODULE: ./packages/drawer/index.js + + +/* istanbul ignore next */ +main.install = function (Vue) { + Vue.component(main.name, main); +}; + +/* harmony default export */ var drawer = __webpack_exports__["default"] = (main); + +/***/ }), + +/***/ 13: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/popup"); + +/***/ }), + +/***/ 4: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/emitter"); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/dropdown-item.js b/public/static/libs/element-ui/lib/dropdown-item.js new file mode 100644 index 0000000..77afaf6 --- /dev/null +++ b/public/static/libs/element-ui/lib/dropdown-item.js @@ -0,0 +1,315 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 84); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 4: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/emitter"); + +/***/ }), + +/***/ 84: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-item.vue?vue&type=template&id=6359102a& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "li", + { + staticClass: "el-dropdown-menu__item", + class: { + "is-disabled": _vm.disabled, + "el-dropdown-menu__item--divided": _vm.divided + }, + attrs: { + "aria-disabled": _vm.disabled, + tabindex: _vm.disabled ? null : -1 + }, + on: { click: _vm.handleClick } + }, + [_vm.icon ? _c("i", { class: _vm.icon }) : _vm._e(), _vm._t("default")], + 2 + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/dropdown/src/dropdown-item.vue?vue&type=template&id=6359102a& + +// EXTERNAL MODULE: external "element-ui/lib/mixins/emitter" +var emitter_ = __webpack_require__(4); +var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-item.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + +/* harmony default export */ var dropdown_itemvue_type_script_lang_js_ = ({ + name: 'ElDropdownItem', + + mixins: [emitter_default.a], + + props: { + command: {}, + disabled: Boolean, + divided: Boolean, + icon: String + }, + + methods: { + handleClick: function handleClick(e) { + this.dispatch('ElDropdown', 'menu-item-click', [this.command, this]); + } + } +}); +// CONCATENATED MODULE: ./packages/dropdown/src/dropdown-item.vue?vue&type=script&lang=js& + /* harmony default export */ var src_dropdown_itemvue_type_script_lang_js_ = (dropdown_itemvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/dropdown/src/dropdown-item.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_dropdown_itemvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/dropdown/src/dropdown-item.vue" +/* harmony default export */ var dropdown_item = (component.exports); +// CONCATENATED MODULE: ./packages/dropdown-item/index.js + + +/* istanbul ignore next */ +dropdown_item.install = function (Vue) { + Vue.component(dropdown_item.name, dropdown_item); +}; + +/* harmony default export */ var packages_dropdown_item = __webpack_exports__["default"] = (dropdown_item); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/dropdown-menu.js b/public/static/libs/element-ui/lib/dropdown-menu.js new file mode 100644 index 0000000..7372b70 --- /dev/null +++ b/public/static/libs/element-ui/lib/dropdown-menu.js @@ -0,0 +1,350 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 83); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 5: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/vue-popper"); + +/***/ }), + +/***/ 83: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-menu.vue?vue&type=template&id=0da6b714& +var render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "transition", + { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": _vm.doDestroy } }, + [ + _c( + "ul", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.showPopper, + expression: "showPopper" + } + ], + staticClass: "el-dropdown-menu el-popper", + class: [_vm.size && "el-dropdown-menu--" + _vm.size] + }, + [_vm._t("default")], + 2 + ) + ] + ) +} +var staticRenderFns = [] +render._withStripped = true + + +// CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue?vue&type=template&id=0da6b714& + +// EXTERNAL MODULE: external "element-ui/lib/utils/vue-popper" +var vue_popper_ = __webpack_require__(5); +var vue_popper_default = /*#__PURE__*/__webpack_require__.n(vue_popper_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-menu.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// + + + +/* harmony default export */ var dropdown_menuvue_type_script_lang_js_ = ({ + name: 'ElDropdownMenu', + + componentName: 'ElDropdownMenu', + + mixins: [vue_popper_default.a], + + props: { + visibleArrow: { + type: Boolean, + default: true + }, + arrowOffset: { + type: Number, + default: 0 + } + }, + + data: function data() { + return { + size: this.dropdown.dropdownSize + }; + }, + + + inject: ['dropdown'], + + created: function created() { + var _this = this; + + this.$on('updatePopper', function () { + if (_this.showPopper) _this.updatePopper(); + }); + this.$on('visible', function (val) { + _this.showPopper = val; + }); + }, + mounted: function mounted() { + this.dropdown.popperElm = this.popperElm = this.$el; + this.referenceElm = this.dropdown.$el; + // compatible with 2.6 new v-slot syntax + // issue link https://github.com/ElemeFE/element/issues/14345 + this.dropdown.initDomOperation(); + }, + + + watch: { + 'dropdown.placement': { + immediate: true, + handler: function handler(val) { + this.currentPlacement = val; + } + } + } +}); +// CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue?vue&type=script&lang=js& + /* harmony default export */ var src_dropdown_menuvue_type_script_lang_js_ = (dropdown_menuvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue + + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_dropdown_menuvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/dropdown/src/dropdown-menu.vue" +/* harmony default export */ var dropdown_menu = (component.exports); +// CONCATENATED MODULE: ./packages/dropdown-menu/index.js + + +/* istanbul ignore next */ +dropdown_menu.install = function (Vue) { + Vue.component(dropdown_menu.name, dropdown_menu); +}; + +/* harmony default export */ var packages_dropdown_menu = __webpack_exports__["default"] = (dropdown_menu); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/dropdown.js b/public/static/libs/element-ui/lib/dropdown.js new file mode 100644 index 0000000..9719a09 --- /dev/null +++ b/public/static/libs/element-ui/lib/dropdown.js @@ -0,0 +1,642 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 130); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ 0: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + + +/***/ }), + +/***/ 11: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/migrating"); + +/***/ }), + +/***/ 12: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/clickoutside"); + +/***/ }), + +/***/ 130: +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// EXTERNAL MODULE: external "element-ui/lib/utils/clickoutside" +var clickoutside_ = __webpack_require__(12); +var clickoutside_default = /*#__PURE__*/__webpack_require__.n(clickoutside_); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/emitter" +var emitter_ = __webpack_require__(4); +var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/migrating" +var migrating_ = __webpack_require__(11); +var migrating_default = /*#__PURE__*/__webpack_require__.n(migrating_); + +// EXTERNAL MODULE: external "element-ui/lib/button" +var button_ = __webpack_require__(14); +var button_default = /*#__PURE__*/__webpack_require__.n(button_); + +// EXTERNAL MODULE: external "element-ui/lib/button-group" +var button_group_ = __webpack_require__(36); +var button_group_default = /*#__PURE__*/__webpack_require__.n(button_group_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/util" +var util_ = __webpack_require__(3); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown.vue?vue&type=script&lang=js& + + + + + + + + +/* harmony default export */ var dropdownvue_type_script_lang_js_ = ({ + name: 'ElDropdown', + + componentName: 'ElDropdown', + + mixins: [emitter_default.a, migrating_default.a], + + directives: { Clickoutside: clickoutside_default.a }, + + components: { + ElButton: button_default.a, + ElButtonGroup: button_group_default.a + }, + + provide: function provide() { + return { + dropdown: this + }; + }, + + + props: { + trigger: { + type: String, + default: 'hover' + }, + type: String, + size: { + type: String, + default: '' + }, + splitButton: Boolean, + hideOnClick: { + type: Boolean, + default: true + }, + placement: { + type: String, + default: 'bottom-end' + }, + visibleArrow: { + default: true + }, + showTimeout: { + type: Number, + default: 250 + }, + hideTimeout: { + type: Number, + default: 150 + }, + tabindex: { + type: Number, + default: 0 + }, + disabled: { + type: Boolean, + default: false + } + }, + + data: function data() { + return { + timeout: null, + visible: false, + triggerElm: null, + menuItems: null, + menuItemsArray: null, + dropdownElm: null, + focusing: false, + listId: 'dropdown-menu-' + Object(util_["generateId"])() + }; + }, + + + computed: { + dropdownSize: function dropdownSize() { + return this.size || (this.$ELEMENT || {}).size; + } + }, + + mounted: function mounted() { + this.$on('menu-item-click', this.handleMenuItemClick); + }, + + + watch: { + visible: function visible(val) { + this.broadcast('ElDropdownMenu', 'visible', val); + this.$emit('visible-change', val); + }, + focusing: function focusing(val) { + var selfDefine = this.$el.querySelector('.el-dropdown-selfdefine'); + if (selfDefine) { + // 自定义 + if (val) { + selfDefine.className += ' focusing'; + } else { + selfDefine.className = selfDefine.className.replace('focusing', ''); + } + } + } + }, + + methods: { + getMigratingConfig: function getMigratingConfig() { + return { + props: { + 'menu-align': 'menu-align is renamed to placement.' + } + }; + }, + show: function show() { + var _this = this; + + if (this.disabled) return; + clearTimeout(this.timeout); + this.timeout = setTimeout(function () { + _this.visible = true; + }, this.trigger === 'click' ? 0 : this.showTimeout); + }, + hide: function hide() { + var _this2 = this; + + if (this.disabled) return; + this.removeTabindex(); + if (this.tabindex >= 0) { + this.resetTabindex(this.triggerElm); + } + clearTimeout(this.timeout); + this.timeout = setTimeout(function () { + _this2.visible = false; + }, this.trigger === 'click' ? 0 : this.hideTimeout); + }, + handleClick: function handleClick() { + if (this.disabled) return; + if (this.visible) { + this.hide(); + } else { + this.show(); + } + }, + handleTriggerKeyDown: function handleTriggerKeyDown(ev) { + var keyCode = ev.keyCode; + if ([38, 40].indexOf(keyCode) > -1) { + // up/down + this.removeTabindex(); + this.resetTabindex(this.menuItems[0]); + this.menuItems[0].focus(); + ev.preventDefault(); + ev.stopPropagation(); + } else if (keyCode === 13) { + // space enter选中 + this.handleClick(); + } else if ([9, 27].indexOf(keyCode) > -1) { + // tab || esc + this.hide(); + } + }, + handleItemKeyDown: function handleItemKeyDown(ev) { + var keyCode = ev.keyCode; + var target = ev.target; + var currentIndex = this.menuItemsArray.indexOf(target); + var max = this.menuItemsArray.length - 1; + var nextIndex = void 0; + if ([38, 40].indexOf(keyCode) > -1) { + // up/down + if (keyCode === 38) { + // up + nextIndex = currentIndex !== 0 ? currentIndex - 1 : 0; + } else { + // down + nextIndex = currentIndex < max ? currentIndex + 1 : max; + } + this.removeTabindex(); + this.resetTabindex(this.menuItems[nextIndex]); + this.menuItems[nextIndex].focus(); + ev.preventDefault(); + ev.stopPropagation(); + } else if (keyCode === 13) { + // enter选中 + this.triggerElmFocus(); + target.click(); + if (this.hideOnClick) { + // click关闭 + this.visible = false; + } + } else if ([9, 27].indexOf(keyCode) > -1) { + // tab // esc + this.hide(); + this.triggerElmFocus(); + } + }, + resetTabindex: function resetTabindex(ele) { + // 下次tab时组件聚焦元素 + this.removeTabindex(); + ele.setAttribute('tabindex', '0'); // 下次期望的聚焦元素 + }, + removeTabindex: function removeTabindex() { + this.triggerElm.setAttribute('tabindex', '-1'); + this.menuItemsArray.forEach(function (item) { + item.setAttribute('tabindex', '-1'); + }); + }, + initAria: function initAria() { + this.dropdownElm.setAttribute('id', this.listId); + this.triggerElm.setAttribute('aria-haspopup', 'list'); + this.triggerElm.setAttribute('aria-controls', this.listId); + + if (!this.splitButton) { + // 自定义 + this.triggerElm.setAttribute('role', 'button'); + this.triggerElm.setAttribute('tabindex', this.tabindex); + this.triggerElm.setAttribute('class', (this.triggerElm.getAttribute('class') || '') + ' el-dropdown-selfdefine'); // 控制 + } + }, + initEvent: function initEvent() { + var _this3 = this; + + var trigger = this.trigger, + show = this.show, + hide = this.hide, + handleClick = this.handleClick, + splitButton = this.splitButton, + handleTriggerKeyDown = this.handleTriggerKeyDown, + handleItemKeyDown = this.handleItemKeyDown; + + this.triggerElm = splitButton ? this.$refs.trigger.$el : this.$slots.default[0].elm; + + var dropdownElm = this.dropdownElm; + + this.triggerElm.addEventListener('keydown', handleTriggerKeyDown); // triggerElm keydown + dropdownElm.addEventListener('keydown', handleItemKeyDown, true); // item keydown + // 控制自定义元素的样式 + if (!splitButton) { + this.triggerElm.addEventListener('focus', function () { + _this3.focusing = true; + }); + this.triggerElm.addEventListener('blur', function () { + _this3.focusing = false; + }); + this.triggerElm.addEventListener('click', function () { + _this3.focusing = false; + }); + } + if (trigger === 'hover') { + this.triggerElm.addEventListener('mouseenter', show); + this.triggerElm.addEventListener('mouseleave', hide); + dropdownElm.addEventListener('mouseenter', show); + dropdownElm.addEventListener('mouseleave', hide); + } else if (trigger === 'click') { + this.triggerElm.addEventListener('click', handleClick); + } + }, + handleMenuItemClick: function handleMenuItemClick(command, instance) { + if (this.hideOnClick) { + this.visible = false; + } + this.$emit('command', command, instance); + }, + triggerElmFocus: function triggerElmFocus() { + this.triggerElm.focus && this.triggerElm.focus(); + }, + initDomOperation: function initDomOperation() { + this.dropdownElm = this.popperElm; + this.menuItems = this.dropdownElm.querySelectorAll("[tabindex='-1']"); + this.menuItemsArray = [].slice.call(this.menuItems); + + this.initEvent(); + this.initAria(); + } + }, + + render: function render(h) { + var _this4 = this; + + var hide = this.hide, + splitButton = this.splitButton, + type = this.type, + dropdownSize = this.dropdownSize, + disabled = this.disabled; + + + var handleMainButtonClick = function handleMainButtonClick(event) { + _this4.$emit('click', event); + hide(); + }; + + var triggerElm = null; + if (splitButton) { + triggerElm = h('el-button-group', [h( + 'el-button', + { + attrs: { type: type, size: dropdownSize, disabled: disabled }, + nativeOn: { + 'click': handleMainButtonClick + } + }, + [this.$slots.default] + ), h( + 'el-button', + { ref: 'trigger', attrs: { type: type, size: dropdownSize, disabled: disabled }, + 'class': 'el-dropdown__caret-button' }, + [h('i', { 'class': 'el-dropdown__icon el-icon-arrow-down' })] + )]); + } else { + triggerElm = this.$slots.default; + var vnodeData = triggerElm[0].data || {}; + var _vnodeData$attrs = vnodeData.attrs, + attrs = _vnodeData$attrs === undefined ? {} : _vnodeData$attrs; + + if (disabled && !attrs.disabled) { + attrs.disabled = true; + vnodeData.attrs = attrs; + } + } + var menuElm = disabled ? null : this.$slots.dropdown; + + return h( + 'div', + { 'class': 'el-dropdown', directives: [{ + name: 'clickoutside', + value: hide + }], + attrs: { 'aria-disabled': disabled } + }, + [triggerElm, menuElm] + ); + } +}); +// CONCATENATED MODULE: ./packages/dropdown/src/dropdown.vue?vue&type=script&lang=js& + /* harmony default export */ var src_dropdownvue_type_script_lang_js_ = (dropdownvue_type_script_lang_js_); +// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +var componentNormalizer = __webpack_require__(0); + +// CONCATENATED MODULE: ./packages/dropdown/src/dropdown.vue +var render, staticRenderFns + + + + +/* normalize component */ + +var component = Object(componentNormalizer["a" /* default */])( + src_dropdownvue_type_script_lang_js_, + render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/dropdown/src/dropdown.vue" +/* harmony default export */ var dropdown = (component.exports); +// CONCATENATED MODULE: ./packages/dropdown/index.js + + +/* istanbul ignore next */ +dropdown.install = function (Vue) { + Vue.component(dropdown.name, dropdown); +}; + +/* harmony default export */ var packages_dropdown = __webpack_exports__["default"] = (dropdown); + +/***/ }), + +/***/ 14: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/button"); + +/***/ }), + +/***/ 3: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/util"); + +/***/ }), + +/***/ 36: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/button-group"); + +/***/ }), + +/***/ 4: +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/emitter"); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/public/static/libs/element-ui/lib/element-ui.common.js b/public/static/libs/element-ui/lib/element-ui.common.js new file mode 100644 index 0000000..5631486 --- /dev/null +++ b/public/static/libs/element-ui/lib/element-ui.common.js @@ -0,0 +1,43907 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 46); +/******/ }) +/************************************************************************/ +/******/ ([ +/* 0 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/date-util"); + +/***/ }), +/* 1 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/dom"); + +/***/ }), +/* 2 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/util"); + +/***/ }), +/* 3 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/emitter"); + +/***/ }), +/* 4 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/locale"); + +/***/ }), +/* 5 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/vue-popper"); + +/***/ }), +/* 6 */ +/***/ (function(module, exports) { + +module.exports = require("vue"); + +/***/ }), +/* 7 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/merge"); + +/***/ }), +/* 8 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/input"); + +/***/ }), +/* 9 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/migrating"); + +/***/ }), +/* 10 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/clickoutside"); + +/***/ }), +/* 11 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/popup"); + +/***/ }), +/* 12 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/locale"); + +/***/ }), +/* 13 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/button"); + +/***/ }), +/* 14 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/checkbox"); + +/***/ }), +/* 15 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/resize-event"); + +/***/ }), +/* 16 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/types"); + +/***/ }), +/* 17 */ +/***/ (function(module, exports) { + +module.exports = require("throttle-debounce/debounce"); + +/***/ }), +/* 18 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/scrollbar"); + +/***/ }), +/* 19 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/shared"); + +/***/ }), +/* 20 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/date"); + +/***/ }), +/* 21 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/transitions/collapse-transition"); + +/***/ }), +/* 22 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/vdom"); + +/***/ }), +/* 23 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/mixins/focus"); + +/***/ }), +/* 24 */ +/***/ (function(module, exports) { + +module.exports = require("babel-helper-vue-jsx-merge-props"); + +/***/ }), +/* 25 */ +/***/ (function(module, exports) { + +module.exports = require("throttle-debounce/throttle"); + +/***/ }), +/* 26 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/tooltip"); + +/***/ }), +/* 27 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/scroll-into-view"); + +/***/ }), +/* 28 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/lodash"); + +/***/ }), +/* 29 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/button-group"); + +/***/ }), +/* 30 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/tag"); + +/***/ }), +/* 31 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/scrollbar-width"); + +/***/ }), +/* 32 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/checkbox-group"); + +/***/ }), +/* 33 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/after-leave"); + +/***/ }), +/* 34 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/progress"); + +/***/ }), +/* 35 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/aria-utils"); + +/***/ }), +/* 36 */ +/***/ (function(module, exports) { + +module.exports = require("throttle-debounce"); + +/***/ }), +/* 37 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/select"); + +/***/ }), +/* 38 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/option"); + +/***/ }), +/* 39 */ +/***/ (function(module, exports) { + +module.exports = require("normalize-wheel"); + +/***/ }), +/* 40 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/utils/aria-dialog"); + +/***/ }), +/* 41 */ +/***/ (function(module, exports) { + +module.exports = require("async-validator"); + +/***/ }), +/* 42 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/input-number"); + +/***/ }), +/* 43 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/cascader-panel"); + +/***/ }), +/* 44 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/radio"); + +/***/ }), +/* 45 */ +/***/ (function(module, exports) { + +module.exports = require("element-ui/lib/popover"); + +/***/ }), +/* 46 */ +/***/ (function(module, exports, __webpack_require__) { + +module.exports = __webpack_require__(47); + + +/***/ }), +/* 47 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/pagination/src/pager.vue?vue&type=template&id=7274f267& +var pagervue_type_template_id_7274f267_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "ul", + { staticClass: "el-pager", on: { click: _vm.onPagerClick } }, + [ + _vm.pageCount > 0 + ? _c( + "li", + { + staticClass: "number", + class: { active: _vm.currentPage === 1, disabled: _vm.disabled } + }, + [_vm._v("1")] + ) + : _vm._e(), + _vm.showPrevMore + ? _c("li", { + staticClass: "el-icon more btn-quickprev", + class: [_vm.quickprevIconClass, { disabled: _vm.disabled }], + on: { + mouseenter: function($event) { + _vm.onMouseenter("left") + }, + mouseleave: function($event) { + _vm.quickprevIconClass = "el-icon-more" + } + } + }) + : _vm._e(), + _vm._l(_vm.pagers, function(pager) { + return _c( + "li", + { + key: pager, + staticClass: "number", + class: { active: _vm.currentPage === pager, disabled: _vm.disabled } + }, + [_vm._v(_vm._s(pager))] + ) + }), + _vm.showNextMore + ? _c("li", { + staticClass: "el-icon more btn-quicknext", + class: [_vm.quicknextIconClass, { disabled: _vm.disabled }], + on: { + mouseenter: function($event) { + _vm.onMouseenter("right") + }, + mouseleave: function($event) { + _vm.quicknextIconClass = "el-icon-more" + } + } + }) + : _vm._e(), + _vm.pageCount > 1 + ? _c( + "li", + { + staticClass: "number", + class: { + active: _vm.currentPage === _vm.pageCount, + disabled: _vm.disabled + } + }, + [_vm._v(_vm._s(_vm.pageCount))] + ) + : _vm._e() + ], + 2 + ) +} +var staticRenderFns = [] +pagervue_type_template_id_7274f267_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/pagination/src/pager.vue?vue&type=template&id=7274f267& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/pagination/src/pager.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + +/* harmony default export */ var pagervue_type_script_lang_js_ = ({ + name: 'ElPager', + + props: { + currentPage: Number, + + pageCount: Number, + + pagerCount: Number, + + disabled: Boolean + }, + + watch: { + showPrevMore: function showPrevMore(val) { + if (!val) this.quickprevIconClass = 'el-icon-more'; + }, + showNextMore: function showNextMore(val) { + if (!val) this.quicknextIconClass = 'el-icon-more'; + } + }, + + methods: { + onPagerClick: function onPagerClick(event) { + var target = event.target; + if (target.tagName === 'UL' || this.disabled) { + return; + } + + var newPage = Number(event.target.textContent); + var pageCount = this.pageCount; + var currentPage = this.currentPage; + var pagerCountOffset = this.pagerCount - 2; + + if (target.className.indexOf('more') !== -1) { + if (target.className.indexOf('quickprev') !== -1) { + newPage = currentPage - pagerCountOffset; + } else if (target.className.indexOf('quicknext') !== -1) { + newPage = currentPage + pagerCountOffset; + } + } + + /* istanbul ignore if */ + if (!isNaN(newPage)) { + if (newPage < 1) { + newPage = 1; + } + + if (newPage > pageCount) { + newPage = pageCount; + } + } + + if (newPage !== currentPage) { + this.$emit('change', newPage); + } + }, + onMouseenter: function onMouseenter(direction) { + if (this.disabled) return; + if (direction === 'left') { + this.quickprevIconClass = 'el-icon-d-arrow-left'; + } else { + this.quicknextIconClass = 'el-icon-d-arrow-right'; + } + } + }, + + computed: { + pagers: function pagers() { + var pagerCount = this.pagerCount; + var halfPagerCount = (pagerCount - 1) / 2; + + var currentPage = Number(this.currentPage); + var pageCount = Number(this.pageCount); + + var showPrevMore = false; + var showNextMore = false; + + if (pageCount > pagerCount) { + if (currentPage > pagerCount - halfPagerCount) { + showPrevMore = true; + } + + if (currentPage < pageCount - halfPagerCount) { + showNextMore = true; + } + } + + var array = []; + + if (showPrevMore && !showNextMore) { + var startPage = pageCount - (pagerCount - 2); + for (var i = startPage; i < pageCount; i++) { + array.push(i); + } + } else if (!showPrevMore && showNextMore) { + for (var _i = 2; _i < pagerCount; _i++) { + array.push(_i); + } + } else if (showPrevMore && showNextMore) { + var offset = Math.floor(pagerCount / 2) - 1; + for (var _i2 = currentPage - offset; _i2 <= currentPage + offset; _i2++) { + array.push(_i2); + } + } else { + for (var _i3 = 2; _i3 < pageCount; _i3++) { + array.push(_i3); + } + } + + this.showPrevMore = showPrevMore; + this.showNextMore = showNextMore; + + return array; + } + }, + + data: function data() { + return { + current: null, + showPrevMore: false, + showNextMore: false, + quicknextIconClass: 'el-icon-more', + quickprevIconClass: 'el-icon-more' + }; + } +}); +// CONCATENATED MODULE: ./packages/pagination/src/pager.vue?vue&type=script&lang=js& + /* harmony default export */ var src_pagervue_type_script_lang_js_ = (pagervue_type_script_lang_js_); +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js +/* globals __VUE_SSR_CONTEXT__ */ + +// IMPORTANT: Do NOT use ES2015 features in this file (except for modules). +// This module is a runtime utility for cleaner component module output and will +// be included in the final webpack user bundle. + +function normalizeComponent ( + scriptExports, + render, + staticRenderFns, + functionalTemplate, + injectStyles, + scopeId, + moduleIdentifier, /* server only */ + shadowMode /* vue-cli only */ +) { + // Vue.extend constructor export interop + var options = typeof scriptExports === 'function' + ? scriptExports.options + : scriptExports + + // render functions + if (render) { + options.render = render + options.staticRenderFns = staticRenderFns + options._compiled = true + } + + // functional template + if (functionalTemplate) { + options.functional = true + } + + // scopedId + if (scopeId) { + options._scopeId = 'data-v-' + scopeId + } + + var hook + if (moduleIdentifier) { // server build + hook = function (context) { + // 2.3 injection + context = + context || // cached call + (this.$vnode && this.$vnode.ssrContext) || // stateful + (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional + // 2.2 with runInNewContext: true + if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { + context = __VUE_SSR_CONTEXT__ + } + // inject component styles + if (injectStyles) { + injectStyles.call(this, context) + } + // register component module identifier for async chunk inferrence + if (context && context._registeredComponents) { + context._registeredComponents.add(moduleIdentifier) + } + } + // used by ssr in case component is cached and beforeCreate + // never gets called + options._ssrRegister = hook + } else if (injectStyles) { + hook = shadowMode + ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } + : injectStyles + } + + if (hook) { + if (options.functional) { + // for template-only hot-reload because in that case the render fn doesn't + // go through the normalizer + options._injectStyles = hook + // register for functioal component in vue file + var originalRender = options.render + options.render = function renderWithStyleInjection (h, context) { + hook.call(context) + return originalRender(h, context) + } + } else { + // inject component registration as beforeCreate hook + var existing = options.beforeCreate + options.beforeCreate = existing + ? [].concat(existing, hook) + : [hook] + } + } + + return { + exports: scriptExports, + options: options + } +} + +// CONCATENATED MODULE: ./packages/pagination/src/pager.vue + + + + + +/* normalize component */ + +var component = normalizeComponent( + src_pagervue_type_script_lang_js_, + pagervue_type_template_id_7274f267_render, + staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var api; } +component.options.__file = "packages/pagination/src/pager.vue" +/* harmony default export */ var pager = (component.exports); +// EXTERNAL MODULE: external "element-ui/lib/select" +var select_ = __webpack_require__(37); +var select_default = /*#__PURE__*/__webpack_require__.n(select_); + +// EXTERNAL MODULE: external "element-ui/lib/option" +var option_ = __webpack_require__(38); +var option_default = /*#__PURE__*/__webpack_require__.n(option_); + +// EXTERNAL MODULE: external "element-ui/lib/input" +var input_ = __webpack_require__(8); +var input_default = /*#__PURE__*/__webpack_require__.n(input_); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/locale" +var locale_ = __webpack_require__(4); +var locale_default = /*#__PURE__*/__webpack_require__.n(locale_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/util" +var util_ = __webpack_require__(2); + +// CONCATENATED MODULE: ./packages/pagination/src/pagination.js + + + + + + + +/* harmony default export */ var pagination = ({ + name: 'ElPagination', + + props: { + pageSize: { + type: Number, + default: 10 + }, + + small: Boolean, + + total: Number, + + pageCount: Number, + + pagerCount: { + type: Number, + validator: function validator(value) { + return (value | 0) === value && value > 4 && value < 22 && value % 2 === 1; + }, + + default: 7 + }, + + currentPage: { + type: Number, + default: 1 + }, + + layout: { + default: 'prev, pager, next, jumper, ->, total' + }, + + pageSizes: { + type: Array, + default: function _default() { + return [10, 20, 30, 40, 50, 100]; + } + }, + + popperClass: String, + + prevText: String, + + nextText: String, + + background: Boolean, + + disabled: Boolean, + + hideOnSinglePage: Boolean + }, + + data: function data() { + return { + internalCurrentPage: 1, + internalPageSize: 0, + lastEmittedPage: -1, + userChangePageSize: false + }; + }, + render: function render(h) { + var layout = this.layout; + if (!layout) return null; + if (this.hideOnSinglePage && (!this.internalPageCount || this.internalPageCount === 1)) return null; + + var template = h('div', { 'class': ['el-pagination', { + 'is-background': this.background, + 'el-pagination--small': this.small + }] }); + var TEMPLATE_MAP = { + prev: h('prev'), + jumper: h('jumper'), + pager: h('pager', { + attrs: { currentPage: this.internalCurrentPage, pageCount: this.internalPageCount, pagerCount: this.pagerCount, disabled: this.disabled }, + on: { + 'change': this.handleCurrentChange + } + }), + next: h('next'), + sizes: h('sizes', { + attrs: { pageSizes: this.pageSizes } + }), + slot: h('slot', [this.$slots.default ? this.$slots.default : '']), + total: h('total') + }; + var components = layout.split(',').map(function (item) { + return item.trim(); + }); + var rightWrapper = h('div', { 'class': 'el-pagination__rightwrapper' }); + var haveRightWrapper = false; + + template.children = template.children || []; + rightWrapper.children = rightWrapper.children || []; + components.forEach(function (compo) { + if (compo === '->') { + haveRightWrapper = true; + return; + } + + if (!haveRightWrapper) { + template.children.push(TEMPLATE_MAP[compo]); + } else { + rightWrapper.children.push(TEMPLATE_MAP[compo]); + } + }); + + if (haveRightWrapper) { + template.children.unshift(rightWrapper); + } + + return template; + }, + + + components: { + Prev: { + render: function render(h) { + return h( + 'button', + { + attrs: { + type: 'button', + + disabled: this.$parent.disabled || this.$parent.internalCurrentPage <= 1 + }, + 'class': 'btn-prev', on: { + 'click': this.$parent.prev + } + }, + [this.$parent.prevText ? h('span', [this.$parent.prevText]) : h('i', { 'class': 'el-icon el-icon-arrow-left' })] + ); + } + }, + + Next: { + render: function render(h) { + return h( + 'button', + { + attrs: { + type: 'button', + + disabled: this.$parent.disabled || this.$parent.internalCurrentPage === this.$parent.internalPageCount || this.$parent.internalPageCount === 0 + }, + 'class': 'btn-next', on: { + 'click': this.$parent.next + } + }, + [this.$parent.nextText ? h('span', [this.$parent.nextText]) : h('i', { 'class': 'el-icon el-icon-arrow-right' })] + ); + } + }, + + Sizes: { + mixins: [locale_default.a], + + props: { + pageSizes: Array + }, + + watch: { + pageSizes: { + immediate: true, + handler: function handler(newVal, oldVal) { + if (Object(util_["valueEquals"])(newVal, oldVal)) return; + if (Array.isArray(newVal)) { + this.$parent.internalPageSize = newVal.indexOf(this.$parent.pageSize) > -1 ? this.$parent.pageSize : this.pageSizes[0]; + } + } + } + }, + + render: function render(h) { + var _this = this; + + return h( + 'span', + { 'class': 'el-pagination__sizes' }, + [h( + 'el-select', + { + attrs: { + value: this.$parent.internalPageSize, + popperClass: this.$parent.popperClass || '', + size: 'mini', + + disabled: this.$parent.disabled }, + on: { + 'input': this.handleChange + } + }, + [this.pageSizes.map(function (item) { + return h('el-option', { + attrs: { + value: item, + label: item + _this.t('el.pagination.pagesize') } + }); + })] + )] + ); + }, + + + components: { + ElSelect: select_default.a, + ElOption: option_default.a + }, + + methods: { + handleChange: function handleChange(val) { + if (val !== this.$parent.internalPageSize) { + this.$parent.internalPageSize = val = parseInt(val, 10); + this.$parent.userChangePageSize = true; + this.$parent.$emit('update:pageSize', val); + this.$parent.$emit('size-change', val); + } + } + } + }, + + Jumper: { + mixins: [locale_default.a], + + components: { ElInput: input_default.a }, + + data: function data() { + return { + userInput: null + }; + }, + + + watch: { + '$parent.internalCurrentPage': function $parentInternalCurrentPage() { + this.userInput = null; + } + }, + + methods: { + handleKeyup: function handleKeyup(_ref) { + var keyCode = _ref.keyCode, + target = _ref.target; + + // Chrome, Safari, Firefox triggers change event on Enter + // Hack for IE: https://github.com/ElemeFE/element/issues/11710 + // Drop this method when we no longer supports IE + if (keyCode === 13) { + this.handleChange(target.value); + } + }, + handleInput: function handleInput(value) { + this.userInput = value; + }, + handleChange: function handleChange(value) { + this.$parent.internalCurrentPage = this.$parent.getValidCurrentPage(value); + this.$parent.emitChange(); + this.userInput = null; + } + }, + + render: function render(h) { + return h( + 'span', + { 'class': 'el-pagination__jump' }, + [this.t('el.pagination.goto'), h('el-input', { + 'class': 'el-pagination__editor is-in-pagination', + attrs: { min: 1, + max: this.$parent.internalPageCount, + value: this.userInput !== null ? this.userInput : this.$parent.internalCurrentPage, + type: 'number', + disabled: this.$parent.disabled + }, + nativeOn: { + 'keyup': this.handleKeyup + }, + on: { + 'input': this.handleInput, + 'change': this.handleChange + } + }), this.t('el.pagination.pageClassifier')] + ); + } + }, + + Total: { + mixins: [locale_default.a], + + render: function render(h) { + return typeof this.$parent.total === 'number' ? h( + 'span', + { 'class': 'el-pagination__total' }, + [this.t('el.pagination.total', { total: this.$parent.total })] + ) : ''; + } + }, + + Pager: pager + }, + + methods: { + handleCurrentChange: function handleCurrentChange(val) { + this.internalCurrentPage = this.getValidCurrentPage(val); + this.userChangePageSize = true; + this.emitChange(); + }, + prev: function prev() { + if (this.disabled) return; + var newVal = this.internalCurrentPage - 1; + this.internalCurrentPage = this.getValidCurrentPage(newVal); + this.$emit('prev-click', this.internalCurrentPage); + this.emitChange(); + }, + next: function next() { + if (this.disabled) return; + var newVal = this.internalCurrentPage + 1; + this.internalCurrentPage = this.getValidCurrentPage(newVal); + this.$emit('next-click', this.internalCurrentPage); + this.emitChange(); + }, + getValidCurrentPage: function getValidCurrentPage(value) { + value = parseInt(value, 10); + + var havePageCount = typeof this.internalPageCount === 'number'; + + var resetValue = void 0; + if (!havePageCount) { + if (isNaN(value) || value < 1) resetValue = 1; + } else { + if (value < 1) { + resetValue = 1; + } else if (value > this.internalPageCount) { + resetValue = this.internalPageCount; + } + } + + if (resetValue === undefined && isNaN(value)) { + resetValue = 1; + } else if (resetValue === 0) { + resetValue = 1; + } + + return resetValue === undefined ? value : resetValue; + }, + emitChange: function emitChange() { + var _this2 = this; + + this.$nextTick(function () { + if (_this2.internalCurrentPage !== _this2.lastEmittedPage || _this2.userChangePageSize) { + _this2.$emit('current-change', _this2.internalCurrentPage); + _this2.lastEmittedPage = _this2.internalCurrentPage; + _this2.userChangePageSize = false; + } + }); + } + }, + + computed: { + internalPageCount: function internalPageCount() { + if (typeof this.total === 'number') { + return Math.max(1, Math.ceil(this.total / this.internalPageSize)); + } else if (typeof this.pageCount === 'number') { + return Math.max(1, this.pageCount); + } + return null; + } + }, + + watch: { + currentPage: { + immediate: true, + handler: function handler(val) { + this.internalCurrentPage = this.getValidCurrentPage(val); + } + }, + + pageSize: { + immediate: true, + handler: function handler(val) { + this.internalPageSize = isNaN(val) ? 10 : val; + } + }, + + internalCurrentPage: { + immediate: true, + handler: function handler(newVal) { + this.$emit('update:currentPage', newVal); + this.lastEmittedPage = -1; + } + }, + + internalPageCount: function internalPageCount(newVal) { + /* istanbul ignore if */ + var oldPage = this.internalCurrentPage; + if (newVal > 0 && oldPage === 0) { + this.internalCurrentPage = 1; + } else if (oldPage > newVal) { + this.internalCurrentPage = newVal === 0 ? 1 : newVal; + this.userChangePageSize && this.emitChange(); + } + this.userChangePageSize = false; + } + } +}); +// CONCATENATED MODULE: ./packages/pagination/index.js + + +/* istanbul ignore next */ +pagination.install = function (Vue) { + Vue.component(pagination.name, pagination); +}; + +/* harmony default export */ var packages_pagination = (pagination); +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/dialog/src/component.vue?vue&type=template&id=60140e62& +var componentvue_type_template_id_60140e62_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "transition", + { + attrs: { name: "dialog-fade" }, + on: { "after-enter": _vm.afterEnter, "after-leave": _vm.afterLeave } + }, + [ + _c( + "div", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.visible, + expression: "visible" + } + ], + staticClass: "el-dialog__wrapper", + on: { + click: function($event) { + if ($event.target !== $event.currentTarget) { + return null + } + return _vm.handleWrapperClick($event) + } + } + }, + [ + _c( + "div", + { + key: _vm.key, + ref: "dialog", + class: [ + "el-dialog", + { + "is-fullscreen": _vm.fullscreen, + "el-dialog--center": _vm.center + }, + _vm.customClass + ], + style: _vm.style, + attrs: { + role: "dialog", + "aria-modal": "true", + "aria-label": _vm.title || "dialog" + } + }, + [ + _c( + "div", + { staticClass: "el-dialog__header" }, + [ + _vm._t("title", [ + _c("span", { staticClass: "el-dialog__title" }, [ + _vm._v(_vm._s(_vm.title)) + ]) + ]), + _vm.showClose + ? _c( + "button", + { + staticClass: "el-dialog__headerbtn", + attrs: { type: "button", "aria-label": "Close" }, + on: { click: _vm.handleClose } + }, + [ + _c("i", { + staticClass: + "el-dialog__close el-icon el-icon-close" + }) + ] + ) + : _vm._e() + ], + 2 + ), + _vm.rendered + ? _c( + "div", + { staticClass: "el-dialog__body" }, + [_vm._t("default")], + 2 + ) + : _vm._e(), + _vm.$slots.footer + ? _c( + "div", + { staticClass: "el-dialog__footer" }, + [_vm._t("footer")], + 2 + ) + : _vm._e() + ] + ) + ] + ) + ] + ) +} +var componentvue_type_template_id_60140e62_staticRenderFns = [] +componentvue_type_template_id_60140e62_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/dialog/src/component.vue?vue&type=template&id=60140e62& + +// EXTERNAL MODULE: external "element-ui/lib/utils/popup" +var popup_ = __webpack_require__(11); +var popup_default = /*#__PURE__*/__webpack_require__.n(popup_); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/migrating" +var migrating_ = __webpack_require__(9); +var migrating_default = /*#__PURE__*/__webpack_require__.n(migrating_); + +// EXTERNAL MODULE: external "element-ui/lib/mixins/emitter" +var emitter_ = __webpack_require__(3); +var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dialog/src/component.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + +/* harmony default export */ var componentvue_type_script_lang_js_ = ({ + name: 'ElDialog', + + mixins: [popup_default.a, emitter_default.a, migrating_default.a], + + props: { + title: { + type: String, + default: '' + }, + + modal: { + type: Boolean, + default: true + }, + + modalAppendToBody: { + type: Boolean, + default: true + }, + + appendToBody: { + type: Boolean, + default: false + }, + + lockScroll: { + type: Boolean, + default: true + }, + + closeOnClickModal: { + type: Boolean, + default: true + }, + + closeOnPressEscape: { + type: Boolean, + default: true + }, + + showClose: { + type: Boolean, + default: true + }, + + width: String, + + fullscreen: Boolean, + + customClass: { + type: String, + default: '' + }, + + top: { + type: String, + default: '15vh' + }, + beforeClose: Function, + center: { + type: Boolean, + default: false + }, + + destroyOnClose: Boolean + }, + + data: function data() { + return { + closed: false, + key: 0 + }; + }, + + + watch: { + visible: function visible(val) { + var _this = this; + + if (val) { + this.closed = false; + this.$emit('open'); + this.$el.addEventListener('scroll', this.updatePopper); + this.$nextTick(function () { + _this.$refs.dialog.scrollTop = 0; + }); + if (this.appendToBody) { + document.body.appendChild(this.$el); + } + } else { + this.$el.removeEventListener('scroll', this.updatePopper); + if (!this.closed) this.$emit('close'); + if (this.destroyOnClose) { + this.$nextTick(function () { + _this.key++; + }); + } + } + } + }, + + computed: { + style: function style() { + var style = {}; + if (!this.fullscreen) { + style.marginTop = this.top; + if (this.width) { + style.width = this.width; + } + } + return style; + } + }, + + methods: { + getMigratingConfig: function getMigratingConfig() { + return { + props: { + 'size': 'size is removed.' + } + }; + }, + handleWrapperClick: function handleWrapperClick() { + if (!this.closeOnClickModal) return; + this.handleClose(); + }, + handleClose: function handleClose() { + if (typeof this.beforeClose === 'function') { + this.beforeClose(this.hide); + } else { + this.hide(); + } + }, + hide: function hide(cancel) { + if (cancel !== false) { + this.$emit('update:visible', false); + this.$emit('close'); + this.closed = true; + } + }, + updatePopper: function updatePopper() { + this.broadcast('ElSelectDropdown', 'updatePopper'); + this.broadcast('ElDropdownMenu', 'updatePopper'); + }, + afterEnter: function afterEnter() { + this.$emit('opened'); + }, + afterLeave: function afterLeave() { + this.$emit('closed'); + } + }, + + mounted: function mounted() { + if (this.visible) { + this.rendered = true; + this.open(); + if (this.appendToBody) { + document.body.appendChild(this.$el); + } + } + }, + destroyed: function destroyed() { + // if appendToBody is true, remove DOM node after destroy + if (this.appendToBody && this.$el && this.$el.parentNode) { + this.$el.parentNode.removeChild(this.$el); + } + } +}); +// CONCATENATED MODULE: ./packages/dialog/src/component.vue?vue&type=script&lang=js& + /* harmony default export */ var src_componentvue_type_script_lang_js_ = (componentvue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/dialog/src/component.vue + + + + + +/* normalize component */ + +var component_component = normalizeComponent( + src_componentvue_type_script_lang_js_, + componentvue_type_template_id_60140e62_render, + componentvue_type_template_id_60140e62_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var component_api; } +component_component.options.__file = "packages/dialog/src/component.vue" +/* harmony default export */ var src_component = (component_component.exports); +// CONCATENATED MODULE: ./packages/dialog/index.js + + +/* istanbul ignore next */ +src_component.install = function (Vue) { + Vue.component(src_component.name, src_component); +}; + +/* harmony default export */ var dialog = (src_component); +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/autocomplete/src/autocomplete.vue?vue&type=template&id=152f2ee6& +var autocompletevue_type_template_id_152f2ee6_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { + directives: [ + { + name: "clickoutside", + rawName: "v-clickoutside", + value: _vm.close, + expression: "close" + } + ], + staticClass: "el-autocomplete", + attrs: { + "aria-haspopup": "listbox", + role: "combobox", + "aria-expanded": _vm.suggestionVisible, + "aria-owns": _vm.id + } + }, + [ + _c( + "el-input", + _vm._b( + { + ref: "input", + on: { + input: _vm.handleInput, + change: _vm.handleChange, + focus: _vm.handleFocus, + blur: _vm.handleBlur, + clear: _vm.handleClear + }, + nativeOn: { + keydown: [ + function($event) { + if ( + !("button" in $event) && + _vm._k($event.keyCode, "up", 38, $event.key, [ + "Up", + "ArrowUp" + ]) + ) { + return null + } + $event.preventDefault() + _vm.highlight(_vm.highlightedIndex - 1) + }, + function($event) { + if ( + !("button" in $event) && + _vm._k($event.keyCode, "down", 40, $event.key, [ + "Down", + "ArrowDown" + ]) + ) { + return null + } + $event.preventDefault() + _vm.highlight(_vm.highlightedIndex + 1) + }, + function($event) { + if ( + !("button" in $event) && + _vm._k($event.keyCode, "enter", 13, $event.key, "Enter") + ) { + return null + } + return _vm.handleKeyEnter($event) + }, + function($event) { + if ( + !("button" in $event) && + _vm._k($event.keyCode, "tab", 9, $event.key, "Tab") + ) { + return null + } + return _vm.close($event) + } + ] + } + }, + "el-input", + [_vm.$props, _vm.$attrs], + false + ), + [ + _vm.$slots.prepend + ? _c("template", { slot: "prepend" }, [_vm._t("prepend")], 2) + : _vm._e(), + _vm.$slots.append + ? _c("template", { slot: "append" }, [_vm._t("append")], 2) + : _vm._e(), + _vm.$slots.prefix + ? _c("template", { slot: "prefix" }, [_vm._t("prefix")], 2) + : _vm._e(), + _vm.$slots.suffix + ? _c("template", { slot: "suffix" }, [_vm._t("suffix")], 2) + : _vm._e() + ], + 2 + ), + _c( + "el-autocomplete-suggestions", + { + ref: "suggestions", + class: [_vm.popperClass ? _vm.popperClass : ""], + attrs: { + "visible-arrow": "", + "popper-options": _vm.popperOptions, + "append-to-body": _vm.popperAppendToBody, + placement: _vm.placement, + id: _vm.id + } + }, + _vm._l(_vm.suggestions, function(item, index) { + return _c( + "li", + { + key: index, + class: { highlighted: _vm.highlightedIndex === index }, + attrs: { + id: _vm.id + "-item-" + index, + role: "option", + "aria-selected": _vm.highlightedIndex === index + }, + on: { + click: function($event) { + _vm.select(item) + } + } + }, + [ + _vm._t( + "default", + [ + _vm._v("\n " + _vm._s(item[_vm.valueKey]) + "\n ") + ], + { item: item } + ) + ], + 2 + ) + }), + 0 + ) + ], + 1 + ) +} +var autocompletevue_type_template_id_152f2ee6_staticRenderFns = [] +autocompletevue_type_template_id_152f2ee6_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete.vue?vue&type=template&id=152f2ee6& + +// EXTERNAL MODULE: external "throttle-debounce/debounce" +var debounce_ = __webpack_require__(17); +var debounce_default = /*#__PURE__*/__webpack_require__.n(debounce_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/clickoutside" +var clickoutside_ = __webpack_require__(10); +var clickoutside_default = /*#__PURE__*/__webpack_require__.n(clickoutside_); + +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/autocomplete/src/autocomplete-suggestions.vue?vue&type=template&id=cd10dcf0& +var autocomplete_suggestionsvue_type_template_id_cd10dcf0_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "transition", + { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": _vm.doDestroy } }, + [ + _c( + "div", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.showPopper, + expression: "showPopper" + } + ], + staticClass: "el-autocomplete-suggestion el-popper", + class: { + "is-loading": !_vm.parent.hideLoading && _vm.parent.loading + }, + style: { width: _vm.dropdownWidth }, + attrs: { role: "region" } + }, + [ + _c( + "el-scrollbar", + { + attrs: { + tag: "ul", + "wrap-class": "el-autocomplete-suggestion__wrap", + "view-class": "el-autocomplete-suggestion__list" + } + }, + [ + !_vm.parent.hideLoading && _vm.parent.loading + ? _c("li", [_c("i", { staticClass: "el-icon-loading" })]) + : _vm._t("default") + ], + 2 + ) + ], + 1 + ) + ] + ) +} +var autocomplete_suggestionsvue_type_template_id_cd10dcf0_staticRenderFns = [] +autocomplete_suggestionsvue_type_template_id_cd10dcf0_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete-suggestions.vue?vue&type=template&id=cd10dcf0& + +// EXTERNAL MODULE: external "element-ui/lib/utils/vue-popper" +var vue_popper_ = __webpack_require__(5); +var vue_popper_default = /*#__PURE__*/__webpack_require__.n(vue_popper_); + +// EXTERNAL MODULE: external "element-ui/lib/scrollbar" +var scrollbar_ = __webpack_require__(18); +var scrollbar_default = /*#__PURE__*/__webpack_require__.n(scrollbar_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/autocomplete/src/autocomplete-suggestions.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + +/* harmony default export */ var autocomplete_suggestionsvue_type_script_lang_js_ = ({ + components: { ElScrollbar: scrollbar_default.a }, + mixins: [vue_popper_default.a, emitter_default.a], + + componentName: 'ElAutocompleteSuggestions', + + data: function data() { + return { + parent: this.$parent, + dropdownWidth: '' + }; + }, + + + props: { + options: { + default: function _default() { + return { + gpuAcceleration: false + }; + } + }, + id: String + }, + + methods: { + select: function select(item) { + this.dispatch('ElAutocomplete', 'item-click', item); + } + }, + + updated: function updated() { + var _this = this; + + this.$nextTick(function (_) { + _this.popperJS && _this.updatePopper(); + }); + }, + mounted: function mounted() { + this.$parent.popperElm = this.popperElm = this.$el; + this.referenceElm = this.$parent.$refs.input.$refs.input || this.$parent.$refs.input.$refs.textarea; + this.referenceList = this.$el.querySelector('.el-autocomplete-suggestion__list'); + this.referenceList.setAttribute('role', 'listbox'); + this.referenceList.setAttribute('id', this.id); + }, + created: function created() { + var _this2 = this; + + this.$on('visible', function (val, inputWidth) { + _this2.dropdownWidth = inputWidth + 'px'; + _this2.showPopper = val; + }); + } +}); +// CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete-suggestions.vue?vue&type=script&lang=js& + /* harmony default export */ var src_autocomplete_suggestionsvue_type_script_lang_js_ = (autocomplete_suggestionsvue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete-suggestions.vue + + + + + +/* normalize component */ + +var autocomplete_suggestions_component = normalizeComponent( + src_autocomplete_suggestionsvue_type_script_lang_js_, + autocomplete_suggestionsvue_type_template_id_cd10dcf0_render, + autocomplete_suggestionsvue_type_template_id_cd10dcf0_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var autocomplete_suggestions_api; } +autocomplete_suggestions_component.options.__file = "packages/autocomplete/src/autocomplete-suggestions.vue" +/* harmony default export */ var autocomplete_suggestions = (autocomplete_suggestions_component.exports); +// EXTERNAL MODULE: external "element-ui/lib/mixins/focus" +var focus_ = __webpack_require__(23); +var focus_default = /*#__PURE__*/__webpack_require__.n(focus_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/autocomplete/src/autocomplete.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + + + + + + +/* harmony default export */ var autocompletevue_type_script_lang_js_ = ({ + name: 'ElAutocomplete', + + mixins: [emitter_default.a, focus_default()('input'), migrating_default.a], + + inheritAttrs: false, + + componentName: 'ElAutocomplete', + + components: { + ElInput: input_default.a, + ElAutocompleteSuggestions: autocomplete_suggestions + }, + + directives: { Clickoutside: clickoutside_default.a }, + + props: { + valueKey: { + type: String, + default: 'value' + }, + popperClass: String, + popperOptions: Object, + placeholder: String, + clearable: { + type: Boolean, + default: false + }, + disabled: Boolean, + name: String, + size: String, + value: String, + maxlength: Number, + minlength: Number, + autofocus: Boolean, + fetchSuggestions: Function, + triggerOnFocus: { + type: Boolean, + default: true + }, + customItem: String, + selectWhenUnmatched: { + type: Boolean, + default: false + }, + prefixIcon: String, + suffixIcon: String, + label: String, + debounce: { + type: Number, + default: 300 + }, + placement: { + type: String, + default: 'bottom-start' + }, + hideLoading: Boolean, + popperAppendToBody: { + type: Boolean, + default: true + }, + highlightFirstItem: { + type: Boolean, + default: false + } + }, + data: function data() { + return { + activated: false, + suggestions: [], + loading: false, + highlightedIndex: -1, + suggestionDisabled: false + }; + }, + + computed: { + suggestionVisible: function suggestionVisible() { + var suggestions = this.suggestions; + var isValidData = Array.isArray(suggestions) && suggestions.length > 0; + return (isValidData || this.loading) && this.activated; + }, + id: function id() { + return 'el-autocomplete-' + Object(util_["generateId"])(); + } + }, + watch: { + suggestionVisible: function suggestionVisible(val) { + var $input = this.getInput(); + if ($input) { + this.broadcast('ElAutocompleteSuggestions', 'visible', [val, $input.offsetWidth]); + } + } + }, + methods: { + getMigratingConfig: function getMigratingConfig() { + return { + props: { + 'custom-item': 'custom-item is removed, use scoped slot instead.', + 'props': 'props is removed, use value-key instead.' + } + }; + }, + getData: function getData(queryString) { + var _this = this; + + if (this.suggestionDisabled) { + return; + } + this.loading = true; + this.fetchSuggestions(queryString, function (suggestions) { + _this.loading = false; + if (_this.suggestionDisabled) { + return; + } + if (Array.isArray(suggestions)) { + _this.suggestions = suggestions; + _this.highlightedIndex = _this.highlightFirstItem ? 0 : -1; + } else { + console.error('[Element Error][Autocomplete]autocomplete suggestions must be an array'); + } + }); + }, + handleInput: function handleInput(value) { + this.$emit('input', value); + this.suggestionDisabled = false; + if (!this.triggerOnFocus && !value) { + this.suggestionDisabled = true; + this.suggestions = []; + return; + } + this.debouncedGetData(value); + }, + handleChange: function handleChange(value) { + this.$emit('change', value); + }, + handleFocus: function handleFocus(event) { + this.activated = true; + this.$emit('focus', event); + if (this.triggerOnFocus) { + this.debouncedGetData(this.value); + } + }, + handleBlur: function handleBlur(event) { + this.$emit('blur', event); + }, + handleClear: function handleClear() { + this.activated = false; + this.$emit('clear'); + }, + close: function close(e) { + this.activated = false; + }, + handleKeyEnter: function handleKeyEnter(e) { + var _this2 = this; + + if (this.suggestionVisible && this.highlightedIndex >= 0 && this.highlightedIndex < this.suggestions.length) { + e.preventDefault(); + this.select(this.suggestions[this.highlightedIndex]); + } else if (this.selectWhenUnmatched) { + this.$emit('select', { value: this.value }); + this.$nextTick(function (_) { + _this2.suggestions = []; + _this2.highlightedIndex = -1; + }); + } + }, + select: function select(item) { + var _this3 = this; + + this.$emit('input', item[this.valueKey]); + this.$emit('select', item); + this.$nextTick(function (_) { + _this3.suggestions = []; + _this3.highlightedIndex = -1; + }); + }, + highlight: function highlight(index) { + if (!this.suggestionVisible || this.loading) { + return; + } + if (index < 0) { + this.highlightedIndex = -1; + return; + } + if (index >= this.suggestions.length) { + index = this.suggestions.length - 1; + } + var suggestion = this.$refs.suggestions.$el.querySelector('.el-autocomplete-suggestion__wrap'); + var suggestionList = suggestion.querySelectorAll('.el-autocomplete-suggestion__list li'); + + var highlightItem = suggestionList[index]; + var scrollTop = suggestion.scrollTop; + var offsetTop = highlightItem.offsetTop; + + if (offsetTop + highlightItem.scrollHeight > scrollTop + suggestion.clientHeight) { + suggestion.scrollTop += highlightItem.scrollHeight; + } + if (offsetTop < scrollTop) { + suggestion.scrollTop -= highlightItem.scrollHeight; + } + this.highlightedIndex = index; + var $input = this.getInput(); + $input.setAttribute('aria-activedescendant', this.id + '-item-' + this.highlightedIndex); + }, + getInput: function getInput() { + return this.$refs.input.getInput(); + } + }, + mounted: function mounted() { + var _this4 = this; + + this.debouncedGetData = debounce_default()(this.debounce, this.getData); + this.$on('item-click', function (item) { + _this4.select(item); + }); + var $input = this.getInput(); + $input.setAttribute('role', 'textbox'); + $input.setAttribute('aria-autocomplete', 'list'); + $input.setAttribute('aria-controls', 'id'); + $input.setAttribute('aria-activedescendant', this.id + '-item-' + this.highlightedIndex); + }, + beforeDestroy: function beforeDestroy() { + this.$refs.suggestions.$destroy(); + } +}); +// CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete.vue?vue&type=script&lang=js& + /* harmony default export */ var src_autocompletevue_type_script_lang_js_ = (autocompletevue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete.vue + + + + + +/* normalize component */ + +var autocomplete_component = normalizeComponent( + src_autocompletevue_type_script_lang_js_, + autocompletevue_type_template_id_152f2ee6_render, + autocompletevue_type_template_id_152f2ee6_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var autocomplete_api; } +autocomplete_component.options.__file = "packages/autocomplete/src/autocomplete.vue" +/* harmony default export */ var autocomplete = (autocomplete_component.exports); +// CONCATENATED MODULE: ./packages/autocomplete/index.js + + +/* istanbul ignore next */ +autocomplete.install = function (Vue) { + Vue.component(autocomplete.name, autocomplete); +}; + +/* harmony default export */ var packages_autocomplete = (autocomplete); +// EXTERNAL MODULE: external "element-ui/lib/button" +var button_ = __webpack_require__(13); +var button_default = /*#__PURE__*/__webpack_require__.n(button_); + +// EXTERNAL MODULE: external "element-ui/lib/button-group" +var button_group_ = __webpack_require__(29); +var button_group_default = /*#__PURE__*/__webpack_require__.n(button_group_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown.vue?vue&type=script&lang=js& + + + + + + + + +/* harmony default export */ var dropdownvue_type_script_lang_js_ = ({ + name: 'ElDropdown', + + componentName: 'ElDropdown', + + mixins: [emitter_default.a, migrating_default.a], + + directives: { Clickoutside: clickoutside_default.a }, + + components: { + ElButton: button_default.a, + ElButtonGroup: button_group_default.a + }, + + provide: function provide() { + return { + dropdown: this + }; + }, + + + props: { + trigger: { + type: String, + default: 'hover' + }, + type: String, + size: { + type: String, + default: '' + }, + splitButton: Boolean, + hideOnClick: { + type: Boolean, + default: true + }, + placement: { + type: String, + default: 'bottom-end' + }, + visibleArrow: { + default: true + }, + showTimeout: { + type: Number, + default: 250 + }, + hideTimeout: { + type: Number, + default: 150 + }, + tabindex: { + type: Number, + default: 0 + }, + disabled: { + type: Boolean, + default: false + } + }, + + data: function data() { + return { + timeout: null, + visible: false, + triggerElm: null, + menuItems: null, + menuItemsArray: null, + dropdownElm: null, + focusing: false, + listId: 'dropdown-menu-' + Object(util_["generateId"])() + }; + }, + + + computed: { + dropdownSize: function dropdownSize() { + return this.size || (this.$ELEMENT || {}).size; + } + }, + + mounted: function mounted() { + this.$on('menu-item-click', this.handleMenuItemClick); + }, + + + watch: { + visible: function visible(val) { + this.broadcast('ElDropdownMenu', 'visible', val); + this.$emit('visible-change', val); + }, + focusing: function focusing(val) { + var selfDefine = this.$el.querySelector('.el-dropdown-selfdefine'); + if (selfDefine) { + // 自定义 + if (val) { + selfDefine.className += ' focusing'; + } else { + selfDefine.className = selfDefine.className.replace('focusing', ''); + } + } + } + }, + + methods: { + getMigratingConfig: function getMigratingConfig() { + return { + props: { + 'menu-align': 'menu-align is renamed to placement.' + } + }; + }, + show: function show() { + var _this = this; + + if (this.disabled) return; + clearTimeout(this.timeout); + this.timeout = setTimeout(function () { + _this.visible = true; + }, this.trigger === 'click' ? 0 : this.showTimeout); + }, + hide: function hide() { + var _this2 = this; + + if (this.disabled) return; + this.removeTabindex(); + if (this.tabindex >= 0) { + this.resetTabindex(this.triggerElm); + } + clearTimeout(this.timeout); + this.timeout = setTimeout(function () { + _this2.visible = false; + }, this.trigger === 'click' ? 0 : this.hideTimeout); + }, + handleClick: function handleClick() { + if (this.disabled) return; + if (this.visible) { + this.hide(); + } else { + this.show(); + } + }, + handleTriggerKeyDown: function handleTriggerKeyDown(ev) { + var keyCode = ev.keyCode; + if ([38, 40].indexOf(keyCode) > -1) { + // up/down + this.removeTabindex(); + this.resetTabindex(this.menuItems[0]); + this.menuItems[0].focus(); + ev.preventDefault(); + ev.stopPropagation(); + } else if (keyCode === 13) { + // space enter选中 + this.handleClick(); + } else if ([9, 27].indexOf(keyCode) > -1) { + // tab || esc + this.hide(); + } + }, + handleItemKeyDown: function handleItemKeyDown(ev) { + var keyCode = ev.keyCode; + var target = ev.target; + var currentIndex = this.menuItemsArray.indexOf(target); + var max = this.menuItemsArray.length - 1; + var nextIndex = void 0; + if ([38, 40].indexOf(keyCode) > -1) { + // up/down + if (keyCode === 38) { + // up + nextIndex = currentIndex !== 0 ? currentIndex - 1 : 0; + } else { + // down + nextIndex = currentIndex < max ? currentIndex + 1 : max; + } + this.removeTabindex(); + this.resetTabindex(this.menuItems[nextIndex]); + this.menuItems[nextIndex].focus(); + ev.preventDefault(); + ev.stopPropagation(); + } else if (keyCode === 13) { + // enter选中 + this.triggerElmFocus(); + target.click(); + if (this.hideOnClick) { + // click关闭 + this.visible = false; + } + } else if ([9, 27].indexOf(keyCode) > -1) { + // tab // esc + this.hide(); + this.triggerElmFocus(); + } + }, + resetTabindex: function resetTabindex(ele) { + // 下次tab时组件聚焦元素 + this.removeTabindex(); + ele.setAttribute('tabindex', '0'); // 下次期望的聚焦元素 + }, + removeTabindex: function removeTabindex() { + this.triggerElm.setAttribute('tabindex', '-1'); + this.menuItemsArray.forEach(function (item) { + item.setAttribute('tabindex', '-1'); + }); + }, + initAria: function initAria() { + this.dropdownElm.setAttribute('id', this.listId); + this.triggerElm.setAttribute('aria-haspopup', 'list'); + this.triggerElm.setAttribute('aria-controls', this.listId); + + if (!this.splitButton) { + // 自定义 + this.triggerElm.setAttribute('role', 'button'); + this.triggerElm.setAttribute('tabindex', this.tabindex); + this.triggerElm.setAttribute('class', (this.triggerElm.getAttribute('class') || '') + ' el-dropdown-selfdefine'); // 控制 + } + }, + initEvent: function initEvent() { + var _this3 = this; + + var trigger = this.trigger, + show = this.show, + hide = this.hide, + handleClick = this.handleClick, + splitButton = this.splitButton, + handleTriggerKeyDown = this.handleTriggerKeyDown, + handleItemKeyDown = this.handleItemKeyDown; + + this.triggerElm = splitButton ? this.$refs.trigger.$el : this.$slots.default[0].elm; + + var dropdownElm = this.dropdownElm; + + this.triggerElm.addEventListener('keydown', handleTriggerKeyDown); // triggerElm keydown + dropdownElm.addEventListener('keydown', handleItemKeyDown, true); // item keydown + // 控制自定义元素的样式 + if (!splitButton) { + this.triggerElm.addEventListener('focus', function () { + _this3.focusing = true; + }); + this.triggerElm.addEventListener('blur', function () { + _this3.focusing = false; + }); + this.triggerElm.addEventListener('click', function () { + _this3.focusing = false; + }); + } + if (trigger === 'hover') { + this.triggerElm.addEventListener('mouseenter', show); + this.triggerElm.addEventListener('mouseleave', hide); + dropdownElm.addEventListener('mouseenter', show); + dropdownElm.addEventListener('mouseleave', hide); + } else if (trigger === 'click') { + this.triggerElm.addEventListener('click', handleClick); + } + }, + handleMenuItemClick: function handleMenuItemClick(command, instance) { + if (this.hideOnClick) { + this.visible = false; + } + this.$emit('command', command, instance); + }, + triggerElmFocus: function triggerElmFocus() { + this.triggerElm.focus && this.triggerElm.focus(); + }, + initDomOperation: function initDomOperation() { + this.dropdownElm = this.popperElm; + this.menuItems = this.dropdownElm.querySelectorAll("[tabindex='-1']"); + this.menuItemsArray = [].slice.call(this.menuItems); + + this.initEvent(); + this.initAria(); + } + }, + + render: function render(h) { + var _this4 = this; + + var hide = this.hide, + splitButton = this.splitButton, + type = this.type, + dropdownSize = this.dropdownSize, + disabled = this.disabled; + + + var handleMainButtonClick = function handleMainButtonClick(event) { + _this4.$emit('click', event); + hide(); + }; + + var triggerElm = null; + if (splitButton) { + triggerElm = h('el-button-group', [h( + 'el-button', + { + attrs: { type: type, size: dropdownSize, disabled: disabled }, + nativeOn: { + 'click': handleMainButtonClick + } + }, + [this.$slots.default] + ), h( + 'el-button', + { ref: 'trigger', attrs: { type: type, size: dropdownSize, disabled: disabled }, + 'class': 'el-dropdown__caret-button' }, + [h('i', { 'class': 'el-dropdown__icon el-icon-arrow-down' })] + )]); + } else { + triggerElm = this.$slots.default; + var vnodeData = triggerElm[0].data || {}; + var _vnodeData$attrs = vnodeData.attrs, + attrs = _vnodeData$attrs === undefined ? {} : _vnodeData$attrs; + + if (disabled && !attrs.disabled) { + attrs.disabled = true; + vnodeData.attrs = attrs; + } + } + var menuElm = disabled ? null : this.$slots.dropdown; + + return h( + 'div', + { 'class': 'el-dropdown', directives: [{ + name: 'clickoutside', + value: hide + }], + attrs: { 'aria-disabled': disabled } + }, + [triggerElm, menuElm] + ); + } +}); +// CONCATENATED MODULE: ./packages/dropdown/src/dropdown.vue?vue&type=script&lang=js& + /* harmony default export */ var src_dropdownvue_type_script_lang_js_ = (dropdownvue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/dropdown/src/dropdown.vue +var dropdown_render, dropdown_staticRenderFns + + + + +/* normalize component */ + +var dropdown_component = normalizeComponent( + src_dropdownvue_type_script_lang_js_, + dropdown_render, + dropdown_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var dropdown_api; } +dropdown_component.options.__file = "packages/dropdown/src/dropdown.vue" +/* harmony default export */ var dropdown = (dropdown_component.exports); +// CONCATENATED MODULE: ./packages/dropdown/index.js + + +/* istanbul ignore next */ +dropdown.install = function (Vue) { + Vue.component(dropdown.name, dropdown); +}; + +/* harmony default export */ var packages_dropdown = (dropdown); +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-menu.vue?vue&type=template&id=0da6b714& +var dropdown_menuvue_type_template_id_0da6b714_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "transition", + { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": _vm.doDestroy } }, + [ + _c( + "ul", + { + directives: [ + { + name: "show", + rawName: "v-show", + value: _vm.showPopper, + expression: "showPopper" + } + ], + staticClass: "el-dropdown-menu el-popper", + class: [_vm.size && "el-dropdown-menu--" + _vm.size] + }, + [_vm._t("default")], + 2 + ) + ] + ) +} +var dropdown_menuvue_type_template_id_0da6b714_staticRenderFns = [] +dropdown_menuvue_type_template_id_0da6b714_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue?vue&type=template&id=0da6b714& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-menu.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// + + + +/* harmony default export */ var dropdown_menuvue_type_script_lang_js_ = ({ + name: 'ElDropdownMenu', + + componentName: 'ElDropdownMenu', + + mixins: [vue_popper_default.a], + + props: { + visibleArrow: { + type: Boolean, + default: true + }, + arrowOffset: { + type: Number, + default: 0 + } + }, + + data: function data() { + return { + size: this.dropdown.dropdownSize + }; + }, + + + inject: ['dropdown'], + + created: function created() { + var _this = this; + + this.$on('updatePopper', function () { + if (_this.showPopper) _this.updatePopper(); + }); + this.$on('visible', function (val) { + _this.showPopper = val; + }); + }, + mounted: function mounted() { + this.dropdown.popperElm = this.popperElm = this.$el; + this.referenceElm = this.dropdown.$el; + // compatible with 2.6 new v-slot syntax + // issue link https://github.com/ElemeFE/element/issues/14345 + this.dropdown.initDomOperation(); + }, + + + watch: { + 'dropdown.placement': { + immediate: true, + handler: function handler(val) { + this.currentPlacement = val; + } + } + } +}); +// CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue?vue&type=script&lang=js& + /* harmony default export */ var src_dropdown_menuvue_type_script_lang_js_ = (dropdown_menuvue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue + + + + + +/* normalize component */ + +var dropdown_menu_component = normalizeComponent( + src_dropdown_menuvue_type_script_lang_js_, + dropdown_menuvue_type_template_id_0da6b714_render, + dropdown_menuvue_type_template_id_0da6b714_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var dropdown_menu_api; } +dropdown_menu_component.options.__file = "packages/dropdown/src/dropdown-menu.vue" +/* harmony default export */ var dropdown_menu = (dropdown_menu_component.exports); +// CONCATENATED MODULE: ./packages/dropdown-menu/index.js + + +/* istanbul ignore next */ +dropdown_menu.install = function (Vue) { + Vue.component(dropdown_menu.name, dropdown_menu); +}; + +/* harmony default export */ var packages_dropdown_menu = (dropdown_menu); +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-item.vue?vue&type=template&id=6359102a& +var dropdown_itemvue_type_template_id_6359102a_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "li", + { + staticClass: "el-dropdown-menu__item", + class: { + "is-disabled": _vm.disabled, + "el-dropdown-menu__item--divided": _vm.divided + }, + attrs: { + "aria-disabled": _vm.disabled, + tabindex: _vm.disabled ? null : -1 + }, + on: { click: _vm.handleClick } + }, + [_vm.icon ? _c("i", { class: _vm.icon }) : _vm._e(), _vm._t("default")], + 2 + ) +} +var dropdown_itemvue_type_template_id_6359102a_staticRenderFns = [] +dropdown_itemvue_type_template_id_6359102a_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/dropdown/src/dropdown-item.vue?vue&type=template&id=6359102a& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-item.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + +/* harmony default export */ var dropdown_itemvue_type_script_lang_js_ = ({ + name: 'ElDropdownItem', + + mixins: [emitter_default.a], + + props: { + command: {}, + disabled: Boolean, + divided: Boolean, + icon: String + }, + + methods: { + handleClick: function handleClick(e) { + this.dispatch('ElDropdown', 'menu-item-click', [this.command, this]); + } + } +}); +// CONCATENATED MODULE: ./packages/dropdown/src/dropdown-item.vue?vue&type=script&lang=js& + /* harmony default export */ var src_dropdown_itemvue_type_script_lang_js_ = (dropdown_itemvue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/dropdown/src/dropdown-item.vue + + + + + +/* normalize component */ + +var dropdown_item_component = normalizeComponent( + src_dropdown_itemvue_type_script_lang_js_, + dropdown_itemvue_type_template_id_6359102a_render, + dropdown_itemvue_type_template_id_6359102a_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var dropdown_item_api; } +dropdown_item_component.options.__file = "packages/dropdown/src/dropdown-item.vue" +/* harmony default export */ var dropdown_item = (dropdown_item_component.exports); +// CONCATENATED MODULE: ./packages/dropdown-item/index.js + + +/* istanbul ignore next */ +dropdown_item.install = function (Vue) { + Vue.component(dropdown_item.name, dropdown_item); +}; + +/* harmony default export */ var packages_dropdown_item = (dropdown_item); +// CONCATENATED MODULE: ./src/utils/aria-utils.js +var aria = aria || {}; + +aria.Utils = aria.Utils || {}; + +/** + * @desc Set focus on descendant nodes until the first focusable element is + * found. + * @param element + * DOM node for which to find the first focusable descendant. + * @returns + * true if a focusable element is found and focus is set. + */ +aria.Utils.focusFirstDescendant = function (element) { + for (var i = 0; i < element.childNodes.length; i++) { + var child = element.childNodes[i]; + if (aria.Utils.attemptFocus(child) || aria.Utils.focusFirstDescendant(child)) { + return true; + } + } + return false; +}; + +/** + * @desc Find the last descendant node that is focusable. + * @param element + * DOM node for which to find the last focusable descendant. + * @returns + * true if a focusable element is found and focus is set. + */ + +aria.Utils.focusLastDescendant = function (element) { + for (var i = element.childNodes.length - 1; i >= 0; i--) { + var child = element.childNodes[i]; + if (aria.Utils.attemptFocus(child) || aria.Utils.focusLastDescendant(child)) { + return true; + } + } + return false; +}; + +/** + * @desc Set Attempt to set focus on the current node. + * @param element + * The node to attempt to focus on. + * @returns + * true if element is focused. + */ +aria.Utils.attemptFocus = function (element) { + if (!aria.Utils.isFocusable(element)) { + return false; + } + aria.Utils.IgnoreUtilFocusChanges = true; + try { + element.focus(); + } catch (e) {} + aria.Utils.IgnoreUtilFocusChanges = false; + return document.activeElement === element; +}; + +aria.Utils.isFocusable = function (element) { + if (element.tabIndex > 0 || element.tabIndex === 0 && element.getAttribute('tabIndex') !== null) { + return true; + } + + if (element.disabled) { + return false; + } + + switch (element.nodeName) { + case 'A': + return !!element.href && element.rel !== 'ignore'; + case 'INPUT': + return element.type !== 'hidden' && element.type !== 'file'; + case 'BUTTON': + case 'SELECT': + case 'TEXTAREA': + return true; + default: + return false; + } +}; + +/** + * 触发一个事件 + * mouseenter, mouseleave, mouseover, keyup, change, click 等 + * @param {Element} elm + * @param {String} name + * @param {*} opts + */ +aria.Utils.triggerEvent = function (elm, name) { + var eventName = void 0; + + if (/^mouse|click/.test(name)) { + eventName = 'MouseEvents'; + } else if (/^key/.test(name)) { + eventName = 'KeyboardEvent'; + } else { + eventName = 'HTMLEvents'; + } + var evt = document.createEvent(eventName); + + for (var _len = arguments.length, opts = Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) { + opts[_key - 2] = arguments[_key]; + } + + evt.initEvent.apply(evt, [name].concat(opts)); + elm.dispatchEvent ? elm.dispatchEvent(evt) : elm.fireEvent('on' + name, evt); + + return elm; +}; + +aria.Utils.keys = { + tab: 9, + enter: 13, + space: 32, + left: 37, + up: 38, + right: 39, + down: 40, + esc: 27 +}; + +/* harmony default export */ var aria_utils = (aria.Utils); +// CONCATENATED MODULE: ./src/utils/menu/aria-submenu.js + + +var SubMenu = function SubMenu(parent, domNode) { + this.domNode = domNode; + this.parent = parent; + this.subMenuItems = []; + this.subIndex = 0; + this.init(); +}; + +SubMenu.prototype.init = function () { + this.subMenuItems = this.domNode.querySelectorAll('li'); + this.addListeners(); +}; + +SubMenu.prototype.gotoSubIndex = function (idx) { + if (idx === this.subMenuItems.length) { + idx = 0; + } else if (idx < 0) { + idx = this.subMenuItems.length - 1; + } + this.subMenuItems[idx].focus(); + this.subIndex = idx; +}; + +SubMenu.prototype.addListeners = function () { + var _this = this; + + var keys = aria_utils.keys; + var parentNode = this.parent.domNode; + Array.prototype.forEach.call(this.subMenuItems, function (el) { + el.addEventListener('keydown', function (event) { + var prevDef = false; + switch (event.keyCode) { + case keys.down: + _this.gotoSubIndex(_this.subIndex + 1); + prevDef = true; + break; + case keys.up: + _this.gotoSubIndex(_this.subIndex - 1); + prevDef = true; + break; + case keys.tab: + aria_utils.triggerEvent(parentNode, 'mouseleave'); + break; + case keys.enter: + case keys.space: + prevDef = true; + event.currentTarget.click(); + break; + } + if (prevDef) { + event.preventDefault(); + event.stopPropagation(); + } + return false; + }); + }); +}; + +/* harmony default export */ var aria_submenu = (SubMenu); +// CONCATENATED MODULE: ./src/utils/menu/aria-menuitem.js + + + +var MenuItem = function MenuItem(domNode) { + this.domNode = domNode; + this.submenu = null; + this.init(); +}; + +MenuItem.prototype.init = function () { + this.domNode.setAttribute('tabindex', '0'); + var menuChild = this.domNode.querySelector('.el-menu'); + if (menuChild) { + this.submenu = new aria_submenu(this, menuChild); + } + this.addListeners(); +}; + +MenuItem.prototype.addListeners = function () { + var _this = this; + + var keys = aria_utils.keys; + this.domNode.addEventListener('keydown', function (event) { + var prevDef = false; + switch (event.keyCode) { + case keys.down: + aria_utils.triggerEvent(event.currentTarget, 'mouseenter'); + _this.submenu && _this.submenu.gotoSubIndex(0); + prevDef = true; + break; + case keys.up: + aria_utils.triggerEvent(event.currentTarget, 'mouseenter'); + _this.submenu && _this.submenu.gotoSubIndex(_this.submenu.subMenuItems.length - 1); + prevDef = true; + break; + case keys.tab: + aria_utils.triggerEvent(event.currentTarget, 'mouseleave'); + break; + case keys.enter: + case keys.space: + prevDef = true; + event.currentTarget.click(); + break; + } + if (prevDef) { + event.preventDefault(); + } + }); +}; + +/* harmony default export */ var aria_menuitem = (MenuItem); +// CONCATENATED MODULE: ./src/utils/menu/aria-menubar.js + + +var Menu = function Menu(domNode) { + this.domNode = domNode; + this.init(); +}; + +Menu.prototype.init = function () { + var menuChildren = this.domNode.childNodes; + [].filter.call(menuChildren, function (child) { + return child.nodeType === 1; + }).forEach(function (child) { + new aria_menuitem(child); // eslint-disable-line + }); +}; +/* harmony default export */ var aria_menubar = (Menu); +// EXTERNAL MODULE: external "element-ui/lib/utils/dom" +var dom_ = __webpack_require__(1); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/menu.vue?vue&type=script&lang=js& + + + + + + +/* harmony default export */ var menuvue_type_script_lang_js_ = ({ + name: 'ElMenu', + + render: function render(h) { + var component = h( + 'ul', + { + attrs: { + role: 'menubar' + }, + key: +this.collapse, + style: { backgroundColor: this.backgroundColor || '' }, + 'class': { + 'el-menu--horizontal': this.mode === 'horizontal', + 'el-menu--collapse': this.collapse, + "el-menu": true + } + }, + [this.$slots.default] + ); + + if (this.collapseTransition) { + return h('el-menu-collapse-transition', [component]); + } else { + return component; + } + }, + + + componentName: 'ElMenu', + + mixins: [emitter_default.a, migrating_default.a], + + provide: function provide() { + return { + rootMenu: this + }; + }, + + + components: { + 'el-menu-collapse-transition': { + functional: true, + render: function render(createElement, context) { + var data = { + props: { + mode: 'out-in' + }, + on: { + beforeEnter: function beforeEnter(el) { + el.style.opacity = 0.2; + }, + enter: function enter(el) { + Object(dom_["addClass"])(el, 'el-opacity-transition'); + el.style.opacity = 1; + }, + afterEnter: function afterEnter(el) { + Object(dom_["removeClass"])(el, 'el-opacity-transition'); + el.style.opacity = ''; + }, + beforeLeave: function beforeLeave(el) { + if (!el.dataset) el.dataset = {}; + + if (Object(dom_["hasClass"])(el, 'el-menu--collapse')) { + Object(dom_["removeClass"])(el, 'el-menu--collapse'); + el.dataset.oldOverflow = el.style.overflow; + el.dataset.scrollWidth = el.clientWidth; + Object(dom_["addClass"])(el, 'el-menu--collapse'); + } else { + Object(dom_["addClass"])(el, 'el-menu--collapse'); + el.dataset.oldOverflow = el.style.overflow; + el.dataset.scrollWidth = el.clientWidth; + Object(dom_["removeClass"])(el, 'el-menu--collapse'); + } + + el.style.width = el.scrollWidth + 'px'; + el.style.overflow = 'hidden'; + }, + leave: function leave(el) { + Object(dom_["addClass"])(el, 'horizontal-collapse-transition'); + el.style.width = el.dataset.scrollWidth + 'px'; + } + } + }; + return createElement('transition', data, context.children); + } + } + }, + + props: { + mode: { + type: String, + default: 'vertical' + }, + defaultActive: { + type: String, + default: '' + }, + defaultOpeneds: Array, + uniqueOpened: Boolean, + router: Boolean, + menuTrigger: { + type: String, + default: 'hover' + }, + collapse: Boolean, + backgroundColor: String, + textColor: String, + activeTextColor: String, + collapseTransition: { + type: Boolean, + default: true + } + }, + data: function data() { + return { + activeIndex: this.defaultActive, + openedMenus: this.defaultOpeneds && !this.collapse ? this.defaultOpeneds.slice(0) : [], + items: {}, + submenus: {} + }; + }, + + computed: { + hoverBackground: function hoverBackground() { + return this.backgroundColor ? this.mixColor(this.backgroundColor, 0.2) : ''; + }, + isMenuPopup: function isMenuPopup() { + return this.mode === 'horizontal' || this.mode === 'vertical' && this.collapse; + } + }, + watch: { + defaultActive: function defaultActive(value) { + if (!this.items[value]) { + this.activeIndex = null; + } + this.updateActiveIndex(value); + }, + defaultOpeneds: function defaultOpeneds(value) { + if (!this.collapse) { + this.openedMenus = value; + } + }, + collapse: function collapse(value) { + if (value) this.openedMenus = []; + this.broadcast('ElSubmenu', 'toggle-collapse', value); + } + }, + methods: { + updateActiveIndex: function updateActiveIndex(val) { + var item = this.items[val] || this.items[this.activeIndex] || this.items[this.defaultActive]; + if (item) { + this.activeIndex = item.index; + this.initOpenedMenu(); + } else { + this.activeIndex = null; + } + }, + getMigratingConfig: function getMigratingConfig() { + return { + props: { + 'theme': 'theme is removed.' + } + }; + }, + getColorChannels: function getColorChannels(color) { + color = color.replace('#', ''); + if (/^[0-9a-fA-F]{3}$/.test(color)) { + color = color.split(''); + for (var i = 2; i >= 0; i--) { + color.splice(i, 0, color[i]); + } + color = color.join(''); + } + if (/^[0-9a-fA-F]{6}$/.test(color)) { + return { + red: parseInt(color.slice(0, 2), 16), + green: parseInt(color.slice(2, 4), 16), + blue: parseInt(color.slice(4, 6), 16) + }; + } else { + return { + red: 255, + green: 255, + blue: 255 + }; + } + }, + mixColor: function mixColor(color, percent) { + var _getColorChannels = this.getColorChannels(color), + red = _getColorChannels.red, + green = _getColorChannels.green, + blue = _getColorChannels.blue; + + if (percent > 0) { + // shade given color + red *= 1 - percent; + green *= 1 - percent; + blue *= 1 - percent; + } else { + // tint given color + red += (255 - red) * percent; + green += (255 - green) * percent; + blue += (255 - blue) * percent; + } + return 'rgb(' + Math.round(red) + ', ' + Math.round(green) + ', ' + Math.round(blue) + ')'; + }, + addItem: function addItem(item) { + this.$set(this.items, item.index, item); + }, + removeItem: function removeItem(item) { + delete this.items[item.index]; + }, + addSubmenu: function addSubmenu(item) { + this.$set(this.submenus, item.index, item); + }, + removeSubmenu: function removeSubmenu(item) { + delete this.submenus[item.index]; + }, + openMenu: function openMenu(index, indexPath) { + var openedMenus = this.openedMenus; + if (openedMenus.indexOf(index) !== -1) return; + // 将不在该菜单路径下的其余菜单收起 + // collapse all menu that are not under current menu item + if (this.uniqueOpened) { + this.openedMenus = openedMenus.filter(function (index) { + return indexPath.indexOf(index) !== -1; + }); + } + this.openedMenus.push(index); + }, + closeMenu: function closeMenu(index) { + var i = this.openedMenus.indexOf(index); + if (i !== -1) { + this.openedMenus.splice(i, 1); + } + }, + handleSubmenuClick: function handleSubmenuClick(submenu) { + var index = submenu.index, + indexPath = submenu.indexPath; + + var isOpened = this.openedMenus.indexOf(index) !== -1; + + if (isOpened) { + this.closeMenu(index); + this.$emit('close', index, indexPath); + } else { + this.openMenu(index, indexPath); + this.$emit('open', index, indexPath); + } + }, + handleItemClick: function handleItemClick(item) { + var _this = this; + + var index = item.index, + indexPath = item.indexPath; + + var oldActiveIndex = this.activeIndex; + var hasIndex = item.index !== null; + + if (hasIndex) { + this.activeIndex = item.index; + } + + this.$emit('select', index, indexPath, item); + + if (this.mode === 'horizontal' || this.collapse) { + this.openedMenus = []; + } + + if (this.router && hasIndex) { + this.routeToItem(item, function (error) { + _this.activeIndex = oldActiveIndex; + if (error) { + // vue-router 3.1.0+ push/replace cause NavigationDuplicated error + // https://github.com/ElemeFE/element/issues/17044 + if (error.name === 'NavigationDuplicated') return; + console.error(error); + } + }); + } + }, + + // 初始化展开菜单 + // initialize opened menu + initOpenedMenu: function initOpenedMenu() { + var _this2 = this; + + var index = this.activeIndex; + var activeItem = this.items[index]; + if (!activeItem || this.mode === 'horizontal' || this.collapse) return; + + var indexPath = activeItem.indexPath; + + // 展开该菜单项的路径上所有子菜单 + // expand all submenus of the menu item + indexPath.forEach(function (index) { + var submenu = _this2.submenus[index]; + submenu && _this2.openMenu(index, submenu.indexPath); + }); + }, + routeToItem: function routeToItem(item, onError) { + var route = item.route || item.index; + try { + this.$router.push(route, function () {}, onError); + } catch (e) { + console.error(e); + } + }, + open: function open(index) { + var _this3 = this; + + var indexPath = this.submenus[index.toString()].indexPath; + + indexPath.forEach(function (i) { + return _this3.openMenu(i, indexPath); + }); + }, + close: function close(index) { + this.closeMenu(index); + } + }, + mounted: function mounted() { + this.initOpenedMenu(); + this.$on('item-click', this.handleItemClick); + this.$on('submenu-click', this.handleSubmenuClick); + if (this.mode === 'horizontal') { + new aria_menubar(this.$el); // eslint-disable-line + } + this.$watch('items', this.updateActiveIndex); + } +}); +// CONCATENATED MODULE: ./packages/menu/src/menu.vue?vue&type=script&lang=js& + /* harmony default export */ var src_menuvue_type_script_lang_js_ = (menuvue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/menu/src/menu.vue +var menu_render, menu_staticRenderFns + + + + +/* normalize component */ + +var menu_component = normalizeComponent( + src_menuvue_type_script_lang_js_, + menu_render, + menu_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var menu_api; } +menu_component.options.__file = "packages/menu/src/menu.vue" +/* harmony default export */ var src_menu = (menu_component.exports); +// CONCATENATED MODULE: ./packages/menu/index.js + + +/* istanbul ignore next */ +src_menu.install = function (Vue) { + Vue.component(src_menu.name, src_menu); +}; + +/* harmony default export */ var packages_menu = (src_menu); +// EXTERNAL MODULE: external "element-ui/lib/transitions/collapse-transition" +var collapse_transition_ = __webpack_require__(21); +var collapse_transition_default = /*#__PURE__*/__webpack_require__.n(collapse_transition_); + +// CONCATENATED MODULE: ./packages/menu/src/menu-mixin.js +/* harmony default export */ var menu_mixin = ({ + inject: ['rootMenu'], + computed: { + indexPath: function indexPath() { + var path = [this.index]; + var parent = this.$parent; + while (parent.$options.componentName !== 'ElMenu') { + if (parent.index) { + path.unshift(parent.index); + } + parent = parent.$parent; + } + return path; + }, + parentMenu: function parentMenu() { + var parent = this.$parent; + while (parent && ['ElMenu', 'ElSubmenu'].indexOf(parent.$options.componentName) === -1) { + parent = parent.$parent; + } + return parent; + }, + paddingStyle: function paddingStyle() { + if (this.rootMenu.mode !== 'vertical') return {}; + + var padding = 20; + var parent = this.$parent; + + if (this.rootMenu.collapse) { + padding = 20; + } else { + while (parent && parent.$options.componentName !== 'ElMenu') { + if (parent.$options.componentName === 'ElSubmenu') { + padding += 20; + } + parent = parent.$parent; + } + } + return { paddingLeft: padding + 'px' }; + } + } +}); +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/submenu.vue?vue&type=script&lang=js& + + + + + + +var poperMixins = { + props: { + transformOrigin: { + type: [Boolean, String], + default: false + }, + offset: vue_popper_default.a.props.offset, + boundariesPadding: vue_popper_default.a.props.boundariesPadding, + popperOptions: vue_popper_default.a.props.popperOptions + }, + data: vue_popper_default.a.data, + methods: vue_popper_default.a.methods, + beforeDestroy: vue_popper_default.a.beforeDestroy, + deactivated: vue_popper_default.a.deactivated +}; + +/* harmony default export */ var submenuvue_type_script_lang_js_ = ({ + name: 'ElSubmenu', + + componentName: 'ElSubmenu', + + mixins: [menu_mixin, emitter_default.a, poperMixins], + + components: { ElCollapseTransition: collapse_transition_default.a }, + + props: { + index: { + type: String, + required: true + }, + showTimeout: { + type: Number, + default: 300 + }, + hideTimeout: { + type: Number, + default: 300 + }, + popperClass: String, + disabled: Boolean, + popperAppendToBody: { + type: Boolean, + default: undefined + } + }, + + data: function data() { + return { + popperJS: null, + timeout: null, + items: {}, + submenus: {}, + mouseInChild: false + }; + }, + + watch: { + opened: function opened(val) { + var _this = this; + + if (this.isMenuPopup) { + this.$nextTick(function (_) { + _this.updatePopper(); + }); + } + } + }, + computed: { + // popper option + appendToBody: function appendToBody() { + return this.popperAppendToBody === undefined ? this.isFirstLevel : this.popperAppendToBody; + }, + menuTransitionName: function menuTransitionName() { + return this.rootMenu.collapse ? 'el-zoom-in-left' : 'el-zoom-in-top'; + }, + opened: function opened() { + return this.rootMenu.openedMenus.indexOf(this.index) > -1; + }, + active: function active() { + var isActive = false; + var submenus = this.submenus; + var items = this.items; + + Object.keys(items).forEach(function (index) { + if (items[index].active) { + isActive = true; + } + }); + + Object.keys(submenus).forEach(function (index) { + if (submenus[index].active) { + isActive = true; + } + }); + + return isActive; + }, + hoverBackground: function hoverBackground() { + return this.rootMenu.hoverBackground; + }, + backgroundColor: function backgroundColor() { + return this.rootMenu.backgroundColor || ''; + }, + activeTextColor: function activeTextColor() { + return this.rootMenu.activeTextColor || ''; + }, + textColor: function textColor() { + return this.rootMenu.textColor || ''; + }, + mode: function mode() { + return this.rootMenu.mode; + }, + isMenuPopup: function isMenuPopup() { + return this.rootMenu.isMenuPopup; + }, + titleStyle: function titleStyle() { + if (this.mode !== 'horizontal') { + return { + color: this.textColor + }; + } + return { + borderBottomColor: this.active ? this.rootMenu.activeTextColor ? this.activeTextColor : '' : 'transparent', + color: this.active ? this.activeTextColor : this.textColor + }; + }, + isFirstLevel: function isFirstLevel() { + var isFirstLevel = true; + var parent = this.$parent; + while (parent && parent !== this.rootMenu) { + if (['ElSubmenu', 'ElMenuItemGroup'].indexOf(parent.$options.componentName) > -1) { + isFirstLevel = false; + break; + } else { + parent = parent.$parent; + } + } + return isFirstLevel; + } + }, + methods: { + handleCollapseToggle: function handleCollapseToggle(value) { + if (value) { + this.initPopper(); + } else { + this.doDestroy(); + } + }, + addItem: function addItem(item) { + this.$set(this.items, item.index, item); + }, + removeItem: function removeItem(item) { + delete this.items[item.index]; + }, + addSubmenu: function addSubmenu(item) { + this.$set(this.submenus, item.index, item); + }, + removeSubmenu: function removeSubmenu(item) { + delete this.submenus[item.index]; + }, + handleClick: function handleClick() { + var rootMenu = this.rootMenu, + disabled = this.disabled; + + if (rootMenu.menuTrigger === 'hover' && rootMenu.mode === 'horizontal' || rootMenu.collapse && rootMenu.mode === 'vertical' || disabled) { + return; + } + this.dispatch('ElMenu', 'submenu-click', this); + }, + handleMouseenter: function handleMouseenter(event) { + var _this2 = this; + + var showTimeout = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.showTimeout; + + + if (!('ActiveXObject' in window) && event.type === 'focus' && !event.relatedTarget) { + return; + } + var rootMenu = this.rootMenu, + disabled = this.disabled; + + if (rootMenu.menuTrigger === 'click' && rootMenu.mode === 'horizontal' || !rootMenu.collapse && rootMenu.mode === 'vertical' || disabled) { + return; + } + this.dispatch('ElSubmenu', 'mouse-enter-child'); + clearTimeout(this.timeout); + this.timeout = setTimeout(function () { + _this2.rootMenu.openMenu(_this2.index, _this2.indexPath); + }, showTimeout); + + if (this.appendToBody) { + this.$parent.$el.dispatchEvent(new MouseEvent('mouseenter')); + } + }, + handleMouseleave: function handleMouseleave() { + var _this3 = this; + + var deepDispatch = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; + var rootMenu = this.rootMenu; + + if (rootMenu.menuTrigger === 'click' && rootMenu.mode === 'horizontal' || !rootMenu.collapse && rootMenu.mode === 'vertical') { + return; + } + this.dispatch('ElSubmenu', 'mouse-leave-child'); + clearTimeout(this.timeout); + this.timeout = setTimeout(function () { + !_this3.mouseInChild && _this3.rootMenu.closeMenu(_this3.index); + }, this.hideTimeout); + + if (this.appendToBody && deepDispatch) { + if (this.$parent.$options.name === 'ElSubmenu') { + this.$parent.handleMouseleave(true); + } + } + }, + handleTitleMouseenter: function handleTitleMouseenter() { + if (this.mode === 'horizontal' && !this.rootMenu.backgroundColor) return; + var title = this.$refs['submenu-title']; + title && (title.style.backgroundColor = this.rootMenu.hoverBackground); + }, + handleTitleMouseleave: function handleTitleMouseleave() { + if (this.mode === 'horizontal' && !this.rootMenu.backgroundColor) return; + var title = this.$refs['submenu-title']; + title && (title.style.backgroundColor = this.rootMenu.backgroundColor || ''); + }, + updatePlacement: function updatePlacement() { + this.currentPlacement = this.mode === 'horizontal' && this.isFirstLevel ? 'bottom-start' : 'right-start'; + }, + initPopper: function initPopper() { + this.referenceElm = this.$el; + this.popperElm = this.$refs.menu; + this.updatePlacement(); + } + }, + created: function created() { + var _this4 = this; + + this.$on('toggle-collapse', this.handleCollapseToggle); + this.$on('mouse-enter-child', function () { + _this4.mouseInChild = true; + clearTimeout(_this4.timeout); + }); + this.$on('mouse-leave-child', function () { + _this4.mouseInChild = false; + clearTimeout(_this4.timeout); + }); + }, + mounted: function mounted() { + this.parentMenu.addSubmenu(this); + this.rootMenu.addSubmenu(this); + this.initPopper(); + }, + beforeDestroy: function beforeDestroy() { + this.parentMenu.removeSubmenu(this); + this.rootMenu.removeSubmenu(this); + }, + render: function render(h) { + var _this5 = this; + + var active = this.active, + opened = this.opened, + paddingStyle = this.paddingStyle, + titleStyle = this.titleStyle, + backgroundColor = this.backgroundColor, + rootMenu = this.rootMenu, + currentPlacement = this.currentPlacement, + menuTransitionName = this.menuTransitionName, + mode = this.mode, + disabled = this.disabled, + popperClass = this.popperClass, + $slots = this.$slots, + isFirstLevel = this.isFirstLevel; + + + var popupMenu = h( + 'transition', + { + attrs: { name: menuTransitionName } + }, + [h( + 'div', + { + ref: 'menu', + directives: [{ + name: 'show', + value: opened + }], + + 'class': ['el-menu--' + mode, popperClass], + on: { + 'mouseenter': function mouseenter($event) { + return _this5.handleMouseenter($event, 100); + }, + 'mouseleave': function mouseleave() { + return _this5.handleMouseleave(true); + }, + 'focus': function focus($event) { + return _this5.handleMouseenter($event, 100); + } + } + }, + [h( + 'ul', + { + attrs: { + role: 'menu' + }, + 'class': ['el-menu el-menu--popup', 'el-menu--popup-' + currentPlacement], + style: { backgroundColor: rootMenu.backgroundColor || '' } }, + [$slots.default] + )] + )] + ); + + var inlineMenu = h('el-collapse-transition', [h( + 'ul', + { + attrs: { + role: 'menu' + }, + 'class': 'el-menu el-menu--inline', + directives: [{ + name: 'show', + value: opened + }], + + style: { backgroundColor: rootMenu.backgroundColor || '' } }, + [$slots.default] + )]); + + var submenuTitleIcon = rootMenu.mode === 'horizontal' && isFirstLevel || rootMenu.mode === 'vertical' && !rootMenu.collapse ? 'el-icon-arrow-down' : 'el-icon-arrow-right'; + + return h( + 'li', + { + 'class': { + 'el-submenu': true, + 'is-active': active, + 'is-opened': opened, + 'is-disabled': disabled + }, + attrs: { role: 'menuitem', + 'aria-haspopup': 'true', + 'aria-expanded': opened + }, + on: { + 'mouseenter': this.handleMouseenter, + 'mouseleave': function mouseleave() { + return _this5.handleMouseleave(false); + }, + 'focus': this.handleMouseenter + } + }, + [h( + 'div', + { + 'class': 'el-submenu__title', + ref: 'submenu-title', + on: { + 'click': this.handleClick, + 'mouseenter': this.handleTitleMouseenter, + 'mouseleave': this.handleTitleMouseleave + }, + + style: [paddingStyle, titleStyle, { backgroundColor: backgroundColor }] + }, + [$slots.title, h('i', { 'class': ['el-submenu__icon-arrow', submenuTitleIcon] })] + ), this.isMenuPopup ? popupMenu : inlineMenu] + ); + } +}); +// CONCATENATED MODULE: ./packages/menu/src/submenu.vue?vue&type=script&lang=js& + /* harmony default export */ var src_submenuvue_type_script_lang_js_ = (submenuvue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/menu/src/submenu.vue +var submenu_render, submenu_staticRenderFns + + + + +/* normalize component */ + +var submenu_component = normalizeComponent( + src_submenuvue_type_script_lang_js_, + submenu_render, + submenu_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var submenu_api; } +submenu_component.options.__file = "packages/menu/src/submenu.vue" +/* harmony default export */ var submenu = (submenu_component.exports); +// CONCATENATED MODULE: ./packages/submenu/index.js + + +/* istanbul ignore next */ +submenu.install = function (Vue) { + Vue.component(submenu.name, submenu); +}; + +/* harmony default export */ var packages_submenu = (submenu); +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/menu-item.vue?vue&type=template&id=2a5dbfea& +var menu_itemvue_type_template_id_2a5dbfea_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "li", + { + staticClass: "el-menu-item", + class: { + "is-active": _vm.active, + "is-disabled": _vm.disabled + }, + style: [ + _vm.paddingStyle, + _vm.itemStyle, + { backgroundColor: _vm.backgroundColor } + ], + attrs: { role: "menuitem", tabindex: "-1" }, + on: { + click: _vm.handleClick, + mouseenter: _vm.onMouseEnter, + focus: _vm.onMouseEnter, + blur: _vm.onMouseLeave, + mouseleave: _vm.onMouseLeave + } + }, + [ + _vm.parentMenu.$options.componentName === "ElMenu" && + _vm.rootMenu.collapse && + _vm.$slots.title + ? _c("el-tooltip", { attrs: { effect: "dark", placement: "right" } }, [ + _c( + "div", + { attrs: { slot: "content" }, slot: "content" }, + [_vm._t("title")], + 2 + ), + _c( + "div", + { + staticStyle: { + position: "absolute", + left: "0", + top: "0", + height: "100%", + width: "100%", + display: "inline-block", + "box-sizing": "border-box", + padding: "0 20px" + } + }, + [_vm._t("default")], + 2 + ) + ]) + : [_vm._t("default"), _vm._t("title")] + ], + 2 + ) +} +var menu_itemvue_type_template_id_2a5dbfea_staticRenderFns = [] +menu_itemvue_type_template_id_2a5dbfea_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/menu/src/menu-item.vue?vue&type=template&id=2a5dbfea& + +// EXTERNAL MODULE: external "element-ui/lib/tooltip" +var tooltip_ = __webpack_require__(26); +var tooltip_default = /*#__PURE__*/__webpack_require__.n(tooltip_); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/menu-item.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + +/* harmony default export */ var menu_itemvue_type_script_lang_js_ = ({ + name: 'ElMenuItem', + + componentName: 'ElMenuItem', + + mixins: [menu_mixin, emitter_default.a], + + components: { ElTooltip: tooltip_default.a }, + + props: { + index: { + default: null, + validator: function validator(val) { + return typeof val === 'string' || val === null; + } + }, + route: [String, Object], + disabled: Boolean + }, + computed: { + active: function active() { + return this.index === this.rootMenu.activeIndex; + }, + hoverBackground: function hoverBackground() { + return this.rootMenu.hoverBackground; + }, + backgroundColor: function backgroundColor() { + return this.rootMenu.backgroundColor || ''; + }, + activeTextColor: function activeTextColor() { + return this.rootMenu.activeTextColor || ''; + }, + textColor: function textColor() { + return this.rootMenu.textColor || ''; + }, + mode: function mode() { + return this.rootMenu.mode; + }, + itemStyle: function itemStyle() { + var style = { + color: this.active ? this.activeTextColor : this.textColor + }; + if (this.mode === 'horizontal' && !this.isNested) { + style.borderBottomColor = this.active ? this.rootMenu.activeTextColor ? this.activeTextColor : '' : 'transparent'; + } + return style; + }, + isNested: function isNested() { + return this.parentMenu !== this.rootMenu; + } + }, + methods: { + onMouseEnter: function onMouseEnter() { + if (this.mode === 'horizontal' && !this.rootMenu.backgroundColor) return; + this.$el.style.backgroundColor = this.hoverBackground; + }, + onMouseLeave: function onMouseLeave() { + if (this.mode === 'horizontal' && !this.rootMenu.backgroundColor) return; + this.$el.style.backgroundColor = this.backgroundColor; + }, + handleClick: function handleClick() { + if (!this.disabled) { + this.dispatch('ElMenu', 'item-click', this); + this.$emit('click', this); + } + } + }, + mounted: function mounted() { + this.parentMenu.addItem(this); + this.rootMenu.addItem(this); + }, + beforeDestroy: function beforeDestroy() { + this.parentMenu.removeItem(this); + this.rootMenu.removeItem(this); + } +}); +// CONCATENATED MODULE: ./packages/menu/src/menu-item.vue?vue&type=script&lang=js& + /* harmony default export */ var src_menu_itemvue_type_script_lang_js_ = (menu_itemvue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/menu/src/menu-item.vue + + + + + +/* normalize component */ + +var menu_item_component = normalizeComponent( + src_menu_itemvue_type_script_lang_js_, + menu_itemvue_type_template_id_2a5dbfea_render, + menu_itemvue_type_template_id_2a5dbfea_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var menu_item_api; } +menu_item_component.options.__file = "packages/menu/src/menu-item.vue" +/* harmony default export */ var menu_item = (menu_item_component.exports); +// CONCATENATED MODULE: ./packages/menu-item/index.js + + +/* istanbul ignore next */ +menu_item.install = function (Vue) { + Vue.component(menu_item.name, menu_item); +}; + +/* harmony default export */ var packages_menu_item = (menu_item); +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/menu-item-group.vue?vue&type=template&id=543b7bdc& +var menu_item_groupvue_type_template_id_543b7bdc_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c("li", { staticClass: "el-menu-item-group" }, [ + _c( + "div", + { + staticClass: "el-menu-item-group__title", + style: { paddingLeft: _vm.levelPadding + "px" } + }, + [!_vm.$slots.title ? [_vm._v(_vm._s(_vm.title))] : _vm._t("title")], + 2 + ), + _c("ul", [_vm._t("default")], 2) + ]) +} +var menu_item_groupvue_type_template_id_543b7bdc_staticRenderFns = [] +menu_item_groupvue_type_template_id_543b7bdc_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/menu/src/menu-item-group.vue?vue&type=template&id=543b7bdc& + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/menu-item-group.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// + +/* harmony default export */ var menu_item_groupvue_type_script_lang_js_ = ({ + name: 'ElMenuItemGroup', + + componentName: 'ElMenuItemGroup', + + inject: ['rootMenu'], + props: { + title: { + type: String + } + }, + data: function data() { + return { + paddingLeft: 20 + }; + }, + + computed: { + levelPadding: function levelPadding() { + var padding = 20; + var parent = this.$parent; + if (this.rootMenu.collapse) return 20; + while (parent && parent.$options.componentName !== 'ElMenu') { + if (parent.$options.componentName === 'ElSubmenu') { + padding += 20; + } + parent = parent.$parent; + } + return padding; + } + } +}); +// CONCATENATED MODULE: ./packages/menu/src/menu-item-group.vue?vue&type=script&lang=js& + /* harmony default export */ var src_menu_item_groupvue_type_script_lang_js_ = (menu_item_groupvue_type_script_lang_js_); +// CONCATENATED MODULE: ./packages/menu/src/menu-item-group.vue + + + + + +/* normalize component */ + +var menu_item_group_component = normalizeComponent( + src_menu_item_groupvue_type_script_lang_js_, + menu_item_groupvue_type_template_id_543b7bdc_render, + menu_item_groupvue_type_template_id_543b7bdc_staticRenderFns, + false, + null, + null, + null + +) + +/* hot reload */ +if (false) { var menu_item_group_api; } +menu_item_group_component.options.__file = "packages/menu/src/menu-item-group.vue" +/* harmony default export */ var menu_item_group = (menu_item_group_component.exports); +// CONCATENATED MODULE: ./packages/menu-item-group/index.js + + +/* istanbul ignore next */ +menu_item_group.install = function (Vue) { + Vue.component(menu_item_group.name, menu_item_group); +}; + +/* harmony default export */ var packages_menu_item_group = (menu_item_group); +// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/input/src/input.vue?vue&type=template&id=343dd774& +var inputvue_type_template_id_343dd774_render = function() { + var _vm = this + var _h = _vm.$createElement + var _c = _vm._self._c || _h + return _c( + "div", + { + class: [ + _vm.type === "textarea" ? "el-textarea" : "el-input", + _vm.inputSize ? "el-input--" + _vm.inputSize : "", + { + "is-disabled": _vm.inputDisabled, + "is-exceed": _vm.inputExceed, + "el-input-group": _vm.$slots.prepend || _vm.$slots.append, + "el-input-group--append": _vm.$slots.append, + "el-input-group--prepend": _vm.$slots.prepend, + "el-input--prefix": _vm.$slots.prefix || _vm.prefixIcon, + "el-input--suffix": + _vm.$slots.suffix || + _vm.suffixIcon || + _vm.clearable || + _vm.showPassword + } + ], + on: { + mouseenter: function($event) { + _vm.hovering = true + }, + mouseleave: function($event) { + _vm.hovering = false + } + } + }, + [ + _vm.type !== "textarea" + ? [ + _vm.$slots.prepend + ? _c( + "div", + { staticClass: "el-input-group__prepend" }, + [_vm._t("prepend")], + 2 + ) + : _vm._e(), + _vm.type !== "textarea" + ? _c( + "input", + _vm._b( + { + ref: "input", + staticClass: "el-input__inner", + attrs: { + tabindex: _vm.tabindex, + type: _vm.showPassword + ? _vm.passwordVisible + ? "text" + : "password" + : _vm.type, + disabled: _vm.inputDisabled, + readonly: _vm.readonly, + autocomplete: _vm.autoComplete || _vm.autocomplete, + "aria-label": _vm.label + }, + on: { + compositionstart: _vm.handleCompositionStart, + compositionupdate: _vm.handleCompositionUpdate, + compositionend: _vm.handleCompositionEnd, + input: _vm.handleInput, + focus: _vm.handleFocus, + blur: _vm.handleBlur, + change: _vm.handleChange + } + }, + "input", + _vm.$attrs, + false + ) + ) + : _vm._e(), + _vm.$slots.prefix || _vm.prefixIcon + ? _c( + "span", + { staticClass: "el-input__prefix" }, + [ + _vm._t("prefix"), + _vm.prefixIcon + ? _c("i", { + staticClass: "el-input__icon", + class: _vm.prefixIcon + }) + : _vm._e() + ], + 2 + ) + : _vm._e(), + _vm.getSuffixVisible() + ? _c("span", { staticClass: "el-input__suffix" }, [ + _c( + "span", + { staticClass: "el-input__suffix-inner" }, + [ + !_vm.showClear || + !_vm.showPwdVisible || + !_vm.isWordLimitVisible + ? [ + _vm._t("suffix"), + _vm.suffixIcon + ? _c("i", { + staticClass: "el-input__icon", + class: _vm.suffixIcon + }) + : _vm._e() + ] + : _vm._e(), + _vm.showClear + ? _c("i", { + staticClass: + "el-input__icon el-icon-circle-close el-input__clear", + on: { + mousedown: function($event) { + $event.preventDefault() + }, + click: _vm.clear + } + }) + : _vm._e(), + _vm.showPwdVisible + ? _c("i", { + staticClass: + "el-input__icon el-icon-view el-input__clear", + on: { click: _vm.handlePasswordVisible } + }) + : _vm._e(), + _vm.isWordLimitVisible + ? _c("span", { staticClass: "el-input__count" }, [ + _c( + "span", + { staticClass: "el-input__count-inner" }, + [ + _vm._v( + "\n " + + _vm._s(_vm.textLength) + + "/" + + _vm._s(_vm.upperLimit) + + "\n " + ) + ] + ) + ]) + : _vm._e() + ], + 2 + ), + _vm.validateState + ? _c("i", { + staticClass: "el-input__icon", + class: ["el-input__validateIcon", _vm.validateIcon] + }) + : _vm._e() + ]) + : _vm._e(), + _vm.$slots.append + ? _c( + "div", + { staticClass: "el-input-group__append" }, + [_vm._t("append")], + 2 + ) + : _vm._e() + ] + : _c( + "textarea", + _vm._b( + { + ref: "textarea", + staticClass: "el-textarea__inner", + style: _vm.textareaStyle, + attrs: { + tabindex: _vm.tabindex, + disabled: _vm.inputDisabled, + readonly: _vm.readonly, + autocomplete: _vm.autoComplete || _vm.autocomplete, + "aria-label": _vm.label + }, + on: { + compositionstart: _vm.handleCompositionStart, + compositionupdate: _vm.handleCompositionUpdate, + compositionend: _vm.handleCompositionEnd, + input: _vm.handleInput, + focus: _vm.handleFocus, + blur: _vm.handleBlur, + change: _vm.handleChange + } + }, + "textarea", + _vm.$attrs, + false + ) + ), + _vm.isWordLimitVisible && _vm.type === "textarea" + ? _c("span", { staticClass: "el-input__count" }, [ + _vm._v(_vm._s(_vm.textLength) + "/" + _vm._s(_vm.upperLimit)) + ]) + : _vm._e() + ], + 2 + ) +} +var inputvue_type_template_id_343dd774_staticRenderFns = [] +inputvue_type_template_id_343dd774_render._withStripped = true + + +// CONCATENATED MODULE: ./packages/input/src/input.vue?vue&type=template&id=343dd774& + +// CONCATENATED MODULE: ./packages/input/src/calcTextareaHeight.js +var hiddenTextarea = void 0; + +var HIDDEN_STYLE = '\n height:0 !important;\n visibility:hidden !important;\n overflow:hidden !important;\n position:absolute !important;\n z-index:-1000 !important;\n top:0 !important;\n right:0 !important\n'; + +var CONTEXT_STYLE = ['letter-spacing', 'line-height', 'padding-top', 'padding-bottom', 'font-family', 'font-weight', 'font-size', 'text-rendering', 'text-transform', 'width', 'text-indent', 'padding-left', 'padding-right', 'border-width', 'box-sizing']; + +function calculateNodeStyling(targetElement) { + var style = window.getComputedStyle(targetElement); + + var boxSizing = style.getPropertyValue('box-sizing'); + + var paddingSize = parseFloat(style.getPropertyValue('padding-bottom')) + parseFloat(style.getPropertyValue('padding-top')); + + var borderSize = parseFloat(style.getPropertyValue('border-bottom-width')) + parseFloat(style.getPropertyValue('border-top-width')); + + var contextStyle = CONTEXT_STYLE.map(function (name) { + return name + ':' + style.getPropertyValue(name); + }).join(';'); + + return { contextStyle: contextStyle, paddingSize: paddingSize, borderSize: borderSize, boxSizing: boxSizing }; +} + +function calcTextareaHeight(targetElement) { + var minRows = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1; + var maxRows = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; + + if (!hiddenTextarea) { + hiddenTextarea = document.createElement('textarea'); + document.body.appendChild(hiddenTextarea); + } + + var _calculateNodeStyling = calculateNodeStyling(targetElement), + paddingSize = _calculateNodeStyling.paddingSize, + borderSize = _calculateNodeStyling.borderSize, + boxSizing = _calculateNodeStyling.boxSizing, + contextStyle = _calculateNodeStyling.contextStyle; + + hiddenTextarea.setAttribute('style', contextStyle + ';' + HIDDEN_STYLE); + hiddenTextarea.value = targetElement.value || targetElement.placeholder || ''; + + var height = hiddenTextarea.scrollHeight; + var result = {}; + + if (boxSizing === 'border-box') { + height = height + borderSize; + } else if (boxSizing === 'content-box') { + height = height - paddingSize; + } + + hiddenTextarea.value = ''; + var singleRowHeight = hiddenTextarea.scrollHeight - paddingSize; + + if (minRows !== null) { + var minHeight = singleRowHeight * minRows; + if (boxSizing === 'border-box') { + minHeight = minHeight + paddingSize + borderSize; + } + height = Math.max(minHeight, height); + result.minHeight = minHeight + 'px'; + } + if (maxRows !== null) { + var maxHeight = singleRowHeight * maxRows; + if (boxSizing === 'border-box') { + maxHeight = maxHeight + paddingSize + borderSize; + } + height = Math.min(maxHeight, height); + } + result.height = height + 'px'; + hiddenTextarea.parentNode && hiddenTextarea.parentNode.removeChild(hiddenTextarea); + hiddenTextarea = null; + return result; +}; +// EXTERNAL MODULE: external "element-ui/lib/utils/merge" +var merge_ = __webpack_require__(7); +var merge_default = /*#__PURE__*/__webpack_require__.n(merge_); + +// EXTERNAL MODULE: external "element-ui/lib/utils/shared" +var shared_ = __webpack_require__(19); + +// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/input/src/input.vue?vue&type=script&lang=js& +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// +// + + + + + + + +/* harmony default export */ var inputvue_type_script_lang_js_ = ({ + name: 'ElInput', + + componentName: 'ElInput', + + mixins: [emitter_default.a, migrating_default.a], + + inheritAttrs: false, + + inject: { + elForm: { + default: '' + }, + elFormItem: { + default: '' + } + }, + + data: function data() { + return { + textareaCalcStyle: {}, + hovering: false, + focused: false, + isComposing: false, + passwordVisible: false + }; + }, + + + props: { + value: [String, Number], + size: String, + resize: String, + form: String, + disabled: Boolean, + readonly: Boolean, + type: { + type: String, + default: 'text' + }, + autosize: { + type: [Boolean, Object], + default: false + }, + autocomplete: { + type: String, + default: 'off' + }, + /** @Deprecated in next major version */ + autoComplete: { + type: String, + validator: function validator(val) { + false && false; + return true; + } + }, + validateEvent: { + type: Boolean, + default: true + }, + suffixIcon: String, + prefixIcon: String, + label: String, + clearable: { + type: Boolean, + default: false + }, + showPassword: { + type: Boolean, + default: false + }, + showWordLimit: { + type: Boolean, + default: false + }, + tabindex: String + }, + + computed: { + _elFormItemSize: function _elFormItemSize() { + return (this.elFormItem || {}).elFormItemSize; + }, + validateState: function validateState() { + return this.elFormItem ? this.elFormItem.validateState : ''; + }, + needStatusIcon: function needStatusIcon() { + return this.elForm ? this.elForm.statusIcon : false; + }, + validateIcon: function validateIcon() { + return { + validating: 'el-icon-loading', + success: 'el-icon-circle-check', + error: 'el-icon-circle-close' + }[this.validateState]; + }, + textareaStyle: function textareaStyle() { + return merge_default()({}, this.textareaCalcStyle, { resize: this.resize }); + }, + inputSize: function inputSize() { + return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size; + }, + inputDisabled: function inputDisabled() { + return this.disabled || (this.elForm || {}).disabled; + }, + nativeInputValue: function nativeInputValue() { + return this.value === null || this.value === undefined ? '' : String(this.value); + }, + showClear: function showClear() { + return this.clearable && !this.inputDisabled && !this.readonly && this.nativeInputValue && (this.focused || this.hovering); + }, + showPwdVisible: function showPwdVisible() { + return this.showPassword && !this.inputDisabled && !this.readonly && (!!this.nativeInputValue || this.focused); + }, + isWordLimitVisible: function isWordLimitVisible() { + return this.showWordLimit && this.$attrs.maxlength && (this.type === 'text' || this.type === 'textarea') && !this.inputDisabled && !this.readonly && !this.showPassword; + }, + upperLimit: function upperLimit() { + return this.$attrs.maxlength; + }, + textLength: function textLength() { + if (typeof this.value === 'number') { + return String(this.value).length; + } + + return (this.value || '').length; + }, + inputExceed: function inputExceed() { + // show exceed style if length of initial value greater then maxlength + return this.isWordLimitVisible && this.textLength > this.upperLimit; + } + }, + + watch: { + value: function value(val) { + this.$nextTick(this.resizeTextarea); + if (this.validateEvent) { + this.dispatch('ElFormItem', 'el.form.change', [val]); + } + }, + + // native input value is set explicitly + // do not use v-model / :value in template + // see: https://github.com/ElemeFE/element/issues/14521 + nativeInputValue: function nativeInputValue() { + this.setNativeInputValue(); + }, + + // when change between and \n
\n
\n
\n \n \n \n
\n
\n
\n
\n
\n \n").replace(/(^|\n)\s*/g, ''); + + /** + * @returns {boolean} + */ + var resetOldContainer = function resetOldContainer() { + var oldContainer = getContainer(); + if (!oldContainer) { + return false; + } + oldContainer.remove(); + removeClass([document.documentElement, document.body], [swalClasses['no-backdrop'], swalClasses['toast-shown'], swalClasses['has-column']]); + return true; + }; + var resetValidationMessage$1 = function resetValidationMessage() { + globalState.currentInstance.resetValidationMessage(); + }; + var addInputChangeListeners = function addInputChangeListeners() { + var popup = getPopup(); + var input = getDirectChildByClass(popup, swalClasses.input); + var file = getDirectChildByClass(popup, swalClasses.file); + /** @type {HTMLInputElement} */ + var range = popup.querySelector(".".concat(swalClasses.range, " input")); + /** @type {HTMLOutputElement} */ + var rangeOutput = popup.querySelector(".".concat(swalClasses.range, " output")); + var select = getDirectChildByClass(popup, swalClasses.select); + /** @type {HTMLInputElement} */ + var checkbox = popup.querySelector(".".concat(swalClasses.checkbox, " input")); + var textarea = getDirectChildByClass(popup, swalClasses.textarea); + input.oninput = resetValidationMessage$1; + file.onchange = resetValidationMessage$1; + select.onchange = resetValidationMessage$1; + checkbox.onchange = resetValidationMessage$1; + textarea.oninput = resetValidationMessage$1; + range.oninput = function () { + resetValidationMessage$1(); + rangeOutput.value = range.value; + }; + range.onchange = function () { + resetValidationMessage$1(); + rangeOutput.value = range.value; + }; + }; + + /** + * @param {string | HTMLElement} target + * @returns {HTMLElement} + */ + var getTarget = function getTarget(target) { + return typeof target === 'string' ? document.querySelector(target) : target; + }; + + /** + * @param {SweetAlertOptions} params + */ + var setupAccessibility = function setupAccessibility(params) { + var popup = getPopup(); + popup.setAttribute('role', params.toast ? 'alert' : 'dialog'); + popup.setAttribute('aria-live', params.toast ? 'polite' : 'assertive'); + if (!params.toast) { + popup.setAttribute('aria-modal', 'true'); + } + }; + + /** + * @param {HTMLElement} targetElement + */ + var setupRTL = function setupRTL(targetElement) { + if (window.getComputedStyle(targetElement).direction === 'rtl') { + addClass(getContainer(), swalClasses.rtl); + } + }; + + /** + * Add modal + backdrop + no-war message for Russians to DOM + * + * @param {SweetAlertOptions} params + */ + var init = function init(params) { + // Clean up the old popup container if it exists + var oldContainerExisted = resetOldContainer(); + if (isNodeEnv()) { + error('SweetAlert2 requires document to initialize'); + return; + } + var container = document.createElement('div'); + container.className = swalClasses.container; + if (oldContainerExisted) { + addClass(container, swalClasses['no-transition']); + } + setInnerHtml(container, sweetHTML); + var targetElement = getTarget(params.target); + targetElement.appendChild(container); + setupAccessibility(params); + setupRTL(targetElement); + addInputChangeListeners(); + }; + + /** + * @param {HTMLElement | object | string} param + * @param {HTMLElement} target + */ + var parseHtmlToContainer = function parseHtmlToContainer(param, target) { + // DOM element + if (param instanceof HTMLElement) { + target.appendChild(param); + } + + // Object + else if (_typeof(param) === 'object') { + handleObject(param, target); + } + + // Plain string + else if (param) { + setInnerHtml(target, param); + } + }; + + /** + * @param {any} param + * @param {HTMLElement} target + */ + var handleObject = function handleObject(param, target) { + // JQuery element(s) + if (param.jquery) { + handleJqueryElem(target, param); + } + + // For other objects use their string representation + else { + setInnerHtml(target, param.toString()); + } + }; + + /** + * @param {HTMLElement} target + * @param {any} elem + */ + var handleJqueryElem = function handleJqueryElem(target, elem) { + target.textContent = ''; + if (0 in elem) { + for (var i = 0; (i in elem); i++) { + target.appendChild(elem[i].cloneNode(true)); + } + } else { + target.appendChild(elem.cloneNode(true)); + } + }; + + /** + * @returns {'webkitAnimationEnd' | 'animationend' | false} + */ + var animationEndEvent = function () { + // Prevent run in Node env + if (isNodeEnv()) { + return false; + } + var testEl = document.createElement('div'); + + // Chrome, Safari and Opera + if (typeof testEl.style.webkitAnimation !== 'undefined') { + return 'webkitAnimationEnd'; + } + + // Standard syntax + if (typeof testEl.style.animation !== 'undefined') { + return 'animationend'; + } + return false; + }(); + + /** + * @param {SweetAlert} instance + * @param {SweetAlertOptions} params + */ + var renderActions = function renderActions(instance, params) { + var actions = getActions(); + var loader = getLoader(); + if (!actions || !loader) { + return; + } + + // Actions (buttons) wrapper + if (!params.showConfirmButton && !params.showDenyButton && !params.showCancelButton) { + hide(actions); + } else { + show(actions); + } + + // Custom class + applyCustomClass(actions, params, 'actions'); + + // Render all the buttons + renderButtons(actions, loader, params); + + // Loader + setInnerHtml(loader, params.loaderHtml || ''); + applyCustomClass(loader, params, 'loader'); + }; + + /** + * @param {HTMLElement} actions + * @param {HTMLElement} loader + * @param {SweetAlertOptions} params + */ + function renderButtons(actions, loader, params) { + var confirmButton = getConfirmButton(); + var denyButton = getDenyButton(); + var cancelButton = getCancelButton(); + if (!confirmButton || !denyButton || !cancelButton) { + return; + } + + // Render buttons + renderButton(confirmButton, 'confirm', params); + renderButton(denyButton, 'deny', params); + renderButton(cancelButton, 'cancel', params); + handleButtonsStyling(confirmButton, denyButton, cancelButton, params); + if (params.reverseButtons) { + if (params.toast) { + actions.insertBefore(cancelButton, confirmButton); + actions.insertBefore(denyButton, confirmButton); + } else { + actions.insertBefore(cancelButton, loader); + actions.insertBefore(denyButton, loader); + actions.insertBefore(confirmButton, loader); + } + } + } + + /** + * @param {HTMLElement} confirmButton + * @param {HTMLElement} denyButton + * @param {HTMLElement} cancelButton + * @param {SweetAlertOptions} params + */ + function handleButtonsStyling(confirmButton, denyButton, cancelButton, params) { + if (!params.buttonsStyling) { + removeClass([confirmButton, denyButton, cancelButton], swalClasses.styled); + return; + } + addClass([confirmButton, denyButton, cancelButton], swalClasses.styled); + + // Buttons background colors + if (params.confirmButtonColor) { + confirmButton.style.backgroundColor = params.confirmButtonColor; + addClass(confirmButton, swalClasses['default-outline']); + } + if (params.denyButtonColor) { + denyButton.style.backgroundColor = params.denyButtonColor; + addClass(denyButton, swalClasses['default-outline']); + } + if (params.cancelButtonColor) { + cancelButton.style.backgroundColor = params.cancelButtonColor; + addClass(cancelButton, swalClasses['default-outline']); + } + } + + /** + * @param {HTMLElement} button + * @param {'confirm' | 'deny' | 'cancel'} buttonType + * @param {SweetAlertOptions} params + */ + function renderButton(button, buttonType, params) { + var buttonName = /** @type {'Confirm' | 'Deny' | 'Cancel'} */capitalizeFirstLetter(buttonType); + toggle(button, params["show".concat(buttonName, "Button")], 'inline-block'); + setInnerHtml(button, params["".concat(buttonType, "ButtonText")] || ''); // Set caption text + button.setAttribute('aria-label', params["".concat(buttonType, "ButtonAriaLabel")] || ''); // ARIA label + + // Add buttons custom classes + button.className = swalClasses[buttonType]; + applyCustomClass(button, params, "".concat(buttonType, "Button")); + } + + /** + * @param {SweetAlert} instance + * @param {SweetAlertOptions} params + */ + var renderCloseButton = function renderCloseButton(instance, params) { + var closeButton = getCloseButton(); + if (!closeButton) { + return; + } + setInnerHtml(closeButton, params.closeButtonHtml || ''); + + // Custom class + applyCustomClass(closeButton, params, 'closeButton'); + toggle(closeButton, params.showCloseButton); + closeButton.setAttribute('aria-label', params.closeButtonAriaLabel || ''); + }; + + /** + * @param {SweetAlert} instance + * @param {SweetAlertOptions} params + */ + var renderContainer = function renderContainer(instance, params) { + var container = getContainer(); + if (!container) { + return; + } + handleBackdropParam(container, params.backdrop); + handlePositionParam(container, params.position); + handleGrowParam(container, params.grow); + + // Custom class + applyCustomClass(container, params, 'container'); + }; + + /** + * @param {HTMLElement} container + * @param {SweetAlertOptions['backdrop']} backdrop + */ + function handleBackdropParam(container, backdrop) { + if (typeof backdrop === 'string') { + container.style.background = backdrop; + } else if (!backdrop) { + addClass([document.documentElement, document.body], swalClasses['no-backdrop']); + } + } + + /** + * @param {HTMLElement} container + * @param {SweetAlertOptions['position']} position + */ + function handlePositionParam(container, position) { + if (!position) { + return; + } + if (position in swalClasses) { + addClass(container, swalClasses[position]); + } else { + warn('The "position" parameter is not valid, defaulting to "center"'); + addClass(container, swalClasses.center); + } + } + + /** + * @param {HTMLElement} container + * @param {SweetAlertOptions['grow']} grow + */ + function handleGrowParam(container, grow) { + if (!grow) { + return; + } + addClass(container, swalClasses["grow-".concat(grow)]); + } + + /** + * This module contains `WeakMap`s for each effectively-"private property" that a `Swal` has. + * For example, to set the private property "foo" of `this` to "bar", you can `privateProps.foo.set(this, 'bar')` + * This is the approach that Babel will probably take to implement private methods/fields + * https://github.com/tc39/proposal-private-methods + * https://github.com/babel/babel/pull/7555 + * Once we have the changes from that PR in Babel, and our core class fits reasonable in *one module* + * then we can use that language feature. + */ + + var privateProps = { + innerParams: new WeakMap(), + domCache: new WeakMap() + }; + + /** @type {InputClass[]} */ + var inputClasses = ['input', 'file', 'range', 'select', 'radio', 'checkbox', 'textarea']; + + /** + * @param {SweetAlert} instance + * @param {SweetAlertOptions} params + */ + var renderInput = function renderInput(instance, params) { + var popup = getPopup(); + if (!popup) { + return; + } + var innerParams = privateProps.innerParams.get(instance); + var rerender = !innerParams || params.input !== innerParams.input; + inputClasses.forEach(function (inputClass) { + var inputContainer = getDirectChildByClass(popup, swalClasses[inputClass]); + if (!inputContainer) { + return; + } + + // set attributes + setAttributes(inputClass, params.inputAttributes); + + // set class + inputContainer.className = swalClasses[inputClass]; + if (rerender) { + hide(inputContainer); + } + }); + if (params.input) { + if (rerender) { + showInput(params); + } + // set custom class + setCustomClass(params); + } + }; + + /** + * @param {SweetAlertOptions} params + */ + var showInput = function showInput(params) { + if (!params.input) { + return; + } + if (!renderInputType[params.input]) { + error("Unexpected type of input! Expected ".concat(Object.keys(renderInputType).join(' | '), ", got \"").concat(params.input, "\"")); + return; + } + var inputContainer = getInputContainer(params.input); + var input = renderInputType[params.input](inputContainer, params); + show(inputContainer); + + // input autofocus + if (params.inputAutoFocus) { + setTimeout(function () { + focusInput(input); + }); + } + }; + + /** + * @param {HTMLInputElement} input + */ + var removeAttributes = function removeAttributes(input) { + for (var i = 0; i < input.attributes.length; i++) { + var attrName = input.attributes[i].name; + if (!['id', 'type', 'value', 'style'].includes(attrName)) { + input.removeAttribute(attrName); + } + } + }; + + /** + * @param {InputClass} inputClass + * @param {SweetAlertOptions['inputAttributes']} inputAttributes + */ + var setAttributes = function setAttributes(inputClass, inputAttributes) { + var input = getInput$1(getPopup(), inputClass); + if (!input) { + return; + } + removeAttributes(input); + for (var attr in inputAttributes) { + input.setAttribute(attr, inputAttributes[attr]); + } + }; + + /** + * @param {SweetAlertOptions} params + */ + var setCustomClass = function setCustomClass(params) { + var inputContainer = getInputContainer(params.input); + if (_typeof(params.customClass) === 'object') { + addClass(inputContainer, params.customClass.input); + } + }; + + /** + * @param {HTMLInputElement | HTMLTextAreaElement} input + * @param {SweetAlertOptions} params + */ + var setInputPlaceholder = function setInputPlaceholder(input, params) { + if (!input.placeholder || params.inputPlaceholder) { + input.placeholder = params.inputPlaceholder; + } + }; + + /** + * @param {Input} input + * @param {Input} prependTo + * @param {SweetAlertOptions} params + */ + var setInputLabel = function setInputLabel(input, prependTo, params) { + if (params.inputLabel) { + var label = document.createElement('label'); + var labelClass = swalClasses['input-label']; + label.setAttribute('for', input.id); + label.className = labelClass; + if (_typeof(params.customClass) === 'object') { + addClass(label, params.customClass.inputLabel); + } + label.innerText = params.inputLabel; + prependTo.insertAdjacentElement('beforebegin', label); + } + }; + + /** + * @param {SweetAlertOptions['input']} inputType + * @returns {HTMLElement} + */ + var getInputContainer = function getInputContainer(inputType) { + return getDirectChildByClass(getPopup(), swalClasses[inputType] || swalClasses.input); + }; + + /** + * @param {HTMLInputElement | HTMLOutputElement | HTMLTextAreaElement} input + * @param {SweetAlertOptions['inputValue']} inputValue + */ + var checkAndSetInputValue = function checkAndSetInputValue(input, inputValue) { + if (['string', 'number'].includes(_typeof(inputValue))) { + input.value = "".concat(inputValue); + } else if (!isPromise(inputValue)) { + warn("Unexpected type of inputValue! Expected \"string\", \"number\" or \"Promise\", got \"".concat(_typeof(inputValue), "\"")); + } + }; + + /** @type {Record Input>} */ + var renderInputType = {}; + + /** + * @param {HTMLInputElement} input + * @param {SweetAlertOptions} params + * @returns {HTMLInputElement} + */ + renderInputType.text = renderInputType.email = renderInputType.password = renderInputType.number = renderInputType.tel = renderInputType.url = renderInputType.search = renderInputType.date = renderInputType['datetime-local'] = renderInputType.time = renderInputType.week = renderInputType.month = function (input, params) { + checkAndSetInputValue(input, params.inputValue); + setInputLabel(input, input, params); + setInputPlaceholder(input, params); + input.type = params.input; + return input; + }; + + /** + * @param {HTMLInputElement} input + * @param {SweetAlertOptions} params + * @returns {HTMLInputElement} + */ + renderInputType.file = function (input, params) { + setInputLabel(input, input, params); + setInputPlaceholder(input, params); + return input; + }; + + /** + * @param {HTMLInputElement} range + * @param {SweetAlertOptions} params + * @returns {HTMLInputElement} + */ + renderInputType.range = function (range, params) { + var rangeInput = range.querySelector('input'); + var rangeOutput = range.querySelector('output'); + checkAndSetInputValue(rangeInput, params.inputValue); + rangeInput.type = params.input; + checkAndSetInputValue(rangeOutput, params.inputValue); + setInputLabel(rangeInput, range, params); + return range; + }; + + /** + * @param {HTMLSelectElement} select + * @param {SweetAlertOptions} params + * @returns {HTMLSelectElement} + */ + renderInputType.select = function (select, params) { + select.textContent = ''; + if (params.inputPlaceholder) { + var placeholder = document.createElement('option'); + setInnerHtml(placeholder, params.inputPlaceholder); + placeholder.value = ''; + placeholder.disabled = true; + placeholder.selected = true; + select.appendChild(placeholder); + } + setInputLabel(select, select, params); + return select; + }; + + /** + * @param {HTMLInputElement} radio + * @returns {HTMLInputElement} + */ + renderInputType.radio = function (radio) { + radio.textContent = ''; + return radio; + }; + + /** + * @param {HTMLLabelElement} checkboxContainer + * @param {SweetAlertOptions} params + * @returns {HTMLInputElement} + */ + renderInputType.checkbox = function (checkboxContainer, params) { + var checkbox = getInput$1(getPopup(), 'checkbox'); + checkbox.value = '1'; + checkbox.checked = Boolean(params.inputValue); + var label = checkboxContainer.querySelector('span'); + setInnerHtml(label, params.inputPlaceholder); + return checkbox; + }; + + /** + * @param {HTMLTextAreaElement} textarea + * @param {SweetAlertOptions} params + * @returns {HTMLTextAreaElement} + */ + renderInputType.textarea = function (textarea, params) { + checkAndSetInputValue(textarea, params.inputValue); + setInputPlaceholder(textarea, params); + setInputLabel(textarea, textarea, params); + + /** + * @param {HTMLElement} el + * @returns {number} + */ + var getMargin = function getMargin(el) { + return parseInt(window.getComputedStyle(el).marginLeft) + parseInt(window.getComputedStyle(el).marginRight); + }; + + // https://github.com/sweetalert2/sweetalert2/issues/2291 + setTimeout(function () { + // https://github.com/sweetalert2/sweetalert2/issues/1699 + if ('MutationObserver' in window) { + var initialPopupWidth = parseInt(window.getComputedStyle(getPopup()).width); + var textareaResizeHandler = function textareaResizeHandler() { + // check if texarea is still in document (i.e. popup wasn't closed in the meantime) + if (!document.body.contains(textarea)) { + return; + } + var textareaWidth = textarea.offsetWidth + getMargin(textarea); + if (textareaWidth > initialPopupWidth) { + getPopup().style.width = "".concat(textareaWidth, "px"); + } else { + applyNumericalStyle(getPopup(), 'width', params.width); + } + }; + new MutationObserver(textareaResizeHandler).observe(textarea, { + attributes: true, + attributeFilter: ['style'] + }); + } + }); + return textarea; + }; + + /** + * @param {SweetAlert} instance + * @param {SweetAlertOptions} params + */ + var renderContent = function renderContent(instance, params) { + var htmlContainer = getHtmlContainer(); + if (!htmlContainer) { + return; + } + showWhenInnerHtmlPresent(htmlContainer); + applyCustomClass(htmlContainer, params, 'htmlContainer'); + + // Content as HTML + if (params.html) { + parseHtmlToContainer(params.html, htmlContainer); + show(htmlContainer, 'block'); + } + + // Content as plain text + else if (params.text) { + htmlContainer.textContent = params.text; + show(htmlContainer, 'block'); + } + + // No content + else { + hide(htmlContainer); + } + renderInput(instance, params); + }; + + /** + * @param {SweetAlert} instance + * @param {SweetAlertOptions} params + */ + var renderFooter = function renderFooter(instance, params) { + var footer = getFooter(); + if (!footer) { + return; + } + showWhenInnerHtmlPresent(footer); + toggle(footer, params.footer, 'block'); + if (params.footer) { + parseHtmlToContainer(params.footer, footer); + } + + // Custom class + applyCustomClass(footer, params, 'footer'); + }; + + /** + * @param {SweetAlert} instance + * @param {SweetAlertOptions} params + */ + var renderIcon = function renderIcon(instance, params) { + var innerParams = privateProps.innerParams.get(instance); + var icon = getIcon(); + if (!icon) { + return; + } + + // if the given icon already rendered, apply the styling without re-rendering the icon + if (innerParams && params.icon === innerParams.icon) { + // Custom or default content + setContent(icon, params); + applyStyles(icon, params); + return; + } + if (!params.icon && !params.iconHtml) { + hide(icon); + return; + } + if (params.icon && Object.keys(iconTypes).indexOf(params.icon) === -1) { + error("Unknown icon! Expected \"success\", \"error\", \"warning\", \"info\" or \"question\", got \"".concat(params.icon, "\"")); + hide(icon); + return; + } + show(icon); + + // Custom or default content + setContent(icon, params); + applyStyles(icon, params); + + // Animate icon + addClass(icon, params.showClass && params.showClass.icon); + }; + + /** + * @param {HTMLElement} icon + * @param {SweetAlertOptions} params + */ + var applyStyles = function applyStyles(icon, params) { + for (var _i = 0, _Object$entries = Object.entries(iconTypes); _i < _Object$entries.length; _i++) { + var _Object$entries$_i = _slicedToArray(_Object$entries[_i], 2), + iconType = _Object$entries$_i[0], + iconClassName = _Object$entries$_i[1]; + if (params.icon !== iconType) { + removeClass(icon, iconClassName); + } + } + addClass(icon, params.icon && iconTypes[params.icon]); + + // Icon color + setColor(icon, params); + + // Success icon background color + adjustSuccessIconBackgroundColor(); + + // Custom class + applyCustomClass(icon, params, 'icon'); + }; + + // Adjust success icon background color to match the popup background color + var adjustSuccessIconBackgroundColor = function adjustSuccessIconBackgroundColor() { + var popup = getPopup(); + if (!popup) { + return; + } + var popupBackgroundColor = window.getComputedStyle(popup).getPropertyValue('background-color'); + /** @type {NodeListOf} */ + var successIconParts = popup.querySelectorAll('[class^=swal2-success-circular-line], .swal2-success-fix'); + for (var i = 0; i < successIconParts.length; i++) { + successIconParts[i].style.backgroundColor = popupBackgroundColor; + } + }; + var successIconHtml = "\n
\n \n
\n
\n"; + var errorIconHtml = "\n \n \n \n \n"; + + /** + * @param {HTMLElement} icon + * @param {SweetAlertOptions} params + */ + var setContent = function setContent(icon, params) { + if (!params.icon && !params.iconHtml) { + return; + } + var oldContent = icon.innerHTML; + var newContent = ''; + if (params.iconHtml) { + newContent = iconContent(params.iconHtml); + } else if (params.icon === 'success') { + newContent = successIconHtml; + oldContent = oldContent.replace(/ style=".*?"/g, ''); // undo adjustSuccessIconBackgroundColor() + } else if (params.icon === 'error') { + newContent = errorIconHtml; + } else if (params.icon) { + var defaultIconHtml = { + question: '?', + warning: '!', + info: 'i' + }; + newContent = iconContent(defaultIconHtml[params.icon]); + } + if (oldContent.trim() !== newContent.trim()) { + setInnerHtml(icon, newContent); + } + }; + + /** + * @param {HTMLElement} icon + * @param {SweetAlertOptions} params + */ + var setColor = function setColor(icon, params) { + if (!params.iconColor) { + return; + } + icon.style.color = params.iconColor; + icon.style.borderColor = params.iconColor; + for (var _i2 = 0, _arr = ['.swal2-success-line-tip', '.swal2-success-line-long', '.swal2-x-mark-line-left', '.swal2-x-mark-line-right']; _i2 < _arr.length; _i2++) { + var sel = _arr[_i2]; + setStyle(icon, sel, 'background-color', params.iconColor); + } + setStyle(icon, '.swal2-success-ring', 'border-color', params.iconColor); + }; + + /** + * @param {string} content + * @returns {string} + */ + var iconContent = function iconContent(content) { + return "
").concat(content, "
"); + }; + + /** + * @param {SweetAlert} instance + * @param {SweetAlertOptions} params + */ + var renderImage = function renderImage(instance, params) { + var image = getImage(); + if (!image) { + return; + } + if (!params.imageUrl) { + hide(image); + return; + } + show(image, ''); + + // Src, alt + image.setAttribute('src', params.imageUrl); + image.setAttribute('alt', params.imageAlt || ''); + + // Width, height + applyNumericalStyle(image, 'width', params.imageWidth); + applyNumericalStyle(image, 'height', params.imageHeight); + + // Class + image.className = swalClasses.image; + applyCustomClass(image, params, 'image'); + }; + + /** + * @param {SweetAlert} instance + * @param {SweetAlertOptions} params + */ + var renderPopup = function renderPopup(instance, params) { + var container = getContainer(); + var popup = getPopup(); + if (!container || !popup) { + return; + } + + // Width + // https://github.com/sweetalert2/sweetalert2/issues/2170 + if (params.toast) { + applyNumericalStyle(container, 'width', params.width); + popup.style.width = '100%'; + var loader = getLoader(); + loader && popup.insertBefore(loader, getIcon()); + } else { + applyNumericalStyle(popup, 'width', params.width); + } + + // Padding + applyNumericalStyle(popup, 'padding', params.padding); + + // Color + if (params.color) { + popup.style.color = params.color; + } + + // Background + if (params.background) { + popup.style.background = params.background; + } + hide(getValidationMessage()); + + // Classes + addClasses$1(popup, params); + }; + + /** + * @param {HTMLElement} popup + * @param {SweetAlertOptions} params + */ + var addClasses$1 = function addClasses(popup, params) { + var showClass = params.showClass || {}; + // Default Class + showClass when updating Swal.update({}) + popup.className = "".concat(swalClasses.popup, " ").concat(isVisible$1(popup) ? showClass.popup : ''); + if (params.toast) { + addClass([document.documentElement, document.body], swalClasses['toast-shown']); + addClass(popup, swalClasses.toast); + } else { + addClass(popup, swalClasses.modal); + } + + // Custom class + applyCustomClass(popup, params, 'popup'); + if (typeof params.customClass === 'string') { + addClass(popup, params.customClass); + } + + // Icon class (#1842) + if (params.icon) { + addClass(popup, swalClasses["icon-".concat(params.icon)]); + } + }; + + /** + * @param {SweetAlert} instance + * @param {SweetAlertOptions} params + */ + var renderProgressSteps = function renderProgressSteps(instance, params) { + var progressStepsContainer = getProgressSteps(); + if (!progressStepsContainer) { + return; + } + var progressSteps = params.progressSteps, + currentProgressStep = params.currentProgressStep; + if (!progressSteps || progressSteps.length === 0 || currentProgressStep === undefined) { + hide(progressStepsContainer); + return; + } + show(progressStepsContainer); + progressStepsContainer.textContent = ''; + if (currentProgressStep >= progressSteps.length) { + warn('Invalid currentProgressStep parameter, it should be less than progressSteps.length ' + '(currentProgressStep like JS arrays starts from 0)'); + } + progressSteps.forEach(function (step, index) { + var stepEl = createStepElement(step); + progressStepsContainer.appendChild(stepEl); + if (index === currentProgressStep) { + addClass(stepEl, swalClasses['active-progress-step']); + } + if (index !== progressSteps.length - 1) { + var lineEl = createLineElement(params); + progressStepsContainer.appendChild(lineEl); + } + }); + }; + + /** + * @param {string} step + * @returns {HTMLLIElement} + */ + var createStepElement = function createStepElement(step) { + var stepEl = document.createElement('li'); + addClass(stepEl, swalClasses['progress-step']); + setInnerHtml(stepEl, step); + return stepEl; + }; + + /** + * @param {SweetAlertOptions} params + * @returns {HTMLLIElement} + */ + var createLineElement = function createLineElement(params) { + var lineEl = document.createElement('li'); + addClass(lineEl, swalClasses['progress-step-line']); + if (params.progressStepsDistance) { + applyNumericalStyle(lineEl, 'width', params.progressStepsDistance); + } + return lineEl; + }; + + /** + * @param {SweetAlert} instance + * @param {SweetAlertOptions} params + */ + var renderTitle = function renderTitle(instance, params) { + var title = getTitle(); + if (!title) { + return; + } + showWhenInnerHtmlPresent(title); + toggle(title, params.title || params.titleText, 'block'); + if (params.title) { + parseHtmlToContainer(params.title, title); + } + if (params.titleText) { + title.innerText = params.titleText; + } + + // Custom class + applyCustomClass(title, params, 'title'); + }; + + /** + * @param {SweetAlert} instance + * @param {SweetAlertOptions} params + */ + var render = function render(instance, params) { + renderPopup(instance, params); + renderContainer(instance, params); + renderProgressSteps(instance, params); + renderIcon(instance, params); + renderImage(instance, params); + renderTitle(instance, params); + renderCloseButton(instance, params); + renderContent(instance, params); + renderActions(instance, params); + renderFooter(instance, params); + var popup = getPopup(); + if (typeof params.didRender === 'function' && popup) { + params.didRender(popup); + } + }; + + /* + * Global function to determine if SweetAlert2 popup is shown + */ + var isVisible = function isVisible() { + return isVisible$1(getPopup()); + }; + + /* + * Global function to click 'Confirm' button + */ + var clickConfirm = function clickConfirm() { + var _dom$getConfirmButton; + return (_dom$getConfirmButton = getConfirmButton()) === null || _dom$getConfirmButton === void 0 ? void 0 : _dom$getConfirmButton.click(); + }; + + /* + * Global function to click 'Deny' button + */ + var clickDeny = function clickDeny() { + var _dom$getDenyButton; + return (_dom$getDenyButton = getDenyButton()) === null || _dom$getDenyButton === void 0 ? void 0 : _dom$getDenyButton.click(); + }; + + /* + * Global function to click 'Cancel' button + */ + var clickCancel = function clickCancel() { + var _dom$getCancelButton; + return (_dom$getCancelButton = getCancelButton()) === null || _dom$getCancelButton === void 0 ? void 0 : _dom$getCancelButton.click(); + }; + + /** @typedef {'cancel' | 'backdrop' | 'close' | 'esc' | 'timer'} DismissReason */ + + /** @type {Record} */ + var DismissReason = Object.freeze({ + cancel: 'cancel', + backdrop: 'backdrop', + close: 'close', + esc: 'esc', + timer: 'timer' + }); + + /** + * @param {GlobalState} globalState + */ + var removeKeydownHandler = function removeKeydownHandler(globalState) { + if (globalState.keydownTarget && globalState.keydownHandlerAdded) { + globalState.keydownTarget.removeEventListener('keydown', globalState.keydownHandler, { + capture: globalState.keydownListenerCapture + }); + globalState.keydownHandlerAdded = false; + } + }; + + /** + * @param {GlobalState} globalState + * @param {SweetAlertOptions} innerParams + * @param {*} dismissWith + */ + var addKeydownHandler = function addKeydownHandler(globalState, innerParams, dismissWith) { + removeKeydownHandler(globalState); + if (!innerParams.toast) { + globalState.keydownHandler = function (e) { + return keydownHandler(innerParams, e, dismissWith); + }; + globalState.keydownTarget = innerParams.keydownListenerCapture ? window : getPopup(); + globalState.keydownListenerCapture = innerParams.keydownListenerCapture; + globalState.keydownTarget.addEventListener('keydown', globalState.keydownHandler, { + capture: globalState.keydownListenerCapture + }); + globalState.keydownHandlerAdded = true; + } + }; + + /** + * @param {number} index + * @param {number} increment + */ + var setFocus = function setFocus(index, increment) { + var _dom$getPopup; + var focusableElements = getFocusableElements(); + // search for visible elements and select the next possible match + if (focusableElements.length) { + index = index + increment; + + // rollover to first item + if (index === focusableElements.length) { + index = 0; + + // go to last item + } else if (index === -1) { + index = focusableElements.length - 1; + } + focusableElements[index].focus(); + return; + } + // no visible focusable elements, focus the popup + (_dom$getPopup = getPopup()) === null || _dom$getPopup === void 0 || _dom$getPopup.focus(); + }; + var arrowKeysNextButton = ['ArrowRight', 'ArrowDown']; + var arrowKeysPreviousButton = ['ArrowLeft', 'ArrowUp']; + + /** + * @param {SweetAlertOptions} innerParams + * @param {KeyboardEvent} event + * @param {Function} dismissWith + */ + var keydownHandler = function keydownHandler(innerParams, event, dismissWith) { + if (!innerParams) { + return; // This instance has already been destroyed + } + + // Ignore keydown during IME composition + // https://developer.mozilla.org/en-US/docs/Web/API/Document/keydown_event#ignoring_keydown_during_ime_composition + // https://github.com/sweetalert2/sweetalert2/issues/720 + // https://github.com/sweetalert2/sweetalert2/issues/2406 + if (event.isComposing || event.keyCode === 229) { + return; + } + if (innerParams.stopKeydownPropagation) { + event.stopPropagation(); + } + + // ENTER + if (event.key === 'Enter') { + handleEnter(event, innerParams); + } + + // TAB + else if (event.key === 'Tab') { + handleTab(event); + } + + // ARROWS - switch focus between buttons + else if ([].concat(arrowKeysNextButton, arrowKeysPreviousButton).includes(event.key)) { + handleArrows(event.key); + } + + // ESC + else if (event.key === 'Escape') { + handleEsc(event, innerParams, dismissWith); + } + }; + + /** + * @param {KeyboardEvent} event + * @param {SweetAlertOptions} innerParams + */ + var handleEnter = function handleEnter(event, innerParams) { + // https://github.com/sweetalert2/sweetalert2/issues/2386 + if (!callIfFunction(innerParams.allowEnterKey)) { + return; + } + var input = getInput$1(getPopup(), innerParams.input); + if (event.target && input && event.target instanceof HTMLElement && event.target.outerHTML === input.outerHTML) { + if (['textarea', 'file'].includes(innerParams.input)) { + return; // do not submit + } + clickConfirm(); + event.preventDefault(); + } + }; + + /** + * @param {KeyboardEvent} event + */ + var handleTab = function handleTab(event) { + var targetElement = event.target; + var focusableElements = getFocusableElements(); + var btnIndex = -1; + for (var i = 0; i < focusableElements.length; i++) { + if (targetElement === focusableElements[i]) { + btnIndex = i; + break; + } + } + + // Cycle to the next button + if (!event.shiftKey) { + setFocus(btnIndex, 1); + } + + // Cycle to the prev button + else { + setFocus(btnIndex, -1); + } + event.stopPropagation(); + event.preventDefault(); + }; + + /** + * @param {string} key + */ + var handleArrows = function handleArrows(key) { + var actions = getActions(); + var confirmButton = getConfirmButton(); + var denyButton = getDenyButton(); + var cancelButton = getCancelButton(); + if (!actions || !confirmButton || !denyButton || !cancelButton) { + return; + } + /** @type HTMLElement[] */ + var buttons = [confirmButton, denyButton, cancelButton]; + if (document.activeElement instanceof HTMLElement && !buttons.includes(document.activeElement)) { + return; + } + var sibling = arrowKeysNextButton.includes(key) ? 'nextElementSibling' : 'previousElementSibling'; + var buttonToFocus = document.activeElement; + if (!buttonToFocus) { + return; + } + for (var i = 0; i < actions.children.length; i++) { + buttonToFocus = buttonToFocus[sibling]; + if (!buttonToFocus) { + return; + } + if (buttonToFocus instanceof HTMLButtonElement && isVisible$1(buttonToFocus)) { + break; + } + } + if (buttonToFocus instanceof HTMLButtonElement) { + buttonToFocus.focus(); + } + }; + + /** + * @param {KeyboardEvent} event + * @param {SweetAlertOptions} innerParams + * @param {Function} dismissWith + */ + var handleEsc = function handleEsc(event, innerParams, dismissWith) { + if (callIfFunction(innerParams.allowEscapeKey)) { + event.preventDefault(); + dismissWith(DismissReason.esc); + } + }; + + /** + * This module contains `WeakMap`s for each effectively-"private property" that a `Swal` has. + * For example, to set the private property "foo" of `this` to "bar", you can `privateProps.foo.set(this, 'bar')` + * This is the approach that Babel will probably take to implement private methods/fields + * https://github.com/tc39/proposal-private-methods + * https://github.com/babel/babel/pull/7555 + * Once we have the changes from that PR in Babel, and our core class fits reasonable in *one module* + * then we can use that language feature. + */ + + var privateMethods = { + swalPromiseResolve: new WeakMap(), + swalPromiseReject: new WeakMap() + }; + + // From https://developer.paciellogroup.com/blog/2018/06/the-current-state-of-modal-dialog-accessibility/ + // Adding aria-hidden="true" to elements outside of the active modal dialog ensures that + // elements not within the active modal dialog will not be surfaced if a user opens a screen + // reader’s list of elements (headings, form controls, landmarks, etc.) in the document. + + var setAriaHidden = function setAriaHidden() { + var container = getContainer(); + var bodyChildren = Array.from(document.body.children); + bodyChildren.forEach(function (el) { + if (el.contains(container)) { + return; + } + if (el.hasAttribute('aria-hidden')) { + el.setAttribute('data-previous-aria-hidden', el.getAttribute('aria-hidden') || ''); + } + el.setAttribute('aria-hidden', 'true'); + }); + }; + var unsetAriaHidden = function unsetAriaHidden() { + var bodyChildren = Array.from(document.body.children); + bodyChildren.forEach(function (el) { + if (el.hasAttribute('data-previous-aria-hidden')) { + el.setAttribute('aria-hidden', el.getAttribute('data-previous-aria-hidden') || ''); + el.removeAttribute('data-previous-aria-hidden'); + } else { + el.removeAttribute('aria-hidden'); + } + }); + }; + + // @ts-ignore + var isSafariOrIOS = typeof window !== 'undefined' && !!window.GestureEvent; // true for Safari desktop + all iOS browsers https://stackoverflow.com/a/70585394 + + /** + * Fix iOS scrolling + * http://stackoverflow.com/q/39626302 + */ + var iOSfix = function iOSfix() { + if (isSafariOrIOS && !hasClass(document.body, swalClasses.iosfix)) { + var offset = document.body.scrollTop; + document.body.style.top = "".concat(offset * -1, "px"); + addClass(document.body, swalClasses.iosfix); + lockBodyScroll(); + } + }; + + /** + * https://github.com/sweetalert2/sweetalert2/issues/1246 + */ + var lockBodyScroll = function lockBodyScroll() { + var container = getContainer(); + if (!container) { + return; + } + /** @type {boolean} */ + var preventTouchMove; + /** + * @param {TouchEvent} event + */ + container.ontouchstart = function (event) { + preventTouchMove = shouldPreventTouchMove(event); + }; + /** + * @param {TouchEvent} event + */ + container.ontouchmove = function (event) { + if (preventTouchMove) { + event.preventDefault(); + event.stopPropagation(); + } + }; + }; + + /** + * @param {TouchEvent} event + * @returns {boolean} + */ + var shouldPreventTouchMove = function shouldPreventTouchMove(event) { + var target = event.target; + var container = getContainer(); + var htmlContainer = getHtmlContainer(); + if (!container || !htmlContainer) { + return false; + } + if (isStylus(event) || isZoom(event)) { + return false; + } + if (target === container) { + return true; + } + if (!isScrollable(container) && target instanceof HTMLElement && target.tagName !== 'INPUT' && + // #1603 + target.tagName !== 'TEXTAREA' && + // #2266 + !(isScrollable(htmlContainer) && + // #1944 + htmlContainer.contains(target))) { + return true; + } + return false; + }; + + /** + * https://github.com/sweetalert2/sweetalert2/issues/1786 + * + * @param {*} event + * @returns {boolean} + */ + var isStylus = function isStylus(event) { + return event.touches && event.touches.length && event.touches[0].touchType === 'stylus'; + }; + + /** + * https://github.com/sweetalert2/sweetalert2/issues/1891 + * + * @param {TouchEvent} event + * @returns {boolean} + */ + var isZoom = function isZoom(event) { + return event.touches && event.touches.length > 1; + }; + var undoIOSfix = function undoIOSfix() { + if (hasClass(document.body, swalClasses.iosfix)) { + var offset = parseInt(document.body.style.top, 10); + removeClass(document.body, swalClasses.iosfix); + document.body.style.top = ''; + document.body.scrollTop = offset * -1; + } + }; + + /** + * Measure scrollbar width for padding body during modal show/hide + * https://github.com/twbs/bootstrap/blob/master/js/src/modal.js + * + * @returns {number} + */ + var measureScrollbar = function measureScrollbar() { + var scrollDiv = document.createElement('div'); + scrollDiv.className = swalClasses['scrollbar-measure']; + document.body.appendChild(scrollDiv); + var scrollbarWidth = scrollDiv.getBoundingClientRect().width - scrollDiv.clientWidth; + document.body.removeChild(scrollDiv); + return scrollbarWidth; + }; + + /** + * Remember state in cases where opening and handling a modal will fiddle with it. + * @type {number | null} + */ + var previousBodyPadding = null; + + /** + * @param {string} initialBodyOverflow + */ + var replaceScrollbarWithPadding = function replaceScrollbarWithPadding(initialBodyOverflow) { + // for queues, do not do this more than once + if (previousBodyPadding !== null) { + return; + } + // if the body has overflow + if (document.body.scrollHeight > window.innerHeight || initialBodyOverflow === 'scroll' // https://github.com/sweetalert2/sweetalert2/issues/2663 + ) { + // add padding so the content doesn't shift after removal of scrollbar + previousBodyPadding = parseInt(window.getComputedStyle(document.body).getPropertyValue('padding-right')); + document.body.style.paddingRight = "".concat(previousBodyPadding + measureScrollbar(), "px"); + } + }; + var undoReplaceScrollbarWithPadding = function undoReplaceScrollbarWithPadding() { + if (previousBodyPadding !== null) { + document.body.style.paddingRight = "".concat(previousBodyPadding, "px"); + previousBodyPadding = null; + } + }; + + /** + * @param {SweetAlert} instance + * @param {HTMLElement} container + * @param {boolean} returnFocus + * @param {Function} didClose + */ + function removePopupAndResetState(instance, container, returnFocus, didClose) { + if (isToast()) { + triggerDidCloseAndDispose(instance, didClose); + } else { + restoreActiveElement(returnFocus).then(function () { + return triggerDidCloseAndDispose(instance, didClose); + }); + removeKeydownHandler(globalState); + } + + // workaround for https://github.com/sweetalert2/sweetalert2/issues/2088 + // for some reason removing the container in Safari will scroll the document to bottom + if (isSafariOrIOS) { + container.setAttribute('style', 'display:none !important'); + container.removeAttribute('class'); + container.innerHTML = ''; + } else { + container.remove(); + } + if (isModal()) { + undoReplaceScrollbarWithPadding(); + undoIOSfix(); + unsetAriaHidden(); + } + removeBodyClasses(); + } + + /** + * Remove SweetAlert2 classes from body + */ + function removeBodyClasses() { + removeClass([document.documentElement, document.body], [swalClasses.shown, swalClasses['height-auto'], swalClasses['no-backdrop'], swalClasses['toast-shown']]); + } + + /** + * Instance method to close sweetAlert + * + * @param {any} resolveValue + */ + function close(resolveValue) { + resolveValue = prepareResolveValue(resolveValue); + var swalPromiseResolve = privateMethods.swalPromiseResolve.get(this); + var didClose = triggerClosePopup(this); + if (this.isAwaitingPromise) { + // A swal awaiting for a promise (after a click on Confirm or Deny) cannot be dismissed anymore #2335 + if (!resolveValue.isDismissed) { + handleAwaitingPromise(this); + swalPromiseResolve(resolveValue); + } + } else if (didClose) { + // Resolve Swal promise + swalPromiseResolve(resolveValue); + } + } + var triggerClosePopup = function triggerClosePopup(instance) { + var popup = getPopup(); + if (!popup) { + return false; + } + var innerParams = privateProps.innerParams.get(instance); + if (!innerParams || hasClass(popup, innerParams.hideClass.popup)) { + return false; + } + removeClass(popup, innerParams.showClass.popup); + addClass(popup, innerParams.hideClass.popup); + var backdrop = getContainer(); + removeClass(backdrop, innerParams.showClass.backdrop); + addClass(backdrop, innerParams.hideClass.backdrop); + handlePopupAnimation(instance, popup, innerParams); + return true; + }; + + /** + * @param {any} error + */ + function rejectPromise(error) { + var rejectPromise = privateMethods.swalPromiseReject.get(this); + handleAwaitingPromise(this); + if (rejectPromise) { + // Reject Swal promise + rejectPromise(error); + } + } + + /** + * @param {SweetAlert} instance + */ + var handleAwaitingPromise = function handleAwaitingPromise(instance) { + if (instance.isAwaitingPromise) { + delete instance.isAwaitingPromise; + // The instance might have been previously partly destroyed, we must resume the destroy process in this case #2335 + if (!privateProps.innerParams.get(instance)) { + instance._destroy(); + } + } + }; + + /** + * @param {any} resolveValue + * @returns {SweetAlertResult} + */ + var prepareResolveValue = function prepareResolveValue(resolveValue) { + // When user calls Swal.close() + if (typeof resolveValue === 'undefined') { + return { + isConfirmed: false, + isDenied: false, + isDismissed: true + }; + } + return Object.assign({ + isConfirmed: false, + isDenied: false, + isDismissed: false + }, resolveValue); + }; + + /** + * @param {SweetAlert} instance + * @param {HTMLElement} popup + * @param {SweetAlertOptions} innerParams + */ + var handlePopupAnimation = function handlePopupAnimation(instance, popup, innerParams) { + var container = getContainer(); + // If animation is supported, animate + var animationIsSupported = animationEndEvent && hasCssAnimation(popup); + if (typeof innerParams.willClose === 'function') { + innerParams.willClose(popup); + } + if (animationIsSupported) { + animatePopup(instance, popup, container, innerParams.returnFocus, innerParams.didClose); + } else { + // Otherwise, remove immediately + removePopupAndResetState(instance, container, innerParams.returnFocus, innerParams.didClose); + } + }; + + /** + * @param {SweetAlert} instance + * @param {HTMLElement} popup + * @param {HTMLElement} container + * @param {boolean} returnFocus + * @param {Function} didClose + */ + var animatePopup = function animatePopup(instance, popup, container, returnFocus, didClose) { + if (!animationEndEvent) { + return; + } + globalState.swalCloseEventFinishedCallback = removePopupAndResetState.bind(null, instance, container, returnFocus, didClose); + popup.addEventListener(animationEndEvent, function (e) { + if (e.target === popup) { + globalState.swalCloseEventFinishedCallback(); + delete globalState.swalCloseEventFinishedCallback; + } + }); + }; + + /** + * @param {SweetAlert} instance + * @param {Function} didClose + */ + var triggerDidCloseAndDispose = function triggerDidCloseAndDispose(instance, didClose) { + setTimeout(function () { + if (typeof didClose === 'function') { + didClose.bind(instance.params)(); + } + // instance might have been destroyed already + if (instance._destroy) { + instance._destroy(); + } + }); + }; + + /** + * Shows loader (spinner), this is useful with AJAX requests. + * By default the loader be shown instead of the "Confirm" button. + * + * @param {HTMLButtonElement | null} [buttonToReplace] + */ + var showLoading = function showLoading(buttonToReplace) { + var popup = getPopup(); + if (!popup) { + new Swal(); // eslint-disable-line no-new + } + popup = getPopup(); + if (!popup) { + return; + } + var loader = getLoader(); + if (isToast()) { + hide(getIcon()); + } else { + replaceButton(popup, buttonToReplace); + } + show(loader); + popup.setAttribute('data-loading', 'true'); + popup.setAttribute('aria-busy', 'true'); + popup.focus(); + }; + + /** + * @param {HTMLElement} popup + * @param {HTMLButtonElement | null} [buttonToReplace] + */ + var replaceButton = function replaceButton(popup, buttonToReplace) { + var actions = getActions(); + var loader = getLoader(); + if (!actions || !loader) { + return; + } + if (!buttonToReplace && isVisible$1(getConfirmButton())) { + buttonToReplace = getConfirmButton(); + } + show(actions); + if (buttonToReplace) { + hide(buttonToReplace); + loader.setAttribute('data-button-to-replace', buttonToReplace.className); + actions.insertBefore(loader, buttonToReplace); + } + addClass([popup, actions], swalClasses.loading); + }; + + /** + * @param {SweetAlert} instance + * @param {SweetAlertOptions} params + */ + var handleInputOptionsAndValue = function handleInputOptionsAndValue(instance, params) { + if (params.input === 'select' || params.input === 'radio') { + handleInputOptions(instance, params); + } else if (['text', 'email', 'number', 'tel', 'textarea'].some(function (i) { + return i === params.input; + }) && (hasToPromiseFn(params.inputValue) || isPromise(params.inputValue))) { + showLoading(getConfirmButton()); + handleInputValue(instance, params); + } + }; + + /** + * @param {SweetAlert} instance + * @param {SweetAlertOptions} innerParams + * @returns {SweetAlertInputValue} + */ + var getInputValue = function getInputValue(instance, innerParams) { + var input = instance.getInput(); + if (!input) { + return null; + } + switch (innerParams.input) { + case 'checkbox': + return getCheckboxValue(input); + case 'radio': + return getRadioValue(input); + case 'file': + return getFileValue(input); + default: + return innerParams.inputAutoTrim ? input.value.trim() : input.value; + } + }; + + /** + * @param {HTMLInputElement} input + * @returns {number} + */ + var getCheckboxValue = function getCheckboxValue(input) { + return input.checked ? 1 : 0; + }; + + /** + * @param {HTMLInputElement} input + * @returns {string | null} + */ + var getRadioValue = function getRadioValue(input) { + return input.checked ? input.value : null; + }; + + /** + * @param {HTMLInputElement} input + * @returns {FileList | File | null} + */ + var getFileValue = function getFileValue(input) { + return input.files && input.files.length ? input.getAttribute('multiple') !== null ? input.files : input.files[0] : null; + }; + + /** + * @param {SweetAlert} instance + * @param {SweetAlertOptions} params + */ + var handleInputOptions = function handleInputOptions(instance, params) { + var popup = getPopup(); + if (!popup) { + return; + } + /** + * @param {Record} inputOptions + */ + var processInputOptions = function processInputOptions(inputOptions) { + if (params.input === 'select') { + populateSelectOptions(popup, formatInputOptions(inputOptions), params); + } else if (params.input === 'radio') { + populateRadioOptions(popup, formatInputOptions(inputOptions), params); + } + }; + if (hasToPromiseFn(params.inputOptions) || isPromise(params.inputOptions)) { + showLoading(getConfirmButton()); + asPromise(params.inputOptions).then(function (inputOptions) { + instance.hideLoading(); + processInputOptions(inputOptions); + }); + } else if (_typeof(params.inputOptions) === 'object') { + processInputOptions(params.inputOptions); + } else { + error("Unexpected type of inputOptions! Expected object, Map or Promise, got ".concat(_typeof(params.inputOptions))); + } + }; + + /** + * @param {SweetAlert} instance + * @param {SweetAlertOptions} params + */ + var handleInputValue = function handleInputValue(instance, params) { + var input = instance.getInput(); + if (!input) { + return; + } + hide(input); + asPromise(params.inputValue).then(function (inputValue) { + input.value = params.input === 'number' ? "".concat(parseFloat(inputValue) || 0) : "".concat(inputValue); + show(input); + input.focus(); + instance.hideLoading(); + })["catch"](function (err) { + error("Error in inputValue promise: ".concat(err)); + input.value = ''; + show(input); + input.focus(); + instance.hideLoading(); + }); + }; + + /** + * @param {HTMLElement} popup + * @param {InputOptionFlattened[]} inputOptions + * @param {SweetAlertOptions} params + */ + function populateSelectOptions(popup, inputOptions, params) { + var select = getDirectChildByClass(popup, swalClasses.select); + if (!select) { + return; + } + /** + * @param {HTMLElement} parent + * @param {string} optionLabel + * @param {string} optionValue + */ + var renderOption = function renderOption(parent, optionLabel, optionValue) { + var option = document.createElement('option'); + option.value = optionValue; + setInnerHtml(option, optionLabel); + option.selected = isSelected(optionValue, params.inputValue); + parent.appendChild(option); + }; + inputOptions.forEach(function (inputOption) { + var optionValue = inputOption[0]; + var optionLabel = inputOption[1]; + // spec: + // https://www.w3.org/TR/html401/interact/forms.html#h-17.6 + // "...all OPTGROUP elements must be specified directly within a SELECT element (i.e., groups may not be nested)..." + // check whether this is a + if (Array.isArray(optionLabel)) { + // if it is an array, then it is an + var optgroup = document.createElement('optgroup'); + optgroup.label = optionValue; + optgroup.disabled = false; // not configurable for now + select.appendChild(optgroup); + optionLabel.forEach(function (o) { + return renderOption(optgroup, o[1], o[0]); + }); + } else { + // case of