[DE mobile] Add protection

This commit is contained in:
SergeyEzhin 2022-12-05 20:24:19 +04:00
parent b6971521c4
commit 20a949da7e
3 changed files with 68 additions and 3 deletions

View file

@ -19,6 +19,7 @@ import PluginsController from '../../../../common/mobile/lib/controller/Plugins.
import EncodingController from "./Encoding"; import EncodingController from "./Encoding";
import DropdownListController from "./DropdownList"; import DropdownListController from "./DropdownList";
import { Device } from '../../../../common/mobile/utils/device'; import { Device } from '../../../../common/mobile/utils/device';
@inject( @inject(
"users", "users",
"storeAppOptions", "storeAppOptions",
@ -46,7 +47,8 @@ class MainController extends Component {
this._state = { this._state = {
licenseType: false, licenseType: false,
isFromGatewayDownloadAs: false, isFromGatewayDownloadAs: false,
isDocModified: false isDocModified: false,
docProtection: false
}; };
this.defaultTitleText = __APP_TITLE_TEXT__; this.defaultTitleText = __APP_TITLE_TEXT__;
@ -762,6 +764,10 @@ class MainController extends Component {
} }
}); });
// Protection document
this.api.asc_registerCallback('asc_onChangeDocumentProtection', this.onChangeProtectDocument.bind(this));
// this.api.asc_registerCallback('asc_onLockDocumentProtection', this.onLockDocumentProtection.bind(this));
// Toolbar settings // Toolbar settings
const storeToolbarSettings = this.props.storeToolbarSettings; const storeToolbarSettings = this.props.storeToolbarSettings;
@ -783,6 +789,56 @@ class MainController extends Component {
}); });
} }
onChangeProtectDocument() {
const storeAppOptions = this.props.storeAppOptions;
const props = this.getDocProps(true);
const isProtected = props && (props.isReadOnly || props.isCommentsOnly || props.isFormsOnly || props.isReviewOnly);
storeAppOptions.setProtection(isProtected);
props && this.applyRestrictions(props.type);
Common.Notifications.trigger('protect:doclock', props);
}
applyRestrictions(type) {
const storeAppOptions = this.props.storeAppOptions;
if (type === Asc.c_oAscEDocProtect.ReadOnly) {
this.api.asc_setRestriction(Asc.c_oAscRestrictionType.View);
} else if (type === Asc.c_oAscEDocProtect.Comments) {
this.api.asc_setRestriction(storeAppOptions.canComments ? Asc.c_oAscRestrictionType.OnlyComments : Asc.c_oAscRestrictionType.View);
} else if (type === Asc.c_oAscEDocProtect.Forms) {
this.api.asc_setRestriction(storeAppOptions.canFillForms ? Asc.c_oAscRestrictionType.OnlyForms : Asc.c_oAscRestrictionType.View);
} else {
if (storeAppOptions?.isRestrictedEdit) {
storeAppOptions.canComments && this.api.asc_setRestriction(Asc.c_oAscRestrictionType.OnlyComments);
storeAppOptions.canFillForms && this.api.asc_setRestriction(Asc.c_oAscRestrictionType.OnlyForms);
} else {
this.api.asc_setRestriction(Asc.c_oAscRestrictionType.None);
}
}
};
getDocProps(isUpdate) {
const storeAppOptions = this.props.storeAppOptions;
if (!storeAppOptions || !storeAppOptions.isEdit && !storeAppOptions.isRestrictedEdit) return;
if (isUpdate || !this.state.docProtection) {
const props = this.api.asc_getDocumentProtection();
const type = props ? props.asc_getEditType() : Asc.c_oAscEDocProtect.None;
this._state.docProtection = {
type: type,
isReadOnly: type === Asc.c_oAscEDocProtect.ReadOnly,
isCommentsOnly: type === Asc.c_oAscEDocProtect.Comments,
isReviewOnly: type === Asc.c_oAscEDocProtect.TrackedChanges,
isFormsOnly: type === Asc.c_oAscEDocProtect.Forms
};
}
return this._state.docProtection;
}
onApiTextReplaced(found, replaced) { onApiTextReplaced(found, replaced) {
const { t } = this.props; const { t } = this.props;

View file

@ -140,6 +140,7 @@ class MainPage extends Component {
const disabledControls = storeToolbarSettings.disabledControls; const disabledControls = storeToolbarSettings.disabledControls;
const disabledSettings = storeToolbarSettings.disabledSettings; const disabledSettings = storeToolbarSettings.disabledSettings;
const config = appOptions.config; const config = appOptions.config;
const isProtected = appOptions.isProtected;
let showLogo = !(config.customization && (config.customization.loaderName || config.customization.loaderLogo)); let showLogo = !(config.customization && (config.customization.loaderName || config.customization.loaderLogo));
if (!Object.keys(config).length) { if (!Object.keys(config).length) {
@ -250,7 +251,7 @@ class MainPage extends Component {
text={isMobileView ? t("Toolbar.textSwitchedMobileView") : t("Toolbar.textSwitchedStandardView")}/> text={isMobileView ? t("Toolbar.textSwitchedMobileView") : t("Toolbar.textSwitchedStandardView")}/>
</CSSTransition> </CSSTransition>
} }
{isViewer && !disabledSettings && !disabledControls && !isDisconnected && isAvailableExt && isEdit && {isViewer && !disabledSettings && !disabledControls && !isDisconnected && isAvailableExt && isEdit && !isProtected &&
<Fab position="right-bottom" slot="fixed" onClick={() => this.turnOffViewerMode()}> <Fab position="right-bottom" slot="fixed" onClick={() => this.turnOffViewerMode()}>
<Icon icon="icon-edit-mode"/> <Icon icon="icon-edit-mode"/>
</Fab> </Fab>

View file

@ -29,12 +29,20 @@ export class storeAppOptions {
changeViewerMode: action, changeViewerMode: action,
isMobileView: observable, isMobileView: observable,
changeMobileView: action changeMobileView: action,
isProtected: observable,
setProtection: action
}); });
} }
isEdit = false; isEdit = false;
isProtected = false;
setProtection(value) {
this.isProtected = value;
}
isMobileView = true; isMobileView = true;
changeMobileView() { changeMobileView() {
this.isMobileView = !this.isMobileView; this.isMobileView = !this.isMobileView;