Merge branch 'feature/copy-link' into 'develop'
Copy status link to clipboard See merge request pleroma/pleroma-fe!1085
This commit is contained in:
		
						commit
						ec7bee6bd6
					
				
					 7 changed files with 32 additions and 9 deletions
				
			
		|  | @ -29,6 +29,11 @@ const ExtraButtons = { | ||||||
|       this.$store.dispatch('unmuteConversation', this.status.id) |       this.$store.dispatch('unmuteConversation', this.status.id) | ||||||
|         .then(() => this.$emit('onSuccess')) |         .then(() => this.$emit('onSuccess')) | ||||||
|         .catch(err => this.$emit('onError', err.error.error)) |         .catch(err => this.$emit('onError', err.error.error)) | ||||||
|  |     }, | ||||||
|  |     copyLink () { | ||||||
|  |       navigator.clipboard.writeText(this.statusLink) | ||||||
|  |         .then(() => this.$emit('onSuccess')) | ||||||
|  |         .catch(err => this.$emit('onError', err.error.error)) | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|   computed: { |   computed: { | ||||||
|  | @ -46,6 +51,9 @@ const ExtraButtons = { | ||||||
|     }, |     }, | ||||||
|     canMute () { |     canMute () { | ||||||
|       return !!this.currentUser |       return !!this.currentUser | ||||||
|  |     }, | ||||||
|  |     statusLink () { | ||||||
|  |       return `${this.$store.state.instance.server}${this.$router.resolve({ name: 'conversation', params: { id: this.status.id } }).href}` | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,11 +1,13 @@ | ||||||
| <template> | <template> | ||||||
|   <Popover |   <Popover | ||||||
|     v-if="canDelete || canMute || canPin" |  | ||||||
|     trigger="click" |     trigger="click" | ||||||
|     placement="top" |     placement="top" | ||||||
|     class="extra-button-popover" |     class="extra-button-popover" | ||||||
|   > |   > | ||||||
|     <div slot="content"> |     <div | ||||||
|  |       slot="content" | ||||||
|  |       slot-scope="{close}" | ||||||
|  |     > | ||||||
|       <div class="dropdown-menu"> |       <div class="dropdown-menu"> | ||||||
|         <button |         <button | ||||||
|           v-if="canMute && !status.thread_muted" |           v-if="canMute && !status.thread_muted" | ||||||
|  | @ -23,28 +25,35 @@ | ||||||
|         </button> |         </button> | ||||||
|         <button |         <button | ||||||
|           v-if="!status.pinned && canPin" |           v-if="!status.pinned && canPin" | ||||||
|           v-close-popover |  | ||||||
|           class="dropdown-item dropdown-item-icon" |           class="dropdown-item dropdown-item-icon" | ||||||
|           @click.prevent="pinStatus" |           @click.prevent="pinStatus" | ||||||
|  |           @click="close" | ||||||
|         > |         > | ||||||
|           <i class="icon-pin" /><span>{{ $t("status.pin") }}</span> |           <i class="icon-pin" /><span>{{ $t("status.pin") }}</span> | ||||||
|         </button> |         </button> | ||||||
|         <button |         <button | ||||||
|           v-if="status.pinned && canPin" |           v-if="status.pinned && canPin" | ||||||
|           v-close-popover |  | ||||||
|           class="dropdown-item dropdown-item-icon" |           class="dropdown-item dropdown-item-icon" | ||||||
|           @click.prevent="unpinStatus" |           @click.prevent="unpinStatus" | ||||||
|  |           @click="close" | ||||||
|         > |         > | ||||||
|           <i class="icon-pin" /><span>{{ $t("status.unpin") }}</span> |           <i class="icon-pin" /><span>{{ $t("status.unpin") }}</span> | ||||||
|         </button> |         </button> | ||||||
|         <button |         <button | ||||||
|           v-if="canDelete" |           v-if="canDelete" | ||||||
|           v-close-popover |  | ||||||
|           class="dropdown-item dropdown-item-icon" |           class="dropdown-item dropdown-item-icon" | ||||||
|           @click.prevent="deleteStatus" |           @click.prevent="deleteStatus" | ||||||
|  |           @click="close" | ||||||
|         > |         > | ||||||
|           <i class="icon-cancel" /><span>{{ $t("status.delete") }}</span> |           <i class="icon-cancel" /><span>{{ $t("status.delete") }}</span> | ||||||
|         </button> |         </button> | ||||||
|  |         <button | ||||||
|  |           class="dropdown-item dropdown-item-icon" | ||||||
|  |           @click.prevent="copyLink" | ||||||
|  |           @click="close" | ||||||
|  |         > | ||||||
|  |           <i class="icon-share" /><span>{{ $t("status.copy_link") }}</span> | ||||||
|  |         </button> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|     <i |     <i | ||||||
|  |  | ||||||
|  | @ -2,7 +2,7 @@ import Popover from '../popover/popover.vue' | ||||||
| import { mapGetters } from 'vuex' | import { mapGetters } from 'vuex' | ||||||
| 
 | 
 | ||||||
| const ReactButton = { | const ReactButton = { | ||||||
|   props: ['status', 'loggedIn'], |   props: ['status'], | ||||||
|   data () { |   data () { | ||||||
|     return { |     return { | ||||||
|       filterWord: '' |       filterWord: '' | ||||||
|  |  | ||||||
|  | @ -37,7 +37,6 @@ | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|     <i |     <i | ||||||
|       v-if="loggedIn" |  | ||||||
|       slot="trigger" |       slot="trigger" | ||||||
|       class="icon-smile button-icon add-reaction-button" |       class="icon-smile button-icon add-reaction-button" | ||||||
|       :title="$t('tool_tip.add_reaction')" |       :title="$t('tool_tip.add_reaction')" | ||||||
|  |  | ||||||
|  | @ -404,7 +404,7 @@ | ||||||
|               :status="status" |               :status="status" | ||||||
|             /> |             /> | ||||||
|             <ReactButton |             <ReactButton | ||||||
|               :logged-in="loggedIn" |               v-if="loggedIn" | ||||||
|               :status="status" |               :status="status" | ||||||
|             /> |             /> | ||||||
|             <extra-buttons |             <extra-buttons | ||||||
|  |  | ||||||
|  | @ -620,7 +620,8 @@ | ||||||
|     "replies_list": "Replies:", |     "replies_list": "Replies:", | ||||||
|     "mute_conversation": "Mute conversation", |     "mute_conversation": "Mute conversation", | ||||||
|     "unmute_conversation": "Unmute conversation", |     "unmute_conversation": "Unmute conversation", | ||||||
|     "status_unavailable": "Status unavailable" |     "status_unavailable": "Status unavailable", | ||||||
|  |     "copy_link": "Copy link to status" | ||||||
|   }, |   }, | ||||||
|   "user_card": { |   "user_card": { | ||||||
|     "approve": "Approve", |     "approve": "Approve", | ||||||
|  |  | ||||||
|  | @ -346,6 +346,12 @@ | ||||||
|       "code": 59427, |       "code": 59427, | ||||||
|       "src": "fontawesome" |       "src": "fontawesome" | ||||||
|     }, |     }, | ||||||
|  |     { | ||||||
|  |       "uid": "4aad6bb50b02c18508aae9cbe14e784e", | ||||||
|  |       "css": "share", | ||||||
|  |       "code": 61920, | ||||||
|  |       "src": "fontawesome" | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|       "uid": "8b80d36d4ef43889db10bc1f0dc9a862", |       "uid": "8b80d36d4ef43889db10bc1f0dc9a862", | ||||||
|       "css": "user", |       "css": "user", | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Shpuld Shpludson
						Shpuld Shpludson