Răsfoiți Sursa

Merge branch 'frontend-ui-refactor' into patch-1

marcin mikołajczak 6 ani în urmă
părinte
comite
3a6064aa7d

+ 1 - 1
package.json

@@ -49,6 +49,6 @@
     },
     "collective": {
         "type": "opencollective",
-        "url": "https://opencollective.com/pixelfed-528"
+        "url": "https://opencollective.com/pixelfed"
     }
 }

BIN
public/vendor/horizon/css/app.css


+ 3 - 3
resources/assets/js/components/DiscoverComponent.vue

@@ -64,7 +64,7 @@ export default {
 	},
 
 	methods: {
-    
+
     followUser(id, event) {
       axios.post('/i/follow', {
         item: id
@@ -74,7 +74,7 @@ export default {
         el.text('Unfollow');
       }).catch(err => {
         swal(
-          'Whoops! Something went wrong...',
+          'Whoops! Something went wrong',
           'An error occurred, please try again later.',
           'error'
         );
@@ -136,4 +136,4 @@ export default {
     },
 	}
 }
-</script>
+</script>

+ 4 - 4
resources/assets/js/components/PostComponent.vue

@@ -152,7 +152,7 @@
             <form class="comment-form d-none" method="post" action="/i/comment" :data-id="statusId" data-truncate="false">
               <input type="hidden" name="_token" value="">
               <input type="hidden" name="item" :value="statusId">
-              <input class="form-control" name="comment" placeholder="Add a comment..." autocomplete="off">
+              <input class="form-control" name="comment" placeholder="Add a comment" autocomplete="off">
               <input type="submit" value="Send" class="btn btn-primary comment-submit" />
             </form>
           </div>
@@ -172,7 +172,7 @@
       <div class="list-group-item border-0" v-for="(user, index) in likes" :key="'modal_likes_'+index">
         <div class="media">
           <a :href="user.url">
-            <img class="mr-3 rounded-circle box-shadow" :src="user.avatar" :alt="user.username + '\'s avatar'" width="30px">
+            <img class="mr-3 rounded-circle box-shadow" :src="user.avatar" :alt="user.username + s avatar'" width="30px">
           </a>
           <div class="media-body">
             <p class="mb-0" style="font-size: 14px">
@@ -203,7 +203,7 @@
       <div class="list-group-item border-0" v-for="(user, index) in shares" :key="'modal_shares_'+index">
         <div class="media">
           <a :href="user.url">
-            <img class="mr-3 rounded-circle box-shadow" :src="user.avatar" :alt="user.username + '\'s avatar'" width="30px">
+            <img class="mr-3 rounded-circle box-shadow" :src="user.avatar" :alt="user.username + 's avatar'" width="30px">
           </a>
           <div class="media-body">
             <div class="d-inline-block">
@@ -526,7 +526,7 @@ export default {
             });
         }
       },
-      
+
       owner() {
         return this.user.id === this.status.account.id;
       },

+ 13 - 13
resources/assets/js/components/Profile.vue

@@ -34,25 +34,25 @@
 							<div class="profile-stats pb-3 d-inline-flex lead">
 								<div class="font-weight-light pr-5">
 									<a class="text-dark" :href="profile.url">
-										<span class="font-weight-bold">{{profile.statuses_count}}</span> 
+										<span class="font-weight-bold">{{profile.statuses_count}}</span>
 										Posts
 									</a>
 								</div>
 								<div class="font-weight-light pr-5">
 									<a class="text-dark cursor-pointer" v-on:click="followersModal()">
-										<span class="font-weight-bold">{{profile.followers_count}}</span> 
+										<span class="font-weight-bold">{{profile.followers_count}}</span>
 										Followers
 									</a>
 								</div>
 								<div class="font-weight-light pr-5">
 									<a class="text-dark cursor-pointer" v-on:click="followingModal()">
-										<span class="font-weight-bold">{{profile.following_count}}</span> 
+										<span class="font-weight-bold">{{profile.following_count}}</span>
 										Following
 									</a>
 								</div>
 							</div>
 							<p class="lead mb-0 d-flex align-items-center">
-								<span class="font-weight-bold pr-3">{{profile.display_name}}</span> 
+								<span class="font-weight-bold pr-3">{{profile.display_name}}</span>
 							</p>
 							<div v-if="profile.note" class="mb-0 lead" v-html="profile.note"></div>
 							<p v-if="profile.website" class="mb-0"><a :href="profile.website" class="font-weight-bold" rel="me external nofollow noopener" target="_blank">{{profile.website}}</a></p>
