+
+ return url('/attachments/' . $this->id . ($openInline ? '?open=true' : ''));
+ }
+
+ /**
+ * Get the representation of this attachment in a format suitable for the page editors.
+ * Detects and adapts video content to use an inline video embed.
+ */
+ public function editorContent(): array
+ {
+ $videoExtensions = ['mp4', 'webm', 'mkv', 'ogg', 'avi'];
+ if (in_array(strtolower($this->extension), $videoExtensions)) {
+ $html = '<video src="' . e($this->getUrl(true)) . '" controls width="480" height="270"></video>';
+ return ['text/html' => $html, 'text/plain' => $html];
+ }
+
+ return ['text/html' => $this->htmlLink(), 'text/plain' => $this->markdownLink()];
+ }
+
+ /**
+ * Generate the HTML link to this attachment.
+ */
+ public function htmlLink(): string
+ {
+ return '<a target="_blank" href="' . e($this->getUrl()) . '">' . e($this->name) . '</a>';
+ }
+
+ /**
+ * Generate a MarkDown link to this attachment.
+ */
+ public function markdownLink(): string
+ {
+ return '[' . $this->name . '](' . $this->getUrl() . ')';
+ }
+
+ /**
+ * Scope the query to those attachments that are visible based upon related page permissions.
+ */
+ public function scopeVisible(): Builder
+ {
+ $permissions = app()->make(PermissionApplicator::class);
+
+ return $permissions->restrictPageRelationQuery(
+ self::query(),
+ 'attachments',
+ 'uploaded_to'
+ );