about summary refs log tree commit diff
path: root/app
diff options
context:
space:
mode:
authorりんすき <428rinsuki+git@gmail.com>2018-01-18 01:08:10 +0900
committerEugen Rochko <eugen@zeonfederated.com>2018-01-17 17:08:10 +0100
commitfbe7756da6e817c3de633f624f5a28bc133e78c8 (patch)
tree19a31c883cdcf17ce284f90fd45fe46d5d742815 /app
parent0a103c774977cda29e5c02e697b4632f98bcc621 (diff)
implement web share target (#6278)
* web share target

* fix

* fix
Diffstat (limited to 'app')
-rw-r--r--app/controllers/shares_controller.rb3
-rw-r--r--app/serializers/manifest_serializer.rb7
2 files changed, 8 insertions, 2 deletions
diff --git a/app/controllers/shares_controller.rb b/app/controllers/shares_controller.rb
index fc2469dea..3ec831a72 100644
--- a/app/controllers/shares_controller.rb
+++ b/app/controllers/shares_controller.rb
@@ -14,13 +14,14 @@ class SharesController < ApplicationController
   private
 
   def initial_state_params
+    text = [params[:title], params[:text], params[:url]].compact.join(' ')
     {
       settings: Web::Setting.find_by(user: current_user)&.data || {},
       push_subscription: current_account.user.web_push_subscription(current_session),
       current_account: current_account,
       token: current_session.token,
       admin: Account.find_local(Setting.site_contact_username),
-      text: params[:text],
+      text: text,
     }
   end
 
diff --git a/app/serializers/manifest_serializer.rb b/app/serializers/manifest_serializer.rb
index 95bcc21bb..859ef0d14 100644
--- a/app/serializers/manifest_serializer.rb
+++ b/app/serializers/manifest_serializer.rb
@@ -6,7 +6,8 @@ class ManifestSerializer < ActiveModel::Serializer
 
   attributes :name, :short_name, :description,
              :icons, :theme_color, :background_color,
-             :display, :start_url, :scope
+             :display, :start_url, :scope,
+             :share_target
 
   def name
     object.site_title
@@ -49,4 +50,8 @@ class ManifestSerializer < ActiveModel::Serializer
   def scope
     root_url
   end
+
+  def share_target
+    { url_template: 'share?title={title}&text={text}&url={url}' }
+  end
 end