@@ -144,7 +144,7 @@
 
 							<div class="postPresenterContainer">
 								<div v-if="status.pf_type === 'photo'" class="w-100">
-									<photo-presenter :status="status"></photo-presenter>	
+									<photo-presenter :status="status"></photo-presenter>
 								</div>
 
 								<div v-else-if="status.pf_type === 'video'" class="w-100">
@@ -233,7 +233,7 @@
       <div class="list-group-item border-0" v-for="(user, index) in following" :key="'following_'+index">
         <div class="media">
           <a :href="user.url">
-            <img class="mr-3 rounded-circle box-shadow" :src="user.avatar" :alt="user.username + '\'s avatar'" width="30px">
+            <img class="mr-3 rounded-circle box-shadow" :src="user.avatar" :alt="user.username + 's avatar'" width="30px">
           </a>
           <div class="media-body">
             <p class="mb-0" style="font-size: 14px">
@@ -262,7 +262,7 @@
       <div class="list-group-item border-0" v-for="(user, index) in followers" :key="'follower_'+index">
         <div class="media">
           <a :href="user.url">
-            <img class="mr-3 rounded-circle box-shadow" :src="user.avatar" :alt="user.username + '\'s avatar'" width="30px">
+            <img class="mr-3 rounded-circle box-shadow" :src="user.avatar" :alt="user.username + 's avatar'" width="30px">
           </a>
           <div class="media-body">
             <p class="mb-0" style="font-size: 14px">
