Assety SASS

Jeśli z jakichś przyczyn nie masz dostępu do assetów SASS w iDir, możesz opublikować odpowiednie pliki poleceniem:

php artisan vendor:publish --tag=idir.sass

Assety JS dostępne są z poziomu folderu:

/resources/sass/vendor/idir/


# Import bibliotek

Wszystkie biblioteki importowane są zbiorczo z poziomu plików:

  • resources/sass/vendor/idir/admin/admin.scss - dla panelu administracyjnego, wersja jasna
  • resources/sass/vendor/idir/admin/admin-dark.scss - dla panelu administracyjnego, wersja ciemna
  • resources/sass/vendor/idir/web/web.scss - dla strony, wersja jasna
  • resources/sass/vendor/idir/web/web-dark.scss - dla strony, wersja ciemna
  • resources/sass/vendor/idir/vendor/vendor.scss - niezależne od Bootstrap 4, wspólne dla obu

# Pliki styli

Wszystkie ustawienia i style klas znajdują się w plikach zaczynających się od znaku podkreślenia _ z poziomu folderów:

  • resources/sass/vendor/idir/admin/ - dla panelu administracyjnego
  • resources/sass/vendor/idir/web/ - dla strony

# Webpack

Wszystkie assety SASS są skompilowane na produkcji za pomocą Laravel Mix. W głównym folderze z aplikacją znajduje się plik konfiguracyjny:

  • webpack.mix.js

który można dostosować do własnych potrzeb (domyślnie umieszcza skompilowane pliki CSS bezpośrednio do folderu public).

Kompilację należy przeprowadzać wyłącznie w trybie deweloperskim. Potrzebne jest do tego środowisko nodejs oraz pobranie dużej liczby zależności przez npm za pomocą polecenia:

npm install

Kompilację można uruchomić poleceniem:

npm run production


# Dodawanie własnych styli/bibliotek do pliku Webpack

Nowe pliki nie ingerujące w assety iDir sugeruje się kompilować do osobnych plików. Proponowana konfiguracja:

  • dla panelu administracyjnego:
    .sass('resources/sass/custom/admin/admin.scss', 'css/custom/admin')
    .sass('resources/sass/custom/admin/admin-dark.scss', 'css/custom/admin')
  • dla strony użytkownika:
    .sass('resources/sass/custom/web/web.scss', 'css/custom/web')
    .sass('resources/sass/custom/web/web-dark.scss', 'css/custom/web')

Pliki publiczne pod tymi ścieżkami są już wstrzyknięte w nagłówek layout.blade.php:

<link href="{{ mix('css/vendor/idir/vendor/vendor.css') }}" rel="stylesheet">
<link href="{{ mix($getStylesheet('css/vendor/idir')) }}" rel="stylesheet">
<link href="{{ asset($getStylesheet('css/custom')) }}" rel="stylesheet">

Dzięki temu możliwe będzie aktualizowanie plików publicznych CSS z iDir bezpośrednio przez publikację bez ryzyka, że nadpisze się swoje zmiany i bez konieczności ponownej kompilacji assetów.