commit
0339ef366f
|
@ -9,11 +9,12 @@ import Modal from 'core-components/modal';
|
|||
|
||||
class ModalContainer extends React.Component {
|
||||
|
||||
static openModal(content, noPadding) {
|
||||
static openModal(content, noPadding, outsideClick=false) {
|
||||
store.dispatch(
|
||||
ModalActions.openModal({
|
||||
content,
|
||||
noPadding
|
||||
noPadding,
|
||||
outsideClick
|
||||
})
|
||||
);
|
||||
}
|
||||
|
@ -49,8 +50,9 @@ class ModalContainer extends React.Component {
|
|||
}
|
||||
|
||||
renderModal() {
|
||||
const {content, noPadding, outsideClick} = this.props.modal;
|
||||
return (
|
||||
<Modal content={this.props.modal.content} noPadding={this.props.modal.noPadding}/>
|
||||
<Modal content={content} noPadding={noPadding} outsideClick={outsideClick} onOutsideClick={this.closeModal.bind(this)}/>
|
||||
);
|
||||
}
|
||||
|
||||
|
|
|
@ -0,0 +1,46 @@
|
|||
import React from 'react';
|
||||
|
||||
import i18n from 'lib-app/i18n';
|
||||
import ModalContainer from 'app-components/modal-container';
|
||||
|
||||
import Button from 'core-components/button';
|
||||
import Icon from 'core-components/icon';
|
||||
import Message from 'core-components/message';
|
||||
|
||||
|
||||
class PopupMessage extends React.Component {
|
||||
static propTypes = Message.propTypes;
|
||||
|
||||
static contextTypes = {
|
||||
closeModal: React.PropTypes.func
|
||||
};
|
||||
|
||||
static open(props) {
|
||||
ModalContainer.openModal(
|
||||
<PopupMessage {...props}/>,
|
||||
true,
|
||||
true
|
||||
);
|
||||
}
|
||||
|
||||
componentDidMount() {
|
||||
this.refs.closeButton && this.refs.closeButton.focus();
|
||||
}
|
||||
|
||||
render() {
|
||||
return (
|
||||
<div className="popup-message">
|
||||
<Message {...this.props} className="popup-message__message"/>
|
||||
<Button className="popup-message__close-button" iconName="times" type="clean" ref="closeButton" onClick={this.closeModal.bind(this)}/>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
closeModal() {
|
||||
if (this.context.closeModal) {
|
||||
this.context.closeModal();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
export default PopupMessage;
|
|
@ -0,0 +1,17 @@
|
|||
@import "../scss/vars";
|
||||
|
||||
.popup-message {
|
||||
min-width: 500px;
|
||||
position: relative;
|
||||
|
||||
&__close-button {
|
||||
position: absolute;
|
||||
top: 0;
|
||||
right: 0;
|
||||
color: $dark-grey;
|
||||
&:focus {
|
||||
outline: none;
|
||||
color: $grey;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -49,7 +49,7 @@ import AdminPanelViewStaff from 'app/admin/panel/staff/admin-panel-view-staff';
|
|||
|
||||
import AdminPanelSystemPreferences from 'app/admin/panel/settings/admin-panel-system-preferences';
|
||||
import AdminPanelAdvancedSettings from 'app/admin/panel/settings/admin-panel-advanced-settings';
|
||||
import AdminPanelEmailTemplates from 'app/admin/panel/settings/admin-panel-email-templates';
|
||||
import AdminPanelEmailSettings from 'app/admin/panel/settings/admin-panel-email-settings';
|
||||
|
||||
// INSTALLATION
|
||||
import InstallLayout from 'app/install/install-layout';
|
||||
|
@ -139,7 +139,7 @@ export default (
|
|||
<IndexRedirect to="system-preferences" />
|
||||
<Route path="system-preferences" component={AdminPanelSystemPreferences} />
|
||||
<Route path="advanced-settings" component={AdminPanelAdvancedSettings} />
|
||||
<Route path="email-templates" component={AdminPanelEmailTemplates} />
|
||||
<Route path="email-settings" component={AdminPanelEmailSettings} />
|
||||
</Route>
|
||||
</Route>
|
||||
</Route>
|
||||
|
|
|
@ -206,8 +206,8 @@ class AdminPanelMenu extends React.Component {
|
|||
level: 3
|
||||
},
|
||||
{
|
||||
name: i18n('EMAIL_TEMPLATES'),
|
||||
path: '/admin/panel/settings/email-templates',
|
||||
name: i18n('EMAIL_SETTINGS'),
|
||||
path: '/admin/panel/settings/email-settings',
|
||||
level: 3
|
||||
}
|
||||
])
|
||||
|
|
|
@ -0,0 +1,505 @@
|
|||
import React from 'react';
|
||||
import _ from 'lodash';
|
||||
import {connect} from 'react-redux';
|
||||
|
||||
import i18n from 'lib-app/i18n';
|
||||
import API from 'lib-app/api-call';
|
||||
|
||||
import AreYouSure from 'app-components/are-you-sure';
|
||||
import LanguageSelector from 'app-components/language-selector';
|
||||
import PopupMessage from 'app-components/popup-message';
|
||||
|
||||
import Button from 'core-components/button';
|
||||
import Header from 'core-components/header';
|
||||
import Listing from 'core-components/listing';
|
||||
import Loading from 'core-components/loading';
|
||||
import Form from 'core-components/form';
|
||||
import FormField from 'core-components/form-field';
|
||||
import SubmitButton from 'core-components/submit-button';
|
||||
import Message from 'core-components/message';
|
||||
|
||||
class AdminPanelEmailSettings extends React.Component {
|
||||
|
||||
static propTypes = {
|
||||
language: React.PropTypes.string,
|
||||
};
|
||||
|
||||
state = {
|
||||
headerImage: '',
|
||||
loadingHeaderImage: false,
|
||||
loadingList: true,
|
||||
loadingTemplate: false,
|
||||
templates: [],
|
||||
loadingForm: false,
|
||||
selectedIndex: -1,
|
||||
edited: false,
|
||||
errors: {},
|
||||
language: this.props.language,
|
||||
imapLoading: false,
|
||||
smtpLoading: false,
|
||||
form: {
|
||||
subject: '',
|
||||
text1: '',
|
||||
text2: '',
|
||||
text3: '',
|
||||
},
|
||||
emailForm: {
|
||||
['server-email']: '',
|
||||
},
|
||||
smtpForm: {
|
||||
['smtp-host']: '',
|
||||
['smtp-user']: '',
|
||||
['smtp-pass']: 'HIDDEN',
|
||||
},
|
||||
imapForm: {
|
||||
['imap-host']: '',
|
||||
['imap-user']: '',
|
||||
['imap-pass']: 'HIDDEN',
|
||||
},
|
||||
};
|
||||
|
||||
componentDidMount() {
|
||||
this.retrieveMailTemplateList();
|
||||
this.retrieveHeaderImage();
|
||||
}
|
||||
|
||||
render() {
|
||||
return (
|
||||
<div className="admin-panel-email-settings">
|
||||
{(!this.state.loadingList) ? this.renderContent() : this.renderLoading()}
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
renderContent() {
|
||||
return (
|
||||
<div>
|
||||
{this.renderEmailSettings()}
|
||||
<Header title={i18n('EMAIL_TEMPLATES')} description={i18n('EMAIL_TEMPLATES_DESCRIPTION')}/>
|
||||
<div className="row">
|
||||
<div className="col-md-3">
|
||||
<Listing {...this.getListingProps()}/>
|
||||
</div>
|
||||
{(this.state.selectedIndex !== -1) ? this.renderForm() : null}
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
renderLoading() {
|
||||
return (
|
||||
<div className="admin-panel-email-settings__loading">
|
||||
<Loading backgrounded size="large"/>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
renderEmailSettings() {
|
||||
return (
|
||||
<div>
|
||||
<Header title={i18n('EMAIL_SETTINGS')} description={i18n('EMAIL_SETTINGS_DESCRIPTION')}/>
|
||||
<Form className="admin-panel-email-settings__email-form"
|
||||
onSubmit={this.submitEmailAddress.bind(this)}
|
||||
onChange={emailForm => this.setState({emailForm})}
|
||||
values={this.state.emailForm}>
|
||||
<FormField name="server-email"
|
||||
label={i18n('EMAIL_SERVER_ADDRESS')}
|
||||
fieldProps={{size: 'large'}}
|
||||
infoMessage={i18n('EMAIL_SERVER_ADDRESS_DESCRIPTION')}/>
|
||||
<SubmitButton className="admin-panel-email-settings__submit" type="secondary"
|
||||
size="small">{i18n('SAVE')}</SubmitButton>
|
||||
</Form>
|
||||
|
||||
<Form values={{headerImage: this.state.headerImage}}
|
||||
onChange={form => this.setState({headerImage: form.headerImage})}
|
||||
onSubmit={this.onHeaderImageSubmit.bind(this)}>
|
||||
<div className="admin-panel-email-settings__image-container">
|
||||
<FormField className="admin-panel-email-settings__image-header-url"
|
||||
label={i18n('IMAGE_HEADER_URL')} name="headerImage" required
|
||||
infoMessage={i18n('IMAGE_HEADER_URL_DESCRIPTION')}
|
||||
fieldProps={{size: 'large'}}/>
|
||||
<SubmitButton className="admin-panel-email-settings__image-header-submit" type="secondary"
|
||||
size="small">{i18n('SAVE')}</SubmitButton>
|
||||
</div>
|
||||
</Form>
|
||||
|
||||
<div className="admin-panel-email-settings__servers">
|
||||
<div className="admin-panel-email-settings__box">
|
||||
<Header title={i18n('SMTP_SERVER')} description={i18n('SMTP_SERVER_DESCRIPTION')}/>
|
||||
<Form onSubmit={this.submitSMTP.bind(this)} onChange={smtpForm => this.setState({smtpForm})}
|
||||
values={this.state.smtpForm} loading={this.state.smtpLoading}>
|
||||
<FormField name="smtp-host" label={i18n('SMTP_SERVER')} fieldProps={{size: 'large'}}/>
|
||||
<FormField name="smtp-user" label={i18n('SMTP_USER')} fieldProps={{size: 'large'}}/>
|
||||
<FormField name="smtp-pass" label={i18n('SMTP_PASSWORD')} fieldProps={{size: 'large'}}/>
|
||||
<div className="admin-panel-email-settings__server-form-buttons">
|
||||
<SubmitButton className="admin-panel-email-settings__submit" type="secondary"
|
||||
size="small">{i18n('SAVE')}</SubmitButton>
|
||||
<SubmitButton type="tertiary" size="small" onClick={this.testSMTP.bind(this)}>
|
||||
Test
|
||||
</SubmitButton>
|
||||
</div>
|
||||
</Form>
|
||||
</div>
|
||||
|
||||
<div className="admin-panel-email-settings__box">
|
||||
<Header title={i18n('IMAP_SERVER')} description={i18n('IMAP_SERVER_DESCRIPTION')}/>
|
||||
<Form onSubmit={this.submitIMAP.bind(this)} onChange={imapForm => this.setState({imapForm})}
|
||||
values={this.state.imapForm} loading={this.state.imapLoading}>
|
||||
<FormField name="imap-host" label={i18n('IMAP_SERVER')} fieldProps={{size: 'large'}}/>
|
||||
<FormField name="imap-user" label={i18n('IMAP_USER')} fieldProps={{size: 'large'}}/>
|
||||
<FormField name="imap-pass" label={i18n('IMAP_PASSWORD')} fieldProps={{size: 'large'}}/>
|
||||
<div className="admin-panel-email-settings__server-form-buttons">
|
||||
<SubmitButton className="admin-panel-email-settings__submit" type="secondary"
|
||||
size="small">{i18n('SAVE')}</SubmitButton>
|
||||
<SubmitButton type="tertiary" size="small" onClick={this.testIMAP.bind(this)}>
|
||||
Test
|
||||
</SubmitButton>
|
||||
</div>
|
||||
</Form>
|
||||
<Message className="admin-panel-email-settings__imap-message" type="info">
|
||||
{i18n('IMAP_POLLING_DESCRIPTION', {url: `${apiRoot}/system/email-polling`})}
|
||||
</Message>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
renderForm() {
|
||||
return (
|
||||
<div className="col-md-9">
|
||||
<FormField label={i18n('LANGUAGE')} decorator={LanguageSelector} value={this.state.language}
|
||||
onChange={event => this.onItemChange(this.state.selectedIndex, event.target.value)}
|
||||
fieldProps={{
|
||||
type: 'allowed',
|
||||
size: 'medium'
|
||||
}}/>
|
||||
<Form {...this.getFormProps()}>
|
||||
<div className="row">
|
||||
<div className="col-md-7">
|
||||
<FormField label={i18n('SUBJECT')} name="subject" validation="TITLE" required
|
||||
fieldProps={{size: 'large'}}/>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<FormField label={i18n('TEXT') + '1'} name="text1" validation="TEXT_AREA" required
|
||||
decorator={'textarea'}
|
||||
fieldProps={{className: 'admin-panel-email-settings__text-area'}}/>
|
||||
{(this.state.form.text2) ?
|
||||
<FormField label={i18n('TEXT') + '2'} name="text2" validation="TEXT_AREA" required
|
||||
decorator={'textarea'}
|
||||
fieldProps={{className: 'admin-panel-email-settings__text-area'}}/> : null}
|
||||
{(this.state.form.text3) ?
|
||||
<FormField label={i18n('TEXT') + '3'} name="text3" validation="TEXT_AREA" required
|
||||
decorator={'textarea'}
|
||||
fieldProps={{className: 'admin-panel-email-settings__text-area'}}/> : null}
|
||||
|
||||
<div className="admin-panel-email-settings__actions">
|
||||
<div className="admin-panel-email-settings__save-button">
|
||||
<SubmitButton type="secondary" size="small">{i18n('SAVE')}</SubmitButton>
|
||||
</div>
|
||||
<div className="admin-panel-email-settings__optional-buttons">
|
||||
{(this.state.edited) ? this.renderDiscardButton() : null}
|
||||
<div className="admin-panel-email-settings__recover-button">
|
||||
<Button onClick={this.onRecoverClick.bind(this)} size="medium">
|
||||
{i18n('RECOVER_DEFAULT')}
|
||||
</Button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Form>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
renderDiscardButton() {
|
||||
return (
|
||||
<div className="admin-panel-email-settings__discard-button">
|
||||
<Button onClick={this.onDiscardChangesClick.bind(this)} size="medium">
|
||||
{i18n('DISCARD_CHANGES')}
|
||||
</Button>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
getListingProps() {
|
||||
return {
|
||||
title: i18n('EMAIL_TEMPLATES'),
|
||||
items: this.getTemplateItems(),
|
||||
selectedIndex: this.state.selectedIndex,
|
||||
onChange: this.onItemChange.bind(this)
|
||||
};
|
||||
}
|
||||
|
||||
getFormProps() {
|
||||
return {
|
||||
values: this.state.form,
|
||||
errors: this.state.errors,
|
||||
loading: this.state.loadingForm,
|
||||
onChange: (form) => {
|
||||
this.setState({form, edited: true})
|
||||
},
|
||||
onValidateErrors: (errors) => {
|
||||
this.setState({errors})
|
||||
},
|
||||
onSubmit: this.onFormSubmit.bind(this)
|
||||
}
|
||||
}
|
||||
|
||||
getTemplateItems() {
|
||||
return this.state.templates.map((template) => {
|
||||
return {
|
||||
content: template
|
||||
};
|
||||
});
|
||||
}
|
||||
|
||||
onItemChange(index, language) {
|
||||
if (this.state.edited) {
|
||||
AreYouSure.openModal(i18n('WILL_LOSE_CHANGES'), this.retrieveEmailTemplate.bind(this, index, language || this.state.language));
|
||||
} else {
|
||||
this.retrieveEmailTemplate(index, language || this.state.language);
|
||||
}
|
||||
}
|
||||
|
||||
onHeaderImageSubmit(form) {
|
||||
this.setState({
|
||||
loadingHeaderImage: true,
|
||||
});
|
||||
|
||||
API.call({
|
||||
path: '/system/edit-settings',
|
||||
data: {
|
||||
'mail-template-header-image': form['headerImage']
|
||||
}
|
||||
}).then(() => this.setState({
|
||||
loadingHeaderImage: false,
|
||||
}))
|
||||
}
|
||||
|
||||
onFormSubmit(form) {
|
||||
const {selectedIndex, language, templates} = this.state;
|
||||
|
||||
this.setState({loadingForm: true});
|
||||
|
||||
API.call({
|
||||
path: '/system/edit-mail-template',
|
||||
data: {
|
||||
template: templates[selectedIndex],
|
||||
language,
|
||||
subject: form.subject,
|
||||
text1: form.text1,
|
||||
text2: form.text2,
|
||||
text3: form.text3,
|
||||
}
|
||||
}).then(() => {
|
||||
this.setState({loadingForm: false, edited: false});
|
||||
}).catch(response => {
|
||||
this.setState({
|
||||
loadingForm: false,
|
||||
});
|
||||
|
||||
switch (response.message) {
|
||||
case 'INVALID_SUBJECT':
|
||||
this.setState({
|
||||
errors: {subject: i18n('INVALID_SYNTAX')}
|
||||
});
|
||||
break;
|
||||
case 'INVALID_TEXT_1':
|
||||
this.setState({
|
||||
errors: {text1: i18n('INVALID_SYNTAX')}
|
||||
});
|
||||
break;
|
||||
case 'INVALID_TEXT_2':
|
||||
this.setState({
|
||||
errors: {text2: i18n('INVALID_SYNTAX')}
|
||||
});
|
||||
break;
|
||||
case 'INVALID_TEXT_3':
|
||||
this.setState({
|
||||
errors: {text3: i18n('INVALID_SYNTAX')}
|
||||
});
|
||||
break;
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
onDiscardChangesClick(event) {
|
||||
event.preventDefault();
|
||||
this.onItemChange(this.state.selectedIndex, this.state.language);
|
||||
}
|
||||
|
||||
onRecoverClick(event) {
|
||||
event.preventDefault();
|
||||
AreYouSure.openModal(i18n('WILL_RECOVER_EMAIL_TEMPLATE'), this.recoverEmailTemplate.bind(this));
|
||||
}
|
||||
|
||||
submitEmailAddress(form) {
|
||||
this.editSettings(form, 'EMAIL_SUCCESS');
|
||||
}
|
||||
|
||||
submitSMTP(form) {
|
||||
this.setState({
|
||||
smtpLoading: true
|
||||
});
|
||||
|
||||
this.editSettings(form, 'SMTP_SUCCESS')
|
||||
.then(() => this.setState({
|
||||
smtpLoading: false
|
||||
}));
|
||||
}
|
||||
|
||||
submitIMAP(form) {
|
||||
this.setState({
|
||||
imapLoading: true
|
||||
});
|
||||
|
||||
this.editSettings(form, 'IMAP_SUCCESS')
|
||||
.then(() => this.setState({
|
||||
imapLoading: false
|
||||
}));
|
||||
}
|
||||
|
||||
editSettings(form, successMessage) {
|
||||
return API.call({
|
||||
path: '/system/edit-settings',
|
||||
data: this.parsePasswordField(form)
|
||||
}).then(() => PopupMessage.open({
|
||||
title: i18n('SETTINGS_UPDATED'),
|
||||
children: i18n(successMessage),
|
||||
type: 'success'
|
||||
})).catch(response => PopupMessage.open({
|
||||
title: i18n('ERROR_UPDATING_SETTINGS'),
|
||||
children: response.message,
|
||||
type: 'error'
|
||||
}));
|
||||
}
|
||||
|
||||
testSMTP(event) {
|
||||
event.preventDefault();
|
||||
|
||||
this.setState({
|
||||
smtpLoading: true
|
||||
});
|
||||
|
||||
API.call({
|
||||
path: '/system/test-smtp',
|
||||
data: this.parsePasswordField(this.state.smtpForm)
|
||||
}).then(() => PopupMessage.open({
|
||||
title: `${i18n('SUCCESSFUL_CONNECTION')}: SMTP`,
|
||||
children: i18n('SERVER_CREDENTIALS_WORKING'),
|
||||
type: 'success',
|
||||
})).catch(response => PopupMessage.open({
|
||||
title: `${i18n('UNSUCCESSFUL_CONNECTION')}: SMTP`,
|
||||
children: `${i18n('SERVER_ERROR')}: ${response.message}`,
|
||||
type: 'error',
|
||||
})).then(() => this.setState({
|
||||
smtpLoading: false
|
||||
}));
|
||||
}
|
||||
|
||||
testIMAP(event) {
|
||||
event.preventDefault();
|
||||
|
||||
this.setState({
|
||||
imapLoading: true
|
||||
});
|
||||
|
||||
API.call({
|
||||
path: '/system/test-imap',
|
||||
data: this.parsePasswordField(this.state.imapForm)
|
||||
}).then(() => PopupMessage.open({
|
||||
title: `${i18n('SUCCESSFUL_CONNECTION')}: IMAP`,
|
||||
children: i18n('SERVER_CREDENTIALS_WORKING'),
|
||||
type: 'success',
|
||||
})).catch(response => PopupMessage.open({
|
||||
title: `${i18n('UNSUCCESSFUL_CONNECTION')}: IMAP`,
|
||||
children: `${i18n('SERVER_ERROR')}: ${response.message}`,
|
||||
type: 'error',
|
||||
})).then(() => this.setState({
|
||||
imapLoading: false
|
||||
}));
|
||||
}
|
||||
|
||||
recoverEmailTemplate() {
|
||||
const {selectedIndex, language, templates} = this.state;
|
||||
|
||||
API.call({
|
||||
path: '/system/recover-mail-template',
|
||||
data: {
|
||||
template: templates[selectedIndex],
|
||||
language
|
||||
}
|
||||
}).then(() => {
|
||||
this.retrieveEmailTemplate(this.state.selectedIndex, language);
|
||||
});
|
||||
}
|
||||
|
||||
retrieveEmailTemplate(index, language) {
|
||||
this.setState({
|
||||
loadingForm: true,
|
||||
});
|
||||
|
||||
API.call({
|
||||
path: '/system/get-mail-template',
|
||||
data: {template: this.state.templates[index], language}
|
||||
}).then((result) => this.setState({
|
||||
language,
|
||||
selectedIndex: index,
|
||||
edited: false,
|
||||
loadingForm: false,
|
||||
form: result.data,
|
||||
errors: {},
|
||||
}));
|
||||
}
|
||||
|
||||
retrieveMailTemplateList() {
|
||||
API.call({
|
||||
path: '/system/get-mail-template-list',
|
||||
data: {}
|
||||
}).then((result) => this.setState({
|
||||
loadingList: false,
|
||||
templates: result.data
|
||||
}));
|
||||
}
|
||||
|
||||
retrieveHeaderImage() {
|
||||
API.call({
|
||||
path: '/system/get-settings',
|
||||
data: {allSettings: 1}
|
||||
}).then(result => this.setState({
|
||||
headerImage: result.data['mail-template-header-image'],
|
||||
emailForm: {
|
||||
['server-email']: result.data['server-email'],
|
||||
},
|
||||
smtpForm: {
|
||||
['smtp-host']: result.data['smtp-host'],
|
||||
['smtp-user']: result.data['smtp-user'],
|
||||
['smtp-pass']: 'HIDDEN',
|
||||
},
|
||||
imapForm: {
|
||||
['imap-host']: result.data['imap-host'],
|
||||
['imap-user']: result.data['imap-user'],
|
||||
['imap-pass']: 'HIDDEN',
|
||||
},
|
||||
}));
|
||||
}
|
||||
|
||||
parsePasswordField(form) {
|
||||
let parsedForm = _.extend({}, form);
|
||||
|
||||
delete parsedForm['smtp-pass'];
|
||||
delete parsedForm['imap-pass'];
|
||||
|
||||
return _.extend(parsedForm, {
|
||||
[ form['smtp-pass'] && form['smtp-pass'] !== 'HIDDEN' ? 'smtp-pass' : null]: form['smtp-pass'],
|
||||
[ form['imap-pass'] && form['imap-pass'] !== 'HIDDEN' ? 'imap-pass' : null]: form['imap-pass'],
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
export default connect((store) => {
|
||||
return {
|
||||
language: store.config.language,
|
||||
};
|
||||
})(AdminPanelEmailSettings);
|
|
@ -1,6 +1,6 @@
|
|||
@import "../../../../scss/vars";
|
||||
|
||||
.admin-panel-email-templates {
|
||||
.admin-panel-email-settings {
|
||||
|
||||
&__text-area {
|
||||
width: 100%;
|
||||
|
@ -26,7 +26,8 @@
|
|||
margin-left: 10px;
|
||||
}
|
||||
|
||||
&__image-container {
|
||||
&__image-container,
|
||||
&__email-form {
|
||||
background-color: $very-light-grey;
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
|
@ -34,4 +35,30 @@
|
|||
padding: 5px 20px;
|
||||
margin-top: 20px;
|
||||
}
|
||||
|
||||
&__box {
|
||||
text-align: center;
|
||||
background-color: $very-light-grey;
|
||||
padding: 30px;
|
||||
margin-bottom: 30px;
|
||||
flex-basis: 48%;
|
||||
}
|
||||
|
||||
&__servers {
|
||||
display: flex;
|
||||
justify-content: space-evenly;
|
||||
margin-top: 30px;
|
||||
}
|
||||
|
||||
&__server-form-buttons {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
}
|
||||
|
||||
&__imap-message {
|
||||
margin-top: 10px;
|
||||
padding-left: 40px;
|
||||
text-align: left;
|
||||
}
|
||||
}
|
|
@ -1,295 +0,0 @@
|
|||
import React from 'react';
|
||||
import _ from 'lodash';
|
||||
import {connect} from 'react-redux';
|
||||
|
||||
import i18n from 'lib-app/i18n';
|
||||
import API from 'lib-app/api-call';
|
||||
|
||||
import AreYouSure from 'app-components/are-you-sure';
|
||||
import LanguageSelector from 'app-components/language-selector';
|
||||
|
||||
import Button from 'core-components/button';
|
||||
import Header from 'core-components/header';
|
||||
import Listing from 'core-components/listing';
|
||||
import Loading from 'core-components/loading';
|
||||
import Form from 'core-components/form';
|
||||
import FormField from 'core-components/form-field';
|
||||
import SubmitButton from 'core-components/submit-button';
|
||||
|
||||
class AdminPanelEmailTemplates extends React.Component {
|
||||
|
||||
static propTypes = {
|
||||
language: React.PropTypes.string,
|
||||
};
|
||||
|
||||
state = {
|
||||
headerImage: '',
|
||||
loadingHeaderImage: false,
|
||||
loadingList: true,
|
||||
loadingTemplate: false,
|
||||
templates: [],
|
||||
loadingForm: false,
|
||||
selectedIndex: -1,
|
||||
edited: false,
|
||||
errors: {},
|
||||
language: this.props.language,
|
||||
form: {
|
||||
subject: '',
|
||||
text1: '',
|
||||
text2: '',
|
||||
text3: '',
|
||||
}
|
||||
};
|
||||
|
||||
componentDidMount() {
|
||||
this.retrieveMailTemplateList();
|
||||
this.retrieveHeaderImage();
|
||||
}
|
||||
|
||||
render() {
|
||||
return (
|
||||
<div className="admin-panel-email-templates">
|
||||
<Header title={i18n('EMAIL_TEMPLATES')} description={i18n('EMAIL_TEMPLATES_DESCRIPTION')} />
|
||||
{(!this.state.loadingList) ? this.renderContent() : this.renderLoading()}
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
renderContent() {
|
||||
return (
|
||||
<div>
|
||||
<div className="row">
|
||||
<div className="col-md-3">
|
||||
<Listing {...this.getListingProps()}/>
|
||||
</div>
|
||||
{(this.state.selectedIndex != -1) ? this.renderForm() : null}
|
||||
</div>
|
||||
<Form values={{headerImage: this.state.headerImage}} onChange={form => this.setState({headerImage: form.headerImage})} onSubmit={this.onHeaderImageSubmit.bind(this)}>
|
||||
<div className="admin-panel-email-templates__image-container">
|
||||
<FormField className="admin-panel-email-templates__image-header-url" label={i18n('IMAGE_HEADER_URL')} name="headerImage" required fieldProps={{size: 'large'}} />
|
||||
<SubmitButton className="admin-panel-email-templates__image-header-submit" type="secondary" size="small">{i18n('SAVE')}</SubmitButton>
|
||||
</div>
|
||||
</Form>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
renderLoading() {
|
||||
return (
|
||||
<div className="admin-panel-email-templates__loading">
|
||||
<Loading backgrounded size="large"/>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
renderForm() {
|
||||
return (
|
||||
<div className="col-md-9">
|
||||
<FormField label={i18n('LANGUAGE')} decorator={LanguageSelector} value={this.state.language} onChange={event => this.onItemChange(this.state.selectedIndex, event.target.value)} fieldProps={{
|
||||
type: 'allowed',
|
||||
size: 'medium'
|
||||
}}/>
|
||||
<Form {...this.getFormProps()}>
|
||||
<div className="row">
|
||||
<div className="col-md-7">
|
||||
<FormField label={i18n('SUBJECT')} name="subject" validation="TITLE" required fieldProps={{size: 'large'}}/>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<FormField label={i18n('TEXT') + '1'} name="text1" validation="TEXT_AREA" required decorator={'textarea'} fieldProps={{className: 'admin-panel-email-templates__text-area'}} />
|
||||
{(this.state.form.text2) ? <FormField label={i18n('TEXT') + '2'} name="text2" validation="TEXT_AREA" required decorator={'textarea'} fieldProps={{className: 'admin-panel-email-templates__text-area'}} /> : null}
|
||||
{(this.state.form.text3) ? <FormField label={i18n('TEXT') + '3'} name="text3" validation="TEXT_AREA" required decorator={'textarea'} fieldProps={{className: 'admin-panel-email-templates__text-area'}} /> : null}
|
||||
|
||||
<div className="admin-panel-email-templates__actions">
|
||||
<div className="admin-panel-email-templates__save-button">
|
||||
<SubmitButton type="secondary" size="small">{i18n('SAVE')}</SubmitButton>
|
||||
</div>
|
||||
<div className="admin-panel-email-templates__optional-buttons">
|
||||
{(this.state.edited) ? this.renderDiscardButton() : null}
|
||||
<div className="admin-panel-email-templates__recover-button">
|
||||
<Button onClick={this.onRecoverClick.bind(this)} size="medium">
|
||||
{i18n('RECOVER_DEFAULT')}
|
||||
</Button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</Form>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
renderDiscardButton() {
|
||||
return (
|
||||
<div className="admin-panel-email-templates__discard-button">
|
||||
<Button onClick={this.onDiscardChangesClick.bind(this)} size="medium">
|
||||
{i18n('DISCARD_CHANGES')}
|
||||
</Button>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
getListingProps() {
|
||||
return {
|
||||
title: i18n('EMAIL_TEMPLATES'),
|
||||
items: this.getTemplateItems(),
|
||||
selectedIndex: this.state.selectedIndex,
|
||||
onChange: this.onItemChange.bind(this)
|
||||
};
|
||||
}
|
||||
|
||||
getFormProps() {
|
||||
return {
|
||||
values: this.state.form,
|
||||
errors: this.state.errors,
|
||||
loading: this.state.loadingForm,
|
||||
onChange: (form) => {this.setState({form, edited: true})},
|
||||
onValidateErrors: (errors) => {this.setState({errors})},
|
||||
onSubmit: this.onFormSubmit.bind(this)
|
||||
}
|
||||
}
|
||||
|
||||
getTemplateItems() {
|
||||
return this.state.templates.map((template) => {
|
||||
return {
|
||||
content: template
|
||||
};
|
||||
});
|
||||
}
|
||||
|
||||
onItemChange(index, language) {
|
||||
if(this.state.edited) {
|
||||
AreYouSure.openModal(i18n('WILL_LOSE_CHANGES'), this.retrieveEmailTemplate.bind(this, index, language || this.state.language));
|
||||
} else {
|
||||
this.retrieveEmailTemplate(index, language || this.state.language);
|
||||
}
|
||||
}
|
||||
|
||||
onHeaderImageSubmit(form) {
|
||||
this.setState({
|
||||
loadingHeaderImage: true,
|
||||
});
|
||||
|
||||
API.call({
|
||||
path: '/system/edit-settings',
|
||||
data: {
|
||||
'mail-template-header-image': form['headerImage']
|
||||
}
|
||||
}).then(() => this.setState({
|
||||
loadingHeaderImage: false,
|
||||
}))
|
||||
}
|
||||
|
||||
onFormSubmit(form) {
|
||||
const {selectedIndex, language, templates} = this.state;
|
||||
|
||||
this.setState({loadingForm: true});
|
||||
|
||||
API.call({
|
||||
path: '/system/edit-mail-template',
|
||||
data: {
|
||||
template: templates[selectedIndex],
|
||||
language,
|
||||
subject: form.subject,
|
||||
text1: form.text1,
|
||||
text2: form.text2,
|
||||
text3: form.text3,
|
||||
}
|
||||
}).then(() => {
|
||||
this.setState({loadingForm: false, edited: false});
|
||||
}).catch(response => {
|
||||
this.setState({
|
||||
loadingForm: false,
|
||||
});
|
||||
|
||||
switch(response.message) {
|
||||
case 'INVALID_SUBJECT':
|
||||
this.setState({
|
||||
errors: {subject: i18n('INVALID_SYNTAX')}
|
||||
});
|
||||
break;
|
||||
case 'INVALID_TEXT_1':
|
||||
this.setState({
|
||||
errors: {text1: i18n('INVALID_SYNTAX')}
|
||||
});
|
||||
break;
|
||||
case 'INVALID_TEXT_2':
|
||||
this.setState({
|
||||
errors: {text2: i18n('INVALID_SYNTAX')}
|
||||
});
|
||||
break;
|
||||
case 'INVALID_TEXT_3':
|
||||
this.setState({
|
||||
errors: {text3: i18n('INVALID_SYNTAX')}
|
||||
});
|
||||
break;
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
onDiscardChangesClick(event) {
|
||||
event.preventDefault();
|
||||
this.onItemChange(this.state.selectedIndex, this.state.language);
|
||||
}
|
||||
|
||||
onRecoverClick(event) {
|
||||
event.preventDefault();
|
||||
AreYouSure.openModal(i18n('WILL_RECOVER_EMAIL_TEMPLATE'), this.recoverEmailTemplate.bind(this));
|
||||
}
|
||||
|
||||
recoverEmailTemplate() {
|
||||
const {selectedIndex, language, templates} = this.state;
|
||||
|
||||
API.call({
|
||||
path: '/system/recover-mail-template',
|
||||
data: {
|
||||
template: templates[selectedIndex],
|
||||
language
|
||||
}
|
||||
}).then(() => {
|
||||
this.retrieveEmailTemplate(this.state.selectedIndex, language);
|
||||
});
|
||||
}
|
||||
|
||||
retrieveEmailTemplate(index, language) {
|
||||
this.setState({
|
||||
loadingForm: true,
|
||||
});
|
||||
|
||||
API.call({
|
||||
path: '/system/get-mail-template',
|
||||
data: {template: this.state.templates[index], language}
|
||||
}).then((result) => this.setState({
|
||||
language,
|
||||
selectedIndex: index,
|
||||
edited: false,
|
||||
loadingForm: false,
|
||||
form: result.data,
|
||||
errors: {},
|
||||
}));
|
||||
}
|
||||
|
||||
retrieveMailTemplateList() {
|
||||
API.call({
|
||||
path: '/system/get-mail-template-list',
|
||||
data: {}
|
||||
}).then((result) => this.setState({
|
||||
loadingList: false,
|
||||
templates: result.data
|
||||
}));
|
||||
}
|
||||
|
||||
retrieveHeaderImage() {
|
||||
API.call({
|
||||
path: '/system/get-settings',
|
||||
data: {allSettings: 1}
|
||||
}).then(result => this.setState({
|
||||
headerImage: result.data['mail-template-header-image']
|
||||
}));
|
||||
}
|
||||
}
|
||||
|
||||
export default connect((store) => {
|
||||
return {
|
||||
language: store.config.language,
|
||||
};
|
||||
})(AdminPanelEmailTemplates);
|
33
client/src/app/admin/panel/settings/admin-panel-system-preferences.js
Normal file → Executable file
33
client/src/app/admin/panel/settings/admin-panel-system-preferences.js
Normal file → Executable file
|
@ -26,7 +26,6 @@ class AdminPanelSystemPreferences extends React.Component {
|
|||
message: null,
|
||||
values: {
|
||||
maintenance: false,
|
||||
'smtp-pass': 'HIDDEN',
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -62,28 +61,6 @@ class AdminPanelSystemPreferences extends React.Component {
|
|||
<FormField label={i18n('DEFAULT_TIMEZONE')} fieldProps={{size: 'large'}} name="time-zone"/>
|
||||
</div>
|
||||
</div>
|
||||
<div className="row">
|
||||
<div className="col-md-12">
|
||||
<span className="separator" />
|
||||
<div className="row">
|
||||
<div className="col-md-6">
|
||||
<FormField label={i18n('NOREPLY_EMAIL')} fieldProps={{size: 'large'}} name="no-reply-email"/>
|
||||
<FormField label={i18n('SMTP_USER')} fieldProps={{size: 'large'}} name="smtp-user"/>
|
||||
</div>
|
||||
<div className="col-md-6">
|
||||
<div className="row">
|
||||
<div className="col-md-9">
|
||||
<FormField label={i18n('SMTP_SERVER')} fieldProps={{size: 'large'}} name="smtp-host"/>
|
||||
<FormField label={i18n('SMTP_PASSWORD')} fieldProps={{size: 'large'}} name="smtp-pass"/>
|
||||
</div>
|
||||
<div className="col-md-3">
|
||||
<FormField label={i18n('PORT')} fieldProps={{size: 'auto'}} name="smtp-port"/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div className="row">
|
||||
<div className="col-md-12">
|
||||
<span className="separator" />
|
||||
|
@ -173,11 +150,6 @@ class AdminPanelSystemPreferences extends React.Component {
|
|||
'title': form['title'],
|
||||
'layout': form['layout'] ? 'full-width' : 'boxed',
|
||||
'time-zone': form['time-zone'],
|
||||
'no-reply-email': form['no-reply-email'],
|
||||
'smtp-host': form['smtp-host'],
|
||||
'smtp-port': form['smtp-port'],
|
||||
'smtp-user': form['smtp-user'],
|
||||
[ form['smtp-pass'] !== 'HIDDEN' ? 'smtp-pass' : null]: form['smtp-pass'],
|
||||
'maintenance-mode': form['maintenance-mode'] * 1,
|
||||
'allow-attachments': form['allow-attachments'] * 1,
|
||||
'max-size': form['max-size'],
|
||||
|
@ -219,11 +191,6 @@ class AdminPanelSystemPreferences extends React.Component {
|
|||
'title': result.data['title'],
|
||||
'layout': (result.data['layout'] == 'full-width') ? 1 : 0,
|
||||
'time-zone': result.data['time-zone'],
|
||||
'no-reply-email': result.data['no-reply-email'],
|
||||
'smtp-host': result.data['smtp-host'],
|
||||
'smtp-port': result.data['smtp-port'],
|
||||
'smtp-user': result.data['smtp-user'],
|
||||
'smtp-pass': 'HIDDEN',
|
||||
'maintenance-mode': !!(result.data['maintenance-mode'] * 1),
|
||||
'allow-attachments': !!(result.data['allow-attachments'] * 1),
|
||||
'max-size': result.data['max-size'],
|
||||
|
|
|
@ -6,6 +6,7 @@ import history from 'lib-app/history';
|
|||
import i18n from 'lib-app/i18n';
|
||||
import API from 'lib-app/api-call';
|
||||
|
||||
import PopupMessage from 'app-components/popup-message';
|
||||
import Button from 'core-components/button';
|
||||
import Header from 'core-components/header';
|
||||
import Form from 'core-components/form';
|
||||
|
@ -17,7 +18,6 @@ class InstallStep5Settings extends React.Component {
|
|||
|
||||
state = {
|
||||
loading: false,
|
||||
smtpConnection: null,
|
||||
form: {},
|
||||
error: false,
|
||||
errorMessage: ''
|
||||
|
@ -31,17 +31,15 @@ class InstallStep5Settings extends React.Component {
|
|||
<Form loading={this.state.loading} onSubmit={this.onSubmit.bind(this)} value={this.state.form} onChange={(form) => this.setState({form})}>
|
||||
<FormField name="title" label={i18n('TITLE')} fieldProps={{size: 'large'}} required/>
|
||||
<FormField className="install-step-5__attachments-field" name="allow-attachments" label={i18n('ALLOW_FILE_ATTACHMENTS')} field="checkbox" fieldProps={{size: 'large'}}/>
|
||||
<FormField name="no-reply-email" label={i18n('NOREPLY_EMAIL')} fieldProps={{size: 'large'}}/>
|
||||
<FormField name="server-email" label={i18n('EMAIL_SERVER_ADDRESS')} fieldProps={{size: 'large'}} infoMessage={i18n('EMAIL_SERVER_ADDRESS_DESCRIPTION')}/>
|
||||
<div className="install-step-5__smtp-block">
|
||||
<Header title={i18n('SMTP_SERVER')} description={i18n('SMTP_SERVER_DESCRIPTION')} />
|
||||
<FormField name="smtp-host" label={i18n('SMTP_SERVER')} fieldProps={{size: 'large'}}/>
|
||||
<FormField name="smtp-port" label={i18n('PORT')} fieldProps={{size: 'small'}}/>
|
||||
<FormField name="smtp-user" label={i18n('SMTP_USER')} fieldProps={{size: 'large'}}/>
|
||||
<FormField name="smtp-password" label={i18n('SMTP_PASSWORD')} fieldProps={{size: 'large', password: true}}/>
|
||||
<Button className="install-step-5__test-connection" size="medium" onClick={this.onTestSMTPClick.bind(this)}>
|
||||
<FormField name="smtp-pass" label={i18n('SMTP_PASSWORD')} fieldProps={{size: 'large', password: true}}/>
|
||||
<SubmitButton className="install-step-5__test-connection" size="medium" onClick={this.onTestSMTPClick.bind(this)} disabled={this.state.loading}>
|
||||
{i18n('TEST_SMTP_CONNECTION')}
|
||||
</Button>
|
||||
{this.renderMessageSMTP()}
|
||||
</SubmitButton>
|
||||
</div>
|
||||
<div className="install-step-5__buttons">
|
||||
<SubmitButton className="install-step-5__next" size="medium" type="secondary">{i18n('NEXT')}</SubmitButton>
|
||||
|
@ -66,36 +64,29 @@ class InstallStep5Settings extends React.Component {
|
|||
return message;
|
||||
}
|
||||
|
||||
renderMessageSMTP() {
|
||||
let message = null;
|
||||
|
||||
if(this.state.smtpConnection !== null) {
|
||||
if(this.state.smtpConnection) {
|
||||
message = (
|
||||
<Message className="install-step-5__smtp-message" type="success">
|
||||
{i18n('SMTP_CONNECTION_SUCCESS')}
|
||||
</Message>
|
||||
);
|
||||
} else {
|
||||
message = (
|
||||
<Message className="install-step-5__smtp-message" type="error">
|
||||
{i18n('SMTP_CONNECTION_ERROR')}
|
||||
</Message>
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
return message;
|
||||
}
|
||||
|
||||
onTestSMTPClick(event) {
|
||||
event.preventDefault();
|
||||
|
||||
this.setState({
|
||||
loading: true
|
||||
});
|
||||
|
||||
API.call({
|
||||
path: '/system/test-smtp',
|
||||
data: this.state.form
|
||||
}).then(() => this.setState({smtpConnection: true}))
|
||||
.catch(() => this.setState({smtpConnection: false}));
|
||||
}).then(() => PopupMessage.open({
|
||||
title: i18n('SETTINGS_UPDATED'),
|
||||
children: i18n('SMTP_SUCCESS'),
|
||||
type: 'success'
|
||||
}))
|
||||
.catch(result => PopupMessage.open({
|
||||
title: i18n('ERROR_UPDATING_SETTINGS'),
|
||||
children: result.message,
|
||||
type: 'error'
|
||||
}))
|
||||
.then(() => this.setState({
|
||||
loading: false
|
||||
}));
|
||||
}
|
||||
|
||||
onPreviousClick(event) {
|
||||
|
|
|
@ -6,7 +6,9 @@ import {Motion, spring} from 'react-motion';
|
|||
class Modal extends React.Component {
|
||||
static propTypes = {
|
||||
content: React.PropTypes.node,
|
||||
noPadding: React.PropTypes.bool
|
||||
noPadding: React.PropTypes.bool,
|
||||
outsideClick: React.PropTypes.bool,
|
||||
onOutsideClick: React.PropTypes.func
|
||||
};
|
||||
|
||||
render() {
|
||||
|
@ -32,8 +34,8 @@ class Modal extends React.Component {
|
|||
|
||||
renderModal(animation) {
|
||||
return (
|
||||
<div className={this.getClass()} style={{opacity: animation.fade}}>
|
||||
<div className="modal__content" style={{transform: 'scale(' + animation.scale + ')'}}>
|
||||
<div className={this.getClass()} style={{opacity: animation.fade}} onClick={this.onModalClick.bind(this)}>
|
||||
<div className="modal__content" style={{transform: 'scale(' + animation.scale + ')'}} onClick={this.onModalContentClick.bind(this)}>
|
||||
{this.props.content}
|
||||
</div>
|
||||
</div>
|
||||
|
@ -48,6 +50,18 @@ class Modal extends React.Component {
|
|||
|
||||
return classNames(classes);
|
||||
}
|
||||
|
||||
onModalClick() {
|
||||
if(this.props.outsideClick) {
|
||||
this.props.onOutsideClick();
|
||||
}
|
||||
}
|
||||
|
||||
onModalContentClick(event) {
|
||||
if(this.props.outsideClick) {
|
||||
event.stopPropagation();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
export default Modal;
|
|
@ -14,7 +14,7 @@ module.exports = [
|
|||
'title': 'Support Center',
|
||||
'layout': 'boxed',
|
||||
'time-zone': 3,
|
||||
'no-reply-email': 'shitr@post.com',
|
||||
'server-email': 'shitr@post.com',
|
||||
'smtp-host': 'localhost',
|
||||
'smtp-port': '7070',
|
||||
'smtp-user': 'Wesa',
|
||||
|
|
|
@ -141,6 +141,9 @@ export default {
|
|||
'SMTP_USER': 'Usuário SMTP',
|
||||
'SMTP_SERVER': 'Servidor SMTP',
|
||||
'SMTP_PASSWORD': 'Senha SMTP',
|
||||
'IMAP_USER': 'Usuário IMAP',
|
||||
'IMAP_SERVER': 'Servidor IMAP',
|
||||
'IMAP_PASSWORD': 'Senha IMAP',
|
||||
'PORT': 'Porta',
|
||||
'RECAPTCHA_PUBLIC_KEY': 'Chave Pública do Recaptcha',
|
||||
'RECAPTCHA_PRIVATE_KEY': 'Private Key do Recaptcha',
|
||||
|
@ -191,6 +194,8 @@ export default {
|
|||
'DISABLE_USER': 'Desativar usuário',
|
||||
'SHOW_CLOSED_TICKETS': 'Mostrar ingressos fechados',
|
||||
'IMAGE_HEADER_URL': 'URL do cabeçalho da imagem',
|
||||
'IMAGE_HEADER_DESCRIPTION': 'Imagem que será usada como cabeçalho do email',
|
||||
'EMAIL_SETTINGS': 'Configurações de email',
|
||||
|
||||
'CHART_CREATE_TICKET': 'Chamados criados',
|
||||
'CHART_CLOSE': 'Chamados fechados',
|
||||
|
@ -303,11 +308,14 @@ export default {
|
|||
'ENABLE_USER_SYSTEM_DESCRIPTION': 'Ativar / desativar o uso de um sistema de usuário. Se você desativá-lo, todos os usuários serão excluídos, mas os chamados serão mantidos. Se você ativá-lo, os chamados de usuários existentes serão criados.',
|
||||
'CSV_DESCRIPTION': 'O arquivo CSV deve ter 3 colunas: e-mail, senha, nome. Não há limite na contagem de linhas. Ele será criado um usuário por linha no arquivo.',
|
||||
'SMTP_SERVER_DESCRIPTION': 'A configuração do servidor SMTP permite que o aplicativo envie e-mails. Se você não configurá-lo, nenhum e-mail será enviado pela OpenSupports.',
|
||||
'IMAP_SERVER_DESCRIPTION': 'A configuração do servidor IMAP permite que o aplicativo crie tickets a partir dos emails enviados para uma caixa de correio.',
|
||||
'ENABLE_USER_DESCRIPTION': 'Essa ação permite que o usuário faça login e crie tickets.',
|
||||
'DISABLE_USER_DESCRIPTION': 'O usuário será desativado e não poderá fazer login e criar tickets.',
|
||||
'PRIVATE_RESPONSE_DESCRIPTION': 'Esta resposta só será vista pelos funcionários',
|
||||
'PRIVATE_TOPIC_DESCRIPTION': 'Este tópico será visto apenas por membros da equipe',
|
||||
'PRIVATE_DEPARTMENT_DESCRIPTION': 'Este departamento só será visto pelos funcionários',
|
||||
'EMAIL_SETTINGS_DESCRIPTION': 'Aqui você pode editar as configurações para receber e enviar e-mail para seus clientes.',
|
||||
'IMAP_POLLING_DESCRIPTION': 'A verificação da caixa de entrada não será feita automaticamente pelo OpenSupports. Você precisa fazer solicitações POST periodicamente para esse URL para processar os e-mails: {url}',
|
||||
|
||||
//ERRORS
|
||||
'EMAIL_OR_PASSWORD': 'E-mail ou senha inválidos',
|
||||
|
@ -365,6 +373,9 @@ export default {
|
|||
'WILL_RECOVER_EMAIL_TEMPLATE': 'Este modelo de e-mail será recuperado para seu valor padrão neste idioma.',
|
||||
'SUCCESS_IMPORTING_CSV_DESCRIPTION': 'O arquivo CSV foi importado com êxito',
|
||||
'SUCCESS_DELETING_ALL_USERS': 'Os usuários foram excluídos com êxito',
|
||||
'SUCCESSFUL_CONNECTION': 'Conexão bem sucedida',
|
||||
'UNSUCCESSFUL_CONNECTION': 'Conexão sem sucesso',
|
||||
'SERVER_CREDENTIALS_WORKING': 'Credenciais do servidor estão funcionando corretamente',
|
||||
|
||||
'LAST_7_DAYS': 'Últimos 7 dias',
|
||||
'LAST_30_DAYS': 'Últimos 30 dias',
|
||||
|
@ -386,6 +397,7 @@ export default {
|
|||
'EMAIL_LOWERCASE': 'email',
|
||||
'PASSWORD_LOWERCASE': 'senha',
|
||||
'TEST_SMTP_CONNECTION': 'Testar conexão SMTP',
|
||||
'SMTP_CONNECTION_SUCCESS': 'As credenciais SMTP são válidas.',
|
||||
'SMTP_CONNECTION_ERROR': 'Não pode se conectar ao servidor SMTP.'
|
||||
'SERVER_ERROR': 'Não é possível se conectar ao servidor.',
|
||||
'EMAIL_SERVER_ADDRESS': 'Endereço do servidor de email',
|
||||
'EMAIL_SERVER_ADDRESS_DESCRIPTION': 'Endereço onde os e-mails serão recebidos e enviados'
|
||||
};
|
||||
|
|
|
@ -141,6 +141,9 @@ export default {
|
|||
'SMTP_USER': 'SMTP用戶',
|
||||
'SMTP_SERVER': 'SMTP服務器',
|
||||
'SMTP_PASSWORD': 'SMTP密碼',
|
||||
'IMAP_USER': 'IMAP用户',
|
||||
'IMAP_SERVER': 'IMAP服务器',
|
||||
'IMAP_PASSWORD': 'IMAP密码',
|
||||
'PORT': '港口',
|
||||
'RECAPTCHA_PUBLIC_KEY': 'Recaptcha公鑰',
|
||||
'RECAPTCHA_PRIVATE_KEY': 'Recaptcha私人鑰匙',
|
||||
|
@ -191,6 +194,8 @@ export default {
|
|||
'DISABLE_USER': '禁用用户',
|
||||
'SHOW_CLOSED_TICKETS': '显示已关闭的门票',
|
||||
'IMAGE_HEADER_URL': '图片标题网址',
|
||||
'IMAGE_HEADER_DESCRIPTION': '将用作电子邮件标题的图像',
|
||||
'EMAIL_SETTINGS': '电邮设定',
|
||||
|
||||
'CHART_CREATE_TICKET': '已創建門票',
|
||||
'CHART_CLOSE': '門票已關閉',
|
||||
|
@ -303,11 +308,14 @@ export default {
|
|||
'ENABLE_USER_SYSTEM_DESCRIPTION': '啟用/禁用用戶系統的使用。如果你禁用它,所有的用戶將被刪除,但票將被保留。如果啟用,將創建現有票證的用戶。',
|
||||
'CSV_DESCRIPTION': 'CSV文件必須有3列:電子郵件,密碼,名稱。行數沒有限制。它將在文件中的每行中創建一個用戶。',
|
||||
'SMTP_SERVER_DESCRIPTION': 'SMTP服务器允许应用程序发送邮件。 如果您没有配置,OpenSupports将不会发送任何电子邮件。',
|
||||
'IMAP_SERVER_DESCRIPTION': 'IMAP服务器的配置允许应用程序根据发送到邮箱的电子邮件创建票证。',
|
||||
'ENABLE_USER_DESCRIPTION': '此操作允许用户登录并创建票证。',
|
||||
'DISABLE_USER_DESCRIPTION': '用户将被禁用,无法登录并创建票证。',
|
||||
'PRIVATE_RESPONSE_DESCRIPTION': '只有工作人员才能看到这种回应',
|
||||
'PRIVATE_TOPIC_DESCRIPTION': '只有工作人员才能看到此主题',
|
||||
'PRIVATE_DEPARTMENT_DESCRIPTION': '只有工作人员才能看到这个部门',
|
||||
'EMAIL_SETTINGS_DESCRIPTION': '您可以在此处编辑接收和发送电子邮件给客户的设置。',
|
||||
'IMAP_POLLING_DESCRIPTION': 'OpenSupports不会自动完成收件箱检查。您必须定期向此网址发送POST请求以处理电子邮件:{url}',
|
||||
|
||||
//ERRORS
|
||||
'EMAIL_OR_PASSWORD': '電子郵件或密碼無效',
|
||||
|
@ -365,6 +373,9 @@ export default {
|
|||
'WILL_RECOVER_EMAIL_TEMPLATE': '此電子郵件模板將恢復為該語言的默認值。',
|
||||
'SUCCESS_IMPORTING_CSV_DESCRIPTION': 'CSV文件已成功導入',
|
||||
'SUCCESS_DELETING_ALL_USERS': '用戶已成功刪除',
|
||||
'SUCCESSFUL_CONNECTION': '成功连接',
|
||||
'UNSUCCESSFUL_CONNECTION': '连接不成功',
|
||||
'SERVER_CREDENTIALS_WORKING': '服务器凭据正常工作',
|
||||
|
||||
'LAST_7_DAYS': '最近7天',
|
||||
'LAST_30_DAYS': '最近30天',
|
||||
|
@ -387,6 +398,7 @@ export default {
|
|||
'PASSWORD_LOWERCASE': '密码',
|
||||
'SYSTEM_SETTINGS': '系统设置',
|
||||
'TEST_SMTP_CONNECTION': '测试SMTP连接',
|
||||
'SMTP_CONNECTION_SUCCESS': 'SMTP凭据有效',
|
||||
'SMTP_CONNECTION_ERROR': '无法连接到SMTP服务器'
|
||||
'SERVER_ERROR': '无法连接到服务器。',
|
||||
'EMAIL_SERVER_ADDRESS': '电邮服务器地址',
|
||||
'EMAIL_SERVER_ADDRESS_DESCRIPTION': '地址将收到和发送邮件'
|
||||
};
|
||||
|
|
|
@ -141,6 +141,9 @@ export default {
|
|||
'SMTP_USER': 'SMTP Benutzer',
|
||||
'SMTP_SERVER': 'SMTP Server',
|
||||
'SMTP_PASSWORD': 'SMTP Kennwort',
|
||||
'IMAP_USER': 'IMAP-Benutzer',
|
||||
'IMAP_SERVER': 'IMAP-Server',
|
||||
'IMAP_PASSWORD': 'IMAP-Passwort',
|
||||
'PORT': 'Port',
|
||||
'RECAPTCHA_PUBLIC_KEY': 'Recaptcha - Öffentlicher Schlüssel',
|
||||
'RECAPTCHA_PRIVATE_KEY': 'Recaptcha - Privater Schlüssel',
|
||||
|
@ -191,6 +194,8 @@ export default {
|
|||
'DISABLE_USER': 'Benutzer deaktivieren',
|
||||
'SHOW_CLOSED_TICKETS': 'Geschlossene Tickets anzeigen',
|
||||
'IMAGE_HEADER_URL': 'URL des Image-Headers',
|
||||
'IMAGE_HEADER_DESCRIPTION': 'Bild, das als Header der E-Mail verwendet wird',
|
||||
'EMAIL_SETTINGS': 'Email Einstellungen',
|
||||
|
||||
'CHART_CREATE_TICKET': 'Tickets erstellt',
|
||||
'CHART_CLOSE': 'Tickets geschlossen',
|
||||
|
@ -303,11 +308,14 @@ export default {
|
|||
'ENABLE_USER_SYSTEM_DESCRIPTION': 'Aktivieren/deaktivieren Sie die Verwendung eines Benutzersystems. Wenn Sie es deaktivieren, werden alle Benutzer gelöscht, aber die Tickets werden behalten. Wenn Sie es aktivieren, werden die Benutzer der vorhandenen Tickets erstellt.',
|
||||
'CSV_DESCRIPTION': 'Die CSV-Datei muss 3 Spalten haben: E-Mail-Adresse, Passwort, Name. Es gibt kein Limit in der Zeilenzahl. Es wird ein Benutzer pro Zeile in der Datei erstellt.',
|
||||
'SMTP_SERVER_DESCRIPTION': 'Die Konfiguration des SMTP-Servers ermöglicht es der Software, Mails zu senden. Wenn Sie es nicht konfigurieren, werden keine E-Mails von OpenSupports gesendet.',
|
||||
'IMAP_SERVER_DESCRIPTION': 'Die Konfiguration des IMAP-Servers ermöglicht es der Anwendung, Tickets aus den an ein Postfach gesendeten E-Mails zu erstellen.',
|
||||
'ENABLE_USER_DESCRIPTION': 'Mit dieser Aktion kann der Benutzer sich anmelden und Tickets erstellen.',
|
||||
'DISABLE_USER_DESCRIPTION': 'Der Benutzer wird deaktiviert und kann keine Tickets anmelden und erstellen.',
|
||||
'PRIVATE_RESPONSE_DESCRIPTION': 'Diese Antwort wird nur von den Mitarbeitern gesehen werden',
|
||||
'PRIVATE_TOPIC_DESCRIPTION': 'Dieses Thema wird nur von Mitarbeitern gesehen',
|
||||
'PRIVATE_DEPARTMENT_DESCRIPTION': 'Diese Abteilung wird nur von Mitarbeitern gesehen',
|
||||
'EMAIL_SETTINGS_DESCRIPTION': 'Hier können Sie die Einstellungen für das Empfangen und Senden von E-Mails an Ihre Kunden bearbeiten.',
|
||||
'IMAP_POLLING_DESCRIPTION': 'Die Posteingangsüberprüfung wird von OpenSupports nicht automatisch durchgeführt. Sie müssen regelmäßig POST-Anfragen an diese URL stellen, um die E-Mails zu verarbeiten: {url}',
|
||||
|
||||
//ERRORS
|
||||
'EMAIL_OR_PASSWORD': 'E-Mail-Adresse oder Passwort ungültig!',
|
||||
|
@ -365,6 +373,9 @@ export default {
|
|||
'WILL_RECOVER_EMAIL_TEMPLATE': 'Diese E-Mail-Vorlage wird auf den Standardwert zurückgesetzt.',
|
||||
'SUCCESS_IMPORTING_CSV_DESCRIPTION': 'Die CSV-Datei wurde erfolgreich importiert.',
|
||||
'SUCCESS_DELETING_ALL_USERS': 'Die Benutzer wurden erfolgreich gelöscht.',
|
||||
'SUCCESSFUL_CONNECTION': 'Erfolgreiche Verbindung',
|
||||
'UNSUCCESSFUL_CONNECTION': 'Verbindung fehlgeschlagen',
|
||||
'SERVER_CREDENTIALS_WORKING': 'Server-Anmeldeinformationen funktionieren ordnungsgemäß',
|
||||
|
||||
'LAST_7_DAYS': 'Letzte 7 Tage',
|
||||
'LAST_30_DAYS': 'Letzte 30 Tage',
|
||||
|
@ -386,6 +397,7 @@ export default {
|
|||
'DEFAULT_PORT': 'Leave leer für 3306 als Standard',
|
||||
'PASSWORD_LOWERCASE': 'Passwort',
|
||||
'TEST_SMTP_CONNECTION': 'SMTP Verbindung testen',
|
||||
'SMTP_CONNECTION_SUCCESS': 'SMTP Anmeldeinformationen sind gültig.',
|
||||
'SMTP_CONNECTION_ERROR': 'Verbindung zum SMTP Server nicht erfolgreich.'
|
||||
'SERVER_ERROR': 'Kann nicht mit dem Server verbinden.',
|
||||
'EMAIL_SERVER_ADDRESS': 'E-Mail-Serveradresse',
|
||||
'EMAIL_SERVER_ADDRESS_DESCRIPTION': 'Adresse, an die Mails gesendet und gesendet werden'
|
||||
};
|
||||
|
|
|
@ -141,6 +141,9 @@ export default {
|
|||
'SMTP_USER': 'SMTP User',
|
||||
'SMTP_SERVER': 'SMTP Server',
|
||||
'SMTP_PASSWORD': 'SMTP Password',
|
||||
'IMAP_USER': 'IMAP User',
|
||||
'IMAP_SERVER': 'IMAP Server',
|
||||
'IMAP_PASSWORD': 'IMAP Password',
|
||||
'PORT': 'Port',
|
||||
'RECAPTCHA_PUBLIC_KEY': 'Recaptcha Public Key',
|
||||
'RECAPTCHA_PRIVATE_KEY': 'Recaptcha Private Key',
|
||||
|
@ -191,6 +194,8 @@ export default {
|
|||
'DISABLE_USER': 'Disable User',
|
||||
'SHOW_CLOSED_TICKETS': 'Show Closed Tickets',
|
||||
'IMAGE_HEADER_URL': 'Image header URL',
|
||||
'IMAGE_HEADER_DESCRIPTION': 'Image that will be used as header of the email',
|
||||
'EMAIL_SETTINGS': 'Email Settings',
|
||||
|
||||
'CHART_CREATE_TICKET': 'Tickets created',
|
||||
'CHART_CLOSE': 'Tickets closed',
|
||||
|
@ -303,11 +308,14 @@ export default {
|
|||
'ENABLE_USER_SYSTEM_DESCRIPTION': 'Enable/disable the use of an user system. If you disable it, all users will be deleted but the tickets will be kept. If you enable it, the users of existent tickets will be created.',
|
||||
'CSV_DESCRIPTION': 'The CSV file must have 3 columns: email, password, name. There is no limit in row count. It will be created one user per row in the file.',
|
||||
'SMTP_SERVER_DESCRIPTION': 'The configuration of the SMTP server allows the application to send mails. If you do not configure it, no emails will be sent by OpenSupports.',
|
||||
'IMAP_SERVER_DESCRIPTION': 'The configuration of the IMAP server allows the application to create tickets from the emails sent to a mailbox.',
|
||||
'ENABLE_USER_DESCRIPTION': 'This action allows the user to sign in and create tickets.',
|
||||
'DISABLE_USER_DESCRIPTION': 'User will be disabled and will not be able to sign in and create tickets.',
|
||||
'PRIVATE_RESPONSE_DESCRIPTION': 'This response will only be seen by staff members',
|
||||
'PRIVATE_TOPIC_DESCRIPTION': 'This topic will only be seen by staff members',
|
||||
'PRIVATE_DEPARTMENT_DESCRIPTION': 'This department will only be seen by staff members',
|
||||
'EMAIL_SETTINGS_DESCRIPTION': 'Here you can edit the settings for receiving and sending email to your customers.',
|
||||
'IMAP_POLLING_DESCRIPTION': 'Inbox checking will not be done automatically by OpenSupports. You have to make POST requests periodically to this url to process the emails: {url}',
|
||||
|
||||
//ERRORS
|
||||
'EMAIL_OR_PASSWORD': 'Email or password invalid',
|
||||
|
@ -365,6 +373,9 @@ export default {
|
|||
'WILL_RECOVER_EMAIL_TEMPLATE': 'This email template will be recover to it\'s default value on this language.',
|
||||
'SUCCESS_IMPORTING_CSV_DESCRIPTION': 'CSV File has been imported successfully',
|
||||
'SUCCESS_DELETING_ALL_USERS': 'Users have beend deleted successfully',
|
||||
'SUCCESSFUL_CONNECTION': 'Successful connection',
|
||||
'UNSUCCESSFUL_CONNECTION': 'Unsuccessful connection',
|
||||
'SERVER_CREDENTIALS_WORKING': 'Server credentials are working correctly',
|
||||
|
||||
'LAST_7_DAYS': 'Last 7 days',
|
||||
'LAST_30_DAYS': 'Last 30 days',
|
||||
|
@ -386,6 +397,7 @@ export default {
|
|||
'EMAIL_LOWERCASE': 'email',
|
||||
'PASSWORD_LOWERCASE': 'password',
|
||||
'TEST_SMTP_CONNECTION': 'Test SMTP connection',
|
||||
'SMTP_CONNECTION_SUCCESS': 'SMTP credentials are valid.',
|
||||
'SMTP_CONNECTION_ERROR': 'Can\'t connect to SMTP server.'
|
||||
'SERVER_ERROR': 'Can not connect to server.',
|
||||
'EMAIL_SERVER_ADDRESS': 'Email server address',
|
||||
'EMAIL_SERVER_ADDRESS_DESCRIPTION': 'Address where mails will be received and sent'
|
||||
};
|
||||
|
|
|
@ -141,6 +141,9 @@ export default {
|
|||
'SMTP_USER': 'Usuario SMTP',
|
||||
'SMTP_SERVER': 'Servidor SMTP',
|
||||
'SMTP_PASSWORD': 'Contraseña SMTP',
|
||||
'IMAP_USER': 'Usuario IMAP',
|
||||
'IMAP_SERVER': 'Servidor IMAP',
|
||||
'IMAP_PASSWORD': 'Contraseña IMAP',
|
||||
'PORT': 'Puerto',
|
||||
'RECAPTCHA_PUBLIC_KEY': 'Recaptcha clave pública',
|
||||
'RECAPTCHA_PRIVATE_KEY': 'Recaptcha clave privada',
|
||||
|
@ -191,6 +194,8 @@ export default {
|
|||
'DISABLE_USER': 'Deshabilitar usuario',
|
||||
'SHOW_CLOSED_TICKETS': 'Mostrar Tickets Cerrados',
|
||||
'IMAGE_HEADER_URL': 'URL del encabezado de la imagen',
|
||||
'IMAGE_HEADER_DESCRIPTION': 'Imagen que se utilizará como encabezado del correo electrónico.',
|
||||
'EMAIL_SETTINGS': 'Ajustes del correo electrónico',
|
||||
|
||||
'CHART_CREATE_TICKET': 'Tickets creados',
|
||||
'CHART_CLOSE': 'Tickets cerrados',
|
||||
|
@ -303,11 +308,14 @@ export default {
|
|||
'ENABLE_USER_SYSTEM_DESCRIPTION': 'Habilitar/Deshabilitar el uso de un sistema de usuario. Si lo deshabilitas, todos los usuarios serán eliminados pero los tickets serán guardados. Si lo habilitas, se crearán los usuarios de los tickets existentes.',
|
||||
'CSV_DESCRIPTION': 'El archivo CSV debe tener 3 columnas: correo electrónico, contraseña, nombre. No hay límite en el recuento de filas. Se creará un usuario por fila en el archivo.',
|
||||
'SMTP_SERVER_DESCRIPTION': 'La configuracion de SMTP permite que la applicacion mande emails. Si no es configurado, ningún mail sera enviado OpenSupports.',
|
||||
'IMAP_SERVER_DESCRIPTION': 'La configuración del servidor IMAP permite que la aplicación cree tickets de los correos electrónicos enviados a un buzón.',
|
||||
'ENABLE_USER_DESCRIPTION': 'Esta acción permite al usuario iniciar sesión y crear tickets..',
|
||||
'DISABLE_USER_DESCRIPTION': 'El usuario estará deshabilitado y no podrá iniciar sesión y crear tickets.',
|
||||
'PRIVATE_RESPONSE_DESCRIPTION': 'Esta respuesta solo será vista por los miembros del personal.',
|
||||
'PRIVATE_TOPIC_DESCRIPTION': 'Este tema solo será visto por los miembros del personal.',
|
||||
'PRIVATE_DEPARTMENT_DESCRIPTION': 'Este departamento solo será visto por miembros del personal.',
|
||||
'EMAIL_SETTINGS_DESCRIPTION': 'Aquí puede editar la configuración para recibir y enviar correos electrónicos a sus clientes.',
|
||||
'IMAP_POLLING_DESCRIPTION': 'La verificación de la bandeja de entrada no se hará automáticamente por OpenSupports. Debe realizar solicitudes POST periódicamente a esta URL para procesar los correos electrónicos: {url}',
|
||||
|
||||
//ERRORS
|
||||
'EMAIL_OR_PASSWORD': 'Email o contraseña inválida',
|
||||
|
@ -365,6 +373,9 @@ export default {
|
|||
'SUCCESS_IMPORTING_CSV_DESCRIPTION': 'El archivo CSV se ha importado correctamente',
|
||||
'SUCCESS_DELETING_ALL_USERS': 'Los usuarios se han eliminado correctamente',
|
||||
'ERROR_IMAGE_SIZE': 'Ninguna imagen puede tener un tamaño superior a {size} MB',
|
||||
'SUCCESSFUL_CONNECTION': 'Conexión exitosa',
|
||||
'UNSUCCESSFUL_CONNECTION': 'Conexión fallida',
|
||||
'SERVER_CREDENTIALS_WORKING': 'Las credenciales del servidor están funcionando correctamente',
|
||||
|
||||
'LAST_7_DAYS': 'Últimos 7 dias',
|
||||
'LAST_30_DAYS': 'Últimos 30 dias',
|
||||
|
@ -386,6 +397,7 @@ export default {
|
|||
'DEFAULT_PORT': 'Deje en blanco para 3306 por defecto',
|
||||
'PASSWORD_LOWERCASE': 'contraseña',
|
||||
'TEST_SMTP_CONNECTION': 'Probar conexion de SMTP',
|
||||
'SMTP_CONNECTION_SUCCESS': 'La credenciales de SMTP son correctas.',
|
||||
'SMTP_CONNECTION_ERROR': 'No es posible conectarse al servidor de SMTP.'
|
||||
'SERVER_ERROR': 'No es posible conectar con el servidor.',
|
||||
'EMAIL_SERVER_ADDRESS': 'Dirección del servidor de correo electrónico',
|
||||
'EMAIL_SERVER_ADDRESS_DESCRIPTION': 'Dirección donde se recibirán y enviarán los correos.'
|
||||
};
|
||||
|
|
|
@ -141,6 +141,9 @@ export default {
|
|||
'SMTP_USER': 'Utilisateur SMTP',
|
||||
'SMTP_SERVER': 'Serveur SMTP',
|
||||
'SMTP_PASSWORD': 'Mot de passe SMTP',
|
||||
'IMAP_USER': 'Utilisateur IMAP',
|
||||
'IMAP_SERVER': 'Serveur IMAP',
|
||||
'IMAP_PASSWORD': 'Mot de passe IMAP',
|
||||
'PORT': 'Port',
|
||||
'RECAPTCHA_PUBLIC_KEY': 'Clé publique Recaptcha',
|
||||
'RECAPTCHA_PRIVATE_KEY': 'Clé privée Recaptcha',
|
||||
|
@ -191,6 +194,8 @@ export default {
|
|||
'DISABLE_USER': 'Désactiver l\'utilisateur',
|
||||
'SHOW_CLOSED_TICKETS': 'Afficher les billets fermés',
|
||||
'IMAGE_HEADER_URL': 'URL de l\'en-tête de l\'image',
|
||||
'IMAGE_HEADER_DESCRIPTION': 'Image qui sera utilisée comme en-tête de l\'email',
|
||||
'EMAIL_SETTINGS': 'Paramètres de messagerie',
|
||||
|
||||
'CHART_CREATE_TICKET': 'Tickets créés',
|
||||
'CHART_CLOSE': 'Tickets fermés',
|
||||
|
@ -303,11 +308,14 @@ export default {
|
|||
'ENABLE_USER_SYSTEM_DESCRIPTION': 'Activer / désactiver l\'utilisation d\'un système utilisateur. Si vous le désactivez, tous les utilisateurs seront supprimés, mais les tickets seront conservés. Si vous l\'activez, les utilisateurs des tickets existants seront créés.',
|
||||
'CSV_DESCRIPTION': 'Le fichier CSV doit comporter 3 colonnes: email, mot de passe, nom. Il n\'y a pas de limite dans le nombre de lignes. Il sera créé un utilisateur par ligne dans le fichier.',
|
||||
'SMTP_SERVER_DESCRIPTION': 'La configuration du serveur SMTP permet à l\'application d\'envoyer des mails. Si vous ne le configurez pas, aucun service d\'email ne sera envoyé par OpenSupports.',
|
||||
'IMAP_SERVER_DESCRIPTION': 'La configuration du serveur IMAP permet à l’application de créer des tickets à partir des emails envoyés à une boîte aux lettres.',
|
||||
'ENABLE_USER_DESCRIPTION': 'Cette action permet à l\'utilisateur de se connecter et de créer des tickets.',
|
||||
'DISABLE_USER_DESCRIPTION': 'L\'utilisateur sera désactivé et ne pourra pas se connecter et créer des tickets.',
|
||||
'PRIVATE_RESPONSE_DESCRIPTION': 'Cette réponse ne sera vue que par les membres du personnel',
|
||||
'PRIVATE_TOPIC_DESCRIPTION': 'Ce sujet ne sera vu que par les membres du personnel',
|
||||
'PRIVATE_DEPARTMENT_DESCRIPTION': 'Ce département ne sera vu que par les membres du personnel',
|
||||
'EMAIL_SETTINGS_DESCRIPTION': 'Ici, vous pouvez modifier les paramètres de réception et d’envoi de courrier électronique à vos clients.',
|
||||
'IMAP_POLLING_DESCRIPTION': 'La vérification de la boîte de réception ne sera pas effectuée automatiquement par OpenSupports. Vous devez faire des demandes POST périodiquement à cette URL pour traiter les emails: {url}',
|
||||
|
||||
//ERRORS
|
||||
'EMAIL_OR_PASSWORD': 'E-mail ou mot de passe invalide',
|
||||
|
@ -365,6 +373,9 @@ export default {
|
|||
'WILL_RECOVER_EMAIL_TEMPLATE': 'Ce modèle de courrier électronique sera réinitialisé à sa valeur par défaut pour cette langue.',
|
||||
'SUCCESS_IMPORTING_CSV_DESCRIPTION': 'Le fichier CSV a été importé avec succès',
|
||||
'SUCCESS_DELETING_ALL_USERS': 'Les utilisateurs ont été supprimés avec succès',
|
||||
'SUCCESSFUL_CONNECTION': 'Connexion réussie',
|
||||
'UNSUCCESSFUL_CONNECTION': 'Connexion infructueuse',
|
||||
'SERVER_CREDENTIALS_WORKING': 'Les informations d\'identification du serveur fonctionnent correctement',
|
||||
|
||||
'LAST_7_DAYS': 'Les 7 derniers jours',
|
||||
'LAST_30_DAYS': 'Les 30 derniers jours',
|
||||
|
@ -386,6 +397,7 @@ export default {
|
|||
'DEFAULT_PORT': 'Laisser vide pour 3306 par défaut',
|
||||
'PASSWORD_LOWERCASE': 'mot de passe',
|
||||
'TEST_SMTP_CONNECTION': 'Test de connexion SMTP',
|
||||
'SMTP_CONNECTION_SUCCESS': 'Les informations d\'identification SMTP sont valides.',
|
||||
'SMTP_CONNECTION_ERROR': 'Ne peut pas se connecter au serveur SMTP.'
|
||||
'SERVER_ERROR': 'Ne peut pas se connecter au serveur.',
|
||||
'EMAIL_SERVER_ADDRESS': 'Adresse du serveur de messagerie',
|
||||
'EMAIL_SERVER_ADDRESS_DESCRIPTION': 'Adresse où les mails seront reçus et envoyés'
|
||||
};
|
||||
|
|
|
@ -141,6 +141,9 @@
|
|||
'SMTP_USER': 'SMTP Χρήστης',
|
||||
'SMTP_SERVER': 'SMTP Εξυπηρετητής',
|
||||
'SMTP_PASSWORD': 'SMTP Κωδικός Πρόσβασης',
|
||||
'IMAP_USER': 'Χρήστης IMAP',
|
||||
'IMAP_SERVER': 'IMAP Server',
|
||||
'IMAP_PASSWORD': 'Κωδικός IMAP',
|
||||
'PORT': 'Θύρα',
|
||||
'RECAPTCHA_PUBLIC_KEY': 'Recaptcha Δημοσίου Κλειδιού',
|
||||
'RECAPTCHA_PRIVATE_KEY': 'Recaptcha Ιδιωτικού Κλειδιού',
|
||||
|
@ -191,6 +194,8 @@
|
|||
'DISABLE_USER': 'Απενεργοποίηση χρήστη',
|
||||
'SHOW_CLOSED_TICKETS': 'Εμφάνιση κλειστών εισιτηρίων',
|
||||
'IMAGE_HEADER_URL': 'Διεύθυνση URL κεφαλίδας εικόνας',
|
||||
'IMAGE_HEADER_DESCRIPTION': 'Εικόνα που θα χρησιμοποιηθεί ως κεφαλίδα του μηνύματος ηλεκτρονικού ταχυδρομείου',
|
||||
'EMAIL_SETTINGS': 'Ρυθμίσεις email',
|
||||
|
||||
'CHART_CREATE_TICKET': 'Τα εισιτήρια δημιουργήθηκαν',
|
||||
'CHART_CLOSE': 'Τα εισιτήρια κλείσανε',
|
||||
|
@ -303,11 +308,14 @@
|
|||
'ENABLE_USER_SYSTEM_DESCRIPTION': 'Ενεργοποίηση / απενεργοποίηση της χρήσης ενός συστήματος χρήστη. Εάν την απενεργοποιήσετε, όλοι οι χρήστες θα διαγραφούν αλλά τα εισιτήρια θα διατηρηθούν. Εάν την ενεργοποιήσετε, θα δημιουργηθούν οι χρήστες των υφιστάμενων εισιτηρίων.',
|
||||
'CSV_DESCRIPTION': 'Το αρχείο CSV πρέπει να έχει 3 στήλες: email, κωδικό πρόσβασης, όνομα. Δεν υπάρχει όριο στην καταμέτρηση των σειρών. Θα δημιουργηθεί ένας χρήστης ανά σειρά στο αρχείο.',
|
||||
'SMTP_SERVER_DESCRIPTION': 'Η διαμόρφωση του διακομιστή SMTP επιτρέπει στην εφαρμογή να στείλει μηνύματα. Αν δεν το ρυθμίσετε, δεν θα σταλούν μηνύματα ηλεκτρονικού ταχυδρομείου από το OpenSupport.',
|
||||
'IMAP_SERVER_DESCRIPTION': 'Η διαμόρφωση του διακομιστή IMAP επιτρέπει στην εφαρμογή να δημιουργεί εισιτήρια από τα μηνύματα ηλεκτρονικού ταχυδρομείου που αποστέλλονται σε ένα γραμματοκιβώτιο.',
|
||||
'ENABLE_USER_DESCRIPTION': 'Αυτή η ενέργεια επιτρέπει στο χρήστη να συνδεθεί και να δημιουργήσει εισιτήρια.',
|
||||
'DISABLE_USER_DESCRIPTION': 'Ο χρήστης θα απενεργοποιηθεί και δεν θα μπορέσει να συνδεθεί και να δημιουργήσει εισιτήρια.',
|
||||
'PRIVATE_RESPONSE_DESCRIPTION': 'Αυτή η απάντηση θα δει μόνο τα μέλη του προσωπικού',
|
||||
'PRIVATE_TOPIC_DESCRIPTION': 'Αυτό το θέμα θα προβληθεί μόνο από μέλη του προσωπικού',
|
||||
'PRIVATE_DEPARTMENT_DESCRIPTION': 'Αυτό το τμήμα θα δει μόνο τα μέλη του προσωπικού',
|
||||
'EMAIL_SETTINGS_DESCRIPTION': 'Εδώ μπορείτε να επεξεργαστείτε τις ρυθμίσεις για τη λήψη και αποστολή μηνυμάτων ηλεκτρονικού ταχυδρομείου στους πελάτες σας.',
|
||||
'IMAP_POLLING_DESCRIPTION': 'Ο έλεγχος εισερχομένων δεν θα γίνει αυτόματα από το OpenSupport. Πρέπει να κάνετε τα αιτήματα POST περιοδικά σε αυτήν τη διεύθυνση url για να επεξεργαστείτε τα μηνύματα ηλεκτρονικού ταχυδρομείου: {url}',
|
||||
|
||||
//ERRORS
|
||||
'EMAIL_OR_PASSWORD': 'Λάθος ηλεκτρονική διεύθυνση ή κωδικός πρόσβασης',
|
||||
|
@ -365,6 +373,9 @@
|
|||
'WILL_RECOVER_EMAIL_TEMPLATE': 'Αυτό το πρότυπο ηλεκτρονικού ταχυδρομείου θα αναληφθεί σε κατάσταση αρχική με την αρχική γλώσσα.',
|
||||
'SUCCESS_IMPORTING_CSV_DESCRIPTION': 'Το αρχείο CSV έχει εισαχθεί επιτυχώς',
|
||||
'SUCCESS_DELETING_ALL_USERS': 'Οι χρήστες έχουν διαγραφεί επιτυχώς',
|
||||
'SUCCESSFUL_CONNECTION': 'Επιτυχής σύνδεση',
|
||||
'UNSUCCESSFUL_CONNECTION': 'Μη επιτυχής σύνδεση',
|
||||
'SERVER_CREDENTIALS_WORKING': 'Οι πιστοποιήσεις διακομιστή λειτουργούν σωστά',
|
||||
|
||||
'LAST_7_DAYS': 'Τελευταίες 7 μέρες',
|
||||
'LAST_30_DAYS': 'Τελευταίες 30 μέρες',
|
||||
|
@ -386,6 +397,7 @@
|
|||
'EMAIL_LOWERCASE': 'ηλεκτρονική διεύθυνση',
|
||||
'PASSWORD_LOWERCASE': 'κωδικός πρόσβασης',
|
||||
'TEST_SMTP_CONNECTION': 'Δοκίμασε την SMTP σύνδεση',
|
||||
'SMTP_CONNECTION_SUCCESS': 'Τα SMTP διαπιστευτήρια είναι έγκυρα.',
|
||||
'SMTP_CONNECTION_ERROR': 'Δεν μπορεί να γίνει σύνδεση στον SMTP διακομιστή.'
|
||||
};
|
||||
'SERVER_ERROR': 'Δεν μπορεί να συνδεθεί στον σέρβερ.',
|
||||
'EMAIL_SERVER_ADDRESS': 'Διεύθυνση διακομιστή ηλεκτρονικού ταχυδρομείου',
|
||||
'EMAIL_SERVER_ADDRESS_DESCRIPTION': 'Διεύθυνση όπου θα ληφθούν και θα αποσταλούν τα μηνύματα'
|
||||
};
|
||||
|
|
|
@ -141,6 +141,9 @@ export default {
|
|||
'SMTP_USER': 'एसएमटीपी उपयोगकर्ता',
|
||||
'SMTP_SERVER': 'एसएमटीपी सर्वर',
|
||||
'SMTP_PASSWORD': 'एसएमटीपी पासवर्ड',
|
||||
'IMAP_USER': 'IMAP उपयोगकर्ता',
|
||||
'IMAP_SERVER': 'IMAP सर्वर',
|
||||
'IMAP_PASSWORD': 'IMAP पासवर्ड',
|
||||
'PORT': 'बंदरगाह',
|
||||
'RECAPTCHA_PUBLIC_KEY': 'Recaptcha सार्वजनिक कुंजी',
|
||||
'RECAPTCHA_PRIVATE_KEY': 'Recaptcha निजी कुंजी',
|
||||
|
@ -191,6 +194,8 @@ export default {
|
|||
'DISABLE_USER': 'उपयोगकर्ता को अक्षम करें',
|
||||
'SHOW_CLOSED_TICKETS': 'बंद टिकट दिखाएं',
|
||||
'IMAGE_HEADER_URL': 'छवि शीर्षलेख यूआरएल',
|
||||
'IMAGE_HEADER_DESCRIPTION': 'वह छवि जो ईमेल के शीर्ष लेख के रूप में उपयोग की जाएगी',
|
||||
'EMAIL_SETTINGS': 'ईमेल सेटिंग',
|
||||
|
||||
'CHART_CREATE_TICKET': 'टिकट बनाया',
|
||||
'CHART_CLOSE': 'टिकट बंद कर दिया',
|
||||
|
@ -303,11 +308,14 @@ export default {
|
|||
'ENABLE_USER_SYSTEM_DESCRIPTION': 'किसी उपयोगकर्ता सिस्टम के उपयोग को सक्षम / अक्षम करें यदि आप इसे अक्षम करते हैं, तो सभी उपयोगकर्ताओं को हटा दिया जाएगा लेकिन टिकट को रखा जाएगा। यदि आप इसे सक्षम करते हैं, तो विद्यमान टिकट के उपयोगकर्ता बनाए जाएंगे',
|
||||
'CSV_DESCRIPTION': 'सीएसवी फ़ाइल में 3 कॉलम होना चाहिए: ईमेल, पासवर्ड, नाम। पंक्ति गणना में कोई सीमा नहीं है फ़ाइल में प्रति पंक्ति एक उपयोगकर्ता बनाया जाएगा।',
|
||||
'SMTP_SERVER_DESCRIPTION': 'एसएमटीपी सर्वर का कॉन्फ़िगरेशन एप्लिकेशन को मेल भेजने की अनुमति देता है। यदि आप इसे कॉन्फ़िगर नहीं करते हैं, तो OpenSupports द्वारा कोई ईमेल नहीं भेजा जाएगा।',
|
||||
'IMAP_SERVER_DESCRIPTION': 'IMAP सर्वर का कॉन्फ़िगरेशन एप्लिकेशन को मेलबॉक्स पर भेजे गए ईमेल से टिकट बनाने की अनुमति देता है।',
|
||||
'ENABLE_USER_DESCRIPTION': 'यह क्रिया उपयोगकर्ता को साइन इन करने और टिकट बनाने की अनुमति देती है।',
|
||||
'DISABLE_USER_DESCRIPTION': 'उपयोगकर्ता अक्षम कर दिया जाएगा और साइन इन करने और टिकट बनाने में सक्षम नहीं होगा।',
|
||||
'PRIVATE_RESPONSE_DESCRIPTION': 'यह प्रतिक्रिया केवल कर्मचारियों के सदस्यों द्वारा देखी जाएगी',
|
||||
'PRIVATE_TOPIC_DESCRIPTION': 'यह विषय केवल कर्मचारियों के सदस्यों द्वारा देखा जाएगा',
|
||||
'PRIVATE_DEPARTMENT_DESCRIPTION': 'यह विभाग केवल कर्मचारियों के सदस्यों द्वारा देखा जाएगा',
|
||||
'EMAIL_SETTINGS_DESCRIPTION': 'यहां आप अपने ग्राहकों को ईमेल प्राप्त करने और भेजने के लिए सेटिंग्स को संपादित कर सकते हैं।',
|
||||
'IMAP_POLLING_DESCRIPTION': 'इनबॉक्स चेकिंग स्वचालित रूप से OpenSupports द्वारा नहीं की जाएगी। ईमेल संसाधित करने के लिए आपको समय-समय पर इस url को POST करना होगा',
|
||||
|
||||
//ERRORS
|
||||
'EMAIL_OR_PASSWORD': 'ईमेल या पासवर्ड अमान्य',
|
||||
|
@ -365,6 +373,9 @@ export default {
|
|||
'WILL_RECOVER_EMAIL_TEMPLATE': 'यह इस भाषा पर डिफ़ॉल्ट मान है करने के लिए इस ईमेल टेम्पलेट की वसूली की जाएगी।',
|
||||
'SUCCESS_IMPORTING_CSV_DESCRIPTION': 'सीएसवी फ़ाइल को सफलतापूर्वक आयात किया गया है',
|
||||
'SUCCESS_DELETING_ALL_USERS': 'उपयोगकर्ताओं को सफलतापूर्वक हटा दिया गया है',
|
||||
'SUCCESSFUL_CONNECTION': 'सफल संबंध',
|
||||
'UNSUCCESSFUL_CONNECTION': 'असफल कनेक्शन',
|
||||
'SERVER_CREDENTIALS_WORKING': 'सर्वर क्रेडेंशियल्स सही ढंग से काम कर रहे हैं',
|
||||
|
||||
'LAST_7_DAYS': 'पिछले 7 दिन',
|
||||
'LAST_30_DAYS': 'अंतिम 30 दिन',
|
||||
|
@ -386,6 +397,7 @@ export default {
|
|||
'DEFAULT_PORT': '3306 के लिए डिफ़ॉल्ट के रूप में खाली छोड़ दें',
|
||||
'PASSWORD_LOWERCASE': 'पासवर्ड',
|
||||
'TEST_SMTP_CONNECTION': 'परीक्षण एसएमटीपी कनेक्शन',
|
||||
'SMTP_CONNECTION_SUCCESS': 'SMTP क्रेडेंशियल्स मान्य हं।',
|
||||
'SMTP_CONNECTION_ERROR': 'एसएमटीपी सर्वर से कनेक्ट नहीं हो सकता'
|
||||
'SERVER_ERROR': 'सर्वर से कनेक्ट नहीं हो पा रहा।',
|
||||
'EMAIL_SERVER_ADDRESS': 'ईमेल सर्वर का पता',
|
||||
'EMAIL_SERVER_ADDRESS_DESCRIPTION': 'पता जहां मेल प्राप्त होगा और भेजा जाएगा'
|
||||
};
|
||||
|
|
|
@ -141,6 +141,9 @@ export default {
|
|||
'SMTP_USER': 'SMTP User',
|
||||
'SMTP_SERVER': 'SMTP Server',
|
||||
'SMTP_PASSWORD': 'SMTP Password',
|
||||
'IMAP_USER': 'Utente IMAP',
|
||||
'IMAP_SERVER': 'Server IMAP',
|
||||
'IMAP_PASSWORD': 'Password IMAP',
|
||||
'PORT': 'Port',
|
||||
'RECAPTCHA_PUBLIC_KEY': 'Recaptcha Public Key',
|
||||
'RECAPTCHA_PRIVATE_KEY': 'Recaptcha Private Key',
|
||||
|
@ -191,6 +194,8 @@ export default {
|
|||
'DISABLE_USER': 'Disabilita utente',
|
||||
'SHOW_CLOSED_TICKETS': 'Mostra biglietti chiusi',
|
||||
'IMAGE_HEADER_URL': 'URL dell\'intestazione dell\'immagine',
|
||||
'IMAGE_HEADER_DESCRIPTION': 'Immagine che verrà utilizzata come intestazione dell\'e-mail',
|
||||
'EMAIL_SETTINGS': 'impostazioni dell \'email',
|
||||
|
||||
'CHART_CREATE_TICKET': 'Tickets creato',
|
||||
'CHART_CLOSE': 'Tickets chiuso',
|
||||
|
@ -303,11 +308,14 @@ export default {
|
|||
'ENABLE_USER_SYSTEM_DESCRIPTION': 'Abilita / disabilita l\'utilizzo di un sistema utente. Se lo disattiverai, tutti gli utenti verranno eliminati ma i biglietti saranno conservati. Se lo abiliterai, verranno creati gli utenti dei biglietti esistenti.',
|
||||
'CSV_DESCRIPTION': 'l file CSV deve avere 3 colonne: e-mail, password, nome. Non esiste alcun limite nel conteggio delle righe. Sarà creato un utente per riga nel file.',
|
||||
'SMTP_SERVER_DESCRIPTION': 'La configurazione del server SMTP consente all\'applicazione di inviare messaggi. Se non lo si configura, non verrà inviata alcuna email da OpenSupports.',
|
||||
'IMAP_SERVER_DESCRIPTION': 'La configurazione del server IMAP consente all\'applicazione di creare ticket dalle e-mail inviate a una casella di posta.',
|
||||
'ENABLE_USER_DESCRIPTION': 'Questa azione consente all\'utente di accedere e creare ticket.',
|
||||
'DISABLE_USER_DESCRIPTION': 'L\'utente sarà disabilitato e non sarà in grado di accedere e creare biglietti.',
|
||||
'PRIVATE_RESPONSE_DESCRIPTION': 'Questa risposta sarà visibile solo ai membri dello staff',
|
||||
'PRIVATE_TOPIC_DESCRIPTION': 'Questo argomento sarà visto solo dai membri dello staff',
|
||||
'PRIVATE_DEPARTMENT_DESCRIPTION': 'Questo dipartimento sarà visto solo dai membri dello staff',
|
||||
'EMAIL_SETTINGS_DESCRIPTION': 'Qui puoi modificare le impostazioni per ricevere e inviare email ai tuoi clienti.',
|
||||
'IMAP_POLLING_DESCRIPTION': 'Il controllo della posta in arrivo non verrà eseguito automaticamente da OpenSupports. Devi effettuare periodicamente richieste POST a questo URL per elaborare le email: {url}',
|
||||
|
||||
//ERRORS
|
||||
'EMAIL_OR_PASSWORD': 'Email o password errate',
|
||||
|
@ -365,6 +373,9 @@ export default {
|
|||
'WILL_RECOVER_EMAIL_TEMPLATE': 'Questo template verrà recuperato al suo valore predefinito in questa lingua.',
|
||||
'SUCCESS_IMPORTING_CSV_DESCRIPTION': 'Il file CSV è stato importato correttamente',
|
||||
'SUCCESS_DELETING_ALL_USERS': 'Gli utenti devono essere eliminati correttamente',
|
||||
'SUCCESSFUL_CONNECTION': 'Connessione riuscita',
|
||||
'UNSUCCESSFUL_CONNECTION': 'Connessione non riuscita',
|
||||
'SERVER_CREDENTIALS_WORKING': 'Le credenziali del server funzionano correttamente',
|
||||
|
||||
'LAST_7_DAYS': 'Ultimi 7 giorni',
|
||||
'LAST_30_DAYS': 'Ultimi 30 giorni',
|
||||
|
@ -386,7 +397,8 @@ export default {
|
|||
'DEFAULT_PORT': 'Lascia vuoto per 3306 come predefinito',
|
||||
'PASSWORD_LOWERCASE': 'password',
|
||||
'TEST_SMTP_CONNECTION': 'Verifica connessione SMTP',
|
||||
'SMTP_CONNECTION_SUCCESS': 'Le credenziali SMTP sono valide.',
|
||||
'SMTP_CONNECTION_ERROR': 'Impossibile connettersi al server SMTP.'
|
||||
'SERVER_ERROR': 'Non è possibile connettersi con il server.',
|
||||
'EMAIL_SERVER_ADDRESS': 'Indirizzo del server email',
|
||||
'EMAIL_SERVER_ADDRESS_DESCRIPTION': 'Indirizzo dove verranno ricevuti e inviati i messaggi'
|
||||
};
|
||||
/** Special thanks to Fabio Giarrusso for translation contribution **/
|
||||
|
|
|
@ -141,6 +141,9 @@ export default {
|
|||
'SMTP_USER': 'SMTPユーザー',
|
||||
'SMTP_SERVER': 'SMTPサーバー',
|
||||
'SMTP_PASSWORD': 'SMTPパスワード',
|
||||
'IMAP_USER': 'IMAPユーザー',
|
||||
'IMAP_SERVER': 'IMAPサーバー',
|
||||
'IMAP_PASSWORD': 'IMAPパスワード',
|
||||
'PORT': 'ポート',
|
||||
'RECAPTCHA_PUBLIC_KEY': 'Recaptcha公開鍵',
|
||||
'RECAPTCHA_PRIVATE_KEY': 'Recaptcha秘密鍵',
|
||||
|
@ -191,6 +194,8 @@ export default {
|
|||
'DISABLE_USER': 'ユーザーを無効にする',
|
||||
'SHOW_CLOSED_TICKETS': 'クローズドチケットを表示する',
|
||||
'IMAGE_HEADER_URL': '画像のヘッダーURL',
|
||||
'IMAGE_HEADER_DESCRIPTION': '電子メールのヘッダーとして使用される画像',
|
||||
'EMAIL_SETTINGS': 'メール設定',
|
||||
|
||||
'CHART_CREATE_TICKET': '作成されたチケット',
|
||||
'CHART_CLOSE': 'チケットが閉じられました',
|
||||
|
@ -303,11 +308,14 @@ export default {
|
|||
'ENABLE_USER_SYSTEM_DESCRIPTION': 'ユーザシステムの使用を有効/無効にします。無効にすると、すべてのユーザーは削除されますが、チケットは保持されます。これを有効にすると、既存のチケットのユーザーが作成されます。',
|
||||
'CSV_DESCRIPTION': 'CSVファイルには、電子メール、パスワード、名前の3つの列が必要です。行数に制限はありません。ファイル内で行ごとに1人ずつ作成されます',
|
||||
'SMTP_SERVER_DESCRIPTION': 'SMTPサーバーの設定により、アプリケーションはメールを送信できます。 これを設定しないと、OpenSupportsから電子メールは送信されません。',
|
||||
'IMAP_SERVER_DESCRIPTION': 'IMAPサーバーの設定により、アプリケーションはメールボックスに送信されたEメールからチケットを作成できます。',
|
||||
'ENABLE_USER_DESCRIPTION': 'これにより、ユーザーはサインインしてチケットを作成できます。',
|
||||
'DISABLE_USER_DESCRIPTION': 'ユーザーは無効になり、ログインしてチケットを作成することはできません。',
|
||||
'PRIVATE_RESPONSE_DESCRIPTION': 'スタッフのみがこの回答を見ることができます',
|
||||
'PRIVATE_TOPIC_DESCRIPTION': 'このトピックは、スタッフによってのみ表示されます',
|
||||
'PRIVATE_DEPARTMENT_DESCRIPTION': 'この部署はスタッフだけが見ることができます',
|
||||
'EMAIL_SETTINGS_DESCRIPTION': 'ここでは、顧客との間でEメールを送受信するための設定を編集できます。',
|
||||
'IMAP_POLLING_DESCRIPTION': '受信トレイのチェックはOpenSupportsによって自動的には行われません。メールを処理するには、定期的にこのURLにPOSTリクエストを送信する必要があります:{url}',
|
||||
|
||||
//ERRORS
|
||||
'EMAIL_OR_PASSWORD': '電子メールまたはパスワードが無効です',
|
||||
|
@ -365,6 +373,9 @@ export default {
|
|||
'WILL_RECOVER_EMAIL_TEMPLATE': 'この電子メールテンプレートは、この言語のデフォルト値にリカバリされます。',
|
||||
'SUCCESS_IMPORTING_CSV_DESCRIPTION': 'CSVファイルを正常にインポートしました',
|
||||
'SUCCESS_DELETING_ALL_USERS': 'ユーザーは正常に削除されました',
|
||||
'SUCCESSFUL_CONNECTION': '成功した接続',
|
||||
'UNSUCCESSFUL_CONNECTION': '失敗した接続',
|
||||
'SERVER_CREDENTIALS_WORKING': 'サーバーの資格情報が正しく機能している',
|
||||
|
||||
'LAST_7_DAYS': '過去7日間',
|
||||
'LAST_30_DAYS': '過去30日間',
|
||||
|
@ -386,6 +397,7 @@ export default {
|
|||
'DEFAULT_PORT': '既定値として3306の場合は空のままにします',
|
||||
'PASSWORD_LOWERCASE': 'パスワード',
|
||||
'TEST_SMTP_CONNECTION': 'SMTP接続をテストする',
|
||||
'SMTP_CONNECTION_SUCCESS': 'SMTP資格情報が有効です。',
|
||||
'SMTP_CONNECTION_ERROR': 'SMTPサーバーに接続できません。'
|
||||
'SERVER_ERROR': 'サーバーに接続できません。',
|
||||
'EMAIL_SERVER_ADDRESS': 'メールサーバーアドレス',
|
||||
'EMAIL_SERVER_ADDRESS_DESCRIPTION': 'メールが送受信されるアドレス'
|
||||
};
|
||||
|
|
|
@ -141,6 +141,9 @@ export default {
|
|||
'SMTP_USER': 'SMTP Gebruiker',
|
||||
'SMTP_SERVER': 'SMTP Server',
|
||||
'SMTP_PASSWORD': 'SMTP Wachtwoord',
|
||||
'IMAP_USER': 'IMAP-gebruiker',
|
||||
'IMAP_SERVER': 'IMAP-server',
|
||||
'IMAP_PASSWORD': 'IMAP-wachtwoord',
|
||||
'PORT': 'Poort',
|
||||
'RECAPTCHA_PUBLIC_KEY': 'Recaptcha Publieke Sleutel',
|
||||
'RECAPTCHA_PRIVATE_KEY': 'Recaptcha Prive Sleutel',
|
||||
|
@ -191,6 +194,8 @@ export default {
|
|||
'DISABLE_USER': 'Gebruiker uitschakelen',
|
||||
'SHOW_CLOSED_TICKETS': 'Toon gesloten tickets',
|
||||
'IMAGE_HEADER_URL': 'Image header URL',
|
||||
'IMAGE_HEADER_DESCRIPTION': 'Afbeelding die wordt gebruikt als koptekst van de e-mail',
|
||||
'EMAIL_SETTINGS': 'Email instellingen',
|
||||
|
||||
'CHART_CREATE_TICKET': 'Aangemaakte incidenten',
|
||||
'CHART_CLOSE': 'Gesloten incidenten',
|
||||
|
@ -303,11 +308,14 @@ export default {
|
|||
'ENABLE_USER_SYSTEM_DESCRIPTION': 'Schakel het gebruik van een gebruikerssysteem in / uit. Als u dit uitschakelt, worden alle gebruikers verwijderd, maar worden de incidenten bewaard. Als u dit inschakelt, worden de gebruikers van bestaande incidenten aangemaakt.',
|
||||
'CSV_DESCRIPTION': 'Het CSV-bestand moet drie kolommen bevatten: e-mailadres, wachtwoord, naam. Er is geen limiet in rijtelling. Er wordt één gebruiker per rij in de database gemaakt.',
|
||||
'SMTP_SERVER_DESCRIPTION': 'De configuratie van de SMTP-server staat het systeem toe om e-mails te verzenden. Als u deze optie niet configureerd, worden er geen e-mails verzonden door OpenSupports.',
|
||||
'IMAP_SERVER_DESCRIPTION': 'Met de configuratie van de IMAP-server kan de applicatie tickets maken van de e-mails die naar een mailbox worden verzonden.',
|
||||
'ENABLE_USER_DESCRIPTION': 'Met deze actie kan de gebruiker inloggen en tickets maken.',
|
||||
'DISABLE_USER_DESCRIPTION': 'De gebruiker wordt uitgeschakeld en kan zich niet aanmelden en geen tickets maken.',
|
||||
'PRIVATE_RESPONSE_DESCRIPTION': 'Dit antwoord is alleen zichtbaar voor personeelsleden',
|
||||
'PRIVATE_TOPIC_DESCRIPTION': 'Dit onderwerp is alleen zichtbaar voor personeelsleden',
|
||||
'PRIVATE_DEPARTMENT_DESCRIPTION': 'Deze afdeling is alleen zichtbaar voor personeelsleden',
|
||||
'EMAIL_SETTINGS_DESCRIPTION': 'Hier kunt u de instellingen voor het ontvangen en verzenden van e-mail naar uw klanten bewerken.',
|
||||
'IMAP_POLLING_DESCRIPTION': 'Inbox controleren wordt niet automatisch gedaan door OpenSupports. U moet regelmatig POST-verzoeken doen naar deze URL om de e-mails te verwerken: {url}',
|
||||
|
||||
//ERRORS
|
||||
'EMAIL_OR_PASSWORD': 'E-mailadres of wachtwoord ongeldig',
|
||||
|
@ -365,6 +373,9 @@ export default {
|
|||
'WILL_RECOVER_EMAIL_TEMPLATE': 'Dit e-mailsjabloon wordt hersteld naar de standaardwaarde voor deze taal.',
|
||||
'SUCCESS_IMPORTING_CSV_DESCRIPTION': 'Het CSV bestand is succesvol geimporteerd',
|
||||
'SUCCESS_DELETING_ALL_USERS': 'Gebruikers zijn succesvol verwijderd',
|
||||
'SUCCESSFUL_CONNECTION': 'Succesvolle verbinding',
|
||||
'UNSUCCESSFUL_CONNECTION': 'Mislukte verbinding',
|
||||
'SERVER_CREDENTIALS_WORKING': 'Serverreferenties werken correct',
|
||||
|
||||
'LAST_7_DAYS': 'Laatste 7 dagen',
|
||||
'LAST_30_DAYS': 'Laatste 30 dagen',
|
||||
|
@ -386,6 +397,7 @@ export default {
|
|||
'EMAIL_LOWERCASE': 'e-mail',
|
||||
'PASSWORD_LOWERCASE': 'Wachtwoord',
|
||||
'TEST_SMTP_CONNECTION': 'Test SMTP verbinding',
|
||||
'SMTP_CONNECTION_SUCCESS': 'SMTP inloggegevens zijn correct.',
|
||||
'SMTP_CONNECTION_ERROR': 'Verbinding naar SMTP server mislukt.'
|
||||
'SERVER_ERROR': 'Kan geen verbinding maken met de server.',
|
||||
'EMAIL_SERVER_ADDRESS': 'E-mailserveradres',
|
||||
'EMAIL_SERVER_ADDRESS_DESCRIPTION': 'Adres waar mails worden ontvangen en verzonden'
|
||||
};
|
||||
|
|
|
@ -141,6 +141,9 @@ export default {
|
|||
'SMTP_USER': 'Usuário SMTP',
|
||||
'SMTP_SERVER': 'Servidor SMTP',
|
||||
'SMTP_PASSWORD': 'Senha SMTP',
|
||||
'IMAP_USER': 'Usuário IMAP',
|
||||
'IMAP_SERVER': 'Servidor IMAP',
|
||||
'IMAP_PASSWORD': 'Senha IMAP',
|
||||
'PORT': 'Porta',
|
||||
'RECAPTCHA_PUBLIC_KEY': 'Recaptcha Chave Pública',
|
||||
'RECAPTCHA_PRIVATE_KEY': 'Recaptcha Private Key',
|
||||
|
@ -191,6 +194,8 @@ export default {
|
|||
'DISABLE_USER': 'Desativar usuário',
|
||||
'SHOW_CLOSED_TICKETS': 'Mostrar ingressos fechados',
|
||||
'IMAGE_HEADER_URL': 'URL do cabeçalho da imagem',
|
||||
'IMAGE_HEADER_DESCRIPTION': 'Imagem que será usada como cabeçalho do email',
|
||||
'EMAIL_SETTINGS': 'Configurações de email',
|
||||
|
||||
'CHART_CREATE_TICKET': 'Ingressos criados',
|
||||
'CHART_CLOSE': 'Ingressos fechados',
|
||||
|
@ -303,11 +308,14 @@ export default {
|
|||
'ENABLE_USER_SYSTEM_DESCRIPTION': 'Ativar / desativar o uso de um sistema de usuário. Se você desativá-lo, todos os usuários serão excluídos, mas os ingressos serão mantidos. Se você ativá-lo, os usuários de tickets existentes serão criados.',
|
||||
'CSV_DESCRIPTION': 'O arquivo CSV deve ter 3 colunas: e-mail, senha, nome. Não há limite na contagem de linhas. Ele será criado um usuário por linha no arquivo.',
|
||||
'SMTP_SERVER_DESCRIPTION': 'A configuração do servidor SMTP permite que o aplicativo envie e-mails. Se você não configurá-lo, nenhum e-mail será enviado pela OpenSupports.',
|
||||
'IMAP_SERVER_DESCRIPTION': 'A configuração do servidor IMAP permite que o aplicativo crie tickets a partir dos emails enviados para uma caixa de correio.',
|
||||
'ENABLE_USER_DESCRIPTION': 'Essa ação permite que o usuário faça login e crie tickets.',
|
||||
'DISABLE_USER_DESCRIPTION': 'O usuário será desativado e não poderá fazer login e criar tickets.',
|
||||
'PRIVATE_RESPONSE_DESCRIPTION': 'Esta resposta só será vista pelos funcionários',
|
||||
'PRIVATE_TOPIC_DESCRIPTION': 'Este tópico será visto apenas por membros da equipe',
|
||||
'PRIVATE_DEPARTMENT_DESCRIPTION': 'Este departamento só será visto pelos funcionários',
|
||||
'EMAIL_SETTINGS_DESCRIPTION': 'Aqui você pode editar as configurações para receber e enviar e-mail para seus clientes.',
|
||||
'IMAP_POLLING_DESCRIPTION': 'A verificação da caixa de entrada não será feita automaticamente pelo OpenSupports. Você precisa fazer solicitações POST periodicamente para esse URL para processar os e-mails: {url}',
|
||||
|
||||
//ERRORS
|
||||
'EMAIL_OR_PASSWORD': 'E-mail ou senha inválidos',
|
||||
|
@ -365,6 +373,9 @@ export default {
|
|||
'WILL_RECOVER_EMAIL_TEMPLATE': 'Este modelo de e-mail será recuperado para seu valor padrão neste idioma.',
|
||||
'SUCCESS_IMPORTING_CSV_DESCRIPTION': 'O arquivo CSV foi importado com êxito',
|
||||
'SUCCESS_DELETING_ALL_USERS': 'Os usuários foram excluídos com êxito',
|
||||
'SUCCESSFUL_CONNECTION': 'Conexão bem sucedida',
|
||||
'UNSUCCESSFUL_CONNECTION': 'Conexão sem sucesso',
|
||||
'SERVER_CREDENTIALS_WORKING': 'Credenciais do servidor estão funcionando corretamente',
|
||||
|
||||
'LAST_7_DAYS': 'Últimos 7 dias',
|
||||
'LAST_30_DAYS': 'Últimos 30 dias',
|
||||
|
@ -386,6 +397,7 @@ export default {
|
|||
'DEFAULT_PORT': 'Deixar vazio para 3306 como padrão',
|
||||
'PASSWORD_LOWERCASE': 'senha',
|
||||
'TEST_SMTP_CONNECTION': 'Testar conexão SMTP',
|
||||
'SMTP_CONNECTION_SUCCESS': 'As credenciais SMTP são válidas.',
|
||||
'SMTP_CONNECTION_ERROR': 'Não pode se conectar ao servidor SMTP.'
|
||||
'SERVER_ERROR': 'Não é possível se conectar ao servidor.',
|
||||
'EMAIL_SERVER_ADDRESS': 'Endereço do servidor de email',
|
||||
'EMAIL_SERVER_ADDRESS_DESCRIPTION': 'Endereço onde os e-mails serão recebidos e enviados'
|
||||
};
|
||||
|
|
|
@ -141,6 +141,9 @@ export default {
|
|||
'SMTP_USER': 'SMTP Пользователь',
|
||||
'SMTP_SERVER': 'SMTP-сервер',
|
||||
'SMTP_PASSWORD': 'Пароль SMTP',
|
||||
'IMAP_USER': 'Пользователь IMAP',
|
||||
'IMAP_SERVER': 'IMAP сервер',
|
||||
'IMAP_PASSWORD': 'Пароль IMAP',
|
||||
'PORT': 'порт',
|
||||
'RECAPTCHA_PUBLIC_KEY': 'Recaptcha Открытый ключ',
|
||||
'RECAPTCHA_PRIVATE_KEY': 'Recaptcha Секретный ключ',
|
||||
|
@ -191,6 +194,8 @@ export default {
|
|||
'DISABLE_USER': 'Отключить пользователя',
|
||||
'SHOW_CLOSED_TICKETS': 'Показать закрытые билеты',
|
||||
'IMAGE_HEADER_URL': 'URL заголовка изображения',
|
||||
'IMAGE_HEADER_DESCRIPTION': 'Изображение, которое будет использоваться в качестве заголовка письма',
|
||||
'EMAIL_SETTINGS': 'Настройки электронной почты',
|
||||
|
||||
'CHART_CREATE_TICKET': 'Билеты создано',
|
||||
'CHART_CLOSE': ' Билеты закрыты',
|
||||
|
@ -303,12 +308,14 @@ export default {
|
|||
'ENABLE_USER_SYSTEM_DESCRIPTION': 'Включить / отключить использование пользовательской системы. Если вы отключите его, все пользователи будут удалены. Если вы включите его, будут созданы пользователи существующих билетов.',
|
||||
'CSV_DESCRIPTION': 'Файл CSV должен иметь 3 столбца: адрес электронной почты, пароль и имя. Количество строк не ограничено. В файле будет создан один пользователь для каждой строки.',
|
||||
'SMTP_SERVER_DESCRIPTION': 'Конфигурация SMTP-сервера позволяет приложению отправлять письма. Если вы не настроите его, никакие электронные письма не будут отправлены OpenSupports.',
|
||||
'IMAP_SERVER_DESCRIPTION': 'Конфигурация сервера IMAP позволяет приложению создавать заявки из электронных писем, отправляемых в почтовый ящик.',
|
||||
'ENABLE_USER_DESCRIPTION': 'Это действие позволяет пользователю входить в систему и создавать билеты.',
|
||||
'DISABLE_USER_DESCRIPTION': 'Пользователь будет отключен и не сможет войти и создать билеты',
|
||||
'PRIVATE_RESPONSE_DESCRIPTION': 'Этот ответ будет рассматриваться только сотрудниками',
|
||||
'PRIVATE_TOPIC_DESCRIPTION': 'Эта тема будет видна только сотрудникам',
|
||||
'PRIVATE_DEPARTMENT_DESCRIPTION': 'Этот отдел будет рассматриваться только сотрудниками',
|
||||
'PRIVATE_DESCRIPTION': 'Этот ответ будет рассматриваться только сотрудниками',
|
||||
'EMAIL_SETTINGS_DESCRIPTION': 'Здесь вы можете редактировать настройки для получения и отправки электронной почты своим клиентам.',
|
||||
'IMAP_POLLING_DESCRIPTION': 'Проверка входящих сообщений не будет выполняться автоматически OpenSupports. Вы должны периодически отправлять POST-запросы к этому URL для обработки электронных писем: {url}',
|
||||
|
||||
//ERRORS
|
||||
'EMAIL_OR_PASSWORD': 'электронной почты или пароль недействительный',
|
||||
|
@ -366,6 +373,9 @@ export default {
|
|||
'WILL_RECOVER_EMAIL_TEMPLATE': 'Этот шаблон электронной почты будет восстанавливаться, чтобы это значение по умолчанию на этом языке.',
|
||||
'SUCCESS_IMPORTING_CSV_DESCRIPTION': 'Файл CSV успешно установлен',
|
||||
'SUCCESS_DELETING_ALL_USERS': 'Пользователи удалили beend',
|
||||
'SUCCESSFUL_CONNECTION': 'Успешное соединение',
|
||||
'UNSUCCESSFUL_CONNECTION': 'Неудачное соединение',
|
||||
'SERVER_CREDENTIALS_WORKING': 'Учетные данные сервера работают правильно',
|
||||
|
||||
'LAST_7_DAYS': 'Последние 7 дней',
|
||||
'LAST_30_DAYS': 'Последние 30 дней',
|
||||
|
@ -387,6 +397,7 @@ export default {
|
|||
'PASSWORD_LOWERCASE': 'пароль',
|
||||
'DEFAULT_PORT': 'Оставьте пустым для 3306 по умолчанию',
|
||||
'TEST_SMTP_CONNECTION': 'Тестирование SMTP-соединения',
|
||||
'SMTP_CONNECTION_SUCCESS': 'Учетные данные SMTP действительны.',
|
||||
'SMTP_CONNECTION_ERROR': 'Не удается подключиться к SMTP-серверу.'
|
||||
'SERVER_ERROR': 'Невозможно установить связь с сервером.',
|
||||
'EMAIL_SERVER_ADDRESS': 'Адрес почтового сервера',
|
||||
'EMAIL_SERVER_ADDRESS_DESCRIPTION': 'Адрес, по которому будут приниматься и отправляться письма'
|
||||
};
|
||||
|
|
|
@ -141,6 +141,9 @@ export default {
|
|||
'SMTP_USER': 'SMTP Kullanıcısı',
|
||||
'SMTP_SERVER': 'SMTP Sunucusu',
|
||||
'SMTP_PASSWORD': 'SMTP Parolası',
|
||||
'IMAP_USER': 'IMAP Kullanıcısı',
|
||||
'IMAP_SERVER': 'IMAP Sunucusu',
|
||||
'IMAP_PASSWORD': 'IMAP Şifresi',
|
||||
'PORT': 'Liman',
|
||||
'RECAPTCHA_PUBLIC_KEY': 'Hızlı Erişim Anahtarı',
|
||||
'RECAPTCHA_PRIVATE_KEY': 'Recaptcha Özel Anahtar',
|
||||
|
@ -191,6 +194,8 @@ export default {
|
|||
'DISABLE_USER': 'Kullanıcıyı Devre Dışı Bırak',
|
||||
'SHOW_CLOSED_TICKETS': 'Kapalı Biletleri Göster',
|
||||
'IMAGE_HEADER_URL': 'Resim başlığı URL\'si',
|
||||
'IMAGE_HEADER_DESCRIPTION': 'E-postanın başlığı olarak kullanılacak resim',
|
||||
'EMAIL_SETTINGS': 'e mail ayarları',
|
||||
|
||||
'CHART_CREATE_TICKET': 'Biletler oluşturuldu',
|
||||
'CHART_CLOSE': 'Biletler kapandı',
|
||||
|
@ -303,12 +308,14 @@ export default {
|
|||
'ENABLE_USER_SYSTEM_DESCRIPTION': 'Bir kullanıcı sisteminin kullanımını etkinleştirir / devre dışı bırakır. Devre dışı bırakırsanız, tüm kullanıcılar silinir ancak biletler muhafaza edilir. Etkinleştirirseniz, mevcut biletler kullanıcıları oluşturulur.',
|
||||
'CSV_DESCRIPTION': 'CSV dosyasının 3 sütun olması gerekir: e-posta, şifre, ad. Satır sayısı sınırı yoktur. Dosya satır başına bir kullanıcı oluşturulur.',
|
||||
'SMTP_SERVER_DESCRIPTION': 'SMTP sunucusunun yapılandırması, uygulamanın postalar göndermesine izin verir. Onu yapılandırmazsanız, OpenSupports tarafından hiçbir e-posta gönderilmeyecektir',
|
||||
'IMAP_SERVER_DESCRIPTION': 'IMAP sunucusunun yapılandırması, uygulamanın bir posta kutusuna gönderilen e-postalardan bilet oluşturmasına izin verir.',
|
||||
'ENABLE_USER_DESCRIPTION': 'Bu eylem, kullanıcının giriş yapmasına ve bilet oluşturmasına izin verir.',
|
||||
'DISABLE_USER_DESCRIPTION': 'Kullanıcı devre dışı bırakılacak ve oturum açıp bilet oluşturamayacak.',
|
||||
'PRIVATE_RESPONSE_DESCRIPTION': 'Bu yanıt sadece personel tarafından görülebilir',
|
||||
'PRIVATE_TOPIC_DESCRIPTION': 'Bu konu sadece çalışanlar tarafından görülebilir',
|
||||
'PRIVATE_DEPARTMENT_DESCRIPTION': 'Bu bölüm sadece personel tarafından görülebilir',
|
||||
'PRIVATE_DESCRIPTION': 'Bu yanıt sadece personel tarafından görülebilir',
|
||||
'EMAIL_SETTINGS_DESCRIPTION': 'Burada, müşterilerinize e-posta alma ve gönderme ayarlarını düzenleyebilirsiniz.',
|
||||
'IMAP_POLLING_DESCRIPTION': 'Gelen kutusu kontrolü, OpenSupports tarafından otomatik olarak yapılmayacaktır. E-postaları işlemek için bu url\'ye düzenli aralıklarla POST istekleri yapmanız gerekir: {url}',
|
||||
|
||||
//ERRORS
|
||||
'EMAIL_OR_PASSWORD': 'E-posta veya şifre geçersiz',
|
||||
|
@ -366,6 +373,9 @@ export default {
|
|||
'WILL_RECOVER_EMAIL_TEMPLATE': 'Bu e-posta şablonu, bu dildeki varsayılan değere kadar düzelir.',
|
||||
'SUCCESS_IMPORTING_CSV_DESCRIPTION': 'CSV Dosyası başarıyla içe aktarıldı',
|
||||
'SUCCESS_DELETING_ALL_USERS': 'Kullanıcılar başarılı bir şekilde silindi',
|
||||
'SUCCESSFUL_CONNECTION': 'Başarılı bağlantı',
|
||||
'UNSUCCESSFUL_CONNECTION': 'Başarısız bağlantı',
|
||||
'SERVER_CREDENTIALS_WORKING': 'Sunucu kimlik bilgileri doğru çalışıyor',
|
||||
|
||||
'LAST_7_DAYS': 'Son 7 gün',
|
||||
'LAST_30_DAYS': 'Son 30 gün',
|
||||
|
@ -387,6 +397,7 @@ export default {
|
|||
'DEFAULT_PORT': '3306 için boş bırak varsayılan olarak',
|
||||
'PASSWORD_LOWERCASE': 'parola',
|
||||
'TEST_SMTP_CONNECTION': 'SMTP bağlantısını test et',
|
||||
'SMTP_CONNECTION_SUCCESS': 'SMTP kimlik bilgileri geçerlidir.',
|
||||
'SMTP_CONNECTION_ERROR': 'SMTP sunucusuna bağlanılamıyor.'
|
||||
'SERVER_ERROR': 'Sunucuya bağlanamıyor.',
|
||||
'EMAIL_SERVER_ADDRESS': 'E-posta sunucusu adresi',
|
||||
'EMAIL_SERVER_ADDRESS_DESCRIPTION': 'Postaların alınacağı ve gönderileceği adres',
|
||||
};
|
||||
|
|
|
@ -8,7 +8,8 @@ class ModalReducer extends Reducer {
|
|||
return {
|
||||
opened: false,
|
||||
noPadding: false,
|
||||
content: null
|
||||
content: null,
|
||||
outsideClick: false,
|
||||
};
|
||||
}
|
||||
|
||||
|
@ -25,7 +26,8 @@ class ModalReducer extends Reducer {
|
|||
return _.extend({}, state, {
|
||||
opened: true,
|
||||
content: payload.content,
|
||||
noPadding: payload.noPadding || false
|
||||
noPadding: payload.noPadding || false,
|
||||
outsideClick: payload.outsideClick
|
||||
});
|
||||
}
|
||||
|
||||
|
@ -35,7 +37,8 @@ class ModalReducer extends Reducer {
|
|||
return _.extend({}, state, {
|
||||
opened: false,
|
||||
content: null,
|
||||
noPadding: false
|
||||
noPadding: false,
|
||||
outsideClick: false
|
||||
});
|
||||
}
|
||||
}
|
||||
|
|
|
@ -7,7 +7,8 @@
|
|||
"gabordemooij/redbean": "^4.3",
|
||||
"ifsnop/mysqldump-php": "2.*",
|
||||
"ezyang/htmlpurifier": "^4.8",
|
||||
"codeguy/upload": "^1.3"
|
||||
"codeguy/upload": "^1.3",
|
||||
"php-imap/php-imap": "^3.0"
|
||||
},
|
||||
"require-dev": {
|
||||
"phpunit/phpunit": "^5.7"
|
||||
|
|
|
@ -30,5 +30,6 @@ $systemControllerGroup->addController(new CSVImportController);
|
|||
$systemControllerGroup->addController(new DisableUserSystemController);
|
||||
$systemControllerGroup->addController(new EnableUserSystemController);
|
||||
$systemControllerGroup->addController(new TestSMTPController);
|
||||
$systemControllerGroup->addController(new TestIMAPController);
|
||||
|
||||
$systemControllerGroup->finalize();
|
||||
|
|
|
@ -14,7 +14,7 @@
|
|||
*
|
||||
* @apiParam {String} allowedLanguages The list of languages allowed.
|
||||
* @apiParam {String} supportedLanguages The list of languages supported.
|
||||
* @apiParam {Setting} setting A setting can be any of the following: language, recaptcha-public, recaptcha-private, no-reply-email, smtp-host, smtp-port, smtp-user, smtp-pass, time-zone, maintenance-mode, layout, allow-attachments, max-size, title, url.
|
||||
* @apiParam {Setting} setting A setting can be any of the following: language, recaptcha-public, recaptcha-private, server-email, smtp-host, smtp-port, smtp-user, smtp-pass, time-zone, maintenance-mode, layout, allow-attachments, max-size, title, url.
|
||||
*
|
||||
* @apiUse NO_PERMISSION
|
||||
*
|
||||
|
@ -38,9 +38,11 @@ class EditSettingsController extends Controller {
|
|||
'language',
|
||||
'recaptcha-public',
|
||||
'recaptcha-private',
|
||||
'no-reply-email',
|
||||
'server-email',
|
||||
'imap-host',
|
||||
'imap-user',
|
||||
'imap-pass',
|
||||
'smtp-host',
|
||||
'smtp-port',
|
||||
'smtp-user',
|
||||
'smtp-pass',
|
||||
'time-zone',
|
||||
|
|
|
@ -0,0 +1,125 @@
|
|||
<?php
|
||||
|
||||
class EmailPolling extends Controller {
|
||||
const PATH = '/email-polling';
|
||||
const METHOD = 'POST';
|
||||
|
||||
private $mailbox;
|
||||
|
||||
public function validations() {
|
||||
return [
|
||||
'permission' => 'any',
|
||||
'requestData' => []
|
||||
];
|
||||
}
|
||||
|
||||
public function handler() {
|
||||
$commentController = new CommentController();
|
||||
$createController = new CreateController();
|
||||
$defaultLanguage = Setting::getSetting('language')->getValue();
|
||||
$defaultDepartmentId = Department::getAll()->first()->id;
|
||||
|
||||
if(Controller::isUserSystemEnabled())
|
||||
throw new RequestException(ERRORS::USER_SYSTEM);
|
||||
|
||||
$this->mailbox = new \PhpImap\Mailbox(
|
||||
Setting::getSetting('imap-host')->getValue(),
|
||||
Setting::getSetting('imap-user')->getValue(),
|
||||
Setting::getSetting('imap-pass')->getValue(),
|
||||
__DIR__
|
||||
);
|
||||
|
||||
$errors = [];
|
||||
$emails = $this->getLastEmails();
|
||||
|
||||
$session = Session::getInstance();
|
||||
$oldSession = [
|
||||
'userId' => $session->getUserId(),
|
||||
'staff' => $session->getToken(),
|
||||
'token' => $session->isStaffLogged(),
|
||||
];
|
||||
|
||||
foreach($emails as $email) {
|
||||
Controller::setDataRequester(function ($key) use ($email, $defaultDepartmentId, $defaultLanguage) {
|
||||
switch ($key) {
|
||||
case 'ticketNumber':
|
||||
return $email->getTicketNumber();
|
||||
case 'title':
|
||||
return $email->getSubject();
|
||||
case 'content':
|
||||
return $email->getContent();
|
||||
case 'departmentId':
|
||||
return $defaultDepartmentId;
|
||||
case 'language':
|
||||
return $defaultLanguage;
|
||||
case 'email':
|
||||
return $email->getSender();
|
||||
case 'name':
|
||||
return $email->getSenderName();
|
||||
}
|
||||
|
||||
return null;
|
||||
});
|
||||
|
||||
try {
|
||||
if($email->isReply()) {
|
||||
if($email->getTicket()->authorToArray()['email'] === $email->getSender()) {
|
||||
$session->clearSessionData();
|
||||
$session->createTicketSession($email->getTicket()->ticketNumber);
|
||||
|
||||
$commentController->handler();
|
||||
}
|
||||
} else {
|
||||
$createController->handler();
|
||||
}
|
||||
} catch(\Exception $e) {
|
||||
$errors[] = [
|
||||
'author' => $email->getSender(),
|
||||
'ticketNumber' => $email->getTicketNumber(),
|
||||
'error' => $e->__toString(),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
$session->clearSessionData();
|
||||
$session->setSessionData($oldSession);
|
||||
|
||||
$this->eraseAllEmails();
|
||||
|
||||
if(count($errors)) {
|
||||
Response::respondError(ERRORS::EMAIL_POLLING, null, $errors);
|
||||
} else {
|
||||
Response::respondSuccess();
|
||||
}
|
||||
}
|
||||
|
||||
public function getLastEmails() {
|
||||
$mailsIds = $this->mailbox->searchMailbox('ALL');
|
||||
$emails = [];
|
||||
sort($mailsIds);
|
||||
|
||||
foreach($mailsIds as $mailId) {
|
||||
$mail = $this->mailbox->getMail($mailId);
|
||||
$mailHeader = $this->mailbox->getMailHeader($mailId);
|
||||
$emails[] = new Email([
|
||||
'fromAddress' => $mailHeader->fromAddress,
|
||||
'fromName' => $mailHeader->fromName,
|
||||
'subject' => $mailHeader->subject,
|
||||
'content' => $mail->textPlain,
|
||||
'file' => null,
|
||||
]);
|
||||
}
|
||||
|
||||
return $emails;
|
||||
}
|
||||
|
||||
public function eraseAllEmails() {
|
||||
$mailsIds = $this->mailbox->searchMailbox('ALL');
|
||||
|
||||
foreach($mailsIds as $mailId) {
|
||||
$this->mailbox->deleteMail($mailId);
|
||||
}
|
||||
|
||||
$this->mailbox->expungeDeletedMails();
|
||||
}
|
||||
}
|
|
@ -1,5 +1,6 @@
|
|||
<?php
|
||||
use Respect\Validation\Validator as DataValidator;
|
||||
use RedBeanPHP\Facade as RedBean;
|
||||
|
||||
/**
|
||||
* @api {post} /system/get-logs Get logs
|
||||
|
|
|
@ -45,10 +45,11 @@ class GetSettingsController extends Controller {
|
|||
'max-size' => Setting::getSetting('max-size')->getValue(),
|
||||
'url' => Setting::getSetting('url')->getValue(),
|
||||
'title' => Setting::getSetting('title')->getValue(),
|
||||
'no-reply-email' => Setting::getSetting('no-reply-email')->getValue(),
|
||||
'smtp-port' => Setting::getSetting('smtp-port')->getValue(),
|
||||
'server-email' => Setting::getSetting('server-email')->getValue(),
|
||||
'smtp-host' => Setting::getSetting('smtp-host')->getValue(),
|
||||
'smtp-user' => Setting::getSetting('smtp-user')->getValue(),
|
||||
'imap-host' => Setting::getSetting('imap-host')->getValue(),
|
||||
'imap-user' => Setting::getSetting('imap-user')->getValue(),
|
||||
'registration' => Setting::getSetting('registration')->getValue(),
|
||||
'departments' => Department::getAllDepartmentNames(),
|
||||
'supportedLanguages' => Language::getSupportedLanguages(),
|
||||
|
|
|
@ -17,7 +17,7 @@ DataValidator::with('CustomValidations', true);
|
|||
* @apiParam {String} language Indicates the default language of the system.
|
||||
* @apiParam {String} user-system-enabled Indicates if the user system should be enabled.
|
||||
* @apiParam {String} registration Indicates if the registration should be enabled.
|
||||
* @apiParam {String} no-reply-email Email from where automated emails will be sent.
|
||||
* @apiParam {String} server-email Email from where automated emails will be sent.
|
||||
* @apiParam {String} smtp-host SMTP Server address.
|
||||
* @apiParam {String} smtp-port SMTP Server port.
|
||||
* @apiParam {String} smtp-user SMTP Authentication User.
|
||||
|
@ -68,11 +68,13 @@ class InitSettingsController extends Controller {
|
|||
'language' => Controller::request('language'),
|
||||
'recaptcha-public' => '',
|
||||
'recaptcha-private' => '',
|
||||
'no-reply-email' => Controller::request('no-reply-email'),
|
||||
'server-email' => Controller::request('server-email'),
|
||||
'imap-host' => Controller::request('imap-host'),
|
||||
'imap-user' => Controller::request('imap-user'),
|
||||
'imap-pass' => Controller::request('imap-pass'),
|
||||
'smtp-host' => Controller::request('smtp-host'),
|
||||
'smtp-port' => Controller::request('smtp-port'),
|
||||
'smtp-user' => Controller::request('smtp-user'),
|
||||
'smtp-pass' => Controller::request('smtp-password'),
|
||||
'smtp-pass' => Controller::request('smtp-pass'),
|
||||
'time-zone' => 0,
|
||||
'maintenance-mode' => 0,
|
||||
'layout' => 'boxed',
|
||||
|
|
|
@ -0,0 +1,43 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* @api {post} /system/test-imap Test IMAP Connection
|
||||
* @apiVersion 4.3.2
|
||||
*
|
||||
* @apiName Test IMAP Connection
|
||||
*
|
||||
* @apiGroup System
|
||||
*
|
||||
* @apiDescription Test if the given values connect correctly to a IMAP server.
|
||||
*
|
||||
* @apiPermission any
|
||||
*
|
||||
* @apiParam {String} imap-host Host of the IMAP server.
|
||||
* @apiParam {String} imap-user User for the IMAP server.
|
||||
* @apiParam {String} imap-pass Password for the IMAP server.
|
||||
*
|
||||
* @apiUse IMAP_CONNECTION
|
||||
*
|
||||
* @apiSuccess {Object} data Empty object
|
||||
*
|
||||
*/
|
||||
|
||||
class TestIMAPController extends Controller {
|
||||
const PATH = '/test-imap';
|
||||
const METHOD = 'POST';
|
||||
|
||||
public function validations() {
|
||||
return [
|
||||
'permission' => 'any',
|
||||
'requestData' => []
|
||||
];
|
||||
}
|
||||
|
||||
public function handler() {
|
||||
if(imap_open(Controller::request('imap-host'), Controller::request('imap-user'), Controller::request('imap-pass'))) {
|
||||
Response::respondSuccess();
|
||||
} else {
|
||||
throw new RequestException(ERRORS::IMAP_CONNECTION);
|
||||
}
|
||||
}
|
||||
}
|
|
@ -39,10 +39,9 @@ class TestSMTPController extends Controller {
|
|||
$mailSender = MailSender::getInstance();
|
||||
$mailSender->setConnectionSettings(
|
||||
Controller::request('smtp-host'),
|
||||
Controller::request('smtp-port'),
|
||||
Controller::request('smtp-user'),
|
||||
Controller::request('smtp-password'),
|
||||
Controller::request('no-reply-email')
|
||||
Controller::request('smtp-pass'),
|
||||
''
|
||||
);
|
||||
|
||||
if($mailSender->isConnected()) {
|
||||
|
|
|
@ -155,6 +155,7 @@ class CommentController extends Controller {
|
|||
'name' => $name,
|
||||
'title' => $this->ticket->title,
|
||||
'ticketNumber' => $this->ticket->ticketNumber,
|
||||
'content' => $this->content,
|
||||
'url' => $url
|
||||
]);
|
||||
|
||||
|
|
|
@ -139,6 +139,10 @@
|
|||
* @apiDefine INVALID_BODY
|
||||
* @apiError {String} INVALID_BODY The body is invalid.
|
||||
*/
|
||||
/**
|
||||
* @apiDefine USER_SYSTEM_ENABLED
|
||||
* @apiError {String} USER_SYSTEM_ENABLED The user system is enabled.
|
||||
*/
|
||||
/**
|
||||
* @apiDefine USER_SYSTEM_DISABLED
|
||||
* @apiError {String} USER_SYSTEM_DISABLED The user system is disabled.
|
||||
|
@ -203,6 +207,10 @@
|
|||
* @apiDefine DEPARTMENT_PRIVATE_TICKETS
|
||||
* @apiError {String} DEPARTMENT_PRIVATE_TICKETS There are tickets for in department created by non-staff and it can't be private
|
||||
*/
|
||||
/**
|
||||
* @apiDefine EMAIL_POLLING
|
||||
* @apiError {String} EMAIL_POLLING Email polling
|
||||
*/
|
||||
|
||||
class ERRORS {
|
||||
const INVALID_CREDENTIALS = 'INVALID_CREDENTIALS';
|
||||
|
@ -241,6 +249,7 @@ class ERRORS {
|
|||
const INVALID_TEMPLATE = 'INVALID_TEMPLATE';
|
||||
const INVALID_SUBJECT = 'INVALID_SUBJECT';
|
||||
const INVALID_BODY = 'INVALID_BODY';
|
||||
const USER_SYSTEM_ENABLED = 'USER_SYSTEM_ENABLED';
|
||||
const USER_SYSTEM_DISABLED = 'USER_SYSTEM_DISABLED';
|
||||
const SYSTEM_USER_IS_ALREADY_DISABLED = 'SYSTEM_USER_IS_ALREADY_DISABLED';
|
||||
const SYSTEM_USER_IS_ALREADY_ENABLED = 'SYSTEM_USER_IS_ALREADY_ENABLED';
|
||||
|
@ -250,6 +259,7 @@ class ERRORS {
|
|||
const DATABASE_CONNECTION = 'DATABASE_CONNECTION';
|
||||
const DATABASE_CREATION = 'DATABASE_CREATION';
|
||||
const SMTP_CONNECTION = 'SMTP_CONNECTION';
|
||||
const IMAP_CONNECTION = 'IMAP_CONNECTION';
|
||||
const ALREADY_DISABLED = 'ALREADY_DISABLED';
|
||||
const ALREADY_ENABLED = 'ALREADY_ENABLED';
|
||||
const USER_DISABLED = 'USER_DISABLED';
|
||||
|
@ -257,4 +267,5 @@ class ERRORS {
|
|||
const INVALID_TEXT_2 = 'INVALID_TEXT_2';
|
||||
const INVALID_TEXT_3 = 'INVALID_TEXT_3';
|
||||
const DEPARTMENT_PRIVATE_TICKETS = 'DEPARTMENT_PRIVATE_TICKETS';
|
||||
const EMAIL_POLLING = 'EMAIL_POLLING';
|
||||
}
|
||||
|
|
|
@ -340,7 +340,13 @@
|
|||
<table cellpadding="0" cellspacing="0" width="100%">
|
||||
<tr>
|
||||
<td style="padding-bottom: 30px;">
|
||||
{{TICKET_RESPONDED_MATCH_3}}
|
||||
{{content}}
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
|
@ -355,12 +361,6 @@
|
|||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
</center>
|
||||
</td>
|
||||
</tr>
|
||||
|
|
|
@ -16,6 +16,11 @@ class DataStoreList implements IteratorAggregate {
|
|||
return new ArrayIterator($this->list);
|
||||
}
|
||||
|
||||
public function first() {
|
||||
if(count($this->list)) return $this->list[0];
|
||||
else return new NullDataStore();
|
||||
}
|
||||
|
||||
public function add(DataStore $dataStore) {
|
||||
$this->list[] = $dataStore;
|
||||
}
|
||||
|
|
|
@ -0,0 +1,71 @@
|
|||
<?php
|
||||
|
||||
class Email {
|
||||
private $sender;
|
||||
private $senderName;
|
||||
private $ticket;
|
||||
private $ticketNumber;
|
||||
private $content;
|
||||
private $attachment;
|
||||
|
||||
public function __construct($data) {
|
||||
$this->sender = $this->parseSender($data);
|
||||
$this->senderName = $this->parseSenderName($data);
|
||||
$this->ticketNumber = $this->parseTicketNumber($data);
|
||||
$this->ticket = $this->parseTicket($data);
|
||||
$this->content = $this->parseContent($data);
|
||||
$this->attachment = $this->parseAttachment($data);
|
||||
$this->subject = $this->parseSubject($data);
|
||||
}
|
||||
|
||||
public function isReply() { return !$this->ticket->isNull(); }
|
||||
|
||||
public function getSender() { return $this->sender; }
|
||||
public function getTicket() { return $this->ticket; }
|
||||
public function getSenderName() { return $this->senderName; }
|
||||
public function getTicketNumber() { return $this->ticketNumber; }
|
||||
public function getSubject() { return $this->subject; }
|
||||
public function getContent() { return $this->content; }
|
||||
public function getAttachment() { return $this->attachment; }
|
||||
|
||||
private function parseSender($data) {
|
||||
return $data['fromAddress'];
|
||||
}
|
||||
|
||||
private function parseSenderName($data) {
|
||||
return $data['fromName'];
|
||||
}
|
||||
|
||||
private function parseTicketNumber($data) {
|
||||
return $this->parseTicketNumberFromString($data['subject']);
|
||||
}
|
||||
|
||||
private function parseTicket() {
|
||||
return Ticket::getByTicketNumber($this->ticketNumber);
|
||||
}
|
||||
|
||||
private function parseSubject($data) {
|
||||
return $data['subject'];
|
||||
}
|
||||
|
||||
private function parseContent($data) {
|
||||
return $data['content'];
|
||||
}
|
||||
|
||||
private function parseAttachment($data) {
|
||||
return $data['file'];
|
||||
}
|
||||
|
||||
private function parseTicketNumberFromString($string) {
|
||||
for($i=0; $i<strlen($string); $i++) {
|
||||
if($string[$i] === '#') {
|
||||
$match = substr($string, $i+1, 6);
|
||||
if(strlen($match) === 6 && is_numeric($match)) {
|
||||
return intval($match);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
}
|
|
@ -2,25 +2,23 @@
|
|||
class MailSender {
|
||||
use SingletonTrait;
|
||||
|
||||
private $mailOptions = [];
|
||||
public $mailOptions = [];
|
||||
private $mailerInstance;
|
||||
|
||||
private function __construct() {
|
||||
$this->setConnectionSettings(
|
||||
Setting::getSetting('smtp-host')->getValue(),
|
||||
Setting::getSetting('smtp-port')->getValue(),
|
||||
Setting::getSetting('smtp-user')->getValue(),
|
||||
Setting::getSetting('smtp-pass')->getValue(),
|
||||
Setting::getSetting('no-reply-email')->getValue()
|
||||
Setting::getSetting('server-email')->getValue()
|
||||
);
|
||||
}
|
||||
|
||||
public function setConnectionSettings($host, $port, $user, $pass, $noReplyEmail) {
|
||||
$this->mailOptions['from'] = $noReplyEmail;
|
||||
public function setConnectionSettings($host, $user, $pass, $serverEmail) {
|
||||
$this->mailOptions['from'] = $serverEmail;
|
||||
$this->mailOptions['fromName'] = 'OpenSupports';
|
||||
|
||||
$this->mailOptions['smtp-host'] = $host;
|
||||
$this->mailOptions['smtp-port'] = $port;
|
||||
$this->mailOptions['smtp-user'] = $user;
|
||||
$this->mailOptions['smtp-pass'] = $pass;
|
||||
}
|
||||
|
@ -70,7 +68,6 @@ class MailSender {
|
|||
$this->mailerInstance->isSMTP();
|
||||
$this->mailerInstance->SMTPAuth = true;
|
||||
$this->mailerInstance->Host = $this->mailOptions['smtp-host'];
|
||||
$this->mailerInstance->Port = $this->mailOptions['smtp-port'];
|
||||
$this->mailerInstance->Username = $this->mailOptions['smtp-user'];
|
||||
$this->mailerInstance->Password = $this->mailOptions['smtp-pass'];
|
||||
$this->mailerInstance->Timeout = 1000;
|
||||
|
|
|
@ -3,11 +3,11 @@ class Response {
|
|||
private static $response;
|
||||
private static $responseException;
|
||||
|
||||
public static function respondError($errorMsg, $exception = null) {
|
||||
public static function respondError($errorMsg, $exception = null, $data = null) {
|
||||
self::$response = array(
|
||||
'status' => 'fail',
|
||||
'message' => $errorMsg,
|
||||
'data' => null
|
||||
'data' => $data
|
||||
);
|
||||
self::$responseException = $exception;
|
||||
|
||||
|
|
|
@ -18,6 +18,18 @@ class Session {
|
|||
session_destroy();
|
||||
}
|
||||
|
||||
public function clearSessionData() {
|
||||
$this->store('userId', null);
|
||||
$this->store('staff', null);
|
||||
$this->store('token', null);
|
||||
$this->store('ticketNumber', null);
|
||||
}
|
||||
|
||||
public function setSessionData($data) {
|
||||
foreach($data as $key => $value)
|
||||
$this->store($key, $value);
|
||||
}
|
||||
|
||||
public function createSession($userId, $staff = false) {
|
||||
$this->store('userId', $userId);
|
||||
$this->store('staff', $staff);
|
||||
|
|
|
@ -2,3 +2,5 @@ source "https://rubygems.org"
|
|||
gem 'mysql'
|
||||
gem 'bacon'
|
||||
gem 'mechanize'
|
||||
gem 'mailfactory'
|
||||
gem 'mail'
|
||||
|
|
|
@ -1,10 +1,14 @@
|
|||
# LIBRARIES
|
||||
require 'bacon'
|
||||
require 'net/http'
|
||||
require 'net/imap'
|
||||
require 'net/smtp'
|
||||
require 'uri'
|
||||
require 'mysql'
|
||||
require 'json'
|
||||
require 'mechanize'
|
||||
require 'mailfactory'
|
||||
require 'mail'
|
||||
require './libs.rb'
|
||||
require './scripts.rb'
|
||||
|
||||
|
|
|
@ -49,8 +49,101 @@ class Database
|
|||
end
|
||||
end
|
||||
|
||||
class MailServer
|
||||
def initialize
|
||||
@smtp_server = ENV['OPENSUPPORTS_SMTP_SERVER']
|
||||
@smtp_port = ENV['OPENSUPPORTS_SMTP_PORT']
|
||||
|
||||
@imap_server = ENV['OPENSUPPORTS_IMAP_SERVER']
|
||||
@imap_port = ENV['OPENSUPPORTS_IMAP_PORT']
|
||||
|
||||
@admin_user = ENV['OPENSUPPORTS_EMAIL_ADMIN_USERNAME']
|
||||
@admin_password = ENV['OPENSUPPORTS_EMAIL_ADMIN_PASSWORD']
|
||||
|
||||
@client_user = ENV['OPENSUPPORTS_EMAIL_CLIENT_USERNAME']
|
||||
@client_password = ENV['OPENSUPPORTS_EMAIL_CLIENT_PASSWORD']
|
||||
|
||||
@admin_imap = Net::IMAP.new(@imap_server, {port: @imap_port})
|
||||
@client_imap = Net::IMAP.new(@imap_server, {port: @imap_port})
|
||||
|
||||
@admin_imap.authenticate('LOGIN', @admin_user, @admin_password)
|
||||
@client_imap.authenticate('LOGIN', @client_user, @client_password)
|
||||
|
||||
@client_stmp = Net::SMTP.start(@smtp_server, @smtp_port, @smtp_server, @client_user, @client_password, :plain)
|
||||
end
|
||||
|
||||
def clear_mails
|
||||
self.clear_admin_mails
|
||||
self.clear_client_mails
|
||||
end
|
||||
|
||||
def clear_admin_mails
|
||||
@admin_imap.examine('INBOX')
|
||||
puts @admin_imap.list("", "*")
|
||||
|
||||
@admin_imap.store(2, "+FLAGS", [:Deleted])
|
||||
@admin_imap.uid_search(['NOT','DELETED']).each do |uid|
|
||||
puts "deleteing #{uid}"
|
||||
@admin_imap.uid_copy(uid, "INBOX.Trash")
|
||||
@admin_imap.uid_store(uid, "+FLAGS", [:Deleted])
|
||||
puts @admin_imap.uid_fetch(uid, ['FLAGS', 'UID'])[0]
|
||||
end
|
||||
|
||||
puts @admin_imap.expunge
|
||||
@admin_imap.logout
|
||||
@admin_imap.disconnect
|
||||
end
|
||||
|
||||
def clear_client_mails
|
||||
@client_imap.examine('INBOX')
|
||||
|
||||
@client_imap.search(['NOT','DELETED']).each do |message_id|
|
||||
@client_imap.copy(message_id, "INBOX.Trash")
|
||||
@client_imap.store(message_id, "+FLAGS", [:Deleted])
|
||||
end
|
||||
|
||||
@client_imap.expunge
|
||||
end
|
||||
|
||||
def send_mail(subject, text, file = nil)
|
||||
# message = MailFactory.new
|
||||
# message.to = @admin_user
|
||||
# message.from = @client_user
|
||||
# message.subject = subject
|
||||
# message.html = text
|
||||
message = <<MESSAGE_END
|
||||
From: Client <#{@client_user}>
|
||||
To: Support <#{@admin_user}>
|
||||
Subject: #{subject}
|
||||
|
||||
#{text}
|
||||
MESSAGE_END
|
||||
|
||||
# unless file.nil?
|
||||
# message.attach(file)
|
||||
# end
|
||||
|
||||
@client_stmp.send_message(message, @client_user, @admin_user)
|
||||
end
|
||||
|
||||
def check
|
||||
puts 'checking...'
|
||||
@admin_imap.examine('INBOX')
|
||||
@admin_imap.search(['NOT','DELETED']).each do |message_id|
|
||||
envelope = @admin_imap.fetch(message_id, "ENVELOPE")[0].attr["ENVELOPE"]
|
||||
# puts "#{envelope.from[0].name}: \t#{envelope.subject}"
|
||||
puts envelope.subject
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
# $mail_server = MailServer.new
|
||||
$database = Database.new
|
||||
|
||||
# $mail_server.clear_mails
|
||||
# $mail_server.send_mail('suppport message 1', 'texttexttext tex')
|
||||
# $mail_server.check
|
||||
|
||||
$staff = {
|
||||
:email => 'staff@opensupports.com',
|
||||
:password => 'staff'
|
||||
|
|
|
@ -3,7 +3,7 @@ describe'system/edit-settings' do
|
|||
Scripts.login($staff[:email], $staff[:password], true)
|
||||
|
||||
it 'should edit settings' do
|
||||
result= request('/system/edit-settings', {
|
||||
result = request('/system/edit-settings', {
|
||||
"csrf_userid" => $csrf_userid,
|
||||
"csrf_token" => $csrf_token,
|
||||
"maintenance-mode" => 0,
|
||||
|
@ -12,7 +12,7 @@ describe'system/edit-settings' do
|
|||
"allow-attachments" => 1,
|
||||
"max-size" => 2,
|
||||
"language" => 'en',
|
||||
"no-reply-email" => 'testemail@hotmail.com'
|
||||
"server-email" => 'testemail@hotmail.com'
|
||||
})
|
||||
|
||||
(result['status']).should.equal('success')
|
||||
|
@ -32,7 +32,7 @@ describe'system/edit-settings' do
|
|||
row = $database.getRow('setting', 'language', 'name')
|
||||
(row['value']).should.equal('en')
|
||||
|
||||
row = $database.getRow('setting', 'no-reply-email', 'name')
|
||||
row = $database.getRow('setting', 'server-email', 'name')
|
||||
(row['value']).should.equal('testemail@hotmail.com')
|
||||
|
||||
request('/user/logout')
|
||||
|
|
|
@ -17,11 +17,10 @@ describe '/system/init-settings' do
|
|||
'user-system-enabled' => true,
|
||||
'registration' => true,
|
||||
'title' => 'Support Center',
|
||||
'smtp-host' => 'localhost',
|
||||
'smtp-port' => 7070,
|
||||
'smtp-user' => 'noreply@opensupports.com',
|
||||
'smtp-password' => '',
|
||||
'no-reply-email' => 'noreply@opensupports.com',
|
||||
'smtp-host' => 'localhost:7070',
|
||||
'smtp-user' => 'testemail@opensupports.com',
|
||||
'smtp-pass' => 'password',
|
||||
'server-email' => 'testemail@opensupports.com',
|
||||
'language' => 'en'
|
||||
})
|
||||
|
||||
|
|
Loading…
Reference in New Issue