@@ -329,7 +329,7 @@ export default {
 			mode: 'grid',
 			modes: ['grid', 'list', 'masonry'],
 			modalStatus: false,
-			relationship: {}, 
+			relationship: {},
 			followers: [],
 			followerCursor: 1,
 			followerMore: true,
@@ -456,7 +456,7 @@ export default {
 			if($('body').hasClass('loggedIn') == false) {
 				return;
 			}
-			
+
 			axios.post('/i/like', {
 				item: status.id
 			}).then(res => {
@@ -671,7 +671,7 @@ export default {
 			.then(res => {
 				this.following = res.data;
 				this.followingCursor++;
-                if(res.data.length < 10) {
+        if(res.data.length < 10) {
 					this.followingMore = false;
 				}
 			});
@@ -691,7 +691,7 @@ export default {
 			.then(res => {
 				this.followers = res.data;
 				this.followerCursor++;
-                if(res.data.length < 10) {
+        if(res.data.length < 10) {
 					this.followerMore = false;
 				}
 			})	
@@ -709,7 +709,7 @@ export default {
 					this.following.push(...res.data);
 					this.followingCursor++;
 				}
-                if(res.data.length < 10) {
+        if(res.data.length < 10) {
 					this.followingMore = false;
 				}
 			});
@@ -727,7 +727,7 @@ export default {
 					this.followers.push(...res.data);
 					this.followerCursor++;
 				}
-                if(res.data.length < 10) {
+        if(res.data.length < 10) {
 					this.followerMore = false;
 				}
 			});

+ 5 - 5
resources/assets/js/components/SearchResults.vue

@@ -2,7 +2,7 @@
 <div class="container">
 	<div v-if="loading" class="pt-5 text-center">
 		<div class="spinner-border" role="status">
-			<span class="sr-only">Loading...</span>
+			<span class="sr-only">Loading</span>
 		</div>
 	</div>
 	<div v-if="networkError" class="pt-5 text-center">
@@ -10,7 +10,7 @@
 	</div>
 
 	<div v-if="!loading && !networkError" class="mt-5 row">
-		
+
 		<div class="col-12 col-md-3">
 			<div>
 				<p class="font-weight-bold">Filters</p>
@@ -31,7 +31,7 @@
 		<div class="col-12 col-md-9">
 			<p class="h3 font-weight-lighter">Showing results for <i>{{query}}</i></p>
 			<hr>
-			
+
 			<div v-if="filters.hashtags && results.hashtags.length" class="row mb-4">
 				<p class="col-12 font-weight-bold text-muted">Hashtags</p>
 				<a v-for="(hashtag, index) in results.hashtags" class="col-12 col-md-4" style="text-decoration: none;" :href="hashtag.url">
@@ -76,7 +76,7 @@
 </template>
 
 <style type="text/css" scoped>
-	
+
 </style>
 
 <script type="text/javascript">
@@ -131,4 +131,4 @@ export default {
 	}
 
 }
-</script>
+</script>

+ 4 - 4
resources/assets/js/components/Stories.vue

@@ -9,12 +9,12 @@
 			</div>
 			<div class="card-body loader text-center" style="height: 120px;">
 				<div class="spinner-border" role="status">
-					<span class="sr-only">Loading...</span>
+					<span class="sr-only">Loading</span>
 				</div>
 			</div>
 			<div class="card-body pt-2 contents" style="max-height: 120px; overflow-y: scroll;">
 				<div id="stories">
-					
+
 				</div>
 			</div>
 		</div>
@@ -22,7 +22,7 @@
 </template>
 
 <style type="text/css" scoped>
-	
+
 </style>
 
 <script type="text/javascript">
@@ -53,4 +53,4 @@
 			}
 		}
 	}
-</script>
+</script>

+ 14 - 14
resources/assets/js/components/Timeline.vue

@@ -58,7 +58,7 @@
 
 				<div class="postPresenterContainer">
 					<div v-if="status.pf_type === 'photo'" class="w-100">
-						<photo-presenter :status="status"></photo-presenter>	
+						<photo-presenter :status="status"></photo-presenter>
 					</div>
 
 					<div v-else-if="status.pf_type === 'video'" class="w-100">
@@ -256,12 +256,12 @@
 								<div v-else-if="n.type == 'follow'">
 									<p class="my-0">
 										<a :href="n.account.url" class="font-weight-bold text-dark word-break">{{n.account.username}}</a> followed you.
-									</p>	
+									</p>
 								</div>
 								<div v-else-if="n.type == 'share'">
 									<p class="my-0">
 										<a :href="n.account.url" class="font-weight-bold text-dark word-break">{{n.account.username}}</a> shared your <a class="font-weight-bold" v-bind:href="n.status.reblog.url">post</a>.
-									</p>	
+									</p>
 								</div>
 							</div>
 						</div>
@@ -307,7 +307,7 @@
       <div class="list-group-item border-0" v-for="(user, index) in following" :key="'following_'+index">
         <div class="media">
           <a :href="user.url">
-            <img class="mr-3 rounded-circle box-shadow" :src="user.avatar" :alt="user.username + '\'s avatar'" width="30px">
+            <img class="mr-3 rounded-circle box-shadow" :src="user.avatar" :alt="user.username + 's avatar'" width="30px">
           </a>
           <div class="media-body">
             <p class="mb-0" style="font-size: 14px">
@@ -336,7 +336,7 @@
       <div class="list-group-item border-0" v-for="(user, index) in followers" :key="'follower_'+index">
         <div class="media">
           <a :href="user.url">
-            <img class="mr-3 rounded-circle box-shadow" :src="user.avatar" :alt="user.username + '\'s avatar'" width="30px">
+            <img class="mr-3 rounded-circle box-shadow" :src="user.avatar" :alt="user.username + 's avatar'" width="30px">
           </a>
           <div class="media-body">
             <p class="mb-0" style="font-size: 14px">
@@ -567,7 +567,7 @@
 				if($('body').hasClass('loggedIn') == false) {
 					return;
 				}
-				
+
 				axios.post('/i/like', {
 					item: status.id
 				}).then(res => {
@@ -786,7 +786,7 @@
 					break;
 
 					case 'disable':
-						msg = 'Are you sure you want to disable ' + username + '\'s account ?';
+						msg = 'Are you sure you want to disable ' + username + 's account ?';
 						swal({
 							title: 'Confirm',
 							text: msg,
@@ -800,7 +800,7 @@
 									item_id: status.id,
 									item_type: 'status'
 								}).then(res => {
-									swal('Success', 'Successfully disabled ' + username + '\'s account', 'success');
+									swal('Success', 'Successfully disabled ' + username + 's account', 'success');
 								}).catch(err => {
 									swal(
 										'Error',
@@ -813,7 +813,7 @@
 					break;
 
 					case 'suspend':
-						msg = 'Are you sure you want to suspend ' + username + '\'s account ?';
+						msg = 'Are you sure you want to suspend ' + username + 's account ?';
 						swal({
 							title: 'Confirm',
 							text: msg,
@@ -827,7 +827,7 @@
 									item_id: status.id,
 									item_type: 'status'
 								}).then(res => {
-									swal('Success', 'Successfully suspend ' + username + '\'s account', 'success');
+									swal('Success', 'Successfully suspend ' + username + 's account', 'success');
 								}).catch(err => {
 									swal(
 										'Error',
@@ -892,7 +892,7 @@
 					this.following = res.data;
 					this.followingCursor++;
 				});
-                if(res.data.length < 10) {
+        if(res.data.length < 10) {
 					this.followingMore = false;
 				}
 				this.$refs.followingModal.show();
@@ -912,7 +912,7 @@
 					this.followers = res.data;
 					this.followerCursor++;
 				})
-                if(res.data.length < 10) {
+        if(res.data.length < 10) {
 					this.followerMore = false;
 				}
 				this.$refs.followerModal.show();
@@ -929,7 +929,7 @@
 						this.following.push(...res.data);
 						this.followingCursor++;
 					}
-                    if(res.data.length < 10) {
+          if(res.data.length < 10) {
 						this.followingMore = false;
 					}
 				});
@@ -947,7 +947,7 @@
 						this.followers.push(...res.data);
 						this.followerCursor++;
 					}
-                    if(res.data.length < 10) {
+          if(res.data.length < 10) {
 						this.followerMore = false;
 					}
 				});

+ 39 - 0
resources/assets/sass/custom.scss

@@ -211,6 +211,45 @@ body, button, input, textarea {
   animation: loading-bar 3s linear infinite;
 }
 
+.liked {
+    position: relative;
+    z-index: 1;
+}
+
+.liked::after {
+    content: "\F0a3";
+    color: transparent;
+    animation: liking 1.5s;
+    position: absolute;
+    z-index: -1;
+    left: 50%;
+    top: 0;
+}
+
+@keyframes liking {
+ 0% {
+  -webkit-transform:rotate(0deg);
+  transform:rotate(0deg);
+  font-size:0;
+  top: .25rem;
+  color: #ebf70e;
+ }
+ 75% {
+  -webkit-transform:rotate(1turn);
+  transform:rotate(1turn);
+  top: -0.55rem;
+  font-size: 2.8rem;
+  opacity:1;
+  left: -0.55rem;
+ }
+ 100% {
+  transform:rotate(1turn);
+  top: 2.5rem;
+  left: 0em;
+  font-size:0;
+  left: 0.9rem
+ }
+
 .max-hide-overflow {
   max-height: 500px;
   overflow-y: hidden;

+ 12 - 8
resources/lang/cs/navmenu.php

@@ -2,13 +2,17 @@
 
 return [
 
-    'viewMyProfile'  => 'Zobrazit můj profil',
-    'myTimeline'     => 'Moje časová osa',
-    'publicTimeline' => 'Veřejná časová osa',
-    'remoteFollow'   => 'Vzdálené sledování',
-    'settings'       => 'Nastavení',
-    'admin'          => 'Administrace',
-    'logout'         => 'Odhlásit',
-    'directMessages' => 'Přímé zprávy',
+	'search'			=> 'Hledat',
+	'home'				=> 'Domů',
+	'local'				=> 'Místní',
+	'discover'			=> 'Objevovat',
+	'viewMyProfile'		=> 'Zobrazit můj profil',
+	'myTimeline'		=> 'Moje časová osa',
+	'publicTimeline'	=> 'Veřejná časová osa',
+	'remoteFollow'		=> 'Vzdálené sledování',
+	'settings'			=> 'Nastavení',
+	'admin'				=> 'Administrace',
+	'logout'			=> 'Odhlásit',
+	'directMessages'	=> 'Přímé zprávy',
 
 ];

+ 1 - 1
resources/lang/de/site.php

@@ -9,7 +9,7 @@ return [
 	'opensource'	=> 'Open Source',
 	'terms'			=> 'Nutzungshinweise',
 	'privacy'		=> 'Privacy',
-	'l10nWip'		=> 'Wir arbeiten noch an der Unterstützung weiterer Sprachen.',
+	'l10nWip'		=> 'Wir arbeiten noch an der Unterstützung weiterer Sprachen',
 	'currentLocale' => 'Aktuelle Sprache',
 	'selectLocale'  => 'Wähle eine der unterstützten Sprachen aus',
   

+ 2 - 2
resources/lang/en/passwords.php

@@ -15,8 +15,8 @@ return [
 
     'password' => 'Passwords must be at least six characters and match the confirmation.',
     'reset'    => 'Your password has been reset!',
-    'sent'     => 'If your email address exists in our database, you will receive a password recovery link at your email address in a few minutes. Please check your spam folder if you didn\'t receive this email.',
+    'sent'     => 'If your email address exists in our database, you will receive a password recovery link at your email address in a few minutes. Please check your spam folder if you didnt receive this email.',
     'token'    => 'This password reset token is invalid.',
-    'user'     => 'If your email address exists in our database, you will receive a password recovery link at your email address in a few minutes. Please check your spam folder if you didn\'t receive this email.',
+    'user'     => 'If your email address exists in our database, you will receive a password recovery link at your email address in a few minutes. Please check your spam folder if you didnt receive this email.',
 
 ];

+ 2 - 2
resources/lang/en/site.php

@@ -11,6 +11,6 @@ return [
 	'privacy'		=> 'Privacy',
 	'l10nWip'		=> 'We’re still working on localization support',
 	'currentLocale' => 'Current locale',
-	'selectLocale'  => 'Select from one of the supported languages',
+	'selectLocale'  => 'Select one of the supported languages',
 
-];
+];

+ 4 - 0
resources/lang/eu/navmenu.php

@@ -2,6 +2,10 @@
 
 return [
 
+    'search'		 => 'Bilatu',
+	'home'			 => 'Sarrera',
+	'local'			 => 'Lokala',
+	'discover'		 => 'Esploratu',
     'viewMyProfile'  => 'Ikusi nire profila',
     'myTimeline'     => 'Nire denboralerroa',
     'publicTimeline' => 'Denboralerro publikoa',

+ 1 - 1
resources/lang/id/auth.php

@@ -14,6 +14,6 @@ return [
     */
 
     'failed'   => 'Kredensial ini tidak cocok dengan data kami.',
-    'throttle' => 'Terlalu banyak percobaan login. COba lagi setelah :seconds detik.',
+    'throttle' => 'Terlalu banyak percobaan login. Coba lagi setelah :seconds detik.',
 
 ];

+ 1 - 1
resources/lang/id/profile.php

@@ -4,7 +4,7 @@ return [
   'emptyFollowers'        => 'User ini belum punya pengikut!',
   'emptyFollowing'        => 'User ini belum mengikuti siapapun!',
   'emptySaved'            => 'Kamu belum membuat posting!',
-  'savedWarning'          => 'Hanya kami yang bisa melihat posting kamu sendiri',
+  'savedWarning'          => 'Hanya kamu yang bisa melihat posting kamu sendiri',
   'privateProfileWarning' => 'Akun ini Privat',
   'alreadyFollow'         => 'Sudah mengikuti :username?',
   'loginToSeeProfile'     => 'untuk melihat foro dan videonya.',

+ 33 - 33
resources/lang/id/validation.php

@@ -31,7 +31,7 @@ return [
     'date'                 => ':attribute bukan berupa tanggal yang benar.',
     'date_format'          => ':attribute tidak sesuai dengan format :format.',
     'different'            => ':attribute dan :other harus berbeda.',
-    'digits'               => ':attribute haurs berisi :digits digit.',
+    'digits'               => ':attribute harus berisi :digits digit.',
     'digits_between'       => ':attribute harus antara :min dan :max digit.',
     'dimensions'           => ':attribute berisi dimensi gambar yang tidak benar.',
     'distinct'             => 'Bagian :attribute memiliki duplikasi.',
@@ -48,43 +48,43 @@ return [
     'ipv6'                 => ':attribute harus berupa alamat IPv6 yang benar.',
     'json'                 => ':attribute harus berupa string JSON yang benar.',
     'max'                  => [
-        'numeric' => 'The :attribute may not be greater than :max.',
-        'file'    => 'The :attribute may not be greater than :max kilobytes.',
-        'string'  => 'The :attribute may not be greater than :max characters.',
-        'array'   => 'The :attribute may not have more than :max items.',
+        'numeric' => ':attribute tidak boleh lebih dari :max.',
+        'file'    => ':attribute tidak boleh lebih dari :max kilobyte.',
+        'string'  => ':attribute tidak boleh lebih dari :max karakter.',
+        'array'   => ':attribute tidak boleh lebih dari :max item.',
     ],
-    'mimes'                => 'The :attribute must be a file of type: :values.',
-    'mimetypes'            => 'The :attribute must be a file of type: :values.',
+    'mimes'                => ':attribute harus berupa berkas: :values.',
+    'mimetypes'            => ':attribute harus berupa berkas: :values.',
     'min'                  => [
-        'numeric' => 'The :attribute must be at least :min.',
-        'file'    => 'The :attribute must be at least :min kilobytes.',
-        'string'  => 'The :attribute must be at least :min characters.',
-        'array'   => 'The :attribute must have at least :min items.',
+        'numeric' => ':attribute minimal harus :min.',
+        'file'    => ':attribute minimal harus :min kilobyte.',
+        'string'  => ':attribute minimal harus :min karakter.',
+        'array'   => ':attribute minimal harus berisi :min item.',
     ],
-    'not_in'               => 'The selected :attribute is invalid.',
-    'not_regex'            => 'The :attribute format is invalid.',
-    'numeric'              => 'The :attribute must be a number.',
-    'present'              => 'The :attribute field must be present.',
-    'regex'                => 'The :attribute format is invalid.',
-    'required'             => 'The :attribute field is required.',
-    'required_if'          => 'The :attribute field is required when :other is :value.',
-    'required_unless'      => 'The :attribute field is required unless :other is in :values.',
-    'required_with'        => 'The :attribute field is required when :values is present.',
-    'required_with_all'    => 'The :attribute field is required when :values is present.',
-    'required_without'     => 'The :attribute field is required when :values is not present.',
-    'required_without_all' => 'The :attribute field is required when none of :values are present.',
-    'same'                 => 'The :attribute and :other must match.',
+    'not_in'               => ':attribute yang dipilih tidak benar.',
+    'not_regex'            => 'Format :attribute tidak benar.',
+    'numeric'              => ':attribute harus berupa angka.',
+    'present'              => 'Bagian :attribute harus diisi.',
+    'regex'                => 'Format :attribute tidak benar.',
+    'required'             => 'Bagian :attribute harus diisi.',
+    'required_if'          => 'Bagian :attribute harus diisi jika :other :value.',
+    'required_unless'      => 'Bagian :attribute harus diisi kecuali jika :other :values.',
+    'required_with'        => 'Bagian :attribute harus diisi jika ada :values.',
+    'required_with_all'    => 'Bagian :attribute harus diisi jika ada :values.',
+    'required_without'     => 'Bagian :attribute harus diisi jika tidak ada :values.',
+    'required_without_all' => 'Bagian :attribute harus diisi jika tidak ada :values.',
+    'same'                 => ':attribute dan :other harus sama.',
     'size'                 => [
-        'numeric' => 'The :attribute must be :size.',
-        'file'    => 'The :attribute must be :size kilobytes.',
-        'string'  => 'The :attribute must be :size characters.',
-        'array'   => 'The :attribute must contain :size items.',
+        'numeric' => ':attribute harus :size.',
+        'file'    => ':attribute harus berukuran :size kilobyte.',
+        'string'  => ':attribute harus berisi :size karaker.',
+        'array'   => ':attribute harus berisi :size item.',
     ],
-    'string'               => 'The :attribute must be a string.',
-    'timezone'             => 'The :attribute must be a valid zone.',
-    'unique'               => 'The :attribute has already been taken.',
-    'uploaded'             => 'The :attribute failed to upload.',
-    'url'                  => 'The :attribute format is invalid.',
+    'string'               => ':attribute harus berupa string.',
+    'timezone'             => ':attribute harus berupa zona yang benar.',
+    'unique'               => ':attribute sudah digunakan.',
+    'uploaded'             => ':attribute gagal diunggah.',
+    'url'                  => 'Format :attribute tidak benar.',
     /*
     |--------------------------------------------------------------------------
     | Custom Validation Language Lines

+ 5 - 1
resources/lang/pl/navmenu.php

@@ -2,12 +2,16 @@
 
 return [
 
+    'search'         => 'Szukaj',
+	'home'           => 'Strona główna',
+	'local'	         => 'Lokalne',
+	'discover'       => 'Odkrywaj',
     'viewMyProfile'  => 'Pokaż mój profil',
     'myTimeline'     => 'Moja oś czasu',
     'publicTimeline' => 'Publiczna oś czasu',
     'remoteFollow'   => 'Zdalne śledzenie',
     'settings'       => 'Ustawienia',
-    'admin'          => 'Administrator',
+    'admin'          => 'Administracja',
     'logout'         => 'Wyloguj się',
     'directMessages' => 'Wiadomości bezpośrednie',
 

+ 1 - 0
resources/lang/pl/notification.php

@@ -6,5 +6,6 @@ return [
   'startedFollowingYou' => 'zaczął(-ęła) Cię obserwować.',
   'commented'           => 'skomentował(a) Twój wpis',
   'mentionedYou'        => 'wspomniał(a) o Tobie.',
+  'shared'				=> 'udostępnił(a) Twój wpis.',
 
 ];

+ 2 - 2
resources/lang/pl/passwords.php

@@ -15,8 +15,8 @@ return [
 
     'password' => 'Hasło musi składać się z przynajmniej 6 znaków i być równe powtórzonemu.',
     'reset'    => 'Twoje hasło zostało zresetowane!',
-    'sent'     => 'Wysłaliśmy Ci link resetujący hasło mailem!',
+    'sent'     => 'Jeżeli ten adres e-mail jest obecny w naszej bazie danych, otrzymasz wiadomość z odnośnikiem resetowania hasła w ciągu kilku minut. Jeżeli nie dostałeś(-aś) tego maila, sprawdź zawartość folderu Spam.',
     'token'    => 'This password reset token is invalid.',
-    'user'     => 'Nie znaleziono użytkownika z tym adresem e-mail.',
+    'user'     => 'Jeżeli ten adres e-mail jest obecny w naszej bazie danych, otrzymasz wiadomość z odnośnikiem resetowania hasła w ciągu kilku minut. Jeżeli nie dostałeś(-aś) tego maila, sprawdź zawartość folderu Spam.',
 
 ];

+ 8 - 5
resources/lang/pl/profile.php

@@ -1,9 +1,12 @@
 <?php
 
 return [
-  'emptyTimeline'  => 'Ten użytkownik nie opublikował jeszcze niczego!',
-  'emptyFollowers' => 'Nikt nie obserwuje tego użytkownika!',
-  'emptyFollowing' => 'Ten użytkownik nie obserwuje nikogo!',
-  'emptySaved'     => 'Nie zapisałeś(-aś) jeszcze niczego!',
-  'savedWarning'   => 'Tylko Ty widzisz to, co zapisałeś(-aś)',
+  'emptyTimeline'         => 'Ten użytkownik nie opublikował jeszcze niczego!',
+  'emptyFollowers'        => 'Nikt nie obserwuje tego użytkownika!',
+  'emptyFollowing'        => 'Ten użytkownik nie obserwuje nikogo!',
+  'emptySaved'            => 'Nie zapisałeś(-aś) jeszcze niczego!',
+  'savedWarning'          => 'Tylko Ty widzisz to, co zapisałeś(-aś)',
+  'privateProfileWarning' => 'To konto jest prywatne',
+  'alreadyFollow'         => 'Już obserwujesz :username?',
+  'loginToSeeProfile'     => 'aby zobaczyć zdjęcia i filmy tego użytkownika.',
 ];

+ 16 - 0
resources/lang/pl/site.php

@@ -0,0 +1,16 @@
+<?php
+
+return [
+
+	'about'			=> 'O nas',
+	'help'			=> 'Pomoc',
+	'language'		=> 'Język',
+	'fediverse'		=> 'Fediwersum',
+	'opensource'	=> 'Otwarte źródło',
+	'terms'			=> 'Zasady',
+	'privacy'		=> 'Prywatność',
+	'l10nWip'		=> 'Wciąż pracujemy nad obsługą wielu języków',
+	'currentLocale' => 'Obecny język',
+	'selectLocale'  => 'Wybierz jeden z dostępnych języków',
+
+];

+ 5 - 5
resources/views/admin/settings/system.blade.php

@@ -32,8 +32,8 @@
           <p class="font-weight-ultralight h2 mb-0 text-truncate">{{$sys['php']}}</p>
         </div>
         <div class="card-footer font-weight-bold py-0 text-center bg-white">PHP</div>
-      </div>    
-    </div>    
+      </div>
+    </div>
   	<div class="col-12 col-md-3">
   		<div class="card mb-3 border-left-blue">
   			<div class="card-body text-center">
@@ -48,9 +48,9 @@
   <div>
     <div class="card-loading text-center">
       <div class="spinner-border" role="status">
-        <span class="sr-only">Loading...</span>
+        <span class="sr-only">Loading</span>
       </div>
-    </div>  
+    </div>
     <div class="card card-release d-none">
       <div class="card-body">
         <div class="d-flex justify-content-between align-items-center">
@@ -112,4 +112,4 @@ $(document).ready(function() {
 
 });
 </script>
-@endpush
+@endpush

+ 1 - 1
resources/views/site/language.blade.php

@@ -11,7 +11,7 @@
   <p class="font-weight-light">{{__('site.selectLocale')}}:</p>
   <ul class="list-group">
     @foreach(App\Util\Localization\Localization::languages() as $lang)
-    <a class="list-group-item font-weight-bold" href="/i/lang/{{$lang}}">{{locale_get_display_language($lang)}}</a>
+    <a class="list-group-item font-weight-bold" href="/i/lang/{{$lang}}">{{locale_get_display_language($lang, $lang)}}</a>
     @endforeach
   </ul>
 @endsection

+ 14 - 14
resources/views/status/compose.blade.php

@@ -13,7 +13,7 @@
                 <span class="font-weight-bold">Compose</span>
               </p>
             </div>
-          </div>   
+          </div>
         </span>
         <div>
           <button class="btn btn-link text-muted" type="button" id="composeMenu">
@@ -23,7 +23,7 @@
       </div>
       <div class="card-body bg-light">
         <div class="composeLoader d-none text-center">
-          <div class="lds-ring"><div></div><div></div><div></div><div></div></div> 
+          <div class="lds-ring"><div></div><div></div><div></div><div></div></div>
         </div>
         <div class="d-none preview-pagination">
           <div class="d-flex justify-content-between align-items-center">
@@ -37,14 +37,14 @@
           </div>
           <div class="preview-thumbs">
             <div class="d-flex justify-content-center" style="overflow-x: auto;">
-              
+
             </div>
           </div>
         </div>
         <div class="preview row"></div>
         <div class="preview-meta mb-4 d-none form-inline">
           <div class="form-group">
-            
+
             <div class="btn-group mr-3" role="group" aria-label="First group">
               <button type="button" class="btn btn-outline-secondary btn-sm py-1" id="cw" data-toggle="tooltip" data-placement="bottom" title="A content warning or nsfw warning is required for certain content."><i class="far fa-eye d-none d-md-block"></i> CW/NSFW</button>
               <button type="button" class="btn btn-outline-secondary btn-sm py-1" id="alt"><i class="fab fa-accessible-icon d-none d-md-block"></i> Media Description</button>
@@ -83,33 +83,33 @@
                 <div class="row">
                   <div class="col-12 col-sm-2 px-0 text-center">
                     <i class="fas fa-globe"></i>
-                  </div> 
+                  </div>
                   <div class="col-12 col-sm-10 pl-2">
                     <p class="font-weight-bold mb-0">Public</p>
                     <p class="small mb-0">Anyone can see</p>
-                  </div> 
+                  </div>
                 </div>
               </a>
               <a class="dropdown-item" href="#" data-id="private" data-title="Followers Only">
                 <div class="row">
                   <div class="col-12 col-sm-2 px-0 text-center">
                     <i class="fas fa-lock"></i>
-                  </div> 
+                  </div>
                   <div class="col-12 col-sm-10 pl-2">
                     <p class="font-weight-bold mb-0">Followers Only</p>
                     <p class="small mb-0">Only followers can see</p>
-                  </div> 
+                  </div>
                 </div>
               </a>
               {{-- <a class="dropdown-item" href="#" data-id="direct" data-title="Direct Message">
                 <div class="row">
                   <div class="col-12 col-sm-2 px-0 text-center">
                     <i class="fas fa-envelope"></i>
-                  </div> 
+                  </div>
                   <div class="col-12 col-sm-10 pl-2">
                     <p class="font-weight-bold mb-0">Direct Message</p>
                     <p class="small mb-0">Recipients only</p>
-                  </div> 
+                  </div>
                 </div>
               </a> --}}
             </div>
@@ -280,7 +280,7 @@ pixelfed.uploader.loadMeta = function() {
     if(pixelfed.uploader.ids.length > 1) {
       $('.next').removeClass('text-light');
     }
-  } 
+  }
   if(cursor > 1) {
       $('.prev').removeClass('text-light');
     if(pixelfed.uploader.ids.length > cursor) {
@@ -490,14 +490,14 @@ $('.visibility .dropdown-item').on('click', function(e) {
   });
   el.addClass('active');
   $('#visibility').text(el.data('title'));
-  pixelfed.uploader.visibility = el.data('id'); 
+  pixelfed.uploader.visibility = el.data('id');
 });
 
 $('#composeMenu').on('click', function(e) {
   e.preventDefault();
   swal(
     'Experimental Feature',
-    'We\'re still working on this feature.',
+    'Were still working on this feature.',
     'info'
   );
 });
@@ -526,4 +526,4 @@ $('#composeMenu').on('click', function(e) {
 }); --}}
 
 </script>
-@endpush
+@endpush

+ 2 - 2
resources/views/status/show/sidebar.blade.php

@@ -111,7 +111,7 @@
       @csrf
       <input type="hidden" name="item" value="{{$status->id}}">
 
-      <input class="form-control" name="comment" placeholder="Add a comment..." autocomplete="off">
+      <input class="form-control" name="comment" placeholder="Add a comment" autocomplete="off">
     </form>
   </div>
-</div>
+</div>