@@ -3,7 +3,7 @@ node_modules | |||||
/dist | /dist | ||||
ses | ses | ||||
resources/assets | resources/assets | ||||
vendor/ | |||||
/vendor | |||||
package-lock.json | package-lock.json | ||||
@@ -0,0 +1,19 @@ | |||||
<table class="action" align="center" width="100%" cellpadding="0" cellspacing="0" role="presentation"> | |||||
<tr> | |||||
<td align="center"> | |||||
<table width="100%" border="0" cellpadding="0" cellspacing="0" role="presentation"> | |||||
<tr> | |||||
<td align="center"> | |||||
<table border="0" cellpadding="0" cellspacing="0" role="presentation"> | |||||
<tr> | |||||
<td> | |||||
<a href="{{ $url }}" class="button button-{{ $color ?? 'primary' }}" target="_blank" rel="noopener">{{ $slot }}</a> | |||||
</td> | |||||
</tr> | |||||
</table> | |||||
</td> | |||||
</tr> | |||||
</table> | |||||
</td> | |||||
</tr> | |||||
</table> |
@@ -0,0 +1,11 @@ | |||||
<tr> | |||||
<td> | |||||
<table class="footer" align="center" width="570" cellpadding="0" cellspacing="0" role="presentation"> | |||||
<tr> | |||||
<td class="content-cell" align="center"> | |||||
{{ Illuminate\Mail\Markdown::parse($slot) }} | |||||
</td> | |||||
</tr> | |||||
</table> | |||||
</td> | |||||
</tr> |
@@ -0,0 +1,11 @@ | |||||
<tr> | |||||
<td class="header"> | |||||
<a href="{{ $url }}" style="display: inline-block;"> | |||||
@if (trim($slot) === 'Laravel') | |||||
<img src="https://laravel.com/img/notification-logo.png" class="logo" alt="Laravel Logo"> | |||||
@else | |||||
{{ $slot }} | |||||
@endif | |||||
</a> | |||||
</td> | |||||
</tr> |
@@ -0,0 +1,56 @@ | |||||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> | |||||
<html xmlns="http://www.w3.org/1999/xhtml"> | |||||
<head> | |||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" /> | |||||
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> | |||||
<meta name="color-scheme" content="light"> | |||||
<meta name="supported-color-schemes" content="light"> | |||||
<style> | |||||
@media only screen and (max-width: 600px) { | |||||
.inner-body { | |||||
width: 100% !important; | |||||
} | |||||
.footer { | |||||
width: 100% !important; | |||||
} | |||||
} | |||||
@media only screen and (max-width: 500px) { | |||||
.button { | |||||
width: 100% !important; | |||||
} | |||||
} | |||||
</style> | |||||
</head> | |||||
<body> | |||||
<table class="wrapper" width="100%" cellpadding="0" cellspacing="0" role="presentation"> | |||||
<tr> | |||||
<td align="center"> | |||||
<table class="content" width="100%" cellpadding="0" cellspacing="0" role="presentation"> | |||||
{{ $header ?? '' }} | |||||
<!-- Email Body --> | |||||
<tr> | |||||
<td class="body" width="100%" cellpadding="0" cellspacing="0"> | |||||
<table class="inner-body" align="center" width="570" cellpadding="0" cellspacing="0" role="presentation"> | |||||
<!-- Body content --> | |||||
<tr> | |||||
<td class="content-cell"> | |||||
{{ Illuminate\Mail\Markdown::parse($slot) }} | |||||
{{ $subcopy ?? '' }} | |||||
</td> | |||||
</tr> | |||||
</table> | |||||
</td> | |||||
</tr> | |||||
{{ $footer ?? '' }} | |||||
</table> | |||||
</td> | |||||
</tr> | |||||
</table> | |||||
</body> | |||||
</html> |
@@ -0,0 +1,27 @@ | |||||
@component('mail::layout') | |||||
{{-- Header --}} | |||||
@slot('header') | |||||
@component('mail::header', ['url' => config('app.url')]) | |||||
{{ config('app.name') }} | |||||
@endcomponent | |||||
@endslot | |||||
{{-- Body --}} | |||||
{{ $slot }} | |||||
{{-- Subcopy --}} | |||||
@isset($subcopy) | |||||
@slot('subcopy') | |||||
@component('mail::subcopy') | |||||
{{ $subcopy }} | |||||
@endcomponent | |||||
@endslot | |||||
@endisset | |||||
{{-- Footer --}} | |||||
@slot('footer') | |||||
@component('mail::footer') | |||||
© {{ date('Y') }} {{ config('app.name') }}. @lang('All rights reserved.') | |||||
@endcomponent | |||||
@endslot | |||||
@endcomponent |
@@ -0,0 +1,14 @@ | |||||
<table class="panel" width="100%" cellpadding="0" cellspacing="0" role="presentation"> | |||||
<tr> | |||||
<td class="panel-content"> | |||||
<table width="100%" cellpadding="0" cellspacing="0" role="presentation"> | |||||
<tr> | |||||
<td class="panel-item"> | |||||
{{ Illuminate\Mail\Markdown::parse($slot) }} | |||||
</td> | |||||
</tr> | |||||
</table> | |||||
</td> | |||||
</tr> | |||||
</table> | |||||
@@ -0,0 +1,7 @@ | |||||
<table class="subcopy" width="100%" cellpadding="0" cellspacing="0" role="presentation"> | |||||
<tr> | |||||
<td> | |||||
{{ Illuminate\Mail\Markdown::parse($slot) }} | |||||
</td> | |||||
</tr> | |||||
</table> |
@@ -0,0 +1,3 @@ | |||||
<div class="table"> | |||||
{{ Illuminate\Mail\Markdown::parse($slot) }} | |||||
</div> |
@@ -0,0 +1,290 @@ | |||||
/* Base */ | |||||
body, | |||||
body *:not(html):not(style):not(br):not(tr):not(code) { | |||||
box-sizing: border-box; | |||||
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, | |||||
'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol'; | |||||
position: relative; | |||||
} | |||||
body { | |||||
-webkit-text-size-adjust: none; | |||||
background-color: #ffffff; | |||||
color: #718096; | |||||
height: 100%; | |||||
line-height: 1.4; | |||||
margin: 0; | |||||
padding: 0; | |||||
width: 100% !important; | |||||
} | |||||
p, | |||||
ul, | |||||
ol, | |||||
blockquote { | |||||
line-height: 1.4; | |||||
text-align: left; | |||||
} | |||||
a { | |||||
color: #3869d4; | |||||
} | |||||
a img { | |||||
border: none; | |||||
} | |||||
/* Typography */ | |||||
h1 { | |||||
color: #3d4852; | |||||
font-size: 18px; | |||||
font-weight: bold; | |||||
margin-top: 0; | |||||
text-align: left; | |||||
} | |||||
h2 { | |||||
font-size: 16px; | |||||
font-weight: bold; | |||||
margin-top: 0; | |||||
text-align: left; | |||||
} | |||||
h3 { | |||||
font-size: 14px; | |||||
font-weight: bold; | |||||
margin-top: 0; | |||||
text-align: left; | |||||
} | |||||
p { | |||||
font-size: 16px; | |||||
line-height: 1.5em; | |||||
margin-top: 0; | |||||
text-align: left; | |||||
} | |||||
p.sub { | |||||
font-size: 12px; | |||||
} | |||||
img { | |||||
max-width: 100%; | |||||
} | |||||
/* Layout */ | |||||
.wrapper { | |||||
-premailer-cellpadding: 0; | |||||
-premailer-cellspacing: 0; | |||||
-premailer-width: 100%; | |||||
background-color: #edf2f7; | |||||
margin: 0; | |||||
padding: 0; | |||||
width: 100%; | |||||
} | |||||
.content { | |||||
-premailer-cellpadding: 0; | |||||
-premailer-cellspacing: 0; | |||||
-premailer-width: 100%; | |||||
margin: 0; | |||||
padding: 0; | |||||
width: 100%; | |||||
} | |||||
/* Header */ | |||||
.header { | |||||
padding: 25px 0; | |||||
text-align: center; | |||||
} | |||||
.header a { | |||||
color: #3d4852; | |||||
font-size: 19px; | |||||
font-weight: bold; | |||||
text-decoration: none; | |||||
} | |||||
/* Logo */ | |||||
.logo { | |||||
height: 75px; | |||||
max-height: 75px; | |||||
width: 75px; | |||||
} | |||||
/* Body */ | |||||
.body { | |||||
-premailer-cellpadding: 0; | |||||
-premailer-cellspacing: 0; | |||||
-premailer-width: 100%; | |||||
background-color: #edf2f7; | |||||
border-bottom: 1px solid #edf2f7; | |||||
border-top: 1px solid #edf2f7; | |||||
margin: 0; | |||||
padding: 0; | |||||
width: 100%; | |||||
} | |||||
.inner-body { | |||||
-premailer-cellpadding: 0; | |||||
-premailer-cellspacing: 0; | |||||
-premailer-width: 570px; | |||||
background-color: #ffffff; | |||||
border-color: #e8e5ef; | |||||
border-radius: 2px; | |||||
border-width: 1px; | |||||
box-shadow: 0 2px 0 rgba(0, 0, 150, 0.025), 2px 4px 0 rgba(0, 0, 150, 0.015); | |||||
margin: 0 auto; | |||||
padding: 0; | |||||
width: 570px; | |||||
} | |||||
/* Subcopy */ | |||||
.subcopy { | |||||
border-top: 1px solid #e8e5ef; | |||||
margin-top: 25px; | |||||
padding-top: 25px; | |||||
} | |||||
.subcopy p { | |||||
font-size: 14px; | |||||
} | |||||
/* Footer */ | |||||
.footer { | |||||
-premailer-cellpadding: 0; | |||||
-premailer-cellspacing: 0; | |||||
-premailer-width: 570px; | |||||
margin: 0 auto; | |||||
padding: 0; | |||||
text-align: center; | |||||
width: 570px; | |||||
} | |||||
.footer p { | |||||
color: #b0adc5; | |||||
font-size: 12px; | |||||
text-align: center; | |||||
} | |||||
.footer a { | |||||
color: #b0adc5; | |||||
text-decoration: underline; | |||||
} | |||||
/* Tables */ | |||||
.table table { | |||||
-premailer-cellpadding: 0; | |||||
-premailer-cellspacing: 0; | |||||
-premailer-width: 100%; | |||||
margin: 30px auto; | |||||
width: 100%; | |||||
} | |||||
.table th { | |||||
border-bottom: 1px solid #edeff2; | |||||
margin: 0; | |||||
padding-bottom: 8px; | |||||
} | |||||
.table td { | |||||
color: #74787e; | |||||
font-size: 15px; | |||||
line-height: 18px; | |||||
margin: 0; | |||||
padding: 10px 0; | |||||
} | |||||
.content-cell { | |||||
max-width: 100vw; | |||||
padding: 32px; | |||||
} | |||||
/* Buttons */ | |||||
.action { | |||||
-premailer-cellpadding: 0; | |||||
-premailer-cellspacing: 0; | |||||
-premailer-width: 100%; | |||||
margin: 30px auto; | |||||
padding: 0; | |||||
text-align: center; | |||||
width: 100%; | |||||
} | |||||
.button { | |||||
-webkit-text-size-adjust: none; | |||||
border-radius: 4px; | |||||
color: #fff; | |||||
display: inline-block; | |||||
overflow: hidden; | |||||
text-decoration: none; | |||||
} | |||||
.button-blue, | |||||
.button-primary { | |||||
background-color: #2d3748; | |||||
border-bottom: 8px solid #2d3748; | |||||
border-left: 18px solid #2d3748; | |||||
border-right: 18px solid #2d3748; | |||||
border-top: 8px solid #2d3748; | |||||
} | |||||
.button-green, | |||||
.button-success { | |||||
background-color: #48bb78; | |||||
border-bottom: 8px solid #48bb78; | |||||
border-left: 18px solid #48bb78; | |||||
border-right: 18px solid #48bb78; | |||||
border-top: 8px solid #48bb78; | |||||
} | |||||
.button-red, | |||||
.button-error { | |||||
background-color: #e53e3e; | |||||
border-bottom: 8px solid #e53e3e; | |||||
border-left: 18px solid #e53e3e; | |||||
border-right: 18px solid #e53e3e; | |||||
border-top: 8px solid #e53e3e; | |||||
} | |||||
/* Panels */ | |||||
.panel { | |||||
border-left: #2d3748 solid 4px; | |||||
margin: 21px 0; | |||||
} | |||||
.panel-content { | |||||
background-color: #edf2f7; | |||||
color: #718096; | |||||
padding: 16px; | |||||
} | |||||
.panel-content p { | |||||
color: #718096; | |||||
} | |||||
.panel-item { | |||||
padding: 0; | |||||
} | |||||
.panel-item p:last-of-type { | |||||
margin-bottom: 0; | |||||
padding-bottom: 0; | |||||
} | |||||
/* Utilities */ | |||||
.break-all { | |||||
word-break: break-all; | |||||
} |
@@ -0,0 +1 @@ | |||||
{{ $slot }}: {{ $url }} |
@@ -0,0 +1 @@ | |||||
{{ $slot }} |
@@ -0,0 +1 @@ | |||||
[{{ $slot }}]({{ $url }}) |
@@ -0,0 +1,9 @@ | |||||
{!! strip_tags($header) !!} | |||||
{!! strip_tags($slot) !!} | |||||
@isset($subcopy) | |||||
{!! strip_tags($subcopy) !!} | |||||
@endisset | |||||
{!! strip_tags($footer) !!} |
@@ -0,0 +1,27 @@ | |||||
@component('mail::layout') | |||||
{{-- Header --}} | |||||
@slot('header') | |||||
@component('mail::header', ['url' => config('app.url')]) | |||||
{{ config('app.name') }} | |||||
@endcomponent | |||||
@endslot | |||||
{{-- Body --}} | |||||
{{ $slot }} | |||||
{{-- Subcopy --}} | |||||
@isset($subcopy) | |||||
@slot('subcopy') | |||||
@component('mail::subcopy') | |||||
{{ $subcopy }} | |||||
@endcomponent | |||||
@endslot | |||||
@endisset | |||||
{{-- Footer --}} | |||||
@slot('footer') | |||||
@component('mail::footer') | |||||
© {{ date('Y') }} {{ config('app.name') }}. @lang('All rights reserved.') | |||||
@endcomponent | |||||
@endslot | |||||
@endcomponent |
@@ -0,0 +1 @@ | |||||
{{ $slot }} |
@@ -0,0 +1 @@ | |||||
{{ $slot }} |
@@ -0,0 +1 @@ | |||||
{{ $slot }} |
@@ -0,0 +1,62 @@ | |||||
@component('mail::message') | |||||
{{-- Greeting --}} | |||||
@if (! empty($greeting)) | |||||
# {{ $greeting }} | |||||
@else | |||||
@if ($level === 'error') | |||||
# @lang('Whoops!') | |||||
@else | |||||
# @lang('Hello!') | |||||
@endif | |||||
@endif | |||||
{{-- Intro Lines --}} | |||||
@foreach ($introLines as $line) | |||||
{{ $line }} | |||||
@endforeach | |||||
{{-- Action Button --}} | |||||
@isset($actionText) | |||||
<?php | |||||
switch ($level) { | |||||
case 'success': | |||||
case 'error': | |||||
$color = $level; | |||||
break; | |||||
default: | |||||
$color = 'primary'; | |||||
} | |||||
?> | |||||
@component('mail::button', ['url' => $actionUrl, 'color' => $color]) | |||||
{{ $actionText }} | |||||
@endcomponent | |||||
@endisset | |||||
{{-- Outro Lines --}} | |||||
@foreach ($outroLines as $line) | |||||
{{ $line }} | |||||
@endforeach | |||||
{{-- Salutation --}} | |||||
@if (! empty($salutation)) | |||||
{{ $salutation }} | |||||
@else | |||||
@lang('Regards'),<br> | |||||
{{ config('app.name') }} | |||||
@endif | |||||
{{-- Subcopy --}} | |||||
@isset($actionText) | |||||
@slot('subcopy') | |||||
@lang( | |||||
"If you’re having trouble clicking the \":actionText\" button, copy and paste the URL below\n". | |||||
'into your web browser:', | |||||
[ | |||||
'actionText' => $actionText, | |||||
] | |||||
) <span class="break-all">[{{ $displayableActionUrl }}]({{ $actionUrl }})</span> | |||||
@endslot | |||||
@endisset | |||||
@endcomponent |