Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix css loader regression #19

Merged
merged 26 commits into from
Oct 24, 2024
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
205308a
extract import boilerplate into blade file for correct conditional re…
gwleuverink Sep 4, 2024
ed72cab
ignore coverage
gwleuverink Sep 4, 2024
1642f41
update deps
gwleuverink Oct 8, 2024
1151bbe
make sure ray is disabled
gwleuverink Oct 8, 2024
750191a
wip - experiment with version matrix
gwleuverink Oct 8, 2024
a94e377
wip - experimenting with matrix
gwleuverink Oct 8, 2024
2dc90ee
wip - experimenting with CI matrix
gwleuverink Oct 8, 2024
b574f0d
fix typo
gwleuverink Oct 8, 2024
a2adb4b
playground improvements
gwleuverink Oct 8, 2024
19867be
test with old import core
gwleuverink Oct 8, 2024
a141f41
wip - revert to refactor
gwleuverink Oct 8, 2024
04d3cfb
update to pest 3
gwleuverink Oct 8, 2024
1d7bd1a
update workbench deps
gwleuverink Oct 8, 2024
2d32306
fix deprecation warnings
gwleuverink Oct 8, 2024
816dbbd
replace test annotation with attribute syntax
gwleuverink Oct 8, 2024
4481e44
tidy
gwleuverink Oct 8, 2024
a103afe
ignore coverage
gwleuverink Oct 8, 2024
f25ef88
fix dusk locally
gwleuverink Oct 22, 2024
b9984bd
update deps
gwleuverink Oct 22, 2024
fa02902
boyscouting
gwleuverink Oct 24, 2024
2a9955f
add consts for controlling dusk tests in 1 place
gwleuverink Oct 24, 2024
64599db
lock bun to a minimum version
gwleuverink Oct 24, 2024
ce1fa42
fix livewire interop after refactor
gwleuverink Oct 24, 2024
dffb2f5
Dusting
gwleuverink Oct 24, 2024
ce149b9
Ignore Dusting commit in git blame
gwleuverink Oct 24, 2024
1a6d4a9
Merge branch 'main' into fix/css-import-regression
gwleuverink Oct 24, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
68 changes: 6 additions & 62 deletions src/Components/Import.php
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,12 @@ public function render()
/** Builds the imported JavaScript & packages it up in a bundle */
protected function bundle()
{
$js = $this->import();
// Wraps import with execution logic
$js = view('x-import::import', [
'module' => $this->module,
'init' => $this->init,
'as' => $this->as,
]);

// Render script tag with bundled code
return view('x-import::script', [
Expand Down Expand Up @@ -59,65 +64,4 @@ protected function raiseConsoleErrorOrException(BundlingFailedException $e)
<!--[ENDBUNDLE]>-->
HTML;
}

/** Builds a bundle for the JavaScript import */
protected function import(): string
{
return <<< JS
//--------------------------------------------------------------------------
// Expose x_import_modules map
//--------------------------------------------------------------------------
if(!window.x_import_modules) window.x_import_modules = {};

//--------------------------------------------------------------------------
// Import the module & push to x_import_modules
// Invoke IIFE so we can break out of execution when needed
//--------------------------------------------------------------------------
(() => {

// Import was marked as invokable
if('{$this->init}') {
// Note: don't return, since we might need to still register the module
import('{$this->module}')
.then(invokable => {
if(typeof invokable.default !== 'function') {
throw `BUNDLING ERROR: '{$this->module}' not invokable - default export is not a function`
}

try {
invokable.default()
} catch(e) {
throw `BUNDLING ERROR: unable to invoke '{$this->module}' - '\${e}'`
}
})
}

// Check if module is already loaded under a different alias
const previous = document.querySelector(`script[data-module="{$this->module}"]`)

// Was previously loaded & needs to be pushed to import map
if(previous && '{$this->as}') {
// Throw error when previously imported under different alias. Otherwise continue
if(previous.dataset.alias !== '{$this->as}') {
throw `BUNDLING ERROR: '{$this->as}' already imported as '\${previous.dataset.alias}'`
}
}

// Handle CSS injection
if('{$this->module}'.endsWith('.css') || '{$this->module}'.endsWith('.scss')) {
return import('{$this->module}').then(result => {
window.x_inject_styles(result.default, previous)
})
}

// Assign the import to the window.x_import_modules object (or invoke IIFE)
'{$this->as}'
// Assign it under an alias
? window.x_import_modules['{$this->as}'] = import('{$this->module}')
// Only import it (for IIFE no alias needed)
: import('{$this->module}')
})();

JS;
}
gwleuverink marked this conversation as resolved.
Show resolved Hide resolved
gwleuverink marked this conversation as resolved.
Show resolved Hide resolved
}
64 changes: 64 additions & 0 deletions src/Components/views/import.blade.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
{{-- @codeCoverageIngoreStart --}}

//--------------------------------------------------------------------------
// Expose x_import_modules map
//--------------------------------------------------------------------------
if (!window.x_import_modules) window.x_import_modules = {};

//--------------------------------------------------------------------------
// Import the module & push to x_import_modules
// Invoke IIFE so we can break out of execution when needed
//--------------------------------------------------------------------------
(() => {

@if ($init)
// Import was marked as invokable
// Note: don't return, since we might need to still register the module
import('{{ $module }}')
.then(invokable => {
if (typeof invokable.default !== 'function') {
throw `BUNDLING ERROR: '{{ $module }}' not invokable - default export is not a function`
}

try {
invokable.default()
} catch (e) {
throw `BUNDLING ERROR: unable to invoke '{$this->module}' - '\${e}'`
}
})
@endif

// Check if module is already loaded under a different alias
const previous = document.querySelector(`script[data-module="{{ $module }}"]`)

// Was previously loaded & needs to be pushed to import map
if (previous && '{{ $as }}') {
// Throw error when previously imported under different alias. Otherwise continue
if (previous.dataset.alias !== '{{ $as }}') {
throw `BUNDLING ERROR: '{{ $as }}' already imported as '\${previous.dataset.alias}'`
}
}

// Handle CSS injection
@if (str_ends_with($module, '.css') || str_ends_with($module, '.scss'))

return import('{{ $module }}').then(result => {
window.x_inject_styles(result.default, previous)
})

@else

@if ($as)

window.x_import_modules['{{ $as }}'] = import('{{ $module }}')

@else

import('{{ $module }}')

@endif

@endif
})();

{{-- @codeCoverageIngoreEnd --}}
Loading