Фонд с Ларавелом и Эликсиром
Как использовать Foundation с Laravel?
Я думал, что я установлю Фонд в vendor
папка с bower install foundation
, В результате получается vendor/bower_components
папка, в которой у меня есть Foundation и все необходимые библиотеки, такие как jQuery.
Что я должен добавить в gulpfile.js
Эликсиру правильно истолковать это? Должно быть возможно
- обновить компоненты Bower
- установить новые пакеты Bower
- изменять переменные Foundation Sass без их перезаписи при обновлении
- использовать компас
В не-Laravel проекте я бы запустил гем Ruby foundation new my_project
и включите скомпилированные файлы вручную. Однако в этом случае команда создает множество файлов, которые не требуются для работы.
2 ответа
Laravel Elixir включает Libsass, поэтому вам не понадобится Ruby для компиляции файлов Foundation Sass из Laravel. Все, что вам нужно, это беседка и эликсир Laravel. Также вам не нужно копировать файлы из bower_components
папка для resources/assets
папка.
Сначала следуйте официальным инструкциям по установке Elixir.
Затем создайте файл .bowerrc
в корне вашего проекта Laravel с этим содержанием:
{
"directory": "vendor/bower_components"
}
Затем создайте файл bower.json
в корне вашего проекта Laravel с этим содержанием:
{
"name": "laravel-and-foundation",
"private": "true",
"dependencies": {
"foundation": "latest"
}
}
Затем установите беседку и фундамент:
npm install --global bower
bower install # This will install Foundation into vendor/bower_components
Затем создайте файл resources/assets/sass/_settings.scss
файл с этим содержанием:
// Custom settings for Zurb Foundation. Default settings can be found at
// vendor/bower_components/foundation/scss/foundation/_settings.scss
Затем отредактируйте файл resources/assets/sass/app.scss
файл с этим содержанием:
@import "normalize";
@import "settings";
// Include all foundation
@import "foundation";
// Or selectively include components
// @import
// "foundation/components/accordion",
// "foundation/components/alert-boxes",
// "foundation/components/block-grid",
// "foundation/components/breadcrumbs",
// "foundation/components/button-groups",
// "foundation/components/buttons",
// "foundation/components/clearing",
// "foundation/components/dropdown",
// "foundation/components/dropdown-buttons",
// "foundation/components/flex-video",
// "foundation/components/forms",
// "foundation/components/grid",
// "foundation/components/inline-lists",
// "foundation/components/joyride",
// "foundation/components/keystrokes",
// "foundation/components/labels",
// "foundation/components/magellan",
// "foundation/components/orbit",
// "foundation/components/pagination",
// "foundation/components/panels",
// "foundation/components/pricing-tables",
// "foundation/components/progress-bars",
// "foundation/components/reveal",
// "foundation/components/side-nav",
// "foundation/components/split-buttons",
// "foundation/components/sub-nav",
// "foundation/components/switches",
// "foundation/components/tables",
// "foundation/components/tabs",
// "foundation/components/thumbs",
// "foundation/components/tooltips",
// "foundation/components/top-bar",
// "foundation/components/type",
// "foundation/components/offcanvas",
// "foundation/components/visibility";
Настройте файл gulpfile.js
с этим содержанием:
elixir(function(mix) {
// Compile CSS
mix.sass(
'app.scss', // Source files
'public/css', // Destination folder
{includePaths: ['vendor/bower_components/foundation/scss']}
);
// Compile JavaScript
mix.scripts(
['vendor/modernizr.js', 'vendor/jquery.js', 'foundation.min.js'], // Source files. You can also selective choose only some components
'public/js/app.js', // Destination file
'vendor/bower_components/foundation/js/' // Source files base directory
);
});
Для создания просто следуйте официальным документам:
gulp # Run all tasks...
gulp --production # Run all tasks and minify files
gulp watch # Watch for changes and run all tasks on the fly
Ваши скомпилированные файлы будут в public/css/app.css
а также public/js/app.js
,
Для обновления до последней версии Zurb Foundation просто запустите:
bower update
Скопируйте Fundation > папку scss в ресурсы> папку активов, переименуйте scss в sass, в вашем gulpfile.js добавьте следующее
elixir(function(mix) {
mix.sass('foundation.scss');
});
Запустите gulp, который сгенерирует файл foundation.css в папке public> css, включите этот файл в свой проект.
Для файлов JS вы можете просто использовать что-то вроде этого, чтобы скопировать файл
mix.copy('resources/assets/foundation/js/app.js', 'public/js/app.js');