vscode-blade-formatter icon indicating copy to clipboard operation
vscode-blade-formatter copied to clipboard

blade formatter work so long time

Open edikurniawan-dev opened this issue 2 years ago • 6 comments

Hi, thank you for created this extension in vscode, it's very help me. But why every time i save the file, blade-formatter works and takes a long time about 14 seconds.

image

edikurniawan-dev avatar Jul 17 '22 13:07 edikurniawan-dev

Thanks @edikurniawan-dev

Formatting times may be longer for certain types of templates. Can you post a example template?

shufo avatar Jul 17 '22 14:07 shufo

In my code there are about 700 lines, about 200 lines are html and php, and the remaining 500 lines are scripts.

Is that what causes the long formatting time?

edikurniawan-dev avatar Jul 17 '22 15:07 edikurniawan-dev

Scripts are not affected in most cases, but if you have a blade directive in a script it may slow down.

I can't tell from the information above if it actually slows down or not, so I'd like you to post your template.

shufo avatar Jul 17 '22 21:07 shufo

Thanks. It seems to take longer if there are conditional blade directives like @if in the script block. I'll look into it.

shufo avatar Jul 19 '22 03:07 shufo

Ok thanks, I'll waiting for update

edikurniawan-dev avatar Jul 19 '22 06:07 edikurniawan-dev

@shufo

This template takes ~20 seconds to format. Perhaps can see https://github.com/amirmarmul/laravel-blade-vscode for reference? It formats instantly, except that it doesn't have tailwind sorting.

I'm not proficient in the language of VSCode plugins, but I would think it should be a 2 pass process, i.e. format the blade first, then perform sorting on the tailwind classes, that should keep things simple and fast.

It also occured to me that alpine might be conflicting with blade, since this template doesn't have any blade directives at all.

Just trying to help. Thank you.

@extends('layout.landlord-body')
@section('content')
<link rel="stylesheet" href="https://unpkg.com/tailwindcss@^1.0/dist/tailwind.min.css">
<script src="https://cdn.jsdelivr.net/gh/alpinejs/[email protected]/dist/alpine.js" defer></script>

<style>
[x-cloak] {
display: none;
}

[type="checkbox"] {
box-sizing: border-box;
padding: 0;
}

.form-checkbox,
.form-radio {
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
-webkit-print-color-adjust: exact;
color-adjust: exact;
display: inline-block;
vertical-align: middle;
background-origin: border-box;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
flex-shrink: 0;
color: currentColor;
background-color: #fff;
border-color: #e2e8f0;
border-width: 1px;
height: 1.4em;
width: 1.4em;
}

.form-checkbox {
border-radius: 0.25rem;
}

.form-radio {
border-radius: 50%;
}

.form-checkbox:checked {
background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M5.707 7.293a1 1 0 0 0-1.414 1.414l2 2a1 1 0 0 0 1.414 0l4-4a1 1 0 0 0-1.414-1.414L7 8.586 5.707 7.293z'/%3e%3c/svg%3e");
border-color: transparent;
background-color: currentColor;
background-size: 100% 100%;
background-position: center;
background-repeat: no-repeat;
}

.form-radio:checked {
background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3ccircle cx='8' cy='8' r='3'/%3e%3c/svg%3e");
border-color: transparent;
background-color: currentColor;
background-size: 100% 100%;
background-position: center;
background-repeat: no-repeat;
}
</style>

<div x-data="app()" x-cloak>
<div class="max-w-3xl px-4 py-10 mx-auto">

<div x-show.transition="step === 'complete'">
<div class="flex items-center justify-between p-10 bg-white rounded-lg shadow">
<div>
<svg class="w-20 h-20 mx-auto mb-4 text-green-500" viewBox="0 0 20 20" fill="currentColor">
<path fill-rule="evenodd"
d="M10 18a8 8 0 100-16 8 8 0 000 16zm3.707-9.293a1 1 0 00-1.414-1.414L9 10.586 7.707 9.293a1 1 0 00-1.414 1.414l2 2a1 1 0 001.414 0l4-4z"
clip-rule="evenodd" />
</svg>

<h2 class="mb-4 text-2xl font-bold text-center text-gray-800">Registration Success</h2>

