• Время чтения ~8 мин
  • 05.07.2023

В этом сообщении блога мы создадим пять повторно используемых компонентов, используя Laravel Blade Components, Alpine.js и TailwindCSS. Мы построим следующие компоненты:

  • Копировать в буфер
  • Глобальный индикатор выполнения
  • Образ
  • Код QrCode
  • Аватар

Я предполагаю, что вы уже использовали AlpineJS, Laravel Blade Components и TailwindCSS. Если вы еще не пробовали AlpineJS и TailwindCSS, вам стоит это сделать. Они фантастические.

Давайте начнем!!

Копировать в буфер

обмена Этот компонент копирования в буфер обмена очень вдохновлен этим обсуждением переполнения стека https://stackoverflow.com/questions/400212/how-do-i-copy-to-the-clipboard-in-javascript.

Как использовать в наших представлениях

<x-copytoclipboard 
  content="Laravel Blade Component is Awesome" 
/>

колонок Ниже приведен пример с HTML-содержимым

<x-copytoclipboard 
  content='<svg xmlns="http://www.w3.org/2000/svg" class="h-6 w-6" fill="none" viewBox="0 0 24 24" stroke="currentColor"><path d="M12 14l9-5-9-5-9 5 9 5z" /><path d="M12 14l6.16-3.422a12.083 12.083 0 01.665 6.479A11.952 11.952 0 0012 20.055a11.952 11.952 0 00-6.824-2.998 12.078 12.078 0 01.665-6.479L12 14z" /><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 14l9-5-9-5-9 5 9 5zm0 0l6.16-3.422a12.083 12.083 0 01.665 6.479A11.952 11.952 0 0012 20.055a11.952 11.952 0 00-6.824-2.998 12.078 12.078 0 01.665-6.479L12 14zm-4 6v-7.5l4-2.222" /></svg>' 
/>

Полный компонент Глобальный индикатор выполнения Этот компонент

// views/components/copytoclipboard.blade.php
@props(['content' => 'Content' ])
<a 
	{{
		$attributes->merge([
			"class" => "no-underline border border-gray-200 px-1 rounded text-xs uppercase tracking-wide font-semibold text-gray-500"
		])
	}}
	href="#"
	x-data="{
		isCopied: false,
		copyToClipBoard() {
			if (! navigator.clipboard) {
				textArea = document.createElement('textarea');
				textArea.value = this.$refs.content.innerHTML;
				textArea.style.top = '0';
				textArea.style.left = '0';
				textArea.style.position = 'fixed';
				document.body.appendChild(textArea);
				textArea.focus();
				textArea.select();
				try {
					if (document.execCommand('copy')) {
						this.isCopied = true;
						setTimeout(() => {
							this.isCopied = false;
						}, 2500);
					}
				} catch (err) {
					console.error('Fallback: Oops, unable to copy', err);
				}
				document.body.removeChild(textArea);
				return;
			} else {
				navigator.clipboard.writeText(this.$refs.content.innerHTML)
					.then(() => {
						this.isCopied = true;
						setTimeout(() => {
							this.isCopied = false;
						}, 2500);
					});
			}
		}  
	}"
	x-on:click.prevent="copyToClipBoard()"
	x-cloak
>
<span class="hidden" x-ref="content">{!! $content !!}</span>
<span x-text="isCopied ? 'Copied' : 'Copy'"></span></a>

показывает индикатор

выполнения в верхней части страницы при переходе с одной страницы на другую. Этот компонент использует библиотеку Pace.js.

Pace.js является прекрасным индикатором прогресса для загрузки вашей страницы и навигации ajax - как определено на их официальном веб-сайте

Как использовать в наших представлениях

<x-global-progress color="coral" />

колонок Поместите приведенный выше код в раздел head вашего мастер-макета, например. app.blade.php

Полный компонент Глобальный индикатор выполнения Этот компонент

// views/components/global-progress.blade.php

@props([
	'color' => '#d72630'
])

<script src="https://cdn.jsdelivr.net/npm/[email protected]/pace.min.js" defer></script>

@once
  @push('styles')
  <style>
    /*!
      * pace.js v1.2.4 | Default theme
      * https://github.com/CodeByZach/pace/
      * Licensed MIT © HubSpot, Inc.
      */
    .pace {
      -webkit-pointer-events: none;
      pointer-events: none;
      -webkit-user-select: none;
      -moz-user-select: none;
      user-select: none
    }

    .pace-inactive {
      display: none
    }

    .pace .pace-progress {
      background: {{ $color }};
      position: fixed;
      z-index: 2000;
      top: 0;
      right: 100%;
      width: 100%;
      height: 3px
    }
  </style>
  @endpush
@endonce

с полным компонентом

Простой компонент изображения, поддерживающий пропорции.

Как использовать в наших представлениях

{{-- Give a width to adjust the height of image --}}
<div class="w-96">
  <x-image 
    image="https://pixabay.com/get/g3b015eccf776a5dbd497250775cdfaeb9846ad5b6f2828a69ae591385ad13fa5344f02279549c74909e2d1429158af0f3565a3384da23ed1ff7fcd9f5b8a26d132cdc60aad5e4795970a71d990e82d6b_640.jpg" 
    image-aspect-ratio="16:9" // Aspect Ratio 1:1, 4:3, 2:1
  />
</div>

Полный компонент Глобальный индикатор выполнения Этот компонент

// views/components/image.blade.php
@props([
	'image' => null,
	'imageAspectRatio' => '16:9',
	'rounded' => true,
	'srcsets' => null,
	'alt' => '',
	'sizes' => "(min-width: 768px) 40vw, 90vw"
])
{{-- 
	The sizes attribute describes the width that the image will display within the layout of your specific site
--}}
@php
	$roundedClass = $rounded ? 'rounded-md' : '';
	$aspectRatio = [
		'16:9' => 'padding-bottom: 56.25%',
		'4:3' => 'padding-bottom: 75%',
		'2:1' => 'padding-bottom: 50%',
		'1:1' => 'padding-bottom: 100%',
		'custom' => ''
	][$imageAspectRatio];
	$defaultImage = '';
@endphp
<div
	@if($aspectRatio)
		style="{{ $aspectRatio }}" 
	@endif
	
	{{
		$attributes->merge([
			'class' => 'relative border border-gray-100 overflow-hidden '. $roundedClass
		])
	}}
>
	@if ($image)
		<img 
			class="absolute object-cover h-full w-full"
			src="{{ $defaultImage }}"
			alt="{{ $alt ?? $image }}"
			loading="lazy"
			data-src="{{ $image }}" 
			onload="if(this.src !== this.getAttribute('data-src')) this.src=this.getAttribute('data-src');"
			
			@if (! is_null($srcsets))
				sizes="{{ $sizes }}"
				srcset="{{ $srcsets }}"
			@endif
		/>
	@else
		<img 
			class="absolute object-cover h-full w-full"
			src="{{ $defaultImage }}"
			alt="Placehoder-image"
			loading="lazy"
		/>
	@endif
</div>
 

QrCode на основе библиотеки https://github.com/milon/barcode

Simple QrCode на основе библиотеки https://github.com/milon/barcode based on the library https://github.com/milon/barcode

laravel Как использовать в наших представлениях

composer require milon/barcode

Как использовать в наших представлениях

<x-qrcode data="Laravel is awesome" />

Полный компонент Глобальный индикатор выполнения Этот компонент

// views/components/qrcode.blade.php
@props([
	'size' => 6,
	'data' => 'Hello QR Code',
	'type' => 'QRCODE',
	'dimension' => 2
])
<img 
	@if ($dimension === 2)
		src="data:image/png;base64,{{ DNS2D::getBarcodePNG($data, $type, $size, $size) }}"
	@else
		src="data:image/png;base64,{{ DNS1D::getBarcodePNG($data, $type) }}"
	@endif
	alt="qrcode"   
/>

Компонент

аватара, основанный на удивительном API, предоставляемом https://avatars.dicebear.com/ и https://boringavatars.com/.

Как использовать в наших представлениях

<x-avatar name="Loki" size="128" />
<x-avatar name="Loki" size="128" source="boringAvatars" />

Полный компонент Глобальный индикатор выполнения Этот компонент

// views/components/avatar.blade.php
@props([
	'shape' => 'circle', // circle or square
	'size' => 40,
  
  // works only with source type boringAvatars
	'variant' => 'beam', // marble, beam, pixel, sunset, bauhaus, ring
  'colors' => ['5e9fa3', 'dcd1b4', 'fab87f', 'f87e7b', 'b05574'],
	
  'name' => 'Tony Stark',
	
	'source' => "dicebearAvatars" // boringAvatars or dicebearAvatars
])
@php
	$avatarShapeClass = [
		'rounded' => 'rounded-lg',
		'square' => 'rounded-lg',
		'circle' => 'rounded-full',
	][$shape];
@endphp
<div class="inline-flex flex-shrink-0 overflow-hidden bg-gray-100 {{ $avatarShapeClass }}" style="width: {{ $size }}px; height: {{ $size }}px;">
	@if ($source === 'dicebearAvatars')
		<img 
	    src="https://avatars.dicebear.com/api/initials/{{ urlencode($name) }}.svg?&width={{ $size }}&height={{ $size }}" 
	    alt="{{ $name }}" 
			title="{{ $name }}" 
	    class="object-fit" 
			loading="lazy"
	  />
	@else
		<img 
			src="https://source.boringavatars.com/{{ $variant }}/{{ $size }}/{{ urlencode($name) }}?colors={{ implode(',', $colors) }}&{{ $shape }}" 
			alt="{{ $name }}" 
			title="{{ $name }}" 
			class="object-fit" 
			loading="lazy"
		/>
	@endif
</div>

Comments

No comments yet
Yurij Finiv

Yurij Finiv

Full stack

Про мене

Professional Fullstack Developer with extensive experience in website and desktop application development. Proficient in a wide range of tools and technologies, including Bootstrap, Tailwind, HTML5, CSS3, PUG, JavaScript, Alpine.js, jQuery, PHP, MODX, and Node.js. Skilled in website development using Symfony, MODX, and Laravel. Experience: Contributed to the development and translation of MODX3 i...

Об авторе CrazyBoy49z
WORK EXPERIENCE
Контакты
Ukraine, Lutsk
+380979856297