]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blobdiff - client/src/app/shared/shared.module.ts
Merge branch 'release/2.2.0' into develop
[github/Chocobozzz/PeerTube.git] / client / src / app / shared / shared.module.ts
index eb57a2fff0fc6db07c5367d9006bd8feea2399fa..813f766723b22ac9ca4f11d4c35792f46b2edf53 100644 (file)
@@ -1,33 +1,30 @@
+import { BytesPipe, KeysPipe, NgPipesModule } from 'ngx-pipes'
+import { SharedModule as PrimeSharedModule } from 'primeng/api'
+import { InputMaskModule } from 'primeng/inputmask'
+import { InputSwitchModule } from 'primeng/inputswitch'
+import { MultiSelectModule } from 'primeng/multiselect'
+import { ClipboardModule } from '@angular/cdk/clipboard'
 import { CommonModule } from '@angular/common'
 import { HttpClientModule } from '@angular/common/http'
 import { NgModule } from '@angular/core'
 import { FormsModule, ReactiveFormsModule } from '@angular/forms'
 import { RouterModule } from '@angular/router'
-import { MarkdownTextareaComponent } from '@app/shared/forms/markdown-textarea.component'
-import { HelpComponent } from '@app/shared/misc/help.component'
-import { InfiniteScrollerDirective } from '@app/shared/video/infinite-scroller.directive'
-
-import { BytesPipe, KeysPipe, NgPipesModule } from 'ngx-pipes'
-import { SharedModule as PrimeSharedModule } from 'primeng/components/common/shared'
-
-import { AUTH_INTERCEPTOR_PROVIDER } from './auth'
-import { ButtonComponent } from './buttons/button.component'
-import { DeleteButtonComponent } from './buttons/delete-button.component'
-import { EditButtonComponent } from './buttons/edit-button.component'
-import { LoaderComponent } from './misc/loader.component'
-import { RestExtractor, RestService } from './rest'
-import { UserService } from './users'
-import { VideoAbuseService } from './video-abuse'
-import { VideoBlacklistService } from './video-blacklist'
-import { VideoOwnershipService } from './video-ownership'
-import { VideoMiniatureComponent } from './video/video-miniature.component'
-import { FeedComponent } from './video/feed.component'
-import { VideoThumbnailComponent } from './video/video-thumbnail.component'
-import { VideoService } from './video/video.service'
+import { BatchDomainsValidatorsService } from '@app/+admin/config/shared/batch-domains-validators.service'
+import { MyAccountInterfaceSettingsComponent } from '@app/+my-account/my-account-settings/my-account-interface'
+import { MyAccountVideoSettingsComponent } from '@app/+my-account/my-account-settings/my-account-video-settings'
+import { ActorAvatarInfoComponent } from '@app/+my-account/shared/actor-avatar-info.component'
 import { AccountService } from '@app/shared/account/account.service'
