mirror of
https://github.com/Alfresco/alfresco-content-app.git
synced 2025-07-24 17:31:52 +00:00
[ACA-2182] ADF 3.3.0 alpha (#1126)
* upgrade to latest adf 3.0.0 alpha * use ADF share dialog * [ACA-2069] make sure toggles have the right color * raise error popups for shared links * update test * use date only for sharing * [ACA-2069] small improvement - make sure toggles have the right color * remove old share dialog * move toggle-shared component to common module
This commit is contained in:
59
package-lock.json
generated
59
package-lock.json
generated
@@ -5,25 +5,25 @@
|
|||||||
"requires": true,
|
"requires": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@alfresco/adf-content-services": {
|
"@alfresco/adf-content-services": {
|
||||||
"version": "3.3.0-8a2a71d60be3f2b3dd0173f6a51d8075241e7203",
|
"version": "3.3.0-626bb01bf7d26e693a4947982d20695c45794503",
|
||||||
"resolved": "https://registry.npmjs.org/@alfresco/adf-content-services/-/adf-content-services-3.3.0-8a2a71d60be3f2b3dd0173f6a51d8075241e7203.tgz",
|
"resolved": "https://registry.npmjs.org/@alfresco/adf-content-services/-/adf-content-services-3.3.0-626bb01bf7d26e693a4947982d20695c45794503.tgz",
|
||||||
"integrity": "sha512-QPbvSfCG/rOLVcwzAw2IWDrGe8fgzK209zgQwgOiGzmHhtY2Ru3GF2in+rlG+VK/qZvErv9x6nT0BVEmlc2SoQ==",
|
"integrity": "sha512-2Y2VPvSxXxlhBJoKLQo9NGy0r9paAnAweXIi9EiuZctLNFDAzG2UVDb93gGhtcAi+ulH5xyoRu/9mDIpE4e5ew==",
|
||||||
"requires": {
|
"requires": {
|
||||||
"tslib": "^1.9.0"
|
"tslib": "^1.9.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"@alfresco/adf-core": {
|
"@alfresco/adf-core": {
|
||||||
"version": "3.3.0-8a2a71d60be3f2b3dd0173f6a51d8075241e7203",
|
"version": "3.3.0-626bb01bf7d26e693a4947982d20695c45794503",
|
||||||
"resolved": "https://registry.npmjs.org/@alfresco/adf-core/-/adf-core-3.3.0-8a2a71d60be3f2b3dd0173f6a51d8075241e7203.tgz",
|
"resolved": "https://registry.npmjs.org/@alfresco/adf-core/-/adf-core-3.3.0-626bb01bf7d26e693a4947982d20695c45794503.tgz",
|
||||||
"integrity": "sha512-BMqpwOyBAXKL9atGa4oNM+8KsQ/twiFiSJFTvi0tKbd+EhxaKINMv9/smnIE1D54hGzBHca/dBua4kT1FWbQwg==",
|
"integrity": "sha512-mEL+/0udJ1R4vnb8UK6QsdLRd/PPMo1q1esTYUAu0in0TR6PesqBiTMAtmj5sVV40IIeW7u7kD/TpZNBRDlxrg==",
|
||||||
"requires": {
|
"requires": {
|
||||||
"tslib": "^1.9.0"
|
"tslib": "^1.9.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"@alfresco/adf-extensions": {
|
"@alfresco/adf-extensions": {
|
||||||
"version": "3.3.0-8a2a71d60be3f2b3dd0173f6a51d8075241e7203",
|
"version": "3.3.0-626bb01bf7d26e693a4947982d20695c45794503",
|
||||||
"resolved": "https://registry.npmjs.org/@alfresco/adf-extensions/-/adf-extensions-3.3.0-8a2a71d60be3f2b3dd0173f6a51d8075241e7203.tgz",
|
"resolved": "https://registry.npmjs.org/@alfresco/adf-extensions/-/adf-extensions-3.3.0-626bb01bf7d26e693a4947982d20695c45794503.tgz",
|
||||||
"integrity": "sha512-iEABQcxgUxlh7/qhbUprgL+zxLue/NSPIAs5rxuBAsGbPusIPh15cvJmo1YUnm0cbjxLs5CMUGurenfeh7afEQ==",
|
"integrity": "sha512-qh2xdGTeNBvh7QzScvaYxHxvoTld5bCwDRIUKNj+Dt+C3aaAs5mdN85hTVQ82+vNptD8NO9nCBaS/CR5ISwt9Q==",
|
||||||
"requires": {
|
"requires": {
|
||||||
"tslib": "^1.9.0"
|
"tslib": "^1.9.0"
|
||||||
}
|
}
|
||||||
@@ -5113,7 +5113,8 @@
|
|||||||
"ansi-regex": {
|
"ansi-regex": {
|
||||||
"version": "2.1.1",
|
"version": "2.1.1",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true
|
"dev": true,
|
||||||
|
"optional": true
|
||||||
},
|
},
|
||||||
"aproba": {
|
"aproba": {
|
||||||
"version": "1.2.0",
|
"version": "1.2.0",
|
||||||
@@ -5134,12 +5135,14 @@
|
|||||||
"balanced-match": {
|
"balanced-match": {
|
||||||
"version": "1.0.0",
|
"version": "1.0.0",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true
|
"dev": true,
|
||||||
|
"optional": true
|
||||||
},
|
},
|
||||||
"brace-expansion": {
|
"brace-expansion": {
|
||||||
"version": "1.1.11",
|
"version": "1.1.11",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true,
|
"dev": true,
|
||||||
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"balanced-match": "^1.0.0",
|
"balanced-match": "^1.0.0",
|
||||||
"concat-map": "0.0.1"
|
"concat-map": "0.0.1"
|
||||||
@@ -5154,17 +5157,20 @@
|
|||||||
"code-point-at": {
|
"code-point-at": {
|
||||||
"version": "1.1.0",
|
"version": "1.1.0",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true
|
"dev": true,
|
||||||
|
"optional": true
|
||||||
},
|
},
|
||||||
"concat-map": {
|
"concat-map": {
|
||||||
"version": "0.0.1",
|
"version": "0.0.1",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true
|
"dev": true,
|
||||||
|
"optional": true
|
||||||
},
|
},
|
||||||
"console-control-strings": {
|
"console-control-strings": {
|
||||||
"version": "1.1.0",
|
"version": "1.1.0",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true
|
"dev": true,
|
||||||
|
"optional": true
|
||||||
},
|
},
|
||||||
"core-util-is": {
|
"core-util-is": {
|
||||||
"version": "1.0.2",
|
"version": "1.0.2",
|
||||||
@@ -5281,7 +5287,8 @@
|
|||||||
"inherits": {
|
"inherits": {
|
||||||
"version": "2.0.3",
|
"version": "2.0.3",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true
|
"dev": true,
|
||||||
|
"optional": true
|
||||||
},
|
},
|
||||||
"ini": {
|
"ini": {
|
||||||
"version": "1.3.5",
|
"version": "1.3.5",
|
||||||
@@ -5293,6 +5300,7 @@
|
|||||||
"version": "1.0.0",
|
"version": "1.0.0",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true,
|
"dev": true,
|
||||||
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"number-is-nan": "^1.0.0"
|
"number-is-nan": "^1.0.0"
|
||||||
}
|
}
|
||||||
@@ -5307,6 +5315,7 @@
|
|||||||
"version": "3.0.4",
|
"version": "3.0.4",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true,
|
"dev": true,
|
||||||
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"brace-expansion": "^1.1.7"
|
"brace-expansion": "^1.1.7"
|
||||||
}
|
}
|
||||||
@@ -5314,12 +5323,14 @@
|
|||||||
"minimist": {
|
"minimist": {
|
||||||
"version": "0.0.8",
|
"version": "0.0.8",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true
|
"dev": true,
|
||||||
|
"optional": true
|
||||||
},
|
},
|
||||||
"minipass": {
|
"minipass": {
|
||||||
"version": "2.3.5",
|
"version": "2.3.5",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true,
|
"dev": true,
|
||||||
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"safe-buffer": "^5.1.2",
|
"safe-buffer": "^5.1.2",
|
||||||
"yallist": "^3.0.0"
|
"yallist": "^3.0.0"
|
||||||
@@ -5338,6 +5349,7 @@
|
|||||||
"version": "0.5.1",
|
"version": "0.5.1",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true,
|
"dev": true,
|
||||||
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"minimist": "0.0.8"
|
"minimist": "0.0.8"
|
||||||
}
|
}
|
||||||
@@ -5418,7 +5430,8 @@
|
|||||||
"number-is-nan": {
|
"number-is-nan": {
|
||||||
"version": "1.0.1",
|
"version": "1.0.1",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true
|
"dev": true,
|
||||||
|
"optional": true
|
||||||
},
|
},
|
||||||
"object-assign": {
|
"object-assign": {
|
||||||
"version": "4.1.1",
|
"version": "4.1.1",
|
||||||
@@ -5430,6 +5443,7 @@
|
|||||||
"version": "1.4.0",
|
"version": "1.4.0",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true,
|
"dev": true,
|
||||||
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"wrappy": "1"
|
"wrappy": "1"
|
||||||
}
|
}
|
||||||
@@ -5515,7 +5529,8 @@
|
|||||||
"safe-buffer": {
|
"safe-buffer": {
|
||||||
"version": "5.1.2",
|
"version": "5.1.2",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true
|
"dev": true,
|
||||||
|
"optional": true
|
||||||
},
|
},
|
||||||
"safer-buffer": {
|
"safer-buffer": {
|
||||||
"version": "2.1.2",
|
"version": "2.1.2",
|
||||||
@@ -5551,6 +5566,7 @@
|
|||||||
"version": "1.0.2",
|
"version": "1.0.2",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true,
|
"dev": true,
|
||||||
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"code-point-at": "^1.0.0",
|
"code-point-at": "^1.0.0",
|
||||||
"is-fullwidth-code-point": "^1.0.0",
|
"is-fullwidth-code-point": "^1.0.0",
|
||||||
@@ -5570,6 +5586,7 @@
|
|||||||
"version": "3.0.1",
|
"version": "3.0.1",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true,
|
"dev": true,
|
||||||
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"ansi-regex": "^2.0.0"
|
"ansi-regex": "^2.0.0"
|
||||||
}
|
}
|
||||||
@@ -5613,12 +5630,14 @@
|
|||||||
"wrappy": {
|
"wrappy": {
|
||||||
"version": "1.0.2",
|
"version": "1.0.2",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true
|
"dev": true,
|
||||||
|
"optional": true
|
||||||
},
|
},
|
||||||
"yallist": {
|
"yallist": {
|
||||||
"version": "3.0.3",
|
"version": "3.0.3",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true
|
"dev": true,
|
||||||
|
"optional": true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@@ -36,9 +36,9 @@
|
|||||||
},
|
},
|
||||||
"private": true,
|
"private": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@alfresco/adf-content-services": "3.3.0-8a2a71d60be3f2b3dd0173f6a51d8075241e7203",
|
"@alfresco/adf-content-services": "3.3.0-626bb01bf7d26e693a4947982d20695c45794503",
|
||||||
"@alfresco/adf-core": "3.3.0-8a2a71d60be3f2b3dd0173f6a51d8075241e7203",
|
"@alfresco/adf-core": "3.3.0-626bb01bf7d26e693a4947982d20695c45794503",
|
||||||
"@alfresco/adf-extensions": "3.3.0-8a2a71d60be3f2b3dd0173f6a51d8075241e7203",
|
"@alfresco/adf-extensions": "3.3.0-626bb01bf7d26e693a4947982d20695c45794503",
|
||||||
"@alfresco/js-api": "3.2.1",
|
"@alfresco/js-api": "3.2.1",
|
||||||
"@angular/animations": "7.2.15",
|
"@angular/animations": "7.2.15",
|
||||||
"@angular/cdk": "^7.3.7",
|
"@angular/cdk": "^7.3.7",
|
||||||
|
@@ -20,6 +20,7 @@
|
|||||||
"logo": "assets/images/alfresco-logo-flower.svg",
|
"logo": "assets/images/alfresco-logo-flower.svg",
|
||||||
"copyright": "APP.COPYRIGHT"
|
"copyright": "APP.COPYRIGHT"
|
||||||
},
|
},
|
||||||
|
"sharedLinkDateTimePickerType": "date",
|
||||||
"headerColor": "#2196F3",
|
"headerColor": "#2196F3",
|
||||||
"languagePicker": true,
|
"languagePicker": true,
|
||||||
"pagination": {
|
"pagination": {
|
||||||
|
@@ -54,6 +54,7 @@ describe('AppComponent', () => {
|
|||||||
null,
|
null,
|
||||||
null,
|
null,
|
||||||
null,
|
null,
|
||||||
|
null,
|
||||||
null
|
null
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
@@ -29,7 +29,8 @@ import {
|
|||||||
AuthenticationService,
|
AuthenticationService,
|
||||||
FileUploadErrorEvent,
|
FileUploadErrorEvent,
|
||||||
PageTitleService,
|
PageTitleService,
|
||||||
UploadService
|
UploadService,
|
||||||
|
SharedLinksApiService
|
||||||
} from '@alfresco/adf-core';
|
} from '@alfresco/adf-core';
|
||||||
import { Component, OnInit, OnDestroy } from '@angular/core';
|
import { Component, OnInit, OnDestroy } from '@angular/core';
|
||||||
import { ActivatedRoute, NavigationEnd, Router } from '@angular/router';
|
import { ActivatedRoute, NavigationEnd, Router } from '@angular/router';
|
||||||
@@ -70,7 +71,8 @@ export class AppComponent implements OnInit, OnDestroy {
|
|||||||
private uploadService: UploadService,
|
private uploadService: UploadService,
|
||||||
private extensions: AppExtensionService,
|
private extensions: AppExtensionService,
|
||||||
private contentApi: ContentApiService,
|
private contentApi: ContentApiService,
|
||||||
private appService: AppService
|
private appService: AppService,
|
||||||
|
private sharedLinksApiService: SharedLinksApiService
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
ngOnInit() {
|
ngOnInit() {
|
||||||
@@ -120,6 +122,12 @@ export class AppComponent implements OnInit, OnDestroy {
|
|||||||
this.onFileUploadedError(error)
|
this.onFileUploadedError(error)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
this.sharedLinksApiService.error
|
||||||
|
.pipe(takeUntil(this.onDestroy$))
|
||||||
|
.subscribe((err: { message: string }) => {
|
||||||
|
this.store.dispatch(new SnackbarErrorAction(err.message));
|
||||||
|
});
|
||||||
|
|
||||||
this.appService.ready$
|
this.appService.ready$
|
||||||
.pipe(takeUntil(this.onDestroy$))
|
.pipe(takeUntil(this.onDestroy$))
|
||||||
.subscribe(isReady => {
|
.subscribe(isReady => {
|
||||||
|
@@ -61,7 +61,6 @@ import { DirectivesModule } from './directives/directives.module';
|
|||||||
import { ContextMenuModule } from './components/context-menu/context-menu.module';
|
import { ContextMenuModule } from './components/context-menu/context-menu.module';
|
||||||
import { ExtensionsModule } from '@alfresco/adf-extensions';
|
import { ExtensionsModule } from '@alfresco/adf-extensions';
|
||||||
import { AppToolbarModule } from './components/toolbar/toolbar.module';
|
import { AppToolbarModule } from './components/toolbar/toolbar.module';
|
||||||
import { AppSharedModule } from './components/shared/shared.module';
|
|
||||||
import { AppCreateMenuModule } from './components/create-menu/create-menu.module';
|
import { AppCreateMenuModule } from './components/create-menu/create-menu.module';
|
||||||
import { AppSidenavModule } from './components/sidenav/sidenav.module';
|
import { AppSidenavModule } from './components/sidenav/sidenav.module';
|
||||||
import { AppPermissionsModule } from './components/permissions/permissions.module';
|
import { AppPermissionsModule } from './components/permissions/permissions.module';
|
||||||
@@ -102,7 +101,6 @@ import { environment } from '../environments/environment';
|
|||||||
ContextMenuModule,
|
ContextMenuModule,
|
||||||
AppInfoDrawerModule,
|
AppInfoDrawerModule,
|
||||||
AppToolbarModule,
|
AppToolbarModule,
|
||||||
AppSharedModule,
|
|
||||||
AppSidenavModule,
|
AppSidenavModule,
|
||||||
AppCreateMenuModule,
|
AppCreateMenuModule,
|
||||||
DocumentListCustomComponentsModule,
|
DocumentListCustomComponentsModule,
|
||||||
|
@@ -29,6 +29,7 @@ import { CommonModule } from '@angular/common';
|
|||||||
import { NgModule } from '@angular/core';
|
import { NgModule } from '@angular/core';
|
||||||
import { GenericErrorModule } from '@alfresco/aca-shared';
|
import { GenericErrorModule } from '@alfresco/aca-shared';
|
||||||
import { LocationLinkComponent } from './location-link/location-link.component';
|
import { LocationLinkComponent } from './location-link/location-link.component';
|
||||||
|
import { ToggleSharedComponent } from './toggle-shared/toggle-shared.component';
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
imports: [
|
imports: [
|
||||||
@@ -37,8 +38,13 @@ import { LocationLinkComponent } from './location-link/location-link.component';
|
|||||||
ExtensionsModule,
|
ExtensionsModule,
|
||||||
GenericErrorModule
|
GenericErrorModule
|
||||||
],
|
],
|
||||||
declarations: [LocationLinkComponent],
|
declarations: [LocationLinkComponent, ToggleSharedComponent],
|
||||||
exports: [ExtensionsModule, LocationLinkComponent, GenericErrorModule],
|
exports: [
|
||||||
entryComponents: [LocationLinkComponent]
|
ExtensionsModule,
|
||||||
|
LocationLinkComponent,
|
||||||
|
GenericErrorModule,
|
||||||
|
ToggleSharedComponent
|
||||||
|
],
|
||||||
|
entryComponents: [LocationLinkComponent, ToggleSharedComponent]
|
||||||
})
|
})
|
||||||
export class AppCommonModule {}
|
export class AppCommonModule {}
|
||||||
|
@@ -1,92 +0,0 @@
|
|||||||
<div class="adf-share-link__dialog-content">
|
|
||||||
<h1 data-automation-id="adf-share-dialog-title" class="adf-share-link__title">
|
|
||||||
{{ 'SHARE.DIALOG-TITLE' | translate }} {{ fileName }}
|
|
||||||
</h1>
|
|
||||||
|
|
||||||
<mat-dialog-content>
|
|
||||||
<p class="adf-share-link__info">{{ 'SHARE.DESCRIPTION' | translate }}</p>
|
|
||||||
|
|
||||||
<div class="adf-share-link--row">
|
|
||||||
<h1 class="adf-share-link__label">{{ 'SHARE.TITLE' | translate }}</h1>
|
|
||||||
|
|
||||||
<mat-slide-toggle
|
|
||||||
data-automation-id="adf-share-toggle"
|
|
||||||
[checked]="isFileShared"
|
|
||||||
[disabled]="isDisabled"
|
|
||||||
(change)="onSlideShareChange()"
|
|
||||||
>
|
|
||||||
</mat-slide-toggle>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<form [formGroup]="form">
|
|
||||||
<mat-form-field class="adf-full-width">
|
|
||||||
<input
|
|
||||||
#sharedLinkInput
|
|
||||||
data-automation-id="adf-share-link"
|
|
||||||
class="adf-share-link__input"
|
|
||||||
matInput
|
|
||||||
cdkFocusInitial
|
|
||||||
placeholder="{{ 'SHARE.PUBLIC-LINK' | translate }}"
|
|
||||||
formControlName="sharedUrl"
|
|
||||||
readonly="readonly"
|
|
||||||
/>
|
|
||||||
<mat-icon
|
|
||||||
class="adf-input-action"
|
|
||||||
matSuffix
|
|
||||||
[clipboard-notification]="'SHARE.CLIPBOARD-MESSAGE' | translate"
|
|
||||||
[adf-clipboard]="sharedLinkInput"
|
|
||||||
>
|
|
||||||
link
|
|
||||||
</mat-icon>
|
|
||||||
</mat-form-field>
|
|
||||||
|
|
||||||
<div class="adf-share-link--row">
|
|
||||||
<h1 class="adf-share-link__label">{{ 'SHARE.EXPIRES' | translate }}</h1>
|
|
||||||
<mat-slide-toggle
|
|
||||||
[disabled]="!canUpdate"
|
|
||||||
#slideToggleExpirationDate
|
|
||||||
data-automation-id="adf-expire-toggle"
|
|
||||||
[checked]="form.controls['time'].value"
|
|
||||||
(change)="onToggleExpirationDate($event)"
|
|
||||||
>
|
|
||||||
</mat-slide-toggle>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<mat-form-field class="adf-full-width">
|
|
||||||
<mat-datetimepicker-toggle
|
|
||||||
#matDatetimepickerToggle="matDatetimepickerToggle"
|
|
||||||
[for]="datetimePicker"
|
|
||||||
matSuffix
|
|
||||||
>
|
|
||||||
</mat-datetimepicker-toggle>
|
|
||||||
<mat-datetimepicker
|
|
||||||
#datetimePicker
|
|
||||||
(closed)="onDatetimepickerClosed()"
|
|
||||||
type="date"
|
|
||||||
openOnFocus="true"
|
|
||||||
timeInterval="1"
|
|
||||||
>
|
|
||||||
</mat-datetimepicker>
|
|
||||||
<input
|
|
||||||
class="adf-share-link__input"
|
|
||||||
#dateTimePickerInput
|
|
||||||
matInput
|
|
||||||
[min]="minDate"
|
|
||||||
formControlName="time"
|
|
||||||
[matDatetimepicker]="datetimePicker"
|
|
||||||
/>
|
|
||||||
</mat-form-field>
|
|
||||||
</form>
|
|
||||||
</mat-dialog-content>
|
|
||||||
|
|
||||||
<div mat-dialog-actions>
|
|
||||||
<button
|
|
||||||
data-automation-id="adf-share-dialog-close"
|
|
||||||
mat-button
|
|
||||||
color="primary"
|
|
||||||
mat-dialog-close
|
|
||||||
>
|
|
||||||
{{ 'SHARE.CLOSE' | translate }}
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
@@ -1,64 +0,0 @@
|
|||||||
@mixin adf-share-link-typography {
|
|
||||||
letter-spacing: -0.4px;
|
|
||||||
line-height: 2;
|
|
||||||
font-weight: normal;
|
|
||||||
font-style: normal;
|
|
||||||
font-stretch: normal;
|
|
||||||
font-size: 16px;
|
|
||||||
opacity: 0.87;
|
|
||||||
}
|
|
||||||
|
|
||||||
.adf-share-link-dialog {
|
|
||||||
.adf-share-link {
|
|
||||||
&__dialog-content {
|
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__label {
|
|
||||||
@include adf-share-link-typography;
|
|
||||||
flex: 1 1 auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__title {
|
|
||||||
@include adf-share-link-typography;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__info {
|
|
||||||
@include adf-share-link-typography;
|
|
||||||
opacity: 0.54;
|
|
||||||
font-size: 13px;
|
|
||||||
}
|
|
||||||
|
|
||||||
&--row {
|
|
||||||
display: flex;
|
|
||||||
flex-direction: row;
|
|
||||||
flex-wrap: wrap;
|
|
||||||
align-items: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__input {
|
|
||||||
opacity: 0.54;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.adf-input-action {
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mat-form-field-infix {
|
|
||||||
border-top: unset;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mat-dialog-actions {
|
|
||||||
justify-content: flex-end;
|
|
||||||
|
|
||||||
& > button {
|
|
||||||
text-transform: uppercase;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.mat-form-field-flex {
|
|
||||||
align-items: center;
|
|
||||||
}
|
|
||||||
}
|
|
@@ -1,350 +0,0 @@
|
|||||||
/*!
|
|
||||||
* @license
|
|
||||||
* Copyright 2019 Alfresco Software, Ltd.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import { NoopAnimationsModule } from '@angular/platform-browser/animations';
|
|
||||||
import { TestBed, fakeAsync, async, tick } from '@angular/core/testing';
|
|
||||||
import {
|
|
||||||
MatDialogRef,
|
|
||||||
MAT_DIALOG_DATA,
|
|
||||||
MatDialog
|
|
||||||
} from '@angular/material/dialog';
|
|
||||||
import { of } from 'rxjs';
|
|
||||||
import {
|
|
||||||
setupTestBed,
|
|
||||||
CoreModule,
|
|
||||||
SharedLinksApiService,
|
|
||||||
NodesApiService,
|
|
||||||
NotificationService
|
|
||||||
} from '@alfresco/adf-core';
|
|
||||||
import { ContentNodeShareModule } from './content-node-share.module';
|
|
||||||
import { ShareDialogComponent } from './content-node-share.dialog';
|
|
||||||
import * as moment from 'moment';
|
|
||||||
import { Store } from '@ngrx/store';
|
|
||||||
|
|
||||||
describe('ShareDialogComponent', () => {
|
|
||||||
let node;
|
|
||||||
let matDialog: MatDialog;
|
|
||||||
const notificationServiceMock = {
|
|
||||||
openSnackMessage: jasmine.createSpy('openSnackMessage')
|
|
||||||
};
|
|
||||||
let sharedLinksApiService: SharedLinksApiService;
|
|
||||||
let nodesApiService: NodesApiService;
|
|
||||||
let fixture;
|
|
||||||
let component;
|
|
||||||
const storeMock = {
|
|
||||||
dispatch: jasmine.createSpy('dispatch')
|
|
||||||
};
|
|
||||||
|
|
||||||
setupTestBed({
|
|
||||||
imports: [
|
|
||||||
NoopAnimationsModule,
|
|
||||||
CoreModule.forRoot(),
|
|
||||||
ContentNodeShareModule
|
|
||||||
],
|
|
||||||
providers: [
|
|
||||||
NodesApiService,
|
|
||||||
SharedLinksApiService,
|
|
||||||
{ provide: Store, useValue: storeMock },
|
|
||||||
{ provide: NotificationService, useValue: notificationServiceMock },
|
|
||||||
{ provide: MatDialogRef, useValue: {} },
|
|
||||||
{ provide: MAT_DIALOG_DATA, useValue: {} }
|
|
||||||
]
|
|
||||||
});
|
|
||||||
|
|
||||||
beforeEach(() => {
|
|
||||||
fixture = TestBed.createComponent(ShareDialogComponent);
|
|
||||||
matDialog = TestBed.get(MatDialog);
|
|
||||||
sharedLinksApiService = TestBed.get(SharedLinksApiService);
|
|
||||||
nodesApiService = TestBed.get(NodesApiService);
|
|
||||||
component = fixture.componentInstance;
|
|
||||||
});
|
|
||||||
|
|
||||||
beforeEach(() => {
|
|
||||||
node = {
|
|
||||||
entry: {
|
|
||||||
id: 'nodeId',
|
|
||||||
allowableOperations: ['update'],
|
|
||||||
isFile: true,
|
|
||||||
properties: {}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
});
|
|
||||||
|
|
||||||
afterEach(() => {
|
|
||||||
fixture.destroy();
|
|
||||||
});
|
|
||||||
|
|
||||||
it(`should toggle share action when property 'sharedId' does not exists`, fakeAsync(() => {
|
|
||||||
spyOn(sharedLinksApiService, 'createSharedLinks').and.returnValue(
|
|
||||||
of({
|
|
||||||
entry: { id: 'sharedId', sharedId: 'sharedId' }
|
|
||||||
})
|
|
||||||
);
|
|
||||||
|
|
||||||
component.data = {
|
|
||||||
node,
|
|
||||||
permission: true,
|
|
||||||
baseShareUrl: 'some-url/'
|
|
||||||
};
|
|
||||||
|
|
||||||
fixture.detectChanges();
|
|
||||||
tick(500);
|
|
||||||
|
|
||||||
expect(sharedLinksApiService.createSharedLinks).toHaveBeenCalled();
|
|
||||||
expect(
|
|
||||||
fixture.nativeElement.querySelector('input[formcontrolname="sharedUrl"]')
|
|
||||||
.value
|
|
||||||
).toBe('some-url/sharedId');
|
|
||||||
expect(
|
|
||||||
fixture.nativeElement.querySelector(
|
|
||||||
'.mat-slide-toggle[data-automation-id="adf-share-toggle"'
|
|
||||||
).classList
|
|
||||||
).toContain('mat-checked');
|
|
||||||
}));
|
|
||||||
|
|
||||||
it(`should not toggle share action when file has 'sharedId' property`, fakeAsync(() => {
|
|
||||||
spyOn(sharedLinksApiService, 'createSharedLinks');
|
|
||||||
node.entry.properties['qshare:sharedId'] = 'sharedId';
|
|
||||||
|
|
||||||
component.data = {
|
|
||||||
node,
|
|
||||||
permission: true,
|
|
||||||
baseShareUrl: 'some-url/'
|
|
||||||
};
|
|
||||||
|
|
||||||
fixture.detectChanges();
|
|
||||||
tick(500);
|
|
||||||
|
|
||||||
expect(sharedLinksApiService.createSharedLinks).not.toHaveBeenCalled();
|
|
||||||
expect(
|
|
||||||
fixture.nativeElement.querySelector('input[formcontrolname="sharedUrl"]')
|
|
||||||
.value
|
|
||||||
).toBe('some-url/sharedId');
|
|
||||||
expect(
|
|
||||||
fixture.nativeElement.querySelector(
|
|
||||||
'.mat-slide-toggle[data-automation-id="adf-share-toggle"'
|
|
||||||
).classList
|
|
||||||
).toContain('mat-checked');
|
|
||||||
}));
|
|
||||||
|
|
||||||
xit(`should copy shared link and notify on button event`, async(() => {
|
|
||||||
node.entry.properties['qshare:sharedId'] = 'sharedId';
|
|
||||||
spyOn(document, 'execCommand').and.callThrough();
|
|
||||||
|
|
||||||
component.data = {
|
|
||||||
node,
|
|
||||||
permission: true,
|
|
||||||
baseShareUrl: 'some-url/'
|
|
||||||
};
|
|
||||||
|
|
||||||
fixture.detectChanges();
|
|
||||||
|
|
||||||
fixture.whenStable().then(() => {
|
|
||||||
fixture.detectChanges();
|
|
||||||
|
|
||||||
fixture.nativeElement
|
|
||||||
.querySelector('.adf-input-action')
|
|
||||||
.dispatchEvent(new MouseEvent('click'));
|
|
||||||
|
|
||||||
fixture.detectChanges();
|
|
||||||
|
|
||||||
expect(document.execCommand).toHaveBeenCalledWith('copy');
|
|
||||||
expect(notificationServiceMock.openSnackMessage).toHaveBeenCalledWith(
|
|
||||||
'SHARE.CLIPBOARD-MESSAGE'
|
|
||||||
);
|
|
||||||
});
|
|
||||||
}));
|
|
||||||
|
|
||||||
it('should open a confirmation dialog when unshare button is triggered', () => {
|
|
||||||
spyOn(matDialog, 'open').and.returnValue({ beforeClose: () => of(false) });
|
|
||||||
spyOn(sharedLinksApiService, 'deleteSharedLink');
|
|
||||||
node.entry.properties['qshare:sharedId'] = 'sharedId';
|
|
||||||
|
|
||||||
component.data = {
|
|
||||||
node,
|
|
||||||
permission: true,
|
|
||||||
baseShareUrl: 'some-url/'
|
|
||||||
};
|
|
||||||
|
|
||||||
fixture.detectChanges();
|
|
||||||
|
|
||||||
fixture.nativeElement
|
|
||||||
.querySelector(
|
|
||||||
'.mat-slide-toggle[data-automation-id="adf-share-toggle"] label'
|
|
||||||
)
|
|
||||||
.dispatchEvent(new MouseEvent('click'));
|
|
||||||
|
|
||||||
fixture.detectChanges();
|
|
||||||
|
|
||||||
expect(matDialog.open).toHaveBeenCalled();
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should unshare file when confirmation dialog returns true', fakeAsync(() => {
|
|
||||||
spyOn(matDialog, 'open').and.returnValue({ beforeClose: () => of(true) });
|
|
||||||
spyOn(sharedLinksApiService, 'deleteSharedLink').and.returnValue(of(null));
|
|
||||||
node.entry.properties['qshare:sharedId'] = 'sharedId';
|
|
||||||
|
|
||||||
component.data = {
|
|
||||||
node,
|
|
||||||
permission: true,
|
|
||||||
baseShareUrl: 'some-url/'
|
|
||||||
};
|
|
||||||
|
|
||||||
fixture.detectChanges();
|
|
||||||
|
|
||||||
fixture.nativeElement
|
|
||||||
.querySelector(
|
|
||||||
'.mat-slide-toggle[data-automation-id="adf-share-toggle"] label'
|
|
||||||
)
|
|
||||||
.dispatchEvent(new MouseEvent('click'));
|
|
||||||
|
|
||||||
fixture.detectChanges();
|
|
||||||
|
|
||||||
expect(sharedLinksApiService.deleteSharedLink).toHaveBeenCalled();
|
|
||||||
}));
|
|
||||||
|
|
||||||
it('should not unshare file when confirmation dialog returns false', fakeAsync(() => {
|
|
||||||
spyOn(matDialog, 'open').and.returnValue({ beforeClose: () => of(false) });
|
|
||||||
spyOn(sharedLinksApiService, 'deleteSharedLink');
|
|
||||||
node.entry.properties['qshare:sharedId'] = 'sharedId';
|
|
||||||
|
|
||||||
component.data = {
|
|
||||||
node,
|
|
||||||
permission: true,
|
|
||||||
baseShareUrl: 'some-url/'
|
|
||||||
};
|
|
||||||
|
|
||||||
fixture.detectChanges();
|
|
||||||
|
|
||||||
fixture.nativeElement
|
|
||||||
.querySelector(
|
|
||||||
'.mat-slide-toggle[data-automation-id="adf-share-toggle"] label'
|
|
||||||
)
|
|
||||||
.dispatchEvent(new MouseEvent('click'));
|
|
||||||
|
|
||||||
fixture.detectChanges();
|
|
||||||
|
|
||||||
expect(sharedLinksApiService.deleteSharedLink).not.toHaveBeenCalled();
|
|
||||||
}));
|
|
||||||
|
|
||||||
it('should reset expiration date when toggle is unchecked', () => {
|
|
||||||
spyOn(nodesApiService, 'updateNode').and.returnValue(of({}));
|
|
||||||
node.entry.properties['qshare:sharedId'] = 'sharedId';
|
|
||||||
node.entry.properties['qshare:sharedId'] = '2017-04-15T18:31:37+00:00';
|
|
||||||
|
|
||||||
component.data = {
|
|
||||||
node,
|
|
||||||
permission: true,
|
|
||||||
baseShareUrl: 'some-url/'
|
|
||||||
};
|
|
||||||
|
|
||||||
fixture.detectChanges();
|
|
||||||
|
|
||||||
component.form.controls['time'].setValue(moment());
|
|
||||||
|
|
||||||
fixture.detectChanges();
|
|
||||||
|
|
||||||
fixture.nativeElement
|
|
||||||
.querySelector(
|
|
||||||
'.mat-slide-toggle[data-automation-id="adf-expire-toggle"] label'
|
|
||||||
)
|
|
||||||
.dispatchEvent(new MouseEvent('click'));
|
|
||||||
|
|
||||||
fixture.detectChanges();
|
|
||||||
|
|
||||||
expect(nodesApiService.updateNode).toHaveBeenCalledWith('nodeId', {
|
|
||||||
properties: { 'qshare:expiryDate': null }
|
|
||||||
});
|
|
||||||
|
|
||||||
expect(
|
|
||||||
fixture.nativeElement.querySelector('input[formcontrolname="time"]').value
|
|
||||||
).toBe('');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should not allow expiration date action when node has no update permission', () => {
|
|
||||||
node.entry.properties['qshare:sharedId'] = 'sharedId';
|
|
||||||
|
|
||||||
component.data = {
|
|
||||||
node,
|
|
||||||
permission: false,
|
|
||||||
baseShareUrl: 'some-url/'
|
|
||||||
};
|
|
||||||
|
|
||||||
fixture.detectChanges();
|
|
||||||
|
|
||||||
expect(
|
|
||||||
fixture.nativeElement.querySelector('input[formcontrolname="time"]')
|
|
||||||
.disabled
|
|
||||||
).toBe(true);
|
|
||||||
expect(
|
|
||||||
fixture.nativeElement.querySelector(
|
|
||||||
'.mat-slide-toggle[data-automation-id="adf-expire-toggle"]'
|
|
||||||
).classList
|
|
||||||
).toContain('mat-disabled');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should show permission error notification on un-share action', () => {
|
|
||||||
node.entry.properties['qshare:sharedId'] = 'sharedId';
|
|
||||||
spyOn(matDialog, 'open').and.returnValue({ beforeClose: () => of(true) });
|
|
||||||
spyOn(sharedLinksApiService, 'deleteSharedLink').and.returnValue(
|
|
||||||
of(new Error('{"error": { "statusCode": 403 } }'))
|
|
||||||
);
|
|
||||||
component.data = {
|
|
||||||
node,
|
|
||||||
permission: false,
|
|
||||||
baseShareUrl: 'some-url/'
|
|
||||||
};
|
|
||||||
|
|
||||||
fixture.detectChanges();
|
|
||||||
|
|
||||||
fixture.nativeElement
|
|
||||||
.querySelector(
|
|
||||||
'.mat-slide-toggle[data-automation-id="adf-share-toggle"] label'
|
|
||||||
)
|
|
||||||
.dispatchEvent(new MouseEvent('click'));
|
|
||||||
|
|
||||||
expect(storeMock.dispatch).toHaveBeenCalled();
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should update node expiration date with selected date and time', () => {
|
|
||||||
const date = moment();
|
|
||||||
node.entry.properties['qshare:sharedId'] = 'sharedId';
|
|
||||||
spyOn(nodesApiService, 'updateNode').and.returnValue(of({}));
|
|
||||||
fixture.componentInstance.form.controls['time'].setValue(null);
|
|
||||||
|
|
||||||
component.data = {
|
|
||||||
node,
|
|
||||||
permission: true,
|
|
||||||
baseShareUrl: 'some-url/'
|
|
||||||
};
|
|
||||||
|
|
||||||
fixture.detectChanges();
|
|
||||||
|
|
||||||
fixture.nativeElement
|
|
||||||
.querySelector(
|
|
||||||
'mat-slide-toggle[data-automation-id="adf-expire-toggle"] label'
|
|
||||||
)
|
|
||||||
.dispatchEvent(new MouseEvent('click'));
|
|
||||||
|
|
||||||
fixture.componentInstance.form.controls['time'].setValue(date);
|
|
||||||
fixture.detectChanges();
|
|
||||||
|
|
||||||
expect(nodesApiService.updateNode).toHaveBeenCalledWith('nodeId', {
|
|
||||||
properties: { 'qshare:expiryDate': date }
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
@@ -1,255 +0,0 @@
|
|||||||
/*!
|
|
||||||
* @license
|
|
||||||
* Copyright 2019 Alfresco Software, Ltd.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import {
|
|
||||||
Component,
|
|
||||||
Inject,
|
|
||||||
OnInit,
|
|
||||||
ViewEncapsulation,
|
|
||||||
ViewChild,
|
|
||||||
OnDestroy
|
|
||||||
} from '@angular/core';
|
|
||||||
import {
|
|
||||||
MAT_DIALOG_DATA,
|
|
||||||
MatDialogRef,
|
|
||||||
MatDialog
|
|
||||||
} from '@angular/material/dialog';
|
|
||||||
import { FormGroup, FormControl } from '@angular/forms';
|
|
||||||
import { Subscription, Observable, throwError } from 'rxjs';
|
|
||||||
import { AppStore, SnackbarErrorAction } from '@alfresco/aca-shared/store';
|
|
||||||
import { Store } from '@ngrx/store';
|
|
||||||
import {
|
|
||||||
skip,
|
|
||||||
mergeMap,
|
|
||||||
catchError,
|
|
||||||
distinctUntilChanged
|
|
||||||
} from 'rxjs/operators';
|
|
||||||
import { SharedLinksApiService, NodesApiService } from '@alfresco/adf-core';
|
|
||||||
import { SharedLinkEntry, MinimalNodeEntryEntity } from '@alfresco/js-api';
|
|
||||||
import { ConfirmDialogComponent } from '@alfresco/adf-content-services';
|
|
||||||
import * as moment from 'moment';
|
|
||||||
|
|
||||||
@Component({
|
|
||||||
selector: 'aca-share-dialog',
|
|
||||||
templateUrl: './content-node-share.dialog.html',
|
|
||||||
styleUrls: ['./content-node-share.dialog.scss'],
|
|
||||||
host: { class: 'adf-share-dialog' },
|
|
||||||
encapsulation: ViewEncapsulation.None
|
|
||||||
})
|
|
||||||
export class ShareDialogComponent implements OnInit, OnDestroy {
|
|
||||||
private subscriptions: Subscription[] = [];
|
|
||||||
|
|
||||||
minDate = moment().add(1, 'd');
|
|
||||||
sharedId: string;
|
|
||||||
fileName: string;
|
|
||||||
baseShareUrl: string;
|
|
||||||
isFileShared = false;
|
|
||||||
isDisabled = false;
|
|
||||||
form: FormGroup = new FormGroup({
|
|
||||||
sharedUrl: new FormControl(''),
|
|
||||||
time: new FormControl({ value: '', disabled: false })
|
|
||||||
});
|
|
||||||
|
|
||||||
@ViewChild('matDatetimepickerToggle')
|
|
||||||
matDatetimepickerToggle;
|
|
||||||
|
|
||||||
@ViewChild('slideToggleExpirationDate')
|
|
||||||
slideToggleExpirationDate;
|
|
||||||
|
|
||||||
@ViewChild('dateTimePickerInput')
|
|
||||||
dateTimePickerInput;
|
|
||||||
|
|
||||||
constructor(
|
|
||||||
private sharedLinksApiService: SharedLinksApiService,
|
|
||||||
private dialogRef: MatDialogRef<ShareDialogComponent>,
|
|
||||||
private dialog: MatDialog,
|
|
||||||
private nodesApiService: NodesApiService,
|
|
||||||
private store: Store<AppStore>,
|
|
||||||
@Inject(MAT_DIALOG_DATA) public data: any
|
|
||||||
) {}
|
|
||||||
|
|
||||||
ngOnInit() {
|
|
||||||
if (!this.canUpdate) {
|
|
||||||
this.form.controls['time'].disable();
|
|
||||||
}
|
|
||||||
|
|
||||||
this.subscriptions.push(
|
|
||||||
this.form.controls.time.valueChanges
|
|
||||||
.pipe(
|
|
||||||
skip(1),
|
|
||||||
distinctUntilChanged(),
|
|
||||||
mergeMap(
|
|
||||||
updates => this.updateNode(updates),
|
|
||||||
formUpdates => formUpdates
|
|
||||||
),
|
|
||||||
catchError(error => {
|
|
||||||
return throwError(error);
|
|
||||||
})
|
|
||||||
)
|
|
||||||
.subscribe(updates => {
|
|
||||||
this.updateEntryExpiryDate(updates);
|
|
||||||
})
|
|
||||||
);
|
|
||||||
|
|
||||||
if (this.data.node && this.data.node.entry) {
|
|
||||||
this.fileName = this.data.node.entry.name;
|
|
||||||
this.baseShareUrl = this.data.baseShareUrl;
|
|
||||||
const properties = this.data.node.entry.properties;
|
|
||||||
|
|
||||||
if (!properties || !properties['qshare:sharedId']) {
|
|
||||||
this.createSharedLinks(this.data.node.entry.id);
|
|
||||||
} else {
|
|
||||||
this.sharedId = properties['qshare:sharedId'];
|
|
||||||
this.isFileShared = true;
|
|
||||||
|
|
||||||
this.updateForm();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ngOnDestroy() {
|
|
||||||
this.subscriptions.forEach(subscription => subscription.unsubscribe);
|
|
||||||
}
|
|
||||||
|
|
||||||
onSlideShareChange() {
|
|
||||||
this.openConfirmationDialog();
|
|
||||||
}
|
|
||||||
|
|
||||||
get canUpdate() {
|
|
||||||
return this.data.permission;
|
|
||||||
}
|
|
||||||
|
|
||||||
onToggleExpirationDate(slideToggle) {
|
|
||||||
if (slideToggle.checked) {
|
|
||||||
this.matDatetimepickerToggle.datetimepicker.open();
|
|
||||||
} else {
|
|
||||||
this.matDatetimepickerToggle.datetimepicker.close();
|
|
||||||
this.form.controls.time.setValue(null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
onDatetimepickerClosed() {
|
|
||||||
this.dateTimePickerInput.nativeElement.blur();
|
|
||||||
|
|
||||||
if (!this.form.controls.time.value) {
|
|
||||||
this.slideToggleExpirationDate.checked = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private openConfirmationDialog() {
|
|
||||||
this.isFileShared = false;
|
|
||||||
|
|
||||||
this.dialog
|
|
||||||
.open(ConfirmDialogComponent, {
|
|
||||||
data: {
|
|
||||||
title: 'SHARE.CONFIRMATION.DIALOG-TITLE',
|
|
||||||
message: 'SHARE.CONFIRMATION.MESSAGE',
|
|
||||||
yesLabel: 'SHARE.CONFIRMATION.REMOVE',
|
|
||||||
noLabel: 'SHARE.CONFIRMATION.CANCEL'
|
|
||||||
},
|
|
||||||
minWidth: '250px',
|
|
||||||
closeOnNavigation: true
|
|
||||||
})
|
|
||||||
.beforeClose()
|
|
||||||
.subscribe(deleteSharedLink => {
|
|
||||||
if (deleteSharedLink) {
|
|
||||||
this.deleteSharedLink(this.sharedId);
|
|
||||||
} else {
|
|
||||||
this.isFileShared = true;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private createSharedLinks(nodeId: string) {
|
|
||||||
this.isDisabled = true;
|
|
||||||
|
|
||||||
this.sharedLinksApiService.createSharedLinks(nodeId).subscribe(
|
|
||||||
(sharedLink: SharedLinkEntry) => {
|
|
||||||
if (sharedLink.entry) {
|
|
||||||
this.sharedId = sharedLink.entry.id;
|
|
||||||
if (this.data.node.entry.properties) {
|
|
||||||
this.data.node.entry.properties['qshare:sharedId'] = this.sharedId;
|
|
||||||
} else {
|
|
||||||
this.data.node.entry.properties = {
|
|
||||||
'qshare:sharedId': this.sharedId
|
|
||||||
};
|
|
||||||
}
|
|
||||||
this.isDisabled = false;
|
|
||||||
this.isFileShared = true;
|
|
||||||
|
|
||||||
this.updateForm();
|
|
||||||
}
|
|
||||||
},
|
|
||||||
() => {
|
|
||||||
this.isDisabled = false;
|
|
||||||
this.isFileShared = false;
|
|
||||||
}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
private deleteSharedLink(sharedId: string) {
|
|
||||||
this.isDisabled = true;
|
|
||||||
|
|
||||||
this.sharedLinksApiService
|
|
||||||
.deleteSharedLink(sharedId)
|
|
||||||
.subscribe((response: any) => {
|
|
||||||
if (response instanceof Error) {
|
|
||||||
this.isDisabled = false;
|
|
||||||
this.isFileShared = true;
|
|
||||||
this.showError(response);
|
|
||||||
} else {
|
|
||||||
this.data.node.entry.properties['qshare:sharedId'] = null;
|
|
||||||
this.data.node.entry.properties['qshare:expiryDate'] = null;
|
|
||||||
this.dialogRef.close(this.data.node);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private updateForm() {
|
|
||||||
const { entry } = this.data.node;
|
|
||||||
const expiryDate = entry.properties['qshare:expiryDate'];
|
|
||||||
|
|
||||||
this.form.setValue({
|
|
||||||
sharedUrl: `${this.baseShareUrl}${this.sharedId}`,
|
|
||||||
time: expiryDate ? expiryDate : null
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private updateNode(date: moment.Moment): Observable<MinimalNodeEntryEntity> {
|
|
||||||
return this.nodesApiService.updateNode(this.data.node.entry.id, {
|
|
||||||
properties: {
|
|
||||||
'qshare:expiryDate': date ? date.endOf('day') : null
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private updateEntryExpiryDate(date: moment.Moment) {
|
|
||||||
const { properties } = this.data.node.entry;
|
|
||||||
|
|
||||||
properties['qshare:expiryDate'] = date ? date.toDate() : null;
|
|
||||||
}
|
|
||||||
|
|
||||||
private showError(response: { message: any }) {
|
|
||||||
let message;
|
|
||||||
const statusCode = JSON.parse(response.message).error.statusCode;
|
|
||||||
if (statusCode === 403) {
|
|
||||||
message = 'SHARED_LINK.UNSHARE_PERMISSION_ERROR';
|
|
||||||
}
|
|
||||||
|
|
||||||
this.store.dispatch(new SnackbarErrorAction(message));
|
|
||||||
}
|
|
||||||
}
|
|
@@ -1,41 +0,0 @@
|
|||||||
/*!
|
|
||||||
* @license
|
|
||||||
* Copyright 2019 Alfresco Software, Ltd.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import { NgModule, ModuleWithProviders } from '@angular/core';
|
|
||||||
import { CommonModule } from '@angular/common';
|
|
||||||
import { CoreModule } from '@alfresco/adf-core';
|
|
||||||
import { ShareDialogComponent } from './content-node-share.dialog';
|
|
||||||
|
|
||||||
@NgModule({
|
|
||||||
imports: [CoreModule.forChild(), CommonModule],
|
|
||||||
declarations: [ShareDialogComponent],
|
|
||||||
exports: [ShareDialogComponent],
|
|
||||||
entryComponents: [ShareDialogComponent]
|
|
||||||
})
|
|
||||||
export class ContentNodeShareModule {
|
|
||||||
static forRoot(): ModuleWithProviders {
|
|
||||||
return {
|
|
||||||
ngModule: ContentNodeShareModule
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
static forChild(): ModuleWithProviders {
|
|
||||||
return {
|
|
||||||
ngModule: ContentNodeShareModule
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
@@ -1,44 +0,0 @@
|
|||||||
/*!
|
|
||||||
* @license
|
|
||||||
* Alfresco Example Content Application
|
|
||||||
*
|
|
||||||
* Copyright (C) 2005 - 2019 Alfresco Software Limited
|
|
||||||
*
|
|
||||||
* This file is part of the Alfresco Example Content Application.
|
|
||||||
* If the software was purchased under a paid Alfresco license, the terms of
|
|
||||||
* the paid license agreement will prevail. Otherwise, the software is
|
|
||||||
* provided under the following open source license terms:
|
|
||||||
*
|
|
||||||
* The Alfresco Example Content Application is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU Lesser General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* The Alfresco Example Content Application is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU Lesser General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Lesser General Public License
|
|
||||||
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import { NgModule } from '@angular/core';
|
|
||||||
import { CommonModule } from '@angular/common';
|
|
||||||
import { CoreModule } from '@alfresco/adf-core';
|
|
||||||
import { ExtensionsModule } from '@alfresco/adf-extensions';
|
|
||||||
import { ToggleSharedModule } from './toggle-shared/toggle-shared.module';
|
|
||||||
import { ContentNodeShareModule } from './content-node-share/content-node-share.module';
|
|
||||||
import { ShareDialogComponent } from './content-node-share/content-node-share.dialog';
|
|
||||||
|
|
||||||
@NgModule({
|
|
||||||
imports: [
|
|
||||||
CommonModule,
|
|
||||||
CoreModule.forChild(),
|
|
||||||
ExtensionsModule,
|
|
||||||
ContentNodeShareModule,
|
|
||||||
ToggleSharedModule
|
|
||||||
],
|
|
||||||
entryComponents: [ShareDialogComponent]
|
|
||||||
})
|
|
||||||
export class AppSharedModule {}
|
|
@@ -1,48 +0,0 @@
|
|||||||
/*!
|
|
||||||
* @license
|
|
||||||
* Alfresco Example Content Application
|
|
||||||
*
|
|
||||||
* Copyright (C) 2005 - 2019 Alfresco Software Limited
|
|
||||||
*
|
|
||||||
* This file is part of the Alfresco Example Content Application.
|
|
||||||
* If the software was purchased under a paid Alfresco license, the terms of
|
|
||||||
* the paid license agreement will prevail. Otherwise, the software is
|
|
||||||
* provided under the following open source license terms:
|
|
||||||
*
|
|
||||||
* The Alfresco Example Content Application is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU Lesser General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* The Alfresco Example Content Application is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU Lesser General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Lesser General Public License
|
|
||||||
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import { NgModule } from '@angular/core';
|
|
||||||
import { CommonModule } from '@angular/common';
|
|
||||||
import { CoreModule } from '@alfresco/adf-core';
|
|
||||||
import { ContentNodeShareModule } from '@alfresco/adf-content-services';
|
|
||||||
import { ExtensionsModule } from '@alfresco/adf-extensions';
|
|
||||||
import { ToggleSharedComponent } from './toggle-shared.component';
|
|
||||||
|
|
||||||
export function components() {
|
|
||||||
return [ToggleSharedComponent];
|
|
||||||
}
|
|
||||||
|
|
||||||
@NgModule({
|
|
||||||
imports: [
|
|
||||||
CommonModule,
|
|
||||||
CoreModule.forChild(),
|
|
||||||
ExtensionsModule,
|
|
||||||
ContentNodeShareModule
|
|
||||||
],
|
|
||||||
declarations: components(),
|
|
||||||
exports: components(),
|
|
||||||
entryComponents: components()
|
|
||||||
})
|
|
||||||
export class ToggleSharedModule {}
|
|
@@ -32,7 +32,6 @@ import { AppExtensionService } from './extension.service';
|
|||||||
import { ToggleInfoDrawerComponent } from '../components/toolbar/toggle-info-drawer/toggle-info-drawer.component';
|
import { ToggleInfoDrawerComponent } from '../components/toolbar/toggle-info-drawer/toggle-info-drawer.component';
|
||||||
import { ToggleFavoriteComponent } from '../components/toolbar/toggle-favorite/toggle-favorite.component';
|
import { ToggleFavoriteComponent } from '../components/toolbar/toggle-favorite/toggle-favorite.component';
|
||||||
import { ToggleFavoriteLibraryComponent } from '../components/toolbar/toggle-favorite-library/toggle-favorite-library.component';
|
import { ToggleFavoriteLibraryComponent } from '../components/toolbar/toggle-favorite-library/toggle-favorite-library.component';
|
||||||
import { ToggleSharedComponent } from '../components/shared/toggle-shared/toggle-shared.component';
|
|
||||||
import { MetadataTabComponent } from '../components/info-drawer/metadata-tab/metadata-tab.component';
|
import { MetadataTabComponent } from '../components/info-drawer/metadata-tab/metadata-tab.component';
|
||||||
import { LibraryMetadataTabComponent } from '../components/info-drawer/library-metadata-tab/library-metadata-tab.component';
|
import { LibraryMetadataTabComponent } from '../components/info-drawer/library-metadata-tab/library-metadata-tab.component';
|
||||||
import { CommentsTabComponent } from '../components/info-drawer/comments-tab/comments-tab.component';
|
import { CommentsTabComponent } from '../components/info-drawer/comments-tab/comments-tab.component';
|
||||||
@@ -50,6 +49,7 @@ import {
|
|||||||
TrashcanNameColumnComponent,
|
TrashcanNameColumnComponent,
|
||||||
LibraryRoleColumnComponent
|
LibraryRoleColumnComponent
|
||||||
} from '@alfresco/adf-content-services';
|
} from '@alfresco/adf-content-services';
|
||||||
|
import { ToggleSharedComponent } from '../components/common/toggle-shared/toggle-shared.component';
|
||||||
|
|
||||||
export function setupExtensions(service: AppExtensionService): Function {
|
export function setupExtensions(service: AppExtensionService): Function {
|
||||||
return () => service.load();
|
return () => service.load();
|
||||||
|
@@ -45,7 +45,8 @@ import {
|
|||||||
import {
|
import {
|
||||||
ConfirmDialogComponent,
|
ConfirmDialogComponent,
|
||||||
FolderDialogComponent,
|
FolderDialogComponent,
|
||||||
LibraryDialogComponent
|
LibraryDialogComponent,
|
||||||
|
ShareDialogComponent
|
||||||
} from '@alfresco/adf-content-services';
|
} from '@alfresco/adf-content-services';
|
||||||
import { TranslationService } from '@alfresco/adf-core';
|
import { TranslationService } from '@alfresco/adf-core';
|
||||||
import {
|
import {
|
||||||
@@ -65,7 +66,6 @@ import { Store } from '@ngrx/store';
|
|||||||
import { forkJoin, Observable, of, Subject, zip } from 'rxjs';
|
import { forkJoin, Observable, of, Subject, zip } from 'rxjs';
|
||||||
import { catchError, flatMap, map, mergeMap, take, tap } from 'rxjs/operators';
|
import { catchError, flatMap, map, mergeMap, take, tap } from 'rxjs/operators';
|
||||||
import { NodePermissionsDialogComponent } from '../components/permissions/permission-dialog/node-permissions.dialog';
|
import { NodePermissionsDialogComponent } from '../components/permissions/permission-dialog/node-permissions.dialog';
|
||||||
import { ShareDialogComponent } from '../components/shared/content-node-share/content-node-share.dialog';
|
|
||||||
import { NodeVersionUploadDialogComponent } from '../dialogs/node-version-upload/node-version-upload.dialog';
|
import { NodeVersionUploadDialogComponent } from '../dialogs/node-version-upload/node-version-upload.dialog';
|
||||||
import { NodeVersionsDialogComponent } from '../dialogs/node-versions/node-versions.dialog';
|
import { NodeVersionsDialogComponent } from '../dialogs/node-versions/node-versions.dialog';
|
||||||
import { NodeActionsService } from './node-actions.service';
|
import { NodeActionsService } from './node-actions.service';
|
||||||
@@ -208,7 +208,6 @@ export class ContentManagementService {
|
|||||||
width: '600px',
|
width: '600px',
|
||||||
panelClass: 'adf-share-link-dialog',
|
panelClass: 'adf-share-link-dialog',
|
||||||
data: {
|
data: {
|
||||||
permission: this.permission.check(node, ['update']),
|
|
||||||
node,
|
node,
|
||||||
baseShareUrl
|
baseShareUrl
|
||||||
}
|
}
|
||||||
|
@@ -17,4 +17,16 @@ $theme: mat-light-theme($primary, $accent, $warn);
|
|||||||
@include adf-content-services-theme($theme);
|
@include adf-content-services-theme($theme);
|
||||||
@include adf-core-theme($theme);
|
@include adf-core-theme($theme);
|
||||||
|
|
||||||
|
// fixes [ACA-2069]
|
||||||
|
$primary: map-get($theme, primary);
|
||||||
|
.mat-slide-toggle.mat-primary.mat-checked:not(.mat-disabled) {
|
||||||
|
.mat-slide-toggle-thumb,
|
||||||
|
.mat-slide-toggle-ripple .mat-ripple-element {
|
||||||
|
background-color: mat-color($primary);
|
||||||
|
}
|
||||||
|
.mat-slide-toggle-bar {
|
||||||
|
background-color: mat-color($primary, 0.54);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@include custom-theme($custom-theme);
|
@include custom-theme($custom-theme);
|
||||||
|
Reference in New Issue
Block a user