<div class="mb-8 text-gray-600">
Thank you. We have sent you an email to [email protected]. Please click the link in the message
to activate your account.
</div>

<button @click="step = 1"
class="block w-40 px-5 py-2 mx-auto font-medium text-center text-gray-600 bg-white border rounded-lg shadow-sm hover:bg-gray-100 focus:outline-none">Back
to home</button>
</div>
</div>
</div>

<div x-show.transition="step != 'complete'">
<!-- Top Navigation -->
<div class="py-4 border-b-2">
<div class="mb-1 text-xs font-bold leading-tight tracking-wide text-gray-500 uppercase"
x-text="`Step: ${step} of 3`"></div>
<div class="flex flex-col md:flex-row md:items-center md:justify-between">
<div class="flex-1">
<div x-show="step === 1">
<div class="text-lg font-bold leading-tight text-gray-700">Your Profile</div>
</div>

<div x-show="step === 2">
<div class="text-lg font-bold leading-tight text-gray-700">Your Password</div>
</div>

<div x-show="step === 3">
<div class="text-lg font-bold leading-tight text-gray-700">Tell me about yourself</div>
</div>
</div>

<div class="flex items-center md:w-64">
<div class="w-full mr-2 bg-white rounded-full">
<div class="h-2 text-xs leading-none text-center text-white bg-green-500 rounded-full"
:style="'width: ' + parseInt(step / 3 * 100) + '%'"></div>
</div>
<div class="w-10 text-xs text-gray-600" x-text="parseInt(step / 3 * 100) +'%'"></div>
</div>
</div>
</div>
<!-- /Top Navigation -->

<!-- Step Content -->
<div class="py-10">
<div x-show.transition.in="step === 1">
<div class="mb-5 text-center">
<div class="relative w-32 h-32 mx-auto mb-2 mb-4 bg-gray-100 border rounded-full shadow-inset">
<img id="image" class="object-cover w-full h-32 rounded-full" :src="image" />
</div>

<label for="fileInput" type="button"
class="items-center justify-between px-4 py-2 font-medium text-left text-gray-600 bg-white border rounded-lg shadow-sm cursor-pointer inine-flex hover:bg-gray-100 focus:outline-none">
<svg xmlns="http://www.w3.org/2000/svg" class="inline-flex flex-shrink-0 w-6 h-6 mr-1 -mt-1"
viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" fill="none"
stroke-linecap="round" stroke-linejoin="round">
<rect x="0" y="0" width="24" height="24" stroke="none">
</rect>
<path
d="M5 7h1a2 2 0 0 0 2 -2a1 1 0 0 1 1 -1h6a1 1 0 0 1 1 1a2 2 0 0 0 2 2h1a2 2 0 0 1 2 2v9a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-9a2 2 0 0 1 2 -2" />
<circle cx="12" cy="13" r="3" />
</svg>
Browse Photo
</label>

<div class="w-48 mx-auto mt-1 text-xs text-center text-gray-500">Click to add profile
picture</div>

<input name="photo" id="fileInput" accept="image/*" class="hidden" type="file"
@change="let file = document.getElementById('fileInput').files[0];
var reader = new FileReader();
reader.onload = (e) => image = e.target.result;
reader.readAsDataURL(file);">
</div>

<div class="mb-5">
<label for="firstname" class="block mb-1 font-bold text-gray-700">Firstname</label>
<input type="text"
class="w-full px-4 py-3 font-medium text-gray-600 rounded-lg shadow-sm focus:shadow-outline focus:outline-none"
placeholder="Enter your firstname...">
</div>

<div class="mb-5">
<label for="email" class="block mb-1 font-bold text-gray-700">Email</label>
<input type="email"
class="w-full px-4 py-3 font-medium text-gray-600 rounded-lg shadow-sm focus:shadow-outline focus:outline-none"
placeholder="Enter your email address...">
</div>

</div>
<div x-show.transition.in="step === 2">

<div class="mb-5">
<label for="password" class="block mb-1 font-bold text-gray-700">Set up password</label>
<div class="mt-2 mb-4 text-gray-600">
Please create a secure password including the following criteria below.