-import { VideoChannelService } from '@app/shared/video-channel/video-channel.service'
-import { I18n } from '@ngx-translate/i18n-polyfill'
-import { FormValidatorService } from '@app/shared/forms/form-validators/form-validator.service'
+import { FromNowPipe } from '@app/shared/angular/from-now.pipe'
+import { HighlightPipe } from '@app/shared/angular/highlight.pipe'
+import { NumberFormatterPipe } from '@app/shared/angular/number-formatter.pipe'
+import { ObjectLengthPipe } from '@app/shared/angular/object-length.pipe'
+import { PeerTubeTemplateDirective } from '@app/shared/angular/peertube-template.directive'
+import { VideoDurationPipe } from '@app/shared/angular/video-duration-formatter.pipe'
+import { BlocklistService } from '@app/shared/blocklist'
+import { ActionDropdownComponent } from '@app/shared/buttons/action-dropdown.component'
+import { AvatarComponent } from '@app/shared/channel/avatar.component'
+import { ConfirmComponent } from '@app/shared/confirm/confirm.component'
+import { DateToggleComponent } from '@app/shared/date/date-toggle.component'
 import {
   CustomConfigValidatorsService,
   InstanceValidatorsService,
@@ -45,54 +42,72 @@ import {
   VideoPlaylistValidatorsService,
   VideoValidatorsService
 } from '@app/shared/forms'
-import { I18nPrimengCalendarService } from '@app/shared/i18n/i18n-primeng-calendar'
-import { InputMaskModule } from 'primeng/inputmask'
-import { ScreenService } from '@app/shared/misc/screen.service'
+import { FormValidatorService } from '@app/shared/forms/form-validators/form-validator.service'
 import { VideoCaptionsValidatorsService } from '@app/shared/forms/form-validators/video-captions-validators.service'
-import { VideoCaptionService } from '@app/shared/video-caption'
+import { InputReadonlyCopyComponent } from '@app/shared/forms/input-readonly-copy.component'
+import { MarkdownTextareaComponent } from '@app/shared/forms/markdown-textarea.component'
 import { PeertubeCheckboxComponent } from '@app/shared/forms/peertube-checkbox.component'
-import { VideoImportService } from '@app/shared/video-import/video-import.service'
-import { ActionDropdownComponent } from '@app/shared/buttons/action-dropdown.component'
-import {
-  NgbCollapseModule,
-  NgbDropdownModule,
-  NgbModalModule,
-  NgbPopoverModule,
-  NgbTabsetModule,
-  NgbTooltipModule
-} from '@ng-bootstrap/ng-bootstrap'
-import { RemoteSubscribeComponent, SubscribeButtonComponent, UserSubscriptionService } from '@app/shared/user-subscription'
+import { TimestampInputComponent } from '@app/shared/forms/timestamp-input.component'
+import { I18nPrimengCalendarService } from '@app/shared/i18n/i18n-primeng-calendar'
+import { GlobalIconComponent } from '@app/shared/images/global-icon.component'
+import { PreviewUploadComponent } from '@app/shared/images/preview-upload.component'
+import { FeatureBooleanComponent } from '@app/shared/instance/feature-boolean.component'
+import { FollowService } from '@app/shared/instance/follow.service'
 import { InstanceFeaturesTableComponent } from '@app/shared/instance/instance-features-table.component'
-import { OverviewService } from '@app/shared/overview'
+import { InstanceStatisticsComponent } from '@app/shared/instance/instance-statistics.component'
+import { InstanceService } from '@app/shared/instance/instance.service'
+import { TopMenuDropdownComponent } from '@app/shared/menu/top-menu-dropdown.component'
+import { HelpComponent } from '@app/shared/misc/help.component'
+import { ListOverflowComponent } from '@app/shared/misc/list-overflow.component'
+import { ScreenService } from '@app/shared/misc/screen.service'
+import { SmallLoaderComponent } from '@app/shared/misc/small-loader.component'
+import { LocalStorageService, SessionStorageService } from '@app/shared/misc/storage.service'
 import { UserBanModalComponent } from '@app/shared/moderation'
 import { UserModerationDropdownComponent } from '@app/shared/moderation/user-moderation-dropdown.component'
-import { BlocklistService } from '@app/shared/blocklist'
-import { TopMenuDropdownComponent } from '@app/shared/menu/top-menu-dropdown.component'
+import { OverviewService } from '@app/shared/overview'
+import { HtmlRendererService, LinkifierService, MarkdownService } from '@app/shared/renderer'
+import { RemoteSubscribeComponent, SubscribeButtonComponent, UserSubscriptionService } from '@app/shared/user-subscription'
 import { UserHistoryService } from '@app/shared/users/user-history.service'
 import { UserNotificationService } from '@app/shared/users/user-notification.service'
 import { UserNotificationsComponent } from '@app/shared/users/user-notifications.component'
-import { InstanceService } from '@app/shared/instance/instance.service'
-import { HtmlRendererService, LinkifierService, MarkdownService } from '@app/shared/renderer'
-import { ConfirmComponent } from '@app/shared/confirm/confirm.component'
-import { SmallLoaderComponent } from '@app/shared/misc/small-loader.component'
-import { VideoPlaylistService } from '@app/shared/video-playlist/video-playlist.service'
-import { PreviewUploadComponent } from '@app/shared/images/preview-upload.component'
-import { GlobalIconComponent } from '@app/shared/images/global-icon.component'
-import { VideoPlaylistMiniatureComponent } from '@app/shared/video-playlist/video-playlist-miniature.component'
+import { VideoCaptionService } from '@app/shared/video-caption'
+import { VideoChannelService } from '@app/shared/video-channel/video-channel.service'
+import { VideoImportService } from '@app/shared/video-import/video-import.service'
 import { VideoAddToPlaylistComponent } from '@app/shared/video-playlist/video-add-to-playlist.component'
-import { TimestampInputComponent } from '@app/shared/forms/timestamp-input.component'
 import { VideoPlaylistElementMiniatureComponent } from '@app/shared/video-playlist/video-playlist-element-miniature.component'
-import { VideosSelectionComponent } from '@app/shared/video/videos-selection.component'
-import { NumberFormatterPipe } from '@app/shared/angular/number-formatter.pipe'
-import { ObjectLengthPipe } from '@app/shared/angular/object-length.pipe'
-import { FromNowPipe } from '@app/shared/angular/from-now.pipe'
-import { PeerTubeTemplateDirective } from '@app/shared/angular/peertube-template.directive'
-import { VideoActionsDropdownComponent } from '@app/shared/video/video-actions-dropdown.component'
+import { VideoPlaylistMiniatureComponent } from '@app/shared/video-playlist/video-playlist-miniature.component'
+import { VideoPlaylistService } from '@app/shared/video-playlist/video-playlist.service'
+import { InfiniteScrollerDirective } from '@app/shared/video/infinite-scroller.directive'
 import { VideoBlacklistComponent } from '@app/shared/video/modals/video-blacklist.component'
 import { VideoDownloadComponent } from '@app/shared/video/modals/video-download.component'
 import { VideoReportComponent } from '@app/shared/video/modals/video-report.component'
-import { ClipboardModule } from 'ngx-clipboard'
-import { FollowService } from '@app/shared/instance/follow.service'
+import { RedundancyService } from '@app/shared/video/redundancy.service'
+import { VideoActionsDropdownComponent } from '@app/shared/video/video-actions-dropdown.component'
+import { VideosSelectionComponent } from '@app/shared/video/videos-selection.component'
+import {
+  NgbCollapseModule,
+  NgbDropdownModule,
+  NgbModalModule,
+  NgbNavModule,
+  NgbPopoverModule,
+  NgbTooltipModule
+} from '@ng-bootstrap/ng-bootstrap'
+import { I18n } from '@ngx-translate/i18n-polyfill'
+import { AUTH_INTERCEPTOR_PROVIDER } from './auth'
+import { BulkService } from './bulk/bulk.service'
+import { ButtonComponent } from './buttons/button.component'
+import { DeleteButtonComponent } from './buttons/delete-button.component'
+import { EditButtonComponent } from './buttons/edit-button.component'
+import { LoaderComponent } from './misc/loader.component'
+import { RestExtractor, RestService } from './rest'
+import { UserService } from './users'
+import { VideoAbuseService } from './video-abuse'
+import { VideoBlacklistService } from './video-blacklist'
+import { VideoOwnershipService } from './video-ownership'
+import { FeedComponent } from './video/feed.component'
+import { VideoMiniatureComponent } from './video/video-miniature.component'
+import { VideoThumbnailComponent } from './video/video-thumbnail.component'
+import { VideoService } from './video/video.service'
 
 @NgModule({
   imports: [
@@ -105,7 +120,7 @@ import { FollowService } from '@app/shared/instance/follow.service'
     NgbDropdownModule,
     NgbModalModule,
     NgbPopoverModule,
-    NgbTabsetModule,
+    NgbNavModule,
     NgbTooltipModule,
     NgbCollapseModule,
 
@@ -113,7 +128,9 @@ import { FollowService } from '@app/shared/instance/follow.service'
 
     PrimeSharedModule,
     InputMaskModule,
-    NgPipesModule
+    NgPipesModule,
+    MultiSelectModule,
+    InputSwitchModule
   ],
 
   declarations: [
@@ -141,29 +158,41 @@ import { FollowService } from '@app/shared/instance/follow.service'
     NumberFormatterPipe,
     ObjectLengthPipe,
     FromNowPipe,
+    HighlightPipe,
     PeerTubeTemplateDirective,
+    VideoDurationPipe,
 
     ActionDropdownComponent,
     MarkdownTextareaComponent,
     InfiniteScrollerDirective,
     TextareaAutoResizeDirective,
     HelpComponent,
+    ListOverflowComponent,
 
     ReactiveFileComponent,
     PeertubeCheckboxComponent,
     TimestampInputComponent,
+    InputReadonlyCopyComponent,
 
+    AvatarComponent,
     SubscribeButtonComponent,
     RemoteSubscribeComponent,
     InstanceFeaturesTableComponent,
+    InstanceStatisticsComponent,
+    FeatureBooleanComponent,
     UserBanModalComponent,
     UserModerationDropdownComponent,
     TopMenuDropdownComponent,
     UserNotificationsComponent,
     ConfirmComponent,
+    DateToggleComponent,
 
     GlobalIconComponent,
-    PreviewUploadComponent
+    PreviewUploadComponent,
+
+    MyAccountVideoSettingsComponent,
+    MyAccountInterfaceSettingsComponent,
+    ActorAvatarInfoComponent
   ],
 
   exports: [
@@ -176,7 +205,7 @@ import { FollowService } from '@app/shared/instance/follow.service'
     NgbDropdownModule,
     NgbModalModule,
     NgbPopoverModule,
-    NgbTabsetModule,
+    NgbNavModule,
     NgbTooltipModule,
     NgbCollapseModule,
 
@@ -186,6 +215,7 @@ import { FollowService } from '@app/shared/instance/follow.service'
     InputMaskModule,
     BytesPipe,
     KeysPipe,
+    MultiSelectModule,
 
     LoaderComponent,
     SmallLoaderComponent,
@@ -213,19 +243,24 @@ import { FollowService } from '@app/shared/instance/follow.service'
     InfiniteScrollerDirective,
     TextareaAutoResizeDirective,
     HelpComponent,
+    ListOverflowComponent,
+    InputReadonlyCopyComponent,
 
     ReactiveFileComponent,
     PeertubeCheckboxComponent,
     TimestampInputComponent,
 
+    AvatarComponent,
     SubscribeButtonComponent,
     RemoteSubscribeComponent,
     InstanceFeaturesTableComponent,
+    InstanceStatisticsComponent,
     UserBanModalComponent,
     UserModerationDropdownComponent,
     TopMenuDropdownComponent,
     UserNotificationsComponent,
     ConfirmComponent,
+    DateToggleComponent,
 
     GlobalIconComponent,
     PreviewUploadComponent,
@@ -233,7 +268,13 @@ import { FollowService } from '@app/shared/instance/follow.service'
     NumberFormatterPipe,
     ObjectLengthPipe,
     FromNowPipe,
-    PeerTubeTemplateDirective
+    HighlightPipe,
+    PeerTubeTemplateDirective,
+    VideoDurationPipe,
+
+    MyAccountVideoSettingsComponent,
+    MyAccountInterfaceSettingsComponent,
+    ActorAvatarInfoComponent
   ],
 
   providers: [
@@ -257,6 +298,7 @@ import { FollowService } from '@app/shared/instance/follow.service'
     LoginValidatorsService,
     ResetPasswordValidatorsService,
     UserValidatorsService,
+    BatchDomainsValidatorsService,
     VideoPlaylistValidatorsService,
     VideoAbuseValidatorsService,
     VideoChannelValidatorsService,
@@ -271,6 +313,7 @@ import { FollowService } from '@app/shared/instance/follow.service'
     BlocklistService,
     UserHistoryService,
     InstanceService,
+    BulkService,
 
     MarkdownService,
     LinkifierService,
@@ -278,10 +321,12 @@ import { FollowService } from '@app/shared/instance/follow.service'
 
     I18nPrimengCalendarService,
     ScreenService,
+    LocalStorageService, SessionStorageService,
 
     UserNotificationService,
 
     FollowService,
+    RedundancyService,
 
     I18n
   ]