使用 Laravel 分享链接

dev-master 2024-10-01 12:37 UTC

This package is not auto-updated.

Last update: 2024-10-02 10:47:55 UTC


README

使用 Laravel 分享链接

这是 John 的 Laravel 4 分享功能的分支。

可用的服务

  • 博客:blogger
  • Dig:digg
  • 电子邮件:email
  • Evernote:evernote
  • Facebook:facebook
  • Gmail:gmail
  • LinkedIn:linkedin
  • Pinterest:pinterest
  • Reddit:reddit
  • Scoop.it:scoopit
  • Telegram.me:telegramMe
  • Tumblr:tumblr
  • Twitter:twitter
  • vk.com:vk

安装

将 Composer 依赖安装到您的项目中

composer require chencha/share

使用方法

获取一个链接(例如 Twitter)

Route::get('/', function()
{
	return Share::load('http://www.example.com', 'My example')->twitter();
});

返回一个字符串

https://twitter.com/intent/tweet?url=http%3A%2F%2Fwww.example.com&text=Link+description

获取多个链接

Route::get('/', function()
{
	return Share::load('http://www.example.com', 'Link description')->services('facebook', 'twitter');
});

返回一个数组

{
    "twitter" : "https://twitter.com/intent/tweet?url=http%3A%2F%2Fwww.example.com&text=Link+description",
    "facebook" : "https://#/sharer/sharer.php?u=http%3A%2F%2Fwww.example.com&title=Link+description"
}

获取所有链接

Route::get('/', function()
{
	return Share::load('http://www.example.com', 'Link description')->services();
});

返回所有定义的服务的查询结果数组

定制

发布包配置

php artisan vendor:publish --provider='Chencha\Share\ShareServiceProvider'

在 config/social-share.php 中添加新的服务

'mynewservice' => [ 'view' => 'share.mynewservice' ]

share.mynewservice 视图文件中添加 Blade 模板代码,以生成 mynewservice 的 URL。您有权限访问

  • service - 服务定义(如上所示)。
  • sep - 参数之间的分隔符,默认为 '&'。可配置为 social-share.separator
  • url - 正在共享的 URL。
  • title - 正在共享的标题。
  • media - 正在共享的媒体链接。

示例

https://mynewservice.example.com?url={{ rawurlencode($url) }}<?php echo $sep; ?>title={{ rawurlencode("Check this out! $title. See it here: $url") }}

对于 email 服务的另一个示例。将服务配置改为 [ 'view' => 'whatever' ] 并在视图文件中添加以下内容

mailto:?subject={{ rawurlencode("Wow, check this: $title") }}<?php echo $sep; ?>body={{ rawurlencode("Check this out! $title. See it here: $url") }}

本地化?简单,使用 Laravel 的 trans() 调用

mailto:?subject={{ rawurlencode(trans('share.email-subject', compact('url', 'title', 'media'))) }}<?php echo $sep ?>body={{ rawurlencode(trans('share.email-body', compact('url', 'title', 'media'))) }}

在 resources/lang/en/share.php 中创建文件,包含您选择的主题和正文。URL 的最大长度可能是 2000 个字符。

注意使用 。这是打印未编码的 & (如果配置为这种方式)的唯一方法。

升级

当包升级时,应将配置和视图的更改重新发布到您的项目中

php artisan vendor:publish --provider='Chencha\Share\ShareServiceProvider'

如果您自定义了文件,请使用源控制来找出发生了什么更改。