<ul class="mt-2 ml-4 text-sm list-disc">
<li>lowercase letters</li>
<li>numbers</li>
<li>capital letters</li>
<li>special characters</li>
</ul>
</div>

<div class="relative">
<input :type="togglePassword ? 'text' : 'password'" @keydown="checkPasswordStrength()"
x-model="password"
class="w-full px-4 py-3 font-medium text-gray-600 rounded-lg shadow-sm focus:shadow-outline focus:outline-none"
placeholder="Your strong password...">

<div class="absolute top-0 bottom-0 right-0 px-3 py-3 cursor-pointer"
@click="togglePassword = !togglePassword">
<svg :class="{ 'hidden': !togglePassword, 'block': togglePassword }"
xmlns="http://www.w3.org/2000/svg" class="w-6 h-6 text-gray-500 fill-current"
viewBox="0 0 24 24">
<path
d="M12 19c.946 0 1.81-.103 2.598-.281l-1.757-1.757C12.568 16.983 12.291 17 12 17c-5.351 0-7.424-3.846-7.926-5 .204-.47.674-1.381 1.508-2.297L4.184 8.305c-1.538 1.667-2.121 3.346-2.132 3.379-.069.205-.069.428 0 .633C2.073 12.383 4.367 19 12 19zM12 5c-1.837 0-3.346.396-4.604.981L3.707 2.293 2.293 3.707l18 18 1.414-1.414-3.319-3.319c2.614-1.951 3.547-4.615 3.561-4.657.069-.205.069-.428 0-.633C21.927 11.617 19.633 5 12 5zM16.972 15.558l-2.28-2.28C14.882 12.888 15 12.459 15 12c0-1.641-1.359-3-3-3-.459 0-.888.118-1.277.309L8.915 7.501C9.796 7.193 10.814 7 12 7c5.351 0 7.424 3.846 7.926 5C19.624 12.692 18.76 14.342 16.972 15.558z" />
</svg>

<svg :class="{ 'hidden': togglePassword, 'block': !togglePassword }"
xmlns="http://www.w3.org/2000/svg" class="w-6 h-6 text-gray-500 fill-current"
viewBox="0 0 24 24">
<path
d="M12,9c-1.642,0-3,1.359-3,3c0,1.642,1.358,3,3,3c1.641,0,3-1.358,3-3C15,10.359,13.641,9,12,9z" />
<path
d="M12,5c-7.633,0-9.927,6.617-9.948,6.684L1.946,12l0.105,0.316C2.073,12.383,4.367,19,12,19s9.927-6.617,9.948-6.684 L22.054,12l-0.105-0.316C21.927,11.617,19.633,5,12,5z M12,17c-5.351,0-7.424-3.846-7.926-5C4.578,10.842,6.652,7,12,7 c5.351,0,7.424,3.846,7.926,5C19.422,13.158,17.348,17,12,17z" />
</svg>
</div>
</div>

<div class="flex items-center h-3 mt-4">
<div class="flex justify-between w-2/3 h-2">
<div :class="{
'bg-red-400': passwordStrengthText == 'Too weak' || passwordStrengthText ==
'Could be stronger' || passwordStrengthText == 'Strong password'
}"
class="w-1/3 h-2 mr-1 bg-gray-300 rounded-full"></div>
<div :class="{
'bg-orange-400': passwordStrengthText == 'Could be stronger' ||
passwordStrengthText == 'Strong password'
}"
class="w-1/3 h-2 mr-1 bg-gray-300 rounded-full"></div>
<div :class="{ 'bg-green-400': passwordStrengthText == 'Strong password' }"
class="w-1/3 h-2 bg-gray-300 rounded-full"></div>
</div>
<div x-text="passwordStrengthText"
class="ml-3 text-sm font-medium leading-none text-gray-500"></div>
</div>

<p class="mt-5 text-gray-600">Inspired from dribbble shot: Exploration for a password
strength meter by <a href="https://dribbble.com/OvertonGraphics"
class="text-blue-500">Josh Overton</a>.</p>
</div>

</div>
<div x-show.transition.in="step === 3">
<div class="mb-5">
<label for="email" class="block mb-1 font-bold text-gray-700">Gender</label>

<div class="flex">
<label
class="flex items-center justify-start py-3 pl-4 pr-6 mr-4 bg-white rounded-lg shadow-sm text-truncate">
<div class="mr-3 text-teal-600">
<input type="radio" x-model="gender" value="Male"
class="form-radio focus:shadow-outline focus:outline-none" />
</div>
<div class="text-gray-700 select-none">Male</div>
</label>

<label
class="flex items-center justify-start py-3 pl-4 pr-6 bg-white rounded-lg shadow-sm text-truncate">
<div class="mr-3 text-teal-600">
<input type="radio" x-model="gender" value="Female"
class="form-radio focus:shadow-outline focus:outline-none" />
</div>
<div class="text-gray-700 select-none">Female</div>
</label>
</div>
</div>

<div class="mb-5">
<label for="profession" class="block mb-1 font-bold text-gray-700">Profession</label>
<input type="profession"
class="w-full px-4 py-3 font-medium text-gray-600 rounded-lg shadow-sm focus:shadow-outline focus:outline-none"
placeholder="eg. Web Developer">
</div>
</div>
</div>
<!-- / Step Content -->
</div>
</div>

<!-- Bottom Navigation -->
<div class="fixed bottom-0 left-0 right-0 py-5 bg-white shadow-md" x-show="step != 'complete'">
<div class="max-w-3xl px-4 mx-auto">
<div class="flex justify-between">
<div class="w-1/2">
<button x-show="step > 1" @click="step--"
class="w-32 px-5 py-2 font-medium text-center text-gray-600 bg-white border rounded-lg shadow-sm hover:bg-gray-100 focus:outline-none">Previous</button>
</div>

<div class="w-1/2 text-right">
<button x-show="step < 3" @click="step++"
class="w-32 px-5 py-2 font-medium text-center text-white bg-blue-500 border border-transparent rounded-lg shadow-sm hover:bg-blue-600 focus:outline-none">Next</button>

<button @click="step = 'complete'" x-show="step === 3"
class="w-32 px-5 py-2 font-medium text-center text-white bg-blue-500 border border-transparent rounded-lg shadow-sm hover:bg-blue-600 focus:outline-none">Complete</button>
</div>
</div>
</div>
</div>
<!-- / Bottom Navigation https://placehold.co/300x300/e2e8f0/cccccc -->
</div>

<script>
function app() {
return {
step: 1,
passwordStrengthText: '',
togglePassword: false,

image: '',
password: '',
gender: 'Male',

checkPasswordStrength() {
var strongRegex = new RegExp("^(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9])(?=.*[!@#\$%\^&\*])(?=.{8,})");
var mediumRegex = new RegExp(
"^(((?=.*[a-z])(?=.*[A-Z]))|((?=.*[a-z])(?=.*[0-9]))|((?=.*[A-Z])(?=.*[0-9])))(?=.{6,})");

let value = this.password;

if (strongRegex.test(value)) {
this.passwordStrengthText = "Strong password";
} else if (mediumRegex.test(value)) {
this.passwordStrengthText = "Could be stronger";
} else {
this.passwordStrengthText = "Too weak";
}
}
}
}
</script>
@endsection

bilogic avatar Aug 13 '22 02:08 bilogic

Thanks @bilogic Reproduced in my environment. The cause of this template seems embedded data url image: 'data:image/jpeg;base64,. It takes about a second to format if this line deleted.

That seems to be a different cause than this, but I'll look into it.

shufo avatar Aug 16 '22 05:08 shufo

@shufo

I can imagine it must have taken some effort to investigate. Thank you!

bilogic avatar Aug 16 '22 05:08 bilogic

Both https://github.com/shufo/vscode-blade-formatter/issues/500#issuecomment-1186689736 and https://github.com/shufo/vscode-blade-formatter/issues/500#issuecomment-1213634770 are fixed at https://github.com/shufo/vscode-blade-formatter/releases/tag/v0.17.2

shufo avatar Aug 22 '22 17:08 shufo

Just tested it, thanks @shufo !

bilogic avatar Aug 23 '22 02:08 bilogic

Nice, thanks @shufo

edikurniawan-dev avatar Aug 23 '22 03:08 edikurniawan-dev