 7199e6f4e0
			
		
	
	7199e6f4e0
	
	
	
		
			
			* Update reaction.vue
* fix  bug
* wip
* wip
* wjio
* wip
* Revert "wip"
This reverts commit e427f2160a.
* wip
* wip
* wip
* Update init.ts
* Update drive-window.vue
* wip
* wip
* Use PascalCase for components
* Use PascalCase for components
* update dep
* wip
* wip
* wip
* Update init.ts
* wip
* Update paging.ts
* Update test.vue
* watch deep
* wip
* lint
* wip
* wip
* wip
* wip
* wiop
* wip
* Update webpack.config.ts
* alllow null poll
* wip
* wip
* wip
* wiop
* UI redesign & refactor (#6714)
* wip
* wip
* wip
* wip
* wip
* Update drive.vue
* Update word-mute.vue
* wip
* wip
* wip
* clean up
* wip
* Update default.vue
* wip
* Update notes.vue
* Update mfm.ts
* Update index.home.vue
* Update post-form.vue
* Update post-form-attaches.vue
* wip
* Update post-form.vue
* Update sidebar.vue
* wip
* wip
* Update index.vue
* wip
* Update default.vue
* Update index.vue
* Update index.vue
* wip
* Update post-form-attaches.vue
* Update note.vue
* wip
* clean up
* Update notes.vue
* wip
* wip
* Update ja-JP.yml
* wip
* wip
* Update index.vue
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* Update default.vue
* wip
* Update _dark.json5
* wip
* wip
* wip
* clean up
* wip
* wip
* Update index.vue
* Update test.vue
* wip
* wip
* fix
* wip
* wip
* wip
* wip
* clena yop
* wip
* wip
* Update store.ts
* Update messaging-room.vue
* Update default.widgets.vue
* fix
* wip
* wip
* Update modal.vue
* wip
* Update os.ts
* Update os.ts
* Update deck.vue
* Update init.ts
* wip
* Update ja-JP.yml
* v-sizeは単にwindowのresizeを監視するだけで良いかもしれない
* Update modal.vue
* wip
* Update tooltip.ts
* wip
* wip
* wip
* wip
* wip
* Update image-viewer.vue
* wip
* wip
* Update style.scss
* Update style.scss
* Update visitor.vue
* wip
* Update init.ts
* Update init.ts
* wip
* wip
* Update visitor.vue
* Update visitor.vue
* Update visitor.vue
* Update visitor.vue
* wip
* wip
* Update modal.vue
* Update header.vue
* Update menu.vue
* Update about.vue
* Update about-misskey.vue
* wip
* wip
* Update visitor.vue
* Update tooltip.ts
* wip
* Update drive.vue
* wip
* Update style.scss
* Update header.vue
* wip
* wip
* Update users.user.vue
* Update announcements.vue
* wip
* wip
* wip
* Update emojis.vue
* wip
* Update emojis.vue
* Update style.scss
* Update users.vue
* wip
* Update style.scss
* wip
* Update welcome.entrance.vue
* Update radio.vue
* Update size.ts
* Update emoji-edit-dialog.vue
* wip
* Update emojis.vue
* wip
* Update emojis.vue
* Update emojis.vue
* Update emojis.vue
* wip
* wip
* wip
* wip
* Update file-dialog.vue
* wip
* wip
* Update token-generate-window.vue
* Update notification-setting-window.vue
* wip
* wip
* Update _error_.vue
* Update ja-JP.yml
* wip
* wip
* Update store.ts
* Update emojis.vue
* Update emojis.vue
* Update emojis.vue
* Update announcements.vue
* Update store.ts
* wip
* Update page-editor.vue
* wip
* wip
* Update modal.vue
* wip
* Update select-file.ts
* Update timeline.vue
* Update emojis.vue
* Update os.ts
* wip
* Update user-select.vue
* Update mfm.ts
* Update get-file-info.ts
* Update drive.vue
* Update init.ts
* Update mfm.ts
* wip
* wip
* Update window.vue
* Update note.vue
* wip
* wip
* Update user-info.vue
* wip
* wip
* wip
* wip
* wip
* Update header.vue
* Update header.vue
* wip
* Update explore.vue
* wip
* wip
* wip
* Update webpack.config.ts
* wip
* wip
* wip
* wip
* wip
* wip
* Update autocomplete.ts
* wip
* wip
* wip
* Update toast.vue
* wip
* Update post-form-dialog.vue
* wip
* wip
* wip
* wip
* wip
* Update users.vue
* wip
* Update explore.vue
* wip
* wip
* wip
* Update package.json
* wip
* Update icon-dialog.vue
* wip
* wip
* Update user-preview.ts
* wip
* wip
* wip
* wip
* wip
* Update instance.vue
* Update user-name.vue
* Update federation.vue
* Update instance.vue
* wip
* wip
* Update tag.vue
* wip
* wip
* wip
* wip
* wip
* Update instance.vue
* wip
* Update os.ts
* Update os.ts
* wip
* wip
* wip
* Update router.ts
* wip
* Update init.ts
* Update note.vue
* Update messages.vue
* wip
* wip
* wip
* wip
* wip
* google
* wip
* wip
* wip
* wip
* Update theme-editor.vue
* wip
* wip
* Update room.vue
* Update channel-editor.vue
* wip
* Update window.vue
* Update window.vue
* wip
* Update window.vue
* Update window.vue
* wip
* Update menu.vue
* wip
* wip
* wip
* wip
* Update messaging-room.vue
* wip
* Update post-form.vue
* Update default.widgets.vue
* Update window.vue
* wip
		
	
		
			
				
	
	
		
			136 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			136 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
| <transition-group class="sqadhkmv _list_" name="list" tag="div" :data-direction="direction" :data-reversed="reversed ? 'true' : 'false'">
 | |
| 	<template v-for="(item, i) in items">
 | |
| 		<slot :item="item"></slot>
 | |
| 		<div class="separator" v-if="showDate(i, item)" :key="item.id + '_date'">
 | |
| 			<p class="date">
 | |
| 				<span><Fa class="icon" :icon="faAngleUp"/>{{ getDateText(item.createdAt) }}</span>
 | |
| 				<span>{{ getDateText(items[i + 1].createdAt) }}<Fa class="icon" :icon="faAngleDown"/></span>
 | |
| 			</p>
 | |
| 		</div>
 | |
| 	</template>
 | |
| </transition-group>
 | |
| </template>
 | |
| 
 | |
| <script lang="ts">
 | |
| import { defineComponent } from 'vue';
 | |
| import { faAngleUp, faAngleDown } from '@fortawesome/free-solid-svg-icons';
 | |
| 
 | |
| export default defineComponent({
 | |
| 	props: {
 | |
| 		items: {
 | |
| 			type: Array,
 | |
| 			required: true,
 | |
| 		},
 | |
| 		direction: {
 | |
| 			type: String,
 | |
| 			required: false,
 | |
| 			default: 'down'
 | |
| 		},
 | |
| 		reversed: {
 | |
| 			type: Boolean,
 | |
| 			required: false,
 | |
| 			default: false
 | |
| 		}
 | |
| 	},
 | |
| 
 | |
| 	data() {
 | |
| 		return {
 | |
| 			faAngleUp, faAngleDown
 | |
| 		};
 | |
| 	},
 | |
| 
 | |
| 	methods: {
 | |
| 		getDateText(time: string) {
 | |
| 			const date = new Date(time).getDate();
 | |
| 			const month = new Date(time).getMonth() + 1;
 | |
| 			return this.$t('monthAndDay', {
 | |
| 				month: month.toString(),
 | |
| 				day: date.toString()
 | |
| 			});
 | |
| 		},
 | |
| 
 | |
| 		showDate(i, item) {
 | |
| 			return (
 | |
| 				i != this.items.length - 1 &&
 | |
| 				new Date(item.createdAt).getDate() != new Date(this.items[i + 1].createdAt).getDate() &&
 | |
| 				!item._prId_ &&
 | |
| 				!this.items[i + 1]._prId_ &&
 | |
| 				!item._featuredId_ &&
 | |
| 				!this.items[i + 1]._featuredId_);
 | |
| 		},
 | |
| 
 | |
| 		focus() {
 | |
| 			this.$slots.default[0].elm.focus();
 | |
| 		}
 | |
| 	}
 | |
| });
 | |
| </script>
 | |
| 
 | |
| <style lang="scss">
 | |
| .sqadhkmv {
 | |
| 	> *:not(:last-child) {
 | |
| 		margin-bottom: var(--margin);
 | |
| 	}
 | |
| 
 | |
| 	> .list-move {
 | |
| 		transition: transform 0.7s cubic-bezier(0.23, 1, 0.32, 1);
 | |
| 	}
 | |
| 
 | |
| 	> .list-enter-active {
 | |
| 		transition: transform 0.7s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.7s cubic-bezier(0.23, 1, 0.32, 1);
 | |
| 	}
 | |
| 
 | |
| 	&[data-direction="up"] {
 | |
| 		> .list-enter-from {
 | |
| 			opacity: 0;
 | |
| 			transform: translateY(64px);
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	&[data-direction="down"] {
 | |
| 		> .list-enter-from {
 | |
| 			opacity: 0;
 | |
| 			transform: translateY(-64px);
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| </style>
 | |
| 
 | |
| <style lang="scss" scoped>
 | |
| .sqadhkmv {
 | |
| 	> .separator {
 | |
| 		text-align: center;
 | |
| 
 | |
| 		> .date {
 | |
| 			display: inline-block;
 | |
| 			position: relative;
 | |
| 			margin: 0;
 | |
| 			padding: 0 16px;
 | |
| 			line-height: 32px;
 | |
| 			text-align: center;
 | |
| 			font-size: 12px;
 | |
| 			color: var(--dateLabelFg);
 | |
| 
 | |
| 			> span {
 | |
| 				&:first-child {
 | |
| 					margin-right: 8px;
 | |
| 
 | |
| 					> .icon {
 | |
| 						margin-right: 8px;
 | |
| 					}
 | |
| 				}
 | |
| 
 | |
| 				&:last-child {
 | |
| 					margin-left: 8px;
 | |
| 
 | |
| 					> .icon {
 | |
| 						margin-left: 8px;
 | |
| 					}
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| </style>
 |