schantldev/statamic-formattach 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

schantldev/statamic-formattach

最新稳定版本:v1.2.0

Composer 安装命令:

composer require schantldev/statamic-formattach

包简介

README 文档

README

Statamic FormAttach is a Statamic addon that allows to easily attach any files to form submission mails dynamically.

Features

This addon provides:

  • A standard PDF attachment for form submissions1
  • Support for any other attachment(s) you might need to add dynamically

How to Install

Install the addon using composer.

composer require schantldev/statamic-formattach

Publish the configuration file.

php artisan vendor:publish --tag=statamic-formattach-config

Swap out the send email job in your statamic/forms.php config file.

/*
|--------------------------------------------------------------------------
| Send Email Job
|--------------------------------------------------------------------------
|
| The class name of the job that will be used to send an email.
|
*/

'send_email_job' => \SchantlDev\Statamic\FormAttach\Forms\SendEmailWithAttachments::class,

How to Use

After publishing the config file, you will be able to add attachments to any forms you wish. There's an array with the form handle and attachments to possibly be added.

'forms' => [
    'form_handle' => [
        // \SchantlDev\Statamic\FormAttach\Attachments\AttachPdf::class,
    ],
],

Attaching PDFs

There is a default attachment that will generate a PDF using Spatie's Browsershot package1. In the config, you can find more settings for choosing a paper size and setting a custom logo. If that's not enough, you can opt in to publish the view[^3] and adjust it to your needs or create your own custom attachment.

php artisan vendor:publish --tag=statamic-formattach-views

Tip

If you wanna see a live preview while working on the view, there's a way! There are two routes you can use for your already saved submission:

  1. as HTML: submissions/{submission_id}/preview
  2. as PDF: submissions/{submission_id}/preview_pdf

Custom attachments

Sometimes, PDFs are just not enough or you need some more fine-grained control over the attachment. In that case, you can extend the FormAttachment class and implement its abstract method to provide any attachment in form of a mailable attachment2.

use Illuminate\Mail\Mailables\Attachment;

abstract class FormAttachment {
    ...
    public function check(): bool;
    abstract public function attachment(): ?Attachment;
}

Controlling whether to add an attachment

In the above excerpt, you can see a check() method that is present within a FormAttachment class. Use it to decide on whether to add an attachment or not. You can use the SubmissionHelper object that gives you access to the submission data, the form, the blueprint of the form and the config of the mail.

Example: (only attach PDF to owner mail - in a Statamic Peak context)

namespace App\FormAttachments;

use SchantlDev\Statamic\FormAttach\Attachments\AttachPdf;

class PdfAttachment extends AttachPdf
{
    public function check(): bool
    {
        return $this->submissionHelper->config['html'] == 'email/form_owner';
    }
}

Contributing and Issues

Contributions and discussions are always welcome, no matter how large or small. If you happen to find an issue, please open up a Github issue or do a PR if you can.

Footnotes

  1. The addon requires Browserhot for the PDF attachment to work out of the box. Please note that the addon will not install Browsershot for you as you might have already installed some version of it. Please install Browsershot directly into your project. 2

  2. Refer to the offical Laravel documentation on how to create attachments in various ways.

统计信息

  • 总下载量: 357
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: Unknown
  • 更新时间: 2024-07-18