web-apps/apps/common/mobile/lib/view/About.jsx

131 lines
6.6 KiB
React
Raw Normal View History

2021-03-17 15:44:35 +00:00
import React, { Fragment } from 'react';
import { observer, inject } from "mobx-react";
import { Page, Navbar, Link } from "framework7-react";
import { useTranslation } from "react-i18next";
2022-12-20 14:52:16 +00:00
import { Device } from '../../utils/device';
2021-03-17 15:44:35 +00:00
const PageAbout = props => {
const { t } = useTranslation();
const _t = t("About", { returnObjects: true });
const store = props.storeAppOptions;
const isCanBranding = store.canBranding;
const licInfo = isCanBranding ? store.customization : null;
const customer = licInfo ? licInfo.customer : null;
const nameCustomer = customer ? customer.name : null;
const mailCustomer = customer ? customer.mail : null;
2022-06-08 09:49:01 +00:00
const phoneCustomer = customer ? customer.phone : null;
2021-03-17 15:44:35 +00:00
const addressCustomer = customer ? customer.address : null;
const urlCustomer = customer ? customer.www : null;
const infoCustomer = customer ? customer.info : null;
const logoCustomer = customer ? customer.logo : null;
2022-12-20 14:52:16 +00:00
const publisherUrl = __PUBLISHER_URL__,
2021-10-23 13:14:30 +00:00
publisherPrintUrl = publisherUrl.replace(/https?:\/{2}|\/$/g,"");
const publisherName = __PUBLISHER_NAME__.replace(/\\"/g, '"');
2021-03-26 14:48:18 +00:00
const editors = {
de: 'DOCUMENT EDITOR',
pe: 'PRESENTATION EDITOR',
sse: 'SPREADSHEET EDITOR'
};
2022-06-06 14:16:42 +00:00
const nameEditor = (_t.textEditor || editors[editorType]).toUpperCase();
2021-03-17 15:44:35 +00:00
return (
2022-12-22 13:59:07 +00:00
<Page className={"about" + (!Device.phone ? " about_tablet" : Device.ios ? " about_ios" : " about_android")}>
2021-03-17 15:44:35 +00:00
<Navbar title={_t.textAbout} backLink={_t.textBack} />
{licInfo && typeof licInfo == 'object' && typeof(customer) == 'object' ? (
<Fragment>
2022-12-20 14:52:16 +00:00
<div className="logo-block">
2021-03-17 15:44:35 +00:00
{logoCustomer && logoCustomer.length ? (
2022-12-20 14:52:16 +00:00
<div id="settings-about-logo" className="logo-block__elem">
2021-03-17 15:44:35 +00:00
<img src={logoCustomer} alt="" />
</div>
) : null}
</div>
2022-12-20 14:52:16 +00:00
<div className="about__editor">
<p className="about__text">{nameEditor}</p>
<p className="about__text">{_t.textVersion} {__PRODUCT_VERSION__}</p>
2021-03-17 15:44:35 +00:00
</div>
2022-12-20 14:52:16 +00:00
{mailCustomer || phoneCustomer ? (
<div className="about__customer">
{mailCustomer && mailCustomer.length ? (
<p className="about__text">
<Link id="settings-about-email" external={true} href={"mailto:"+mailCustomer}>{mailCustomer}</Link>
</p>
) : null}
{phoneCustomer && phoneCustomer.length ? (
<p className="about__text">
<Link id="settings-about-tel" external={true} href={"tel:"+phoneCustomer}>{phoneCustomer}</Link>
</p>
) : null}
</div>
) : null}
{addressCustomer && addressCustomer.length ? (
<div className="about__customer">
<p className="about__text">
2022-05-11 14:55:02 +00:00
<Link id="settings-about-address" external={true}>{addressCustomer}</Link>
2021-03-17 15:44:35 +00:00
</p>
2022-12-20 14:52:16 +00:00
</div>
) : null}
{nameCustomer || infoCustomer || urlCustomer ? (
<div className="about__customer">
{nameCustomer && nameCustomer.length ? (
<p id="settings-about-name" className="about__text">{nameCustomer}</p>
) : null}
{infoCustomer && infoCustomer.length ? (
<p className="about__text">{infoCustomer}</p>
) : null}
{urlCustomer && urlCustomer.length ? (
<p className="about__text">
<Link id="settings-about-url" external={true} target="_blank"
href={!/^https?:\/{2}/i.test(urlCustomer) ? "http:\/\/" : '' + urlCustomer}>
{urlCustomer}
</Link>
</p>
2021-03-17 15:44:35 +00:00
) : null}
2022-12-20 14:52:16 +00:00
</div>
) : null}
<div className="about__contacts">
<p className="about__text" id="settings-about-address">
{__PUBLISHER_ADDRESS__}
2021-03-17 15:44:35 +00:00
</p>
2022-12-20 14:52:16 +00:00
</div>
<div className="about__licensor" id="settings-about-licensor">
<p className="about__text">{publisherName}</p>
<p className="about__text">
2022-05-11 14:55:02 +00:00
<Link external={true} target="_blank" href={publisherUrl}>{publisherPrintUrl}</Link>
2021-03-17 15:44:35 +00:00
</p>
</div>
</Fragment>
) : (
<Fragment>
2022-12-20 14:52:16 +00:00
<div className="about__logo"></div>
<div className="about__editor">
<p className="about__text">{nameEditor}</p>
<p className="about__text">{_t.textVersion} {__PRODUCT_VERSION__}</p>
2021-03-17 15:44:35 +00:00
</div>
2022-12-20 14:52:16 +00:00
<div className="about__contacts">
<p className="about__text" id="settings-about-address">
{__PUBLISHER_ADDRESS__}
2021-03-17 15:44:35 +00:00
</p>
2022-12-20 14:52:16 +00:00
</div>
<div className="about__licensor">
<p className="about__text" id="settings-about-name">{publisherName}</p>
<p className="about__text">
2022-05-11 14:55:02 +00:00
<Link id="settings-about-url" external={true} target="_blank" href={publisherUrl}>{publisherPrintUrl}</Link>
2021-03-17 15:44:35 +00:00
</p>
</div>
</Fragment>
)}
</Page>
);
};
const About = inject("storeAppOptions")(observer(PageAbout));
2022-06-24 19:09:02 +00:00
About.appVersion = () => (__PRODUCT_VERSION__).match(/\d+.\d+.\d+/)[0]; // skip build number
About.compareVersions = () => /d$/.test(__PRODUCT_VERSION__);
2021-05-03 17:02:21 +00:00
About.developVersion = () => /(?:d|debug)$/.test(__PRODUCT_VERSION__);
2021-03-17 15:44:35 +00:00
